Evaluate point cloud generation#
Evaluate if the Autoware point cloud generation process (if there is a connection between sensing and perception nodes) runs, and if data is being published to the /perception/obstacle_segmentation/pointcloud
topic as intended.
The following evaluations are performed simultaneously to check if point cloud published by perception nodes is valid.
- Check whether vehicles, pedestrians and other traffic participants, annotated in advance, are detected (detection step).
- Check whether extra point clouds appear in the overlapping area between the lane and the polygons around the vehicle defined in the scenario (non_detection step).
It is also possible not to evaluate if null is specified as the evaluation condition. In other words, evaluation can be performed in the following three modes.
- evaluate detection and non_detection at the same time
- evaluate only detection (NonDetection: null)
- Evaluate only non_detection (Detection: null)
The recommended annotation tool is Deepen, but any tool that supports conversion to t4_dataset
format can be used.
Multiple annotation tools can be used as long as a conversion tool can be created.
Evaluation method#
Launching the file executes the following steps:
- Execute launch of evaluation node (
obstacle_segmentation_evaluator_node
),logging_simulator.launch
file andros2 bag play
command - Autoware receives sensor data output from input rosbag and outputs
/perception/obstacle_segmentation/pointcloud
topic. - The evaluation node subscribes
/perception/obstacle_segmentation/pointcloud
topic and calculates the polygon of the non-detection area at the time specified in the header. - The evaluation node passes the point cloud and the polygon of the non-detected area to perception_eval for evaluation. The result is dumped into a file.
- When the playback of the rosbag is finished, Autoware's launch is automatically terminated, and the evaluation is completed.
How to calculate polygon for non-detectable area#
The non-detect area is calculated as the area where the polygon given in the scenario overlaps with the road_lanelet. It is calculated according to the following steps:
- get the transform of map_to_base_link at the time of the header.stamp in pointcloud, and transform the polygon to the map coordinate system.
- get the road_lanelet in the range of search_range (see the figure below) from the point where the vehicle is.
- take the intersection of the road_lanelet and polygon obtained in step 2.
- return the array of polygons obtained in step 3 to the base_link coordinate system (to match the coordinate system to filter the pointcloud).
In step 2, by narrowing down to the lanelets in the range where polygons can exist, the intersection process with lanelets that are obvious to return empty polygons in step 3 is omitted.
Evaluation Result#
The results are calculated for each subscription. The format and available states are described below.
Detection Normal#
If all of the following conditions are met, the evaluation is reported as normal:
- A bounding box with the UUID specified in the scenario must contain a point cloud (topic
/perception/obstacle_segmentation/pointcloud
) with at least a number of points equal to the specified number.- If multiple UUIDs are specified, the condition must be satisfied for all the specified bounding boxes.
- The output rate of the point cloud cannot be in error state (this data is provided by Autoware's diagnostic function). The default frequency value is 1.0Hz.
Detection Warning#
The state is achieved when the visibility of the bounding box with the UUID specified in the scenario is none (bounding box is occluded) and cannot be evaluated.
Detection Error#
The detection state is Error
when neither conditions for Normal
nor Warning
state cannot be met.
Non-Detection Normal#
The state is Normal
when no point is contained in the non-detection area, which is calculated by the node in step 3 of the evaluation method.
Non-Detection Error#
The state is Error
when any point was found in the non-detection area.
Topic name and data type used by evaluation node#
Subscribed topics:
Topic name | Data type |
---|---|
/perception/obstacle_segmentation/pointcloud | sensor_msgs/msg/PointCloud2 |
/diagnostics | diagnostic_msgs/msg/DiagnosticArray |
/tf | tf2_msgs/msg/TFMessage |
/planning/scenario_planning/status/stop_reasons | tier4_planning_msgs/msg/StopReasonArray |
/planning/scenario_planning/trajectory | autoware_planning_msgs/msg/Trajectory |
Published topics:
Topic name | Data type |
---|---|
/driving_log_replayer_v2/marker/detection | visualization_msgs/msg/MarkerArray |
/driving_log_replayer_v2/marker/non_detection | visualization_msgs/msg/MarkerArray |
/driving_log_replayer_v2/pcd/detection | sensor_msgs/msg/PointCloud2 |
/driving_log_replayer_v2/pcd/non_detection | sensor_msgs/msg/PointCloud2 |
/planning/mission_planning/goal | geometry_msgs/msg/PoseStamped |
Arguments passed to logging_simulator.launch#
- localization: false
- control: false
- scenario_simulation: true
About simulation#
State the information required to run the simulation.
Topic to be included in the input rosbag#
Must contain the required topics in t4_dataset
format.
The vehicle's ECU CAN and sensors data topics are required for the evaluation to be run correctly. The following example shows the topic list available in evaluation input rosbag when multiple LiDARs.
Topic name | Data type |
---|---|
/pacmod/from_can_bus | can_msgs/msg/Frame |
/localization/kinematic_state | Type: nav_msgs/msg/Odometry |
/sensing/gnss/ublox/fix_velocity | geometry_msgs/msg/TwistWithCovarianceStamped |
/sensing/gnss/ublox/nav_sat_fix | sensor_msgs/msg/NavSatFix |
/sensing/gnss/ublox/navpvt | ublox_msgs/msg/NavPVT |
/sensing/imu/tamagawa/imu_raw | sensor_msgs/msg/Imu |
/sensing/lidar/*/velodyne_packets | velodyne_msgs/VelodyneScan |
/tf | tf2_msgs/msg/TFMessage |
The vehicle topics can be included instead of CAN.
Topic name | Data type |
---|---|
/localization/kinematic_state | Type: nav_msgs/msg/Odometry |
/sensing/gnss/ublox/fix_velocity | geometry_msgs/msg/TwistWithCovarianceStamped |
/sensing/gnss/ublox/nav_sat_fix | sensor_msgs/msg/NavSatFix |
/sensing/gnss/ublox/navpvt | ublox_msgs/msg/NavPVT |
/sensing/imu/tamagawa/imu_raw | sensor_msgs/msg/Imu |
/sensing/lidar/*/velodyne_packets | velodyne_msgs/VelodyneScan |
/tf | tf2_msgs/msg/TFMessage |
/vehicle/status/control_mode | autoware_vehicle_msgs/msg/ControlModeReport |
/vehicle/status/gear_status | autoware_vehicle_msgs/msg/GearReport |
/vehicle/status/steering_status | autoware_vehicle_msgs/SteeringReport |
/vehicle/status/turn_indicators_status | autoware_vehicle_msgs/msg/TurnIndicatorsReport |
/vehicle/status/velocity_status | autoware_vehicle_msgs/msg/VelocityReport |
Topics that must not be included in the input rosbag#
Topic name | Data type |
---|---|
/clock | rosgraph_msgs/msg/Clock |
The clock is output by the --clock option of ros2 bag play, so if it is recorded in the bag itself, it is output twice, so it is not included in the bag.
About Evaluation#
State the information necessary for the evaluation.
Scenario Format#
See sample.
Evaluation Result Format#
See sample.
In obstacle_segmentation
evaluation scenario, two types of checks, detection (Detection) and non-detection (NonDetection), are evaluated.
Although they are evaluated simultaneously, in one callback function, they are counted separately.
The Result
is true
if both detection and non-detection evaluation steps have passed. Otherwise the Result
is false
.
An example of evaluation is described below. NOTE: common part of the result file format, which has already been explained, is omitted.
{
"Frame": {
"FrameName": "Frame number of t4_dataset used for evaluation",
"FrameSkip": "Number of times that an object was requested to be evaluated but the evaluation was skipped because there was no ground truth in the dataset within 75msec",
"StopReasons": "Reasons for stopping output by the Planning module. Reference value",
"TopicRate": "Result of diag indicating whether the output rate of the point cloud is normal or not.",
"Detection": {
"Result": { "Total": "Success or Fail", "Frame": "Success, Fail, Warn or Invalid" },
"Info": {
"DetectionSuccess or DetectionFail or DetectionWarn": {
"Annotation": {
"Scale": {
"x": "Length of bounding box in x-direction",
"y": "Length of bounding box in y-direction",
"z": "Length of bounding box in z-direction"
},
"Position": {
"position": {
"x": "Bounding box position x",
"y": "Bounding box position y",
"z": "Bounding box position z"
},
"orientation": {
"x": "Bounding box direction x",
"y": "Bounding box direction y",
"z": "Bounding box direction z",
"w": "Bounding box direction w"
}
},
"UUID": "UUID of the bounding box",
"StampFloat": "Bounding box unix_time[us] made into a float."
},
"PointCloud": {
"NumPoints": "Number of point clouds contained within the bounding box.",
"Nearest": "[x,y,z] coordinates of the closest point in the bounding box from the base_link",
"Stamp": {
"sec": "Sec of header.stamp of the point cloud",
"nanosec": "NanoSec of header.stamp of the point cloud"
}
}
}
}
},
"NonDetection": {
"Result": "Success, Fail, or Invalid",
"Info": {
"PointCloud": {
"NumPoints": "Number of point clouds out in non-detected areas.",
"Distance": {
"0-1": "Number of point clouds out in non-detected areas between 0-1 m from base_link",
"x-x+1": "Distribution of point clouds appearing in non-detected areas by distance",
"99-100": "Number of point clouds out in non-detected areas between 99-100 m from base_link"
}
}
}
}
}
}