chi-square test fixes

metadata
Wenzel Jakob 2014-07-01 12:21:23 +02:00
parent c81b015cea
commit 641f0a96dd
7 changed files with 23 additions and 24 deletions

View File

@ -1,4 +1,4 @@
<scene version="0.4.0"> <scene version="0.5.0">
<integrator type="ptracer"/> <integrator type="ptracer"/>
<shape type="disk"> <shape type="disk">

View File

@ -1,4 +1,4 @@
<scene version="0.4.0"> <scene version="0.5.0">
<sensor type="radiancemeter"> <sensor type="radiancemeter">
<transform name="toWorld"> <transform name="toWorld">
<lookAt origin="0, 0, -1" target="0, 0, 0"/> <lookAt origin="0, 0, -1" target="0, 0, 0"/>

View File

@ -1,4 +1,4 @@
<scene version="0.4.0"> <scene version="0.5.0">
<medium id="medium" type="homogeneous"> <medium id="medium" type="homogeneous">
<spectrum name="sigmaS" value="0"/> <spectrum name="sigmaS" value="0"/>
<spectrum name="sigmaA" value="1"/> <spectrum name="sigmaA" value="1"/>

View File

@ -1,7 +1,7 @@
<!-- This file defines a series of BSDF instances <!-- This file defines a series of BSDF instances
to be tested for consistency. This is done to be tested for consistency. This is done
using the testcase 'test_chisquare' --> using the testcase 'test_chisquare' -->
<scene version="0.4.0"> <scene version="0.5.0">
<!-- Test the smooth plastic model with preserveColors=false --> <!-- Test the smooth plastic model with preserveColors=false -->
<bsdf type="plastic"> <bsdf type="plastic">
<boolean name="preserveColors" value="false"/> <boolean name="preserveColors" value="false"/>

View File

@ -1,7 +1,7 @@
<!-- This file defines a series of emitter instances <!-- This file defines a series of emitter instances
to be tested for consistency. This is done using the to be tested for consistency. This is done using the
testcase 'test_chisquare' --> testcase 'test_chisquare' -->
<scene version="0.4.0"> <scene version="0.5.0">
<!-- Test the emitter emitter <!-- Test the emitter emitter
<emitter type="emitter"/> <emitter type="emitter"/>
--> -->

View File

@ -1,7 +1,7 @@
<!-- This file defines a series of phase function instances <!-- This file defines a series of phase function instances
to be tested for consistency. This is done using the to be tested for consistency. This is done using the
testcase 'test_chisquare' --> testcase 'test_chisquare' -->
<scene version="0.3.0"> <scene version="0.5.0">
<!-- Test the isotropic phase function --> <!-- Test the isotropic phase function -->
<phase type="isotropic"/> <phase type="isotropic"/>

View File

@ -329,8 +329,8 @@ public:
bRec.sampledType = EDeltaReflection; bRec.sampledType = EDeltaReflection;
bRec.wo = reflect(bRec.wi); bRec.wo = reflect(bRec.wi);
return m_specularReflectance->eval(bRec.its) * return m_specularReflectance->eval(bRec.its)
(Fi / probSpecular); * Fi / probSpecular;
} else { } else {
bRec.sampledComponent = 1; bRec.sampledComponent = 1;
bRec.sampledType = EDiffuseReflection; bRec.sampledType = EDiffuseReflection;
@ -354,13 +354,12 @@ public:
bRec.wo = reflect(bRec.wi); bRec.wo = reflect(bRec.wi);
return m_specularReflectance->eval(bRec.its) * Fi; return m_specularReflectance->eval(bRec.its) * Fi;
} else { } else {
bRec.wo = Warp::squareToCosineHemisphere(sample);
Float Fo = fresnelDielectricExt(Frame::cosTheta(bRec.wo), m_eta);
bRec.sampledComponent = 1; bRec.sampledComponent = 1;
bRec.sampledType = EDiffuseReflection; bRec.sampledType = EDiffuseReflection;
bRec.wo = Warp::squareToCosineHemisphere(sample);
Float Fo = fresnelDielectricExt(Frame::cosTheta(bRec.wo), m_eta);
Spectrum diff = m_diffuseReflectance->eval(bRec.its); Spectrum diff = m_diffuseReflectance->eval(bRec.its);
diff /= Spectrum(1.0f) - m_fdrInt*diff;
if (m_nonlinear) if (m_nonlinear)
diff /= Spectrum(1.0f) - diff*m_fdrInt; diff /= Spectrum(1.0f) - diff*m_fdrInt;
else else