Holds Fusion process data and functions. More...
| Functions | |
| Fusion () | |
| Default constructor.  More... | |
| ~Fusion () | |
| Default destructor.  More... | |
| FUSION_ERROR_CODE | init (sl::InitFusionParameters init_parameters=InitFusionParameters()) | 
| Initialize the fusion module with the requested parameters.  More... | |
| void | close () | 
| Will deactivate all the fusion modules and free internal data.  More... | |
| FUSION_ERROR_CODE | subscribe (const sl::FusionConfiguration &fusion_config) | 
| Set the specified camera as a data provider.  More... | |
| FUSION_ERROR_CODE | subscribe (CameraIdentifier uuid, CommunicationParameters param=CommunicationParameters(), sl::Transform pose=sl::Transform(), bool override_gravity=false) | 
| Set the specified camera as a data provider.  More... | |
| FUSION_ERROR_CODE | unsubscribe (CameraIdentifier uuid) | 
| Remove the specified camera from data provider.  More... | |
| FUSION_ERROR_CODE | updatePose (CameraIdentifier uuid, sl::Transform pose) | 
| Updates the specified camera position inside fusion WORLD.  More... | |
| FUSION_ERROR_CODE | getPose (CameraIdentifier uuid, sl::Transform &pose) | 
| Get the specified camera position inside fusion WORLD.  More... | |
| FUSION_ERROR_CODE | getProcessMetrics (FusionMetrics &metrics) | 
| Get the metrics of the Fusion process, for the fused data as well as individual camera provider data.  More... | |
| std::map< CameraIdentifier, SENDER_ERROR_CODE > | getSenderState () | 
| Returns the state of each connected data senders.  More... | |
| FUSION_ERROR_CODE | process () | 
| Runs the main function of the Fusion, this trigger the retrieve and synchronization of all connected senders and updates the enabled modules.  More... | |
| FUSION_ERROR_CODE | retrieveImage (sl::Mat &mat, CameraIdentifier uuid, sl::Resolution resolution=sl::Resolution(0, 0)) | 
| Returns the current sl::VIEW::LEFT of the specified camera, the data is synchronized.  More... | |
| FUSION_ERROR_CODE | retrieveMeasure (sl::Mat &mat, CameraIdentifier uuid, sl::MEASURE measure=sl::MEASURE::DEPTH, sl::Resolution resolution=sl::Resolution(0, 0), sl::FUSION_REFERENCE_FRAME reference_frame=sl::FUSION_REFERENCE_FRAME::BASELINK) | 
| Returns the current measure of the specified camera, the data is synchronized.  More... | |
| FUSION_ERROR_CODE | enableBodyTracking (const BodyTrackingFusionParameters ¶ms=BodyTrackingFusionParameters()) | 
| Enables the body tracking fusion module.  More... | |
| FUSION_ERROR_CODE | retrieveBodies (sl::Bodies &objs, BodyTrackingFusionRuntimeParameters parameters=BodyTrackingFusionRuntimeParameters(), CameraIdentifier uuid=CameraIdentifier(), sl::FUSION_REFERENCE_FRAME reference_frame=sl::FUSION_REFERENCE_FRAME::BASELINK) | 
| Retrieves the body data, can be the fused data (default), or the raw data provided by a specific sender.  More... | |
| void | disableBodyTracking () | 
| Disable the body fusion tracking module.  More... | |
| FUSION_ERROR_CODE | enableObjectDetection (const ObjectDetectionFusionParameters ¶ms=ObjectDetectionFusionParameters()) | 
| Enables the object detection fusion module.  More... | |
| FUSION_ERROR_CODE | retrieveObjects (std::unordered_map< sl::String, sl::Objects > &objs, sl::FUSION_REFERENCE_FRAME reference_frame=sl::FUSION_REFERENCE_FRAME::BASELINK) | 
| Retrieves all the fused objects data.  More... | |
| FUSION_ERROR_CODE | retrieveObjects (sl::Objects &objs, const sl::String &fused_od_group_name, sl::FUSION_REFERENCE_FRAME reference_frame=sl::FUSION_REFERENCE_FRAME::BASELINK) | 
| Retrieves the fused objects of a given fused OD group.  More... | |
| FUSION_ERROR_CODE | retrieveObjects (std::unordered_map< unsigned int, sl::Objects > &objs, const CameraIdentifier &uuid) | 
| Retrieves all the raw objects data provided by a specific sender.  More... | |
| FUSION_ERROR_CODE | retrieveObjects (sl::Objects &objs, const CameraIdentifier &uuid, const unsigned int instance_id) | 
| Retrieves the raw objects data provided by a specific sender and a specific instance id.  More... | |
| void | disableObjectDetection () | 
| Disable the object detection fusion module.  More... | |
| FUSION_ERROR_CODE | enablePositionalTracking (PositionalTrackingFusionParameters parameters=PositionalTrackingFusionParameters()) | 
| Enables positional tracking fusion module.  More... | |
| POSITIONAL_TRACKING_STATE | getPosition (Pose &camera_pose, sl::REFERENCE_FRAME reference_frame=REFERENCE_FRAME::WORLD, CameraIdentifier uuid=CameraIdentifier(), POSITION_TYPE position_type=POSITION_TYPE::FUSION) | 
| Get the Fused Position referenced to the first camera subscribed. If uuidis specified then project position on the referenced camera.  More... | |
| FusedPositionalTrackingStatus | getFusedPositionalTrackingStatus () | 
| Get the current status of fused position.  More... | |
| FUSION_ERROR_CODE | ingestGNSSData (sl::GNSSData gnss_data) | 
| Ingest GNSS data from an external sensor into the fusion module.  More... | |
| POSITIONAL_TRACKING_STATE | getCurrentGNSSData (sl::GNSSData &out) | 
| Returns the last synchronized gnss data.  More... | |
| GNSS_FUSION_STATUS | getGeoPose (sl::GeoPose &pose) | 
| Returns the current GeoPose.  More... | |
| GNSS_FUSION_STATUS | Geo2Camera (sl::LatLng &in, sl::Pose &out) | 
| Convert latitude / longitude into position in sl::Fusion coordinate system.  More... | |
| GNSS_FUSION_STATUS | Camera2Geo (sl::Pose const &in, sl::GeoPose &out) | 
| Convert a position in sl::Fusion coordinate system in global world coordinate.  More... | |
| FUSION_ERROR_CODE | ENU2Geo (const sl::ENU &in, sl::LatLng &out) const | 
| Convert a ENU position expressed inside the Fusion coordinate system to a global world coordinate.  More... | |
| FUSION_ERROR_CODE | Geo2ENU (const sl::LatLng &in, sl::ENU &out) const | 
| Convert a global world coordinate to a ENU position expressed inside the Fusion coordinate system.  More... | |
| void | disablePositionalTracking () | 
| Disable the fusion positional tracking module.  More... | |
| sl::Timestamp | getCurrentTimeStamp () | 
| Return the current fusion timestamp, aligned with the synchronized GNSS and camera data.  More... | |
| GNSS_FUSION_STATUS | getCurrentGNSSCalibrationSTD (float &yaw_std, sl::float3 &position_std) | 
| Get the current calibration uncertainty obtained during calibration process.  More... | |
| sl::Transform | getGeoTrackingCalibration () | 
| Get the calibration found between VIO and GNSS.  More... | |
| FUSION_ERROR_CODE | enableSpatialMapping (SpatialMappingFusionParameters parameters=SpatialMappingFusionParameters()) | 
| Initializes and starts the spatial mapping processes.  More... | |
| void | requestSpatialMapAsync () | 
| Starts the spatial map generation process in a non blocking thread from the spatial mapping process.  More... | |
| FUSION_ERROR_CODE | getSpatialMapRequestStatusAsync () | 
| Returns the spatial map generation status. This status allows to know if the mesh can be retrieved by calling retrieveSpatialMapAsync.  More... | |
| FUSION_ERROR_CODE | retrieveSpatialMapAsync (Mesh &mesh) | 
| Retrieves the current generated spatial map only if SpatialMappingParameters::map_type was set as SPATIAL_MAP_TYPE::MESH.  More... | |
| FUSION_ERROR_CODE | retrieveSpatialMapAsync (FusedPointCloud &fpc) | 
| Retrieves the current generated spatial map only if SpatialMappingParameters::map_type was set as SPATIAL_MAP_TYPE::FUSED_POINT_CLOUD. After calling requestSpatialMapAsync , this function allows you to retrieve the generated fused point cloud.  More... | |
| void | disableSpatialMapping () | 
| Disables the spatial mapping process.  More... | |
Holds Fusion process data and functions.
| Fusion | ( | ) | 
Default constructor.
| ~Fusion | ( | ) | 
Default destructor.
| FUSION_ERROR_CODE init | ( | sl::InitFusionParameters | init_parameters = InitFusionParameters() | ) | 
Initialize the fusion module with the requested parameters.
| init_parameters | Initialization parameters. | 
| void close | ( | ) | 
Will deactivate all the fusion modules and free internal data.
| FUSION_ERROR_CODE subscribe | ( | const sl::FusionConfiguration & | fusion_config | ) | 
Set the specified camera as a data provider.
| fusion_config | The fusion configuration parameters. | 
| FUSION_ERROR_CODE subscribe | ( | CameraIdentifier | uuid, | 
| CommunicationParameters | param = CommunicationParameters(), | ||
| sl::Transform | pose = sl::Transform(), | ||
| bool | override_gravity = false | ||
| ) | 
Set the specified camera as a data provider.
| uuid | The requested camera identifier. | 
| param | The communication parameters to connect to the camera. | 
| pose | The World position of the camera, regarding the other camera of the setup. | 
| override_gravity | : Indicates the behavior of the fusion with respect to given calibration pose. If true : The calibration pose directly specifies the camera's absolute pose relative to a global reference frame. If false : The calibration pose (Pose_rel) is defined relative to the camera's IMU rotational pose. To determine the true absolute position, the Fusion process will compute Pose_abs = Pose_rel * Rot_IMU_camera. set to false by default | 
| FUSION_ERROR_CODE unsubscribe | ( | CameraIdentifier | uuid | ) | 
Remove the specified camera from data provider.
| uuid | The requested camera identifier.. | 
| FUSION_ERROR_CODE updatePose | ( | CameraIdentifier | uuid, | 
| sl::Transform | pose | ||
| ) | 
Updates the specified camera position inside fusion WORLD.
| uuid | The requested camera identifier. | 
| pose | The World position of the camera, regarding the other camera of the setup. | 
| FUSION_ERROR_CODE getPose | ( | CameraIdentifier | uuid, | 
| sl::Transform & | pose | ||
| ) | 
Get the specified camera position inside fusion WORLD.
| uuid | The requested camera identifier. | 
| pose | The World position of the camera, regarding the other camera of the setup. | 
| FUSION_ERROR_CODE getProcessMetrics | ( | FusionMetrics & | metrics | ) | 
| std::map<CameraIdentifier, SENDER_ERROR_CODE> getSenderState | ( | ) | 
Returns the state of each connected data senders.
| FUSION_ERROR_CODE process | ( | ) | 
| FUSION_ERROR_CODE retrieveImage | ( | sl::Mat & | mat, | 
| CameraIdentifier | uuid, | ||
| sl::Resolution | resolution = sl::Resolution(0, 0) | ||
| ) | 
Returns the current sl::VIEW::LEFT of the specified camera, the data is synchronized.
| mat | the CPU BGRA image of the requested camera. | 
| uuid | the requested camera identifier. | 
| resolution | the requested resolution of the output image, can be lower or equal (default) to the original image resolution. | 
| FUSION_ERROR_CODE retrieveMeasure | ( | sl::Mat & | mat, | 
| CameraIdentifier | uuid, | ||
| sl::MEASURE | measure = sl::MEASURE::DEPTH, | ||
| sl::Resolution | resolution = sl::Resolution(0, 0), | ||
| sl::FUSION_REFERENCE_FRAME | reference_frame = sl::FUSION_REFERENCE_FRAME::BASELINK | ||
| ) | 
Returns the current measure of the specified camera, the data is synchronized.
| mat | the CPU data of the requested camera. | 
| uuid | the requested camera identifier. | 
| measure | the requested measure type, by default DEPTH (F32_C1) | 
| resolution | the requested resolution of the output image, can be lower or equal (default) to the original image resolution. | 
| reference_frame | the requested reference frame, by default BASELINK. it is only available for fused point clouds | 
| FUSION_ERROR_CODE enableBodyTracking | ( | const BodyTrackingFusionParameters & | params = BodyTrackingFusionParameters() | ) | 
Enables the body tracking fusion module.
| params | Structure containing all specific parameters for body tracking fusion. For more information, see the BodyTrackingFusionParameters documentation. | 
| FUSION_ERROR_CODE retrieveBodies | ( | sl::Bodies & | objs, | 
| BodyTrackingFusionRuntimeParameters | parameters = BodyTrackingFusionRuntimeParameters(), | ||
| CameraIdentifier | uuid = CameraIdentifier(), | ||
| sl::FUSION_REFERENCE_FRAME | reference_frame = sl::FUSION_REFERENCE_FRAME::BASELINK | ||
| ) | 
Retrieves the body data, can be the fused data (default), or the raw data provided by a specific sender.
| objs | The fused bodies will be saved into this objects. | 
| parameters | Body detection runtime settings, can be changed at each detection. | 
| uuid | If set to a sender serial number (different from 0), this will retrieve the raw data provided by this sender. | 
| reference_frame | The reference frame in which the objects will be expressed. Default: FUSION_REFERENCE_FRAME::BASELINK. | 
| void disableBodyTracking | ( | ) | 
Disable the body fusion tracking module.
| FUSION_ERROR_CODE enableObjectDetection | ( | const ObjectDetectionFusionParameters & | params = ObjectDetectionFusionParameters() | ) | 
Enables the object detection fusion module.
| params | Structure containing all specific parameters for object detection fusion. For more information, see the ObjectDetectionFusionParameters documentation. | 
| FUSION_ERROR_CODE retrieveObjects | ( | std::unordered_map< sl::String, sl::Objects > & | objs, | 
| sl::FUSION_REFERENCE_FRAME | reference_frame = sl::FUSION_REFERENCE_FRAME::BASELINK | ||
| ) | 
Retrieves all the fused objects data.
| objs | The fused objects will be saved into this objects. | 
| reference_frame | The reference frame in which the objects will be expressed. Default: FUSION_REFERENCE_FRAME::BASELINK. | 
| FUSION_ERROR_CODE retrieveObjects | ( | sl::Objects & | objs, | 
| const sl::String & | fused_od_group_name, | ||
| sl::FUSION_REFERENCE_FRAME | reference_frame = sl::FUSION_REFERENCE_FRAME::BASELINK | ||
| ) | 
Retrieves the fused objects of a given fused OD group.
| objs | The fused objects will be saved into this objects. | 
| fused_od_group_name | The name of the fused objects group to retrieve. | 
| reference_frame | The reference frame in which the objects will be expressed. Default: FUSION_REFERENCE_FRAME::BASELINK. | 
| FUSION_ERROR_CODE retrieveObjects | ( | std::unordered_map< unsigned int, sl::Objects > & | objs, | 
| const CameraIdentifier & | uuid | ||
| ) | 
Retrieves all the raw objects data provided by a specific sender.
| objs | The fused objects will be saved into this objects. | 
| uuid | Retrieve the raw data provided by this sender. | 
| FUSION_ERROR_CODE retrieveObjects | ( | sl::Objects & | objs, | 
| const CameraIdentifier & | uuid, | ||
| const unsigned int | instance_id | ||
| ) | 
Retrieves the raw objects data provided by a specific sender and a specific instance id.
| objs | The fused objects will be saved into this objects. | 
| uuid | Retrieve the raw data provided by this sender. | 
| instance_id | Retrieve the objects inferred by the model with this ID only. | 
| void disableObjectDetection | ( | ) | 
Disable the object detection fusion module.
| FUSION_ERROR_CODE enablePositionalTracking | ( | PositionalTrackingFusionParameters | parameters = PositionalTrackingFusionParameters() | ) | 
Enables positional tracking fusion module.
| parameters | A structure containing all the PositionalTrackingFusionParameters that define positional tracking fusion module. | 
| POSITIONAL_TRACKING_STATE getPosition | ( | Pose & | camera_pose, | 
| sl::REFERENCE_FRAME | reference_frame = REFERENCE_FRAME::WORLD, | ||
| CameraIdentifier | uuid = CameraIdentifier(), | ||
| POSITION_TYPE | position_type = POSITION_TYPE::FUSION | ||
| ) | 
Get the Fused Position referenced to the first camera subscribed. If uuid is specified then project position on the referenced camera. 
| camera_pose | Will contain the fused position referenced by default in world (world is given by the calibration of the cameras system). | 
| reference_frame | Defines the reference from which you want the pose to be expressed. Default : REFERENCE_FRAME::WORLD. | 
| uuid | If set to a sender serial number (different from 0), this will retrieve position projected on the requested camera if position_typeis equal to POSITION_TYPE::FUSION or raw sender position ifposition_typeis equal to POSITION_TYPE::RAW. | 
| position_type | Select if the position should the fused position re-projected in the camera with uuid or if the position should be the raw position (without fusion) of camera with uui. | 
| FusedPositionalTrackingStatus getFusedPositionalTrackingStatus | ( | ) | 
Get the current status of fused position.
| FUSION_ERROR_CODE ingestGNSSData | ( | sl::GNSSData | gnss_data | ) | 
Ingest GNSS data from an external sensor into the fusion module.
| gnss_data | The current GNSS data to combine with the current positional tracking data. | 
| POSITIONAL_TRACKING_STATE getCurrentGNSSData | ( | sl::GNSSData & | out | ) | 
Returns the last synchronized gnss data.
| out | Last synchronized gnss data. | 
| GNSS_FUSION_STATUS getGeoPose | ( | sl::GeoPose & | pose | ) | 
| GNSS_FUSION_STATUS Geo2Camera | ( | sl::LatLng & | in, | 
| sl::Pose & | out | ||
| ) | 
Convert latitude / longitude into position in sl::Fusion coordinate system.
| in | The latitude / longitude to be converted in sl::Fusion coordinate system. | 
| out | Converted position in sl::Fusion coordinate system. | 
| GNSS_FUSION_STATUS Camera2Geo | ( | sl::Pose const & | in, | 
| sl::GeoPose & | out | ||
| ) | 
Convert a position in sl::Fusion coordinate system in global world coordinate.
| in | Position to convert in global world coordinate. | 
| out | Converted position in global world coordinate. | 
| FUSION_ERROR_CODE ENU2Geo | ( | const sl::ENU & | in, | 
| sl::LatLng & | out | ||
| ) | const | 
| FUSION_ERROR_CODE Geo2ENU | ( | const sl::LatLng & | in, | 
| sl::ENU & | out | ||
| ) | const | 
| void disablePositionalTracking | ( | ) | 
Disable the fusion positional tracking module.
| sl::Timestamp getCurrentTimeStamp | ( | ) | 
Return the current fusion timestamp, aligned with the synchronized GNSS and camera data.
| GNSS_FUSION_STATUS getCurrentGNSSCalibrationSTD | ( | float & | yaw_std, | 
| sl::float3 & | position_std | ||
| ) | 
Get the current calibration uncertainty obtained during calibration process.
| yaw_std | Output yaw uncertainty in radian. | 
| position_std | Output position uncertainty in meter. | 
| sl::Transform getGeoTrackingCalibration | ( | ) | 
Get the calibration found between VIO and GNSS.
| FUSION_ERROR_CODE enableSpatialMapping | ( | SpatialMappingFusionParameters | parameters = SpatialMappingFusionParameters() | ) | 
Initializes and starts the spatial mapping processes.
The spatial mapping will create a geometric representation of the scene based on both tracking data and 3D point clouds. 
 The resulting output can be a Mesh or a FusedPointCloud. It can be be obtained by calling retrieveSpatialMapAsync(). Note that retrieveSpatialMapAsync() should be called after requestSpatialMapAsync().
