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 layers
metadata
Wenzel Jakob 2015-06-30 11:16:48 +02:00
parent 10d47cef56
commit 9b225443a4
2 changed files with 8 additions and 14 deletions

View File

@ -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;
} }

View File

@ -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;
} }