Structured Light
List of Operators ↓
This chapter describes operators for using structured light.
Concept of Structured Light
The basic concept behind structured light is to use a structured
illumination, i.e. an illumination showing well known patterns.
The way those patterns appear in the scene after hitting surfaces
helps to further analyze or reconstruct the surfaces.
To use structured light, a model must first be created using
create_structured_light_modelcreate_structured_light_modelCreateStructuredLightModelCreateStructuredLightModelcreate_structured_light_model. The model type is specified in
ModelTypeModelTypeModelTypemodelTypemodel_type. Currently, the model types 'deflectometry'"deflectometry""deflectometry""deflectometry""deflectometry"
and '3d_reconstruction'"3d_reconstruction""3d_reconstruction""3d_reconstruction""3d_reconstruction" are supported.
Depending on the task, different kinds of illumination should be used:
-
For deflectometry, i.e. for detecting defects on a specular
or shiny surface, a display or monitor should be used.
-
For 3D surface reconstruction of lambertian or diffuse surfaces
a pattern projector should be used.
Deflectometry is the procedure of analyzing the reflections
of known patterns from specular or semi-specular surfaces. In
such a setup, every pattern image must be shown by the display or monitor.
It is then reflected by the specular surface under test, and
a camera image of the reflection is acquired. Deformations of the pattern
in the camera image are caused by the form of the specular surface
which implies that defects on the specular surface can be detected.
For non-specular surfaces, a 3D surface can be reconstructed,
using a projector projecting light like an 'inverse camera'.
For every projected pattern image, a camera image of the projection
on the surface is acquired. Using the decoded correspondence between
projector coordinates lighting the camera coordinates, as well as
calibration information, the 3D surface is reconstructed.
In the following, the steps that are required to use structured light
are described briefly.
- Create a structured light model:
-
In the first step, a structured light model is created with
or read with
- Set the model parameters:
-
The different structured light model parameters can then be set with
set_structured_light_model_paramset_structured_light_model_paramSetStructuredLightModelParamSetStructuredLightModelParamset_structured_light_model_param or queried with
get_structured_light_model_paramget_structured_light_model_paramGetStructuredLightModelParamGetStructuredLightModelParamget_structured_light_model_param. The pattern parameters
'pattern_width'"pattern_width""pattern_width""pattern_width""pattern_width", 'pattern_height'"pattern_height""pattern_height""pattern_height""pattern_height",
'pattern_orientation'"pattern_orientation""pattern_orientation""pattern_orientation""pattern_orientation", and 'pattern_type'"pattern_type""pattern_type""pattern_type""pattern_type" specify along
with the stripe parameters 'min_stripe_width'"min_stripe_width""min_stripe_width""min_stripe_width""min_stripe_width" and
'single_stripe_width'"single_stripe_width""single_stripe_width""single_stripe_width""single_stripe_width" the specifications of the pattern images to
be used to illuminate the surface. Finally, the
'persistence'"persistence""persistence""persistence""persistence" parameter can be enabled to debug intermediate
results.
- Generate the pattern images:
-
The pattern images are to be generated with
gen_structured_light_patterngen_structured_light_patternGenStructuredLightPatternGenStructuredLightPatterngen_structured_light_pattern after setting all relevant parameters.
Please ensure that the output images are as needed in the particular setup.
- Use the patterns to illuminate the surface and acquire the camera images:
-
At this stage, the pattern images are shown on the display or projected.
The respective image of the illuminated surface is acquired by the camera
for each pattern image.
- Decode the acquired images:
-
The acquired CameraImagesCameraImagesCameraImagescameraImagescamera_images can be decoded with
decode_structured_light_patterndecode_structured_light_patternDecodeStructuredLightPatternDecodeStructuredLightPatterndecode_structured_light_pattern. Upon calling this operator, the
correspondence images are created and stored in the model
StructuredLightModelStructuredLightModelStructuredLightModelstructuredLightModelstructured_light_model.
The decoded 'correspondence_image'"correspondence_image""correspondence_image""correspondence_image""correspondence_image", as well as other results
can be queried with get_structured_light_objectget_structured_light_objectGetStructuredLightObjectGetStructuredLightObjectget_structured_light_object. For more
details of the different objects that can be queried, please refer
to the operator's documentation.
- Get the results for structured light models of type 'deflectometry':
-
The 'defect_image'"defect_image""defect_image""defect_image""defect_image" can be generated and queried with
get_structured_light_objectget_structured_light_objectGetStructuredLightObjectGetStructuredLightObjectget_structured_light_object.
- Get the results for structured light models of type '3d_reconstruction':
-
The calibration information can be specified with the parameter
'camera_setup_model'"camera_setup_model""camera_setup_model""camera_setup_model""camera_setup_model" of set_structured_light_model_paramset_structured_light_model_paramSetStructuredLightModelParamSetStructuredLightModelParamset_structured_light_model_param.
The reconstructed surface can then be obtained with
reconstruct_surface_structured_lightreconstruct_surface_structured_lightReconstructSurfaceStructuredLightReconstructSurfaceStructuredLightreconstruct_surface_structured_light.
Further operators
The structured light model offers various other operators that help access
and update the various parameters of the model.
The operator write_structured_light_modelwrite_structured_light_modelWriteStructuredLightModelWriteStructuredLightModelwrite_structured_light_model enables writing the
structured light model to a file. Please note that previously generated
pattern images are not written in this file. A structured light model file
can be read using read_structured_light_modelread_structured_light_modelReadStructuredLightModelReadStructuredLightModelread_structured_light_model.
Furthermore, it is possible to serialize and deserialize the structured
light model using serialize_structured_light_modelserialize_structured_light_modelSerializeStructuredLightModelSerializeStructuredLightModelserialize_structured_light_model and
deserialize_structured_light_modeldeserialize_structured_light_modelDeserializeStructuredLightModelDeserializeStructuredLightModeldeserialize_structured_light_model.
Further Information
See also the “Solution Guide Basics” for further details.
List of Operators
clear_structured_light_modelClearStructuredLightModelclear_structured_light_modelClearStructuredLightModelclear_structured_light_model
- Clear a structured light model and free the allocated memory.
create_structured_light_modelCreateStructuredLightModelcreate_structured_light_modelCreateStructuredLightModelcreate_structured_light_model
- Create a structured light model.
decode_structured_light_patternDecodeStructuredLightPatterndecode_structured_light_patternDecodeStructuredLightPatterndecode_structured_light_pattern
- Decode the camera images acquired with a structured light setup.
deserialize_structured_light_modelDeserializeStructuredLightModeldeserialize_structured_light_modelDeserializeStructuredLightModeldeserialize_structured_light_model
- Deserialize a structured light model.
gen_structured_light_patternGenStructuredLightPatterngen_structured_light_patternGenStructuredLightPatterngen_structured_light_pattern
- Generate the pattern images to be displayed in a structured light setup.
get_structured_light_model_paramGetStructuredLightModelParamget_structured_light_model_paramGetStructuredLightModelParamget_structured_light_model_param
- Query parameters of a structured light model.
get_structured_light_objectGetStructuredLightObjectget_structured_light_objectGetStructuredLightObjectget_structured_light_object
- Get (intermediate) iconic results of a structured light model.
read_structured_light_modelReadStructuredLightModelread_structured_light_modelReadStructuredLightModelread_structured_light_model
- Read a structured light model from a file.
reconstruct_surface_structured_lightReconstructSurfaceStructuredLightreconstruct_surface_structured_lightReconstructSurfaceStructuredLightreconstruct_surface_structured_light
- Reconstruct a surface from a decoded structured light setup.
serialize_structured_light_modelSerializeStructuredLightModelserialize_structured_light_modelSerializeStructuredLightModelserialize_structured_light_model
- Serialize a structured light model.
set_structured_light_model_paramSetStructuredLightModelParamset_structured_light_model_paramSetStructuredLightModelParamset_structured_light_model_param
- Set parameters of a structured light model.
write_structured_light_modelWriteStructuredLightModelwrite_structured_light_modelWriteStructuredLightModelwrite_structured_light_model
- Write a structured light model to a file.