GUI documentation update pass, part 1

metadata
Wenzel Jakob 2012-10-18 11:28:07 -04:00
parent c7892f5bdc
commit 9c4b1d9a1c
3 changed files with 76 additions and 52 deletions

View File

@ -37,7 +37,7 @@ static StatsCounter avgPathLength("Path tracer", "Average path length", EAverage
* path termination criterion. \default{\code{5}} * path termination criterion. \default{\code{5}}
* } * }
* \parameter{strictNormals}{\Boolean}{Be strict about potential * \parameter{strictNormals}{\Boolean}{Be strict about potential
* inconsistencies involving shading normals? See \pluginref{path} * inconsistencies involving shading normals? See the description below
* for details.\default{no, i.e. \code{false}}} * for details.\default{no, i.e. \code{false}}}
* } * }
* *

View File

@ -44,7 +44,9 @@ static StatsCounter avgPathLength("Volumetric path tracer", "Average path length
* This plugin provides a volumetric path tracer that can be used to * This plugin provides a volumetric path tracer that can be used to
* compute approximate solutions to the radiative transfer equation. * compute approximate solutions to the radiative transfer equation.
* Its implementation makes use of multiple importance sampling to * Its implementation makes use of multiple importance sampling to
* combine BSDF and emitter sampling strategies. * combine BSDF and phase function sampling with direct illumination
* sampling strategies. On surfaces, this integrator behaves exactly
* like the standard path tracer.
* *
* \remarks{ * \remarks{
* \item This integrator will generally perform poorly when rendering * \item This integrator will generally perform poorly when rendering

View File

@ -37,20 +37,23 @@
</param> </param>
<param name="strictNormals" readableName="Strict surface normals" type="boolean" default="false" importance="1"> <param name="strictNormals" readableName="Strict surface normals" type="boolean" default="false" importance="1">
<p> <p>
This parameter specifies the action to be taken when the geometric Be strict about potential inconsistencies involving shading normals?
and shading normals of a surface don't agree on whether a ray is on
the front or back-side of a surface.
</p>
<p>
When <tt>strictNormals</tt> is set to <tt>false</tt>, the shading normal has
precedence, and rendering proceeds normally at the risk of
introducing small light leaks (this is the default).
</p>
<p>
When <tt>strictNormals</tt> is set to <tt>true</tt>, the random walk is
terminated when encountering such a situation. This may
produce silhouette darkening on badly tesselated meshes.
</p> </p>
<p>Triangle meshes often rely on interpolated shading normals
to suppress the inherently faceted appearance of the underlying geometry. These
"fake" normals are not without problems, however. They can lead to paradoxical
situations where a light ray impinges on an object from a direction that is classified as "outside"
according to the shading normal, and "inside" according to the true geometric normal.</p>
<p>The <tt>strictNormals</tt>
parameter specifies the intended behavior when such cases arise. The default (<tt>false</tt>, i.e. "carry on")
gives precedence to information given by the shading normal and considers such light paths to be valid.
This can theoretically cause light "leaks" through boundaries, but it is not much of a problem in practice.</p>
<p>When set to <tt>true</tt>, the path tracer detects inconsistencies and ignores these paths. When objects
are poorly tesselated, this latter option may cause them to lose a significant amount of the incident
radiation (or, in other words, they will look dark).
The bidirectional integrators in Mitsuba (BDPT, PSSMLT, MLT, ..)
implicitly have <tt>strictNormals</tt> activated. Hence, another use of this parameter
is to match renderings created by these methods.</p>
</param> </param>
</plugin> </plugin>
@ -160,32 +163,47 @@
<plugin type="integrator" name="direct" readableName="Direct illumination" <plugin type="integrator" name="direct" readableName="Direct illumination"
show="true" className="MIDirectIntegrator" extends="SampleIntegrator"> show="true" className="MIDirectIntegrator" extends="SampleIntegrator">
<descr> <descr>
Direct-only integrator using multiple importance sampling. <p>This integrator implements a direct illumination technique that makes use
Takes a user-specifiable amount of luminaire of <em>multiple importance sampling</em>: for each pixel sample, the
and BSDF samples and combines them using the power heuristic integrator generates a user-specifiable number of BSDF and emitter
By setting one of the strategies to zero, this samples and combines them using the power heuristic. Usually, the BSDF
plugin can effectively be turned into a luminaire sampling or sampling technique works very well on glossy objects but does badly
BSDF sampling-based integrator. Ignores participating media everywhere else, while the opposite is true for the emitter sampling
if they are present. technique. By combining these approaches, one
can obtain a rendering technique that works well in both cases.</p>
<p>The number of samples spent on either technique is configurable, hence
it is also possible to turn this plugin into an emitter sampling-only
or BSDF sampling-only integrator.</p>
<p>For best results, combine the direct illumination integrator with the
low-discrepancy sample generator. Generally, the number
of pixel samples of the sample generator can be kept relatively
low (e.g. <tt>sampleCount=4</tt>), whereas the emitter and BSDF sample
parameters of this integrator should be increased until the variance in
the output renderings is acceptable.</p>
</descr> </descr>
<param name="emitterSamples" readableName="Emitter samples" type="integer" default="1">Number of samples to take using the emitter sampling technique</param> <param name="emitterSamples" readableName="Emitter samples" type="integer" default="1">Number of samples to take using the emitter sampling technique</param>
<param name="bsdfSamples" readableName="BSDF samples" type="integer" default="1">Number of samples to take using the BSDF sampling technique</param> <param name="bsdfSamples" readableName="BSDF samples" type="integer" default="1">Number of samples to take using the BSDF sampling technique</param>
<param name="strictNormals" readableName="Strict surface normals" type="boolean" default="false" importance="1"> <param name="strictNormals" readableName="Strict surface normals" type="boolean" default="false" importance="1">
<p> <p>
This parameter specifies the action to be taken when the geometric Be strict about potential inconsistencies involving shading normals?
and shading normals of a surface don't agree on whether a ray is on
the front or back-side of a surface.
</p>
<p>
When <tt>strictNormals</tt> is set to <tt>false</tt>, the shading normal has
precedence, and rendering proceeds normally at the risk of
introducing small light leaks (this is the default).
</p>
<p>
When <tt>strictNormals</tt> is set to <tt>true</tt>, the random walk is
terminated when encountering such a situation. This may
produce silhouette darkening on badly tesselated meshes.
</p> </p>
<p>Triangle meshes often rely on interpolated shading normals
to suppress the inherently faceted appearance of the underlying geometry. These
"fake" normals are not without problems, however. They can lead to paradoxical
situations where a light ray impinges on an object from a direction that is classified as "outside"
according to the shading normal, and "inside" according to the true geometric normal.</p>
<p>The <tt>strictNormals</tt>
parameter specifies the intended behavior when such cases arise. The default (<tt>false</tt>, i.e. "carry on")
gives precedence to information given by the shading normal and considers such light paths to be valid.
This can theoretically cause light "leaks" through boundaries, but it is not much of a problem in practice.</p>
<p>When set to <tt>true</tt>, the path tracer detects inconsistencies and ignores these paths. When objects
are poorly tesselated, this latter option may cause them to lose a significant amount of the incident
radiation (or, in other words, they will look dark).
The bidirectional integrators in Mitsuba (BDPT, PSSMLT, MLT, ..)
implicitly have <tt>strictNormals</tt> activated. Hence, another use of this parameter
is to match renderings created by these methods.</p>
</param> </param>
</plugin> </plugin>
@ -202,27 +220,26 @@
<plugin type="integrator" name="volpath_simple" readableName = "Volumetric path tracer (Simple)" <plugin type="integrator" name="volpath_simple" readableName = "Volumetric path tracer (Simple)"
show="true" className="SimpleVolumetricPathTracer" extends="MonteCarloIntegrator"> show="true" className="SimpleVolumetricPathTracer" extends="MonteCarloIntegrator">
<descr> <descr>
Volumetric path tracer, which solves the full radiative transfer This plugin provides a basic volumetric path tracer that can be used to
equation in the presence of participating media. compute approximate solutions to the radiative transfer equation. This
Simplified version without multiple importance sampling - this particular integrator is named "simple" because it does not make use of
version can be significantly faster than the extended multiple importance sampling. This results in a potentially
version when when rendering heterogeneous participating media using the faster execution time. On the other hand, it also means that this
[Coleman et al.] sampling technique, as fewer attenuation plugin will likely not perform well when given a scene that contains
evaluations will be performed. highly glossy materials. In this case, please use the extended volumetric
path tracer or one of the bidirectional techniques.
</descr> </descr>
</plugin> </plugin>
<plugin type="integrator" name="volpath" readableName = "Volumetric path tracer (Extended)" <plugin type="integrator" name="volpath" readableName = "Volumetric path tracer (Extended)"
show="true" className="VolumetricPathTracer" extends="MonteCarloIntegrator"> show="true" className="VolumetricPathTracer" extends="MonteCarloIntegrator">
<descr> <descr>
Volumetric path tracer, which solves the full radiative transfer This plugin provides a volumetric path tracer that can be used to
equation in the presence of participating media. Estimates single compute approximate solutions to the radiative transfer equation.
scattering using both phase function and luminaire sampling and Its implementation makes use of multiple importance sampling to
combines the two with multiple importance sampling and the power combine BSDF and phase function sampling with direct illumination
heuristic. Afterwards, the phase function sample is reused to sampling strategies. On surfaces, this integrator behaves exactly
recursively estimate the multiple scattering component, which saves an like the standard path tracer.
intersection computation.
On surfaces, this integrator behaves exactly like the MI path tracer.
</descr> </descr>
</plugin> </plugin>
@ -250,6 +267,11 @@
hitting it via ray tracing. This is one of the worst conceivable rendering hitting it via ray tracing. This is one of the worst conceivable rendering
and not recommended for any applications. It is mainly included for and not recommended for any applications. It is mainly included for
debugging purposes.</p> debugging purposes.</p>
<p>The number of traced particles is given by the number of "samples per
pixel" of the sample generator times the pixel count of the output image.
For instance, 16 samples per pixel on a 512x512 image will cause 4M particles
to be generated.</p>
</descr> </descr>
<param name="granularity" readableName="Work unit granularity" type="integer" default="200000" importance="1"> <param name="granularity" readableName="Work unit granularity" type="integer" default="200000" importance="1">
Specifies the work unit granularity used to parallize the Specifies the work unit granularity used to parallize the