Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(detected_object_validation): add 3d pointcloud based validator #5327

Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,5 @@
min_points_and_distance_ratio:
#UNKNOWN, CAR, TRUCK, BUS, TRAILER, MOTORBIKE, BICYCLE, PEDESTRIAN
[800.0, 800.0, 800.0, 800.0, 800.0, 800.0, 800.0, 800.0]

using_2d_validator: false
Original file line number Diff line number Diff line change
Expand Up @@ -71,11 +71,18 @@
void addNeighborPointcloud(const pcl::PointCloud<pcl::PointXY>::Ptr & input)
{
pcl::PointCloud<pcl::PointXYZ>::Ptr input_xyz = toXYZ(input);
for (const auto & point : *input_xyz) {
neighbor_pointcloud_->push_back(point);
}
addNeighborPointcloud(input_xyz);
}

void addNeighborPointcloud(const pcl::PointCloud<pcl::PointXYZ>::Ptr & input)

Check warning on line 77 in perception/detected_object_validation/include/obstacle_pointcloud_based_validator/debugger.hpp

View check run for this annotation

Codecov / codecov/patch

perception/detected_object_validation/include/obstacle_pointcloud_based_validator/debugger.hpp#L77

Added line #L77 was not covered by tests
{
if (!input->empty()) {
neighbor_pointcloud_->reserve(neighbor_pointcloud_->size() + input->size());
for (const auto & point : *input) {

Check warning on line 81 in perception/detected_object_validation/include/obstacle_pointcloud_based_validator/debugger.hpp

View check run for this annotation

Codecov / codecov/patch

perception/detected_object_validation/include/obstacle_pointcloud_based_validator/debugger.hpp#L79-L81

Added lines #L79 - L81 were not covered by tests
neighbor_pointcloud_->push_back(point);
}
}
}

Check warning on line 85 in perception/detected_object_validation/include/obstacle_pointcloud_based_validator/debugger.hpp

View check run for this annotation

Codecov / codecov/patch

perception/detected_object_validation/include/obstacle_pointcloud_based_validator/debugger.hpp#L85

Added line #L85 was not covered by tests
void addPointcloudWithinPolygon(const pcl::PointCloud<pcl::PointXYZ>::Ptr & input)
{
// pcl::PointCloud<pcl::PointXYZ>::Ptr input_xyz = toXYZ(input);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,13 @@
#include <message_filters/subscriber.h>
#include <message_filters/sync_policies/approximate_time.h>
#include <message_filters/synchronizer.h>
#include <pcl/filters/crop_hull.h>
#include <pcl/kdtree/kdtree_flann.h>
#include <pcl/point_cloud.h>
#include <pcl/point_types.h>
#include <pcl/search/kdtree.h>
#include <pcl/search/pcl_search.h>
#include <pcl_conversions/pcl_conversions.h>
#include <tf2_ros/buffer.h>
#include <tf2_ros/transform_listener.h>

Expand All @@ -35,12 +40,88 @@
#include <vector>
namespace obstacle_pointcloud_based_validator
{

struct PointsNumThresholdParam
{
std::vector<int64_t> min_points_num;
std::vector<int64_t> max_points_num;
std::vector<double> min_points_and_distance_ratio;
};

class Validator
{
private:
PointsNumThresholdParam points_num_threshold_param_;

protected:
pcl::PointCloud<pcl::PointXYZ>::Ptr cropped_pointcloud_;

public:
explicit Validator(PointsNumThresholdParam & points_num_threshold_param);
inline pcl::PointCloud<pcl::PointXYZ>::Ptr getDebugPointCloudWithinObject()
{
return cropped_pointcloud_;
}

virtual bool setKdtreeInputCloud(
const sensor_msgs::msg::PointCloud2::ConstSharedPtr & input_pointcloud) = 0;
virtual bool validate_object(
const autoware_auto_perception_msgs::msg::DetectedObject & transformed_object) = 0;
virtual std::optional<float> getMaxRadius(
const autoware_auto_perception_msgs::msg::DetectedObject & object) = 0;
size_t getThresholdPointCloud(const autoware_auto_perception_msgs::msg::DetectedObject & object);
virtual pcl::PointCloud<pcl::PointXYZ>::Ptr getDebugNeighborPointCloud() = 0;
};

class Validator2D : public Validator
{
private:
pcl::PointCloud<pcl::PointXY>::Ptr obstacle_pointcloud_;
pcl::PointCloud<pcl::PointXY>::Ptr neighbor_pointcloud_;
pcl::search::Search<pcl::PointXY>::Ptr kdtree_;

public:
explicit Validator2D(PointsNumThresholdParam & points_num_threshold_param);

pcl::PointCloud<pcl::PointXYZ>::Ptr convertToXYZ(
const pcl::PointCloud<pcl::PointXY>::Ptr & pointcloud_xy);
inline pcl::PointCloud<pcl::PointXYZ>::Ptr getDebugNeighborPointCloud()

Check warning on line 88 in perception/detected_object_validation/include/obstacle_pointcloud_based_validator/obstacle_pointcloud_based_validator.hpp

View check run for this annotation

Codecov / codecov/patch

perception/detected_object_validation/include/obstacle_pointcloud_based_validator/obstacle_pointcloud_based_validator.hpp#L88

Added line #L88 was not covered by tests
{
return convertToXYZ(neighbor_pointcloud_);

Check warning on line 90 in perception/detected_object_validation/include/obstacle_pointcloud_based_validator/obstacle_pointcloud_based_validator.hpp

View check run for this annotation

Codecov / codecov/patch

perception/detected_object_validation/include/obstacle_pointcloud_based_validator/obstacle_pointcloud_based_validator.hpp#L90

Added line #L90 was not covered by tests
}

bool setKdtreeInputCloud(const sensor_msgs::msg::PointCloud2::ConstSharedPtr & input_cloud);
bool validate_object(
const autoware_auto_perception_msgs::msg::DetectedObject & transformed_object);
std::optional<float> getMaxRadius(
const autoware_auto_perception_msgs::msg::DetectedObject & object);
std::optional<size_t> getPointCloudWithinObject(
const autoware_auto_perception_msgs::msg::DetectedObject & object,
const pcl::PointCloud<pcl::PointXY>::Ptr neighbor_pointcloud);
};
class Validator3D : public Validator
{
private:
pcl::PointCloud<pcl::PointXYZ>::Ptr obstacle_pointcloud_;
pcl::PointCloud<pcl::PointXYZ>::Ptr neighbor_pointcloud_;
pcl::search::Search<pcl::PointXYZ>::Ptr kdtree_;

public:
explicit Validator3D(PointsNumThresholdParam & points_num_threshold_param);
inline pcl::PointCloud<pcl::PointXYZ>::Ptr getDebugNeighborPointCloud()

Check warning on line 111 in perception/detected_object_validation/include/obstacle_pointcloud_based_validator/obstacle_pointcloud_based_validator.hpp

View check run for this annotation

Codecov / codecov/patch

perception/detected_object_validation/include/obstacle_pointcloud_based_validator/obstacle_pointcloud_based_validator.hpp#L111

Added line #L111 was not covered by tests
{
return neighbor_pointcloud_;

Check warning on line 113 in perception/detected_object_validation/include/obstacle_pointcloud_based_validator/obstacle_pointcloud_based_validator.hpp

View check run for this annotation

Codecov / codecov/patch

perception/detected_object_validation/include/obstacle_pointcloud_based_validator/obstacle_pointcloud_based_validator.hpp#L113

Added line #L113 was not covered by tests
}
bool setKdtreeInputCloud(const sensor_msgs::msg::PointCloud2::ConstSharedPtr & input_cloud);
bool validate_object(
const autoware_auto_perception_msgs::msg::DetectedObject & transformed_object);
std::optional<float> getMaxRadius(
const autoware_auto_perception_msgs::msg::DetectedObject & object);
std::optional<size_t> getPointCloudWithinObject(
const autoware_auto_perception_msgs::msg::DetectedObject & object,
const pcl::PointCloud<pcl::PointXYZ>::Ptr neighbor_pointcloud);
};

class ObstaclePointCloudBasedValidator : public rclcpp::Node
{
public:
Expand All @@ -61,16 +142,13 @@
PointsNumThresholdParam points_num_threshold_param_;

std::shared_ptr<Debugger> debugger_;
bool using_2d_validator_;
std::unique_ptr<Validator> validator_;

private:
void onObjectsAndObstaclePointCloud(
const autoware_auto_perception_msgs::msg::DetectedObjects::ConstSharedPtr & input_objects,
const sensor_msgs::msg::PointCloud2::ConstSharedPtr & input_obstacle_pointcloud);
std::optional<size_t> getPointCloudNumWithinPolygon(
const autoware_auto_perception_msgs::msg::DetectedObject & object,
const pcl::PointCloud<pcl::PointXY>::Ptr pointcloud);
std::optional<float> getMaxRadius(
const autoware_auto_perception_msgs::msg::DetectedObject & object);
};
} // namespace obstacle_pointcloud_based_validator

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ In the debug image above, the red DetectedObject is the validated object. The bl

| Name | Type | Description |
| ------------------------------- | ----- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `using_2d_validator` | bool | The xy-plane projected (2D) obstacle point clouds will be used for validation |
| `min_points_num` | int | The minimum number of obstacle point clouds in DetectedObjects |
| `max_points_num` | int | The max number of obstacle point clouds in DetectedObjects |
| `min_points_and_distance_ratio` | float | Threshold value of the number of point clouds per object when the distance from baselink is 1m, because the number of point clouds varies with the distance from baselink. |
Expand Down
Loading
Loading