Operator Reference
object_model_3d_to_xyz (Operator)
object_model_3d_to_xyz
— Transform 3D points from a 3D object model to images.
Signature
Description
The operator object_model_3d_to_xyz
transforms the 3D points of
the 3D object model ObjectModel3D
into the three images
X
, Y
, and Z
.
Three transformation modes are possible. The parameter Type
is
used to select one of them. Note that multiple 3D object models can be
passed in ObjectModel3D
only for the mode 'cartesian_faces' .
All other modes expect a single 3D object model.
- 'cartesian' :
-
First, each point is transformed into the camera coordinate system using the given
Pose
. Then, these coordinates are projected into the image coordinate system based on the internal camera parametersCamParam
.The internal camera parameters
CamParam
describe the projection characteristics of the camera (see Calibration). ThePose
is in the form , where ccs denotes camera coordinate system and mcs the model coordinate system (which is a 3D world coordinate system), see Transformations / Poses and“Solution Guide III-C - 3D Vision”
. Hence, it describes the position and orientation of the model coordinate system relative to the camera coordinate system.The X-, Y-, and Z-coordinates of the transformed point are written into the corresponding image at the position of the projection. If multiple points are projected to the same image coordinates, the point with the smallest Z-value is written (hidden-point removal). The dimensions of the returned images are defined by the camera parameters.
The returned images show the object as it would look like when seeing it with the specified camera under the specified pose.
- 'cartesian_faces' :
-
In order to use this transformation, the input 3D object models need to contain faces (triangles or polygons), otherwise, the 3D object model without faces is disregarded. Note that if the 3D object models have polygon faces, those are converted internally to triangles. This conversion can be done beforehand to speed up this operator. For this,
read_object_model_3d
can be called with theGenParamName
'convert_to_triangles' set to 'true' , to convert all faces to triangles. Alternatively,triangulate_object_model_3d
can be called prior to this operator.First, each face of the 3D object models
ObjectModel3D
is transformed into the camera coordinate system using the givenPose
. Then, these coordinates are projected into the image coordinate system based on the internal camera parametersCamParam
, while keeping the 3D information (X-, Y-, and Z-coordinates) for each of those pixels. For a more detailed explanation ofCamParam
andPose
please refer to the section 'cartesian' . If multiple faces are projected to the same image coordinates, the value with the smallest Z-value is written (hidden-point removal). The dimensions of the returned images are defined by the camera parameters.The returned images show the objects as they would look like when seeing them with the specified camera under the specified pose.
In case that OpenGL 2.1, GLSL 1.2, and the OpenGL extensions GL_EXT_framebuffer_object and GL_EXT_framebuffer_blit are available, speed increases.
This
Type
can be used to create 3D object models containing 2D mapping data, by creating a 3D object model from the returned images usingxyz_to_object_model_3d
. Note that in many cases, it is recommended to use the 2D mapping data, if available, for speed and robustness reasons. This is beneficial for example when usingsample_object_model_3d
,surface_normals_object_model_3d
, or when preparing a 3D object model for surface-based matching, e.g., smoothing, removing outliers, and reducing the domain. - 'cartesian_faces_no_opengl' :
-
This transformation mode works in the same way as the method 'cartesian_faces' but does not use OpenGL. In general, 'cartesian_faces' automatically determines if OpenGL is available. Thus, it is usually not required to use 'cartesian_faces_no_opengl' explicitly. It can make sense, however, to use it in cases where the automatic mode selection does not work due to, for example, driver issues with OpenGL.
- 'from_xyz_map' :
-
This transformation mode works only if the 3D object model was created with the operator
xyz_to_object_model_3d
. It writes each 3D point to the image coordinate where it originally came from, using the mapping attribute that is stored within the 3D object model.The parameters
CamParam
andPose
are ignored. The dimensions of the returned images are equal to the dimensions of the original images that were used withxyz_to_object_model_3d
to create the 3D object model and can be queried fromget_object_model_3d_params
with 'mapping_size' .This transformation mode is faster than 'cartesian' . It is suitable, e.g., to visualize the results of a segmentation done with
segment_object_model_3d
.
Attention
Cameras with hypercentric lenses are not supported.
For displaying large faces with a non-zero distortion
in CamParam
, note that the distortion is only applied to the
points of the model. In the projection, these points are subsequently
connected by straight lines. For a good approximation of the distorted
lines, please use a triangulation with sufficiently small triangles.
Execution Information
- Multithreading type: reentrant (runs in parallel with non-exclusive operators).
- Multithreading scope: global (may be called from any thread).
- Processed without parallelization.
Parameters
X
(output_object) singlechannelimage →
object (real)
Image with the X-Coordinates of the 3D points.
Y
(output_object) singlechannelimage →
object (real)
Image with the Y-Coordinates of the 3D points.
Z
(output_object) singlechannelimage →
object (real)
Image with the Z-Coordinates of the 3D points.
ObjectModel3D
(input_control) object_model_3d(-array) →
(handle)
Handle of the 3D object model.
Type
(input_control) string →
(string)
Type of the conversion.
Default: 'cartesian'
List of values: 'cartesian' , 'cartesian_faces' , 'cartesian_faces_no_opengl' , 'from_xyz_map'
CamParam
(input_control) campar →
(real / integer / string)
Camera parameters.
Pose
(input_control) pose →
(real / integer)
Pose of the 3D object model.
Number of elements: Pose == 0 || Pose == 7 || Pose == 12
Result
The operator object_model_3d_to_xyz
returns the value
2 (
H_MSG_TRUE)
if the given parameters are correct. Otherwise, an exception
will be raised.
Possible Predecessors
read_object_model_3d
,
xyz_to_object_model_3d
,
triangulate_object_model_3d
Alternatives
See also
xyz_to_object_model_3d
,
get_object_model_3d_params
Module
3D Metrology