| parameters | The structure containing all the specific parameters for the spatial mapping. Default: a balanced parameter preset between geometric fidelity and output file size. For more information, see the SpatialMappingParameters documentation. | 
| void requestSpatialMapAsync | ( | ) | 
Starts the spatial map generation process in a non blocking thread from the spatial mapping process.
The spatial map generation can take a long time depending on the mapping resolution and covered area. This function will trigger the generation of a mesh without blocking the program. You can get info about the current generation using getSpatialMapRequestStatusAsync(), and retrieve the mesh using retrieveSpatialMapAsync.
| FUSION_ERROR_CODE getSpatialMapRequestStatusAsync | ( | ) | 
Returns the spatial map generation status. This status allows to know if the mesh can be retrieved by calling retrieveSpatialMapAsync.
 See requestSpatialMapAsync() for an example. 
| FUSION_ERROR_CODE retrieveSpatialMapAsync | ( | Mesh & | mesh | ) | 
Retrieves the current generated spatial map only if SpatialMappingParameters::map_type was set as SPATIAL_MAP_TYPE::MESH.
After calling requestSpatialMapAsync , this function allows you to retrieve the generated mesh.
| mesh | : The mesh to be filled with the generated spatial map. | 
| FUSION_ERROR_CODE retrieveSpatialMapAsync | ( | FusedPointCloud & | fpc | ) | 
Retrieves the current generated spatial map only if SpatialMappingParameters::map_type was set as SPATIAL_MAP_TYPE::FUSED_POINT_CLOUD. After calling requestSpatialMapAsync , this function allows you to retrieve the generated fused point cloud.
| fpc | : The fused point cloud to be filled with the generated spatial map. | 
 See requestSpatialMapAsync() for an example. 
| void disableSpatialMapping | ( | ) | 
Disables the spatial mapping process.
The spatial mapping is immediately stopped. 
 If the mapping has been enabled, this function will automatically be called by close().