Fixed an incorrect radiance conversion factor in 'coating' and 'roughcoating' reported by Attila Afra.
The models now produce the right falloff compared to Monte Carlo reference renderings with explicitly instantiated layersmetadata
parent
10d47cef56
commit
9b225443a4
|
@ -246,12 +246,10 @@ public:
|
||||||
(1/std::abs(Frame::cosTheta(bRecInt.wi)) +
|
(1/std::abs(Frame::cosTheta(bRecInt.wi)) +
|
||||||
1/std::abs(Frame::cosTheta(bRecInt.wo)))).exp();
|
1/std::abs(Frame::cosTheta(bRecInt.wo)))).exp();
|
||||||
|
|
||||||
if (measure == ESolidAngle) {
|
|
||||||
/* Solid angle compression & irradiance conversion factors */
|
/* Solid angle compression & irradiance conversion factors */
|
||||||
|
if (measure == ESolidAngle)
|
||||||
result *= m_invEta * m_invEta *
|
result *= m_invEta * m_invEta *
|
||||||
Frame::cosTheta(bRec.wi) * Frame::cosTheta(bRec.wo)
|
Frame::cosTheta(bRec.wo) / Frame::cosTheta(bRecInt.wo);
|
||||||
/ (Frame::cosTheta(bRecInt.wi) * Frame::cosTheta(bRecInt.wo));
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -364,11 +362,9 @@ public:
|
||||||
|
|
||||||
result *= (1 - R12) * (1 - R21);
|
result *= (1 - R12) * (1 - R21);
|
||||||
|
|
||||||
if (BSDF::getMeasure(bRec.sampledType) == ESolidAngle) {
|
|
||||||
/* Solid angle compression & irradiance conversion factors */
|
/* Solid angle compression & irradiance conversion factors */
|
||||||
result *= Frame::cosTheta(bRec.wi) / Frame::cosTheta(wiPrime);
|
if (BSDF::getMeasure(bRec.sampledType) == ESolidAngle)
|
||||||
pdf *= m_invEta * m_invEta * Frame::cosTheta(bRec.wo) / Frame::cosTheta(woPrime);
|
pdf *= m_invEta * m_invEta * Frame::cosTheta(bRec.wo) / Frame::cosTheta(woPrime);
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
|
@ -306,12 +306,10 @@ public:
|
||||||
(1/std::abs(Frame::cosTheta(bRecInt.wi)) +
|
(1/std::abs(Frame::cosTheta(bRecInt.wi)) +
|
||||||
1/std::abs(Frame::cosTheta(bRecInt.wo)))).exp();
|
1/std::abs(Frame::cosTheta(bRecInt.wo)))).exp();
|
||||||
|
|
||||||
if (measure == ESolidAngle) {
|
|
||||||
/* Solid angle compression & irradiance conversion factors */
|
/* Solid angle compression & irradiance conversion factors */
|
||||||
|
if (measure == ESolidAngle)
|
||||||
nestedResult *= m_invEta * m_invEta *
|
nestedResult *= m_invEta * m_invEta *
|
||||||
Frame::cosTheta(bRec.wi) * Frame::cosTheta(bRec.wo)
|
Frame::cosTheta(bRec.wo) / Frame::cosTheta(bRecInt.wo);
|
||||||
/ (Frame::cosTheta(bRecInt.wi) * Frame::cosTheta(bRecInt.wo));
|
|
||||||
}
|
|
||||||
|
|
||||||
result += nestedResult;
|
result += nestedResult;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue