Layered Diffuse Surface (Interfaced Lambertian BRDF)
このページは レイトレ合宿5‽ アドベントカレンダー第9週目の記事です.
本ページでは,モンテカルロレイトレーシング法において, 上図のような鏡面反射する層を持った拡散反射基板の表面 (Interfaced Lambertian BRDF) をレンダリングする方法を説明します. Interfaced Lambertian BRDF の実装に必要な パラメータや数式,重点的サンプリングの方法を説明します.
記号について
本ページでは以下の記号は定義済として扱います.
\(\omega_{n}\) |
Macrosurfaceの単位法線ベクトル |
\(\omega_{m}\) |
Microsurfaceの単位法線ベクトル,本ページではマイクロファセット法線と呼ぶ |
\(\omega_{i}\) |
入射方向の単位ベクトル |
\(\omega_{o}\) |
反射方向の単位ベクトル |
\(f_{r}\) |
BRDF |
\(n_{i}\) |
入射側の媒体の屈折率 |
\(n_{o}\) |
透過側の媒体の屈折率 |
\(n\) |
\(\frac{n_{o}}{n_{i}}\) |
\(F\) |
フレネル項 |
本モデルについて
Interfaced Lambertian BRDF は,下図のようにフレネル反射層と拡散反射基板から構成されます. このモデルは,フレネル反射層の境界での鏡面反射と 層内部の多重反射後の散乱を考慮しています. フレネル反射層と拡散反射基板はそれぞれ鏡面反射,拡散反射のMicrofacetモデルで表現され, 必要なパラメータもそれぞれのMicrofacetモデルのパラメータを組み合わせるだけの シンプルなモデルとなっています.
Interfaced Lambertian BRDF
Interfaced Lambertian BRDF の評価は, 入射光に対する鏡面反射 \(f_{s}\) と, 多重反射後の散乱 \(f_{b}\) に分けて行います.
\[
\begin{align}
f_{r} \left( x, \omega_{i}, \omega_{o} \right) =
f_{s} \left( x, \omega_{i}, \omega_{o} \right) +
f_{b} \left( x, \omega_{i}, \omega_{o} \right)
\tag{1}
\end{align}
\]
入射光に対する鏡面反射 \(f_{s}\) には, 鏡面のMicrofacetモデルを用います (Beckman,GGXなど) .
\[
\begin{align}
f_{s} \left( x, \omega_{i}, \omega_{o} \right) =
\frac{1}{4 \left( \omega_{i} \cdot \omega_{n} \right)
\left( \omega_{o} \cdot \omega_{n} \right)}
F \left( \omega_{i}, \omega_{m} \right)
G_{2} \left( \omega_{i}, \omega_{o}, \omega_{m} \right)
D \left( \omega_{m} \right)
\tag{2}
\end{align}
\]
多重反射後の散乱 \(f_{b}\) は, 拡散反射面のMicrofacetモデルに, 入射光の内部への屈折 \(T \left( \omega_{i}, \omega_{m} \right)\) と 内部での多重反射 \(\frac{1}{\pi n^{2} \left( 1 - r_{i} \rho \right) }\) と, 内部から外部へ散乱する時の屈折 \(T \left( \omega_{o}, \omega_{m} \right)\) を 考慮したものになります.
\[
\begin{align}
f_{b} \left( x, \omega_{i}, \omega_{o} \right) = &
\frac{\rho}{\pi n^{2} \left( 1 - r_{i} \rho \right)}
\int T \left( \omega_{i}, \omega_{m_{b}} \right)
T \left( \omega_{i}, \omega_{m_{b}} \right)
D \left( \omega_{m_{b}} \right)
G \left( \omega_{i}, \omega_{o}, \omega_{m_{b}} \right)
\frac{ \left| \omega_{i} \cdot \omega_{m_{b}} \right|
\left| \omega_{o} \cdot \omega_{m_{b}} \right| }
{ \left| \omega_{i} \cdot \omega_{n} \right|
\left| \omega_{o} \cdot \omega_{n} \right| }
d \omega_{m_{b}}
\\
r_{i} = & 1 - \frac{1 - r_{e}}{n^{2}}
\\
r_{e} = & \frac{1}{2} -
\frac{2 n^{3} \left( n^{2} + 2 n - 1 \right)}
{\left( n^{2} + 1 \right) \left( n^{4} - 1 \right)} +
\frac{\left( n - 1 \right) \left( 3 n + 1 \right)}
{6 \left( n + 1 \right)^{2}} +
\frac{8 n^{4} \left( n^{4} + 1 \right)}
{\left( n^{2} + 1 \right) \left( n^{4} - 1 \right)^{2}}
ln \left( n \right) +
\frac{n^{2} \left( n^{2} - 1 \right)^{2}}
{\left( n^{2} + 1 \right)^{3}}
ln \left( \frac{n - 1}{n + 1} \right)
\tag{3}
\end{align}
\]
この式には積分が含まれているため,モンテカルロ法を用いて Microfacet法線 \(\omega_{m_{b}}\) をサンプリングして解きます.
\[
\begin{align}
f_{b} \left( x, \omega_{i}, \omega_{o} \right) =
\frac{\rho}{\pi n^{2} \left( 1 - r_{i} \rho \right)}
\frac{
T \left( \omega_{i}, \omega_{m_{b}} \right)
T \left( \omega_{i}, \omega_{m_{b}} \right)
D \left( \omega_{m_{b}} \right)
G \left( \omega_{i}, \omega_{o}, \omega_{m_{b}} \right)
\frac{ \left| \omega_{i} \cdot \omega_{m_{b}} \right|
\left| \omega_{o} \cdot \omega_{m_{b}} \right| }
{ \left| \omega_{i} \cdot \omega_{n} \right|
\left| \omega_{o} \cdot \omega_{n} \right| }}
{p \left( \omega_{m_{b}} \right) }
\tag{4}
\end{align}
\]
重点的サンプリング (Importance Sampling)
Interfaced Lambertian BRDF の重点的サンプリングは, フレネル反射層の反射分布,もしくは拡散反射基板の反射分布に従ってサンプリングを行います.
まず最初は,フレネル反射層,拡散反射基板どちらの反射分布に従ってサンプリングを行うかを決定します. ここでは,フレネル反射層,拡散反射基板それぞれの総反射率をもとに確率的に決定します.
\[
\begin{align}
R_{s} = & r_{e}
\\
R_{b} = & \frac{ \left( 1 - r_{e} \right) ^{2} \rho }
{ n^{2} \left( 1 - r_{i} \rho \right) }
\tag{5}
\end{align}
\]
\(R_{s}\) ,\(R_{b}\) はそれぞれフレネル反射層,拡散反射基板の総反射率です. \(u_{1} \in [0, 1)\) となる一様乱数を用いて, \(u_{1} < \frac{R_{s}}{ \left( R_{s} + R_{b} \right) }\) となる場合は フレネル反射層の反射分布に従ったサンプリングを行い,そうでない場合は, 拡散反射基板の反射分布に従ったサンプリングを行います.
フレネル反射層の反射分布のpdf \(p_{s} \left( \omega_{o} \right)\) や 反射方向のサンプリング方法は層のMicrofacetモデルに従う (Beckman,GGXなど). 反射方向のサンプリングの方法については,アドベントカレンダー第8回 や Rough Specular Surface (GGX BRDF) を参照してください.
拡散反射基板の反射分布のpdf \(p_{b} \left( \omega_{o} \right)\) は,
\[
\begin{align}
p_{b} \left( \omega_{o} \right) =
\frac{ \left( \omega_{o} \cdot \omega_{n} \right) }{\pi}
\tag{6}
\end{align}
\]
であり, \(p_{b} \left( \omega_{o} \right)\) に従って反射方向をサンプリングします. 反射方向のサンプリング方法は Smooth Diffuse Surface (Lambert BRDF) を参照してください.
最終的な反射方向のpdf \(p \left( \omega_{o} \right)\) は,
\[
\begin{align}
p \left( \omega_{o} \right) =
\frac{R_{s}}{ \left( R_{s} + R_{b} \right) }
p_{s} \left( \omega_{o} \right) +
\frac{R_{b}}{ \left( R_{s} + R_{b} \right) }
p_{b} \left( \omega_{o} \right)
\tag{7}
\end{align}
\]
となります.
まとめ
パラメータ
拡散反射基板の反射率 |
\(\rho\) |
\(0 \le \rho \le 1\) |
表面粗さ |
\(roughness\) |
\(0 < roughness \le 1\) |
レンダリング
BRDF |
\(f_{r} \left( x, \omega_{i}, \omega_{o} \right)\) |
\(f_{s} \left( x, \omega_{i}, \omega_{o} \right) + f_{b} \left( x, \omega_{i}, \omega_{o} \right)\) |
pdf |
\(p \left( \omega_{o} \right)\) |
\(\frac{R_{s}}{ \left( R_{s} + R_{b} \right) } p_{s} \left( \omega_{o} \right) + \frac{R_{b}}{ \left( R_{s} + R_{b} \right) } p_{b} \left( \omega_{o} \right)\) |
反射レイのWeight |
\(\frac{f_{r} \left( x, \omega_{i}, \omega_{o} \right) \left( \omega_{o} \cdot \omega_{n} \right)} {p \left( \omega_{o} \right)}\) |
\(\frac{f_{r} \left( x, \omega_{i}, \omega_{o} \right) \left( \omega_{o} \cdot \omega_{n} \right)} {p \left( \omega_{o} \right)}\) (特にキャンセルできる項は無い) |
以上,Interfaced Lambertian BRDFについて簡単にまとめました.
参考文献
- Daniel Meneveaux: Rendering Rough Opaque Materials with Interfaced Lambertian Microfacets (2017)