This section describes the low level baking API (the EnlightenBake
library).
As an additional resource, the Enlighten SDK includes a sample application called |
|
The initial stage of the baking is:
Enlighten IPrecompInputGeometry
instances you want in each bake system. Each bake system represents one output lightmap.IBakeInputSystem
for each bake system you want. Ensure the name is unique.Enlighten IBakeInputProperties
, and if you are not creating your own lightmap UV stream, turn packing on here also. Use IBakeInputSystem::SetBakeProperties
to pass the properties to the bake system.Enlighten BakeInputMeshInfo
object filling out the fields appropriately, and then call IBakeInputSystem::AddMesh()
.IBakeInputSystem::Finalise()
, and extract the new lightmap UV stream if packing was required.Outputs from a previous stage are never modified by a later one, so you can often run these stages in parallel (for example, through distributed build systems such as IncrediBuild).
The diagram below shows the creation of one IBakeInputSystem
. Repeat for each output map required.
|
BakeSystemResource
object. This object is used to create a KD tree for the other stages to trace against, so requires updating if any geometry changes.IBakeInputLighting
object.BakeSystemResource
, create an IBakeVisibilityBuffer
with the IBake
API. This operation is slow; therefore if only the lights have changed (and not the geometry) you can pass in an IBakeVisibilityBuffer
from a previous run and it will be updated.IBake::BakeSystemDirect()
to create the IBakeOutputSystemDirect
. Optionally pass in a BakeSystemResource
object to be able to apply a visibility-aware post-processing filter, with its size set as the filter size baking property. The final output texture, in FP16 format, can be pulled from this object.The diagrams below show a scene with two IBakeInputSystem
s; there may be more or fewer than this.
|
IBakeInputRuntime
and fill it with the RadSystemCore
and InputWorkspace
of each Enlighten system.IBakeInputSystem
using all the Radiosity objects of the Enlighten system. This is required later in the process in order to fit the Enlighten lit instances to the bake system instances. Set the resolution of the IBakeInputSystem
to the resolution of the Enlighten lightmap via an IBakeInputProperties
object passed to the IBakeInputSystem::SetBakeProperties
method.IBake::CreateRuntimeLighting
to create an IBakeRuntimeLighting
from:IBakeInputSystem
that you just madeIPrecompSystemDuster
IPrecompPackedSystem
IBakeInputLighting
IBake::UpdateRuntimeLighting
to apply the light and albedo information for each bake system to the Enlighten system.IBake::FinaliseRuntimeLighting
IBake::RunEnlightenSolver
; this takes all the information and spins a small Enlighten Runtime until the lighting values settle. This is run only once as it contains information about every system in the bake.IBake::BakeSystemIndirect
and extract the indirect lighting from the IBakeOutputSystemIndirect
it creates. Optionally pass in a BakeSystemResource
object and a IBakeInputRayOriginPositions
to be able to enable visibility-aware upsampling with the identically named baking property.
|
Final Gather creates a refined version of the indirect lightmap through ray tracing, by using previously calculated indirect and direct lightmaps. The final gather baking thus has a dependency on all the IBakeOutputSystemIndirect
and all the IBakeOutputSystemDirect
objects previously created for the baked scene, as well as their matching IBakeInputSystem
objects. It also has a dependency on the IBakeSystemResource
object (used for raytracing) and the IBakeSolvedRuntime
objects for the baked scene.
IBakeInputSystem
, call IBake::BakeSystemFinalGather
.IBakeOutputSystemFinalGather
objects.node [fontname=Helvetica, fontsize=10]; ips [ shape=folder fillcolor=white color=firebrick label="IBakeInputSystem" URL="" ]; sr [ shape=note fillcolor=white color=darkslategrey label="IBakeSystemResource" URL="" ]; srt [ shape=note fillcolor=white color=darkslategrey label="IBakeSolvedRuntime" URL="" ]; sod [ shape=note fillcolor=white color=green4 label="IBakeOutputSystemDirect" URL="" ]; soi [ shape=note fillcolor=white color=green4 label="IBakeOutputSystemIndirect" URL="" ]; bsfg [ shape=box fillcolor=white color=goldenrod1 style=rounded label="IBake::BakeSystemFinalGather" URL="" ]; sfg [ shape=note fillcolor=white color=green4 label="IBakeOutputSystemFinalGather" URL="" ]; ips -> bsfg; sr -> bsfg; srt -> bsfg; sod -> bsfg; soi -> bsfg; bsfg -> sfg; |
BakeSystemResource
, call IBake::BakeSystemAO
.IBakeOutputSystemAO
objects.node [fontname=Helvetica, fontsize=10]; sr1 [ shape=folder fillcolor=white color=firebrick label="IBakeSystemResource" URL="" ]; bao1 [ shape=box fillcolor=white color=goldenrod1 style=rounded label="IBake::BakeSystemAO" URL="" ]; ao1 [ shape=note fillcolor=white color=green4 label="IBakeOutputSystemAO" URL="" ]; sr1 -> bao1 -> ao1; |
IBakeInputLighting
object.IPrecompInputProbeSet
, create an IBakeVisibilityBuffer
with the IBake
API. You also need to pass in a BakeSystemResource
object, with all the systems that can influence the direct lighting for the probes. This operation is slow; therefore if only the lights have changed (and not the geometry) you can pass in an IBakeVisibilityBuffer
from a previous run and it will be updated.IBake::BakeProbeSetDirect()
to create the IBakeOutputProbeSet
. Use the IBakeOutputProbeSet::GetOutput()
method to retrieve the SH coefficients of all probes in the probe set.node [fontname=Helvetica, fontsize=10]; ips1 [ shape=folder fillcolor=white color=firebrick label="IPrecompInputProbeSet" URL="" ]; bsr1 [ shape=folder fillcolor=white color=firebrick label="IBakeSystemResource" URL="" ]; upvb1 [ shape=box fillcolor=white color=goldenrod1 style=rounded label="IBake::UpdateProbeVisibilityBuffer" URL="" ]; bvb1 [ shape=folder fillcolor=white color=firebrick label="IBakeVisibilityBuffer" URL="" ]; ips2 [ shape=folder fillcolor=white color=firebrick label="IPrecompInputProbeSet" URL="" ]; bvb2 [ shape=folder fillcolor=white color=firebrick label="IBakeVisibilityBuffer" URL="" ]; bpsd2 [ shape=box fillcolor=white color=goldenrod1 style=rounded label="IBake::BakeProbeSetDirect" URL="" ]; bops2 [ shape=note fillcolor=white color=green4 label="IBakeOutputProbeSet" URL="" ]; ips1 -> upvb1; bsr1 -> upvb1; upvb1 -> bvb1; ips2 -> bpsd2; bvb2 -> bpsd2; bpsd2 -> bops2; |
IBakeSolvedRuntime::GetSolvedProbe()
method of IBakeSolvedRuntime
to retrieve the SH coefficients.bsr1 [ shape=folder fillcolor=white color=firebrick label="IBakeSolvedRuntime" URL="" ]; gsp1 [ shape=box fillcolor=white color=blue style=rounded label="IBakeSolvedRuntime::GetSolvedProbe" URL="" ]; ipv1 [ shape=note fillcolor=white color=green4 label="Individual probe value" URL="" ]; bsr1 -> gsp1; gsp1 -> ipv1; |
The baked radiosity normal texture is needed when using baked directional irradiance to better bring out features when the fine-grained shading normal used in runtime deviates from the cruder normal used for computing radiosity. (typical example is re-lighting normal maps)
BakeInputSystem
, call IBake::BakeSystemRadiosityNormal
, providing the BakeSolvedRuntime
for all Enlighten systems.IBakeOutputSystemRadiosityNormal
objects.node [fontname=Helvetica, fontsize=10]; ips [ shape=folder fillcolor=white color=firebrick label="IBakeInputSystem" URL="" ]; sr [ shape=note fillcolor=white color=darkslategrey label="IBakeSolvedRuntime" URL="" ]; bsrn [ shape=box fillcolor=white color=goldenrod1 style=rounded label="IBake::BakeSystemRadiosityNormal" URL="" ]; srn [ shape=note fillcolor=white color=green4 label="IBakeOutputSystemRadiosityNormal" URL="" ]; ips -> bsrn; sr -> bsrn; bsrn -> srn; |
If you experience problems when using the Low Level Precompute API, call the GeoAttachSystemLoggers/GeoAttachLogger
functions to issue error and warning messages. For more information, see the API documentation at module Message Reporting and Error Handling.
To debug scenes with baked light maps using GeoRadiosity, follow the steps required for the low-level precompute API. In addition to the precompute input files, you also need to serialise the IBakeInputSystem
and IBakeInputProperties
objects. Please note that you should have assigned a GUID to the IBakeInputProperties
because this identifier is used to link the properties with the generated light maps.
If you pass in different chart UVs to the low-level baking API than to the low-level precompute API, you must generate an object of the IBakeInputGeometryUvs
class for each geometry in your scene. This file must have the same file name as the serialised IPrecompInputGeometry
object, but with the extension changed to .buv
.
Additionally, to support materials in baking, you must generate XML-based material files as used in the high-level build system. For each IPrecompInputGeometry
you have, a material file can be created for each mesh with the index of the mesh appended to the file name and the extension changed to .mats
. For example, if your serialized IPrecompInputGeometry
is called Geom.ig
and contains two meshes, then you should create two materials files called Geom_0.mats
and Geom_1.mats
. Please note that this is optional and only required if you need to reproduce the materials in the reconstructed scene; for example if it important for your debugging effort.
Any referenced texture in the materials file should have a file path relative to the material file. Use the GeoRGBXTexture
class to serialise the texture.
Only scenes which assign instances to light maps can be extracted. Scenes which map individual meshes to light maps are currently not supported. |