Skip to content

Commit

Permalink
Merge branch 'main' into refactor/tensorrt-yolox/autoware-prefix
Browse files Browse the repository at this point in the history
  • Loading branch information
ktro2828 authored Jul 25, 2024
2 parents 0cceb2f + e46c927 commit 98679f8
Show file tree
Hide file tree
Showing 83 changed files with 321 additions and 2,799 deletions.
2 changes: 1 addition & 1 deletion .github/CODEOWNERS
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ perception/elevation_map_loader/** [email protected] shintaro.tomie@tier4
perception/autoware_euclidean_cluster/** [email protected] [email protected]
perception/autoware_ground_segmentation/** [email protected] [email protected] [email protected] [email protected] [email protected]
perception/autoware_image_projection_based_fusion/** [email protected] [email protected] [email protected] [email protected] [email protected] [email protected] [email protected]
perception/lidar_apollo_instance_segmentation/** [email protected] [email protected]
perception/autowar_lidar_apollo_instance_segmentation/** [email protected] [email protected]

Check warning on line 129 in .github/CODEOWNERS

View workflow job for this annotation

GitHub Actions / spell-check-differential

Unknown word (autowar)
perception/lidar_apollo_segmentation_tvm/** [email protected] [email protected]
perception/lidar_apollo_segmentation_tvm_nodes/** [email protected] [email protected]
perception/autoware_lidar_centerpoint/** [email protected] [email protected]
Expand Down
2 changes: 2 additions & 0 deletions .github/workflows/pr-agent.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -36,3 +36,5 @@ jobs:
config.max_model_tokens: 64000
pr_code_suggestions.max_context_tokens: 12000
pr_code_suggestions.commitable_code_suggestions: true
pr_reviewer.enable_review_labels_effort: false
pr_reviewer.enable_review_labels_security: false
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@
<group if="$(eval &quot;'$(var lidar_detection_model)'=='apollo'&quot;)">
<push-ros-namespace namespace="apollo"/>
<group>
<include file="$(find-pkg-share lidar_apollo_instance_segmentation)/launch/lidar_apollo_instance_segmentation.launch.xml">
<include file="$(find-pkg-share autoware_lidar_apollo_instance_segmentation)/launch/lidar_apollo_instance_segmentation.launch.xml">
<arg name="input/pointcloud" value="$(var input/pointcloud)"/>
<arg name="output/objects" value="labeled_clusters"/>
</include>
Expand Down
2 changes: 1 addition & 1 deletion launch/tier4_perception_launch/package.xml
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
<exec_depend>autoware_euclidean_cluster</exec_depend>
<exec_depend>autoware_ground_segmentation</exec_depend>
<exec_depend>autoware_image_projection_based_fusion</exec_depend>
<exec_depend>autoware_lidar_apollo_instance_segmentation</exec_depend>
<exec_depend>autoware_map_based_prediction</exec_depend>
<exec_depend>autoware_multi_object_tracker</exec_depend>
<exec_depend>autoware_object_merger</exec_depend>
Expand All @@ -37,7 +38,6 @@
<exec_depend>autoware_tracking_object_merger</exec_depend>
<exec_depend>elevation_map_loader</exec_depend>
<exec_depend>image_transport_decompressor</exec_depend>
<exec_depend>lidar_apollo_instance_segmentation</exec_depend>
<exec_depend>occupancy_grid_map_outlier_filter</exec_depend>
<exec_depend>pointcloud_to_laserscan</exec_depend>
<exec_depend>probabilistic_occupancy_grid_map</exec_depend>
Expand Down
4 changes: 2 additions & 2 deletions localization/ndt_scan_matcher/src/map_update_module.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -265,7 +265,7 @@ bool MapUpdateModule::update_ndt(
}
diagnostics_ptr->add_key_value("is_succeed_call_pcd_loader", true);

auto & maps_to_add = result.get()->new_pointcloud_with_ids;
auto & maps_to_add = result.get()->new_pointcloud_cells;
auto & map_ids_to_remove = result.get()->ids_to_remove;

diagnostics_ptr->add_key_value("maps_to_add_size", maps_to_add.size());
Expand All @@ -283,7 +283,7 @@ bool MapUpdateModule::update_ndt(
auto cloud = pcl::make_shared<pcl::PointCloud<PointTarget>>();

pcl::fromROSMsg(map.pointcloud, *cloud);
ndt.addTarget(cloud, map.cell_id);
ndt.addTarget(cloud, map.metadata.cell_id);
}

// Remove pcd
Expand Down
24 changes: 12 additions & 12 deletions localization/ndt_scan_matcher/test/stub_pcd_loader.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -60,26 +60,26 @@ class StubPcdLoader : public rclcpp::Node
return true;
}

autoware_map_msgs::msg::PointCloudMapCellWithID pcd_map_cell_with_id;
pcd_map_cell_with_id.cell_id = "0";
autoware_map_msgs::msg::PointCloudMapCellWithMetaData pcd_map_cell;
pcd_map_cell.metadata.cell_id = "0";
pcl::PointCloud<pcl::PointXYZ> cloud = make_sample_half_cubic_pcd();
for (auto & point : cloud.points) {
point.x += offset_x;
point.y += offset_y;
}
pcd_map_cell_with_id.metadata.min_x = std::numeric_limits<float>::max();
pcd_map_cell_with_id.metadata.min_y = std::numeric_limits<float>::max();
pcd_map_cell_with_id.metadata.max_x = std::numeric_limits<float>::lowest();
pcd_map_cell_with_id.metadata.max_y = std::numeric_limits<float>::lowest();
pcd_map_cell.metadata.min_x = std::numeric_limits<float>::max();
pcd_map_cell.metadata.min_y = std::numeric_limits<float>::max();
pcd_map_cell.metadata.max_x = std::numeric_limits<float>::lowest();
pcd_map_cell.metadata.max_y = std::numeric_limits<float>::lowest();
for (const auto & point : cloud.points) {
pcd_map_cell_with_id.metadata.min_x = std::min(pcd_map_cell_with_id.metadata.min_x, point.x);
pcd_map_cell_with_id.metadata.min_y = std::min(pcd_map_cell_with_id.metadata.min_y, point.y);
pcd_map_cell_with_id.metadata.max_x = std::max(pcd_map_cell_with_id.metadata.max_x, point.x);
pcd_map_cell_with_id.metadata.max_y = std::max(pcd_map_cell_with_id.metadata.max_y, point.y);
pcd_map_cell.metadata.min_x = std::min(pcd_map_cell.metadata.min_x, point.x);
pcd_map_cell.metadata.min_y = std::min(pcd_map_cell.metadata.min_y, point.y);
pcd_map_cell.metadata.max_x = std::max(pcd_map_cell.metadata.max_x, point.x);
pcd_map_cell.metadata.max_y = std::max(pcd_map_cell.metadata.max_y, point.y);
}
RCLCPP_INFO_STREAM(get_logger(), "cloud size: " << cloud.size());
pcl::toROSMsg(cloud, pcd_map_cell_with_id.pointcloud);
res->new_pointcloud_with_ids.push_back(pcd_map_cell_with_id);
pcl::toROSMsg(cloud, pcd_map_cell.pointcloud);
res->new_pointcloud_cells.push_back(pcd_map_cell);
res->header.frame_id = "map";
return true;
}
Expand Down
12 changes: 6 additions & 6 deletions map/map_height_fitter/src/map_height_fitter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -145,17 +145,17 @@ bool MapHeightFitter::Impl::get_partial_point_cloud_map(const Point & point)
const auto res = future.get();
RCLCPP_DEBUG(
logger, "Loaded partial pcd map from map_loader (grid size: %lu)",
res->new_pointcloud_with_ids.size());
res->new_pointcloud_cells.size());

sensor_msgs::msg::PointCloud2 pcd_msg;
for (const auto & pcd_with_id : res->new_pointcloud_with_ids) {
for (const auto & pcd_cell : res->new_pointcloud_cells) {
if (pcd_msg.width == 0) {
pcd_msg = pcd_with_id.pointcloud;
pcd_msg = pcd_cell.pointcloud;
} else {
pcd_msg.width += pcd_with_id.pointcloud.width;
pcd_msg.row_step += pcd_with_id.pointcloud.row_step;
pcd_msg.width += pcd_cell.pointcloud.width;
pcd_msg.row_step += pcd_cell.pointcloud.row_step;
pcd_msg.data.insert(
pcd_msg.data.end(), pcd_with_id.pointcloud.data.begin(), pcd_with_id.pointcloud.data.end());
pcd_msg.data.end(), pcd_cell.pointcloud.data.begin(), pcd_cell.pointcloud.data.end());
}
}
map_frame_ = res->header.frame_id;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,13 +48,13 @@ void DifferentialMapLoaderModule::differential_area_load(
int index = static_cast<int>(id_in_cached_list - cached_ids.begin());
should_remove[index] = false;
} else {
autoware_map_msgs::msg::PointCloudMapCellWithID pointcloud_map_cell_with_id =
load_point_cloud_map_cell_with_id(path, map_id);
pointcloud_map_cell_with_id.metadata.min_x = metadata.min.x;
pointcloud_map_cell_with_id.metadata.min_y = metadata.min.y;
pointcloud_map_cell_with_id.metadata.max_x = metadata.max.x;
pointcloud_map_cell_with_id.metadata.max_y = metadata.max.y;
response->new_pointcloud_with_ids.push_back(pointcloud_map_cell_with_id);
autoware_map_msgs::msg::PointCloudMapCellWithMetaData pointcloud_map_cell =
load_point_cloud_map_cell_with_metadata(path, map_id);
pointcloud_map_cell.metadata.min_x = metadata.min.x;
pointcloud_map_cell.metadata.min_y = metadata.min.y;
pointcloud_map_cell.metadata.max_x = metadata.max.x;
pointcloud_map_cell.metadata.max_y = metadata.max.y;
response->new_pointcloud_cells.push_back(pointcloud_map_cell);
}
}

Expand All @@ -76,16 +76,16 @@ bool DifferentialMapLoaderModule::on_service_get_differential_point_cloud_map(
return true;
}

autoware_map_msgs::msg::PointCloudMapCellWithID
DifferentialMapLoaderModule::load_point_cloud_map_cell_with_id(
autoware_map_msgs::msg::PointCloudMapCellWithMetaData
DifferentialMapLoaderModule::load_point_cloud_map_cell_with_metadata(
const std::string & path, const std::string & map_id) const
{
sensor_msgs::msg::PointCloud2 pcd;
if (pcl::io::loadPCDFile(path, pcd) == -1) {
RCLCPP_ERROR_STREAM(logger_, "PCD load failed: " << path);
}
autoware_map_msgs::msg::PointCloudMapCellWithID pointcloud_map_cell_with_id;
pointcloud_map_cell_with_id.pointcloud = pcd;
pointcloud_map_cell_with_id.cell_id = map_id;
return pointcloud_map_cell_with_id;
autoware_map_msgs::msg::PointCloudMapCellWithMetaData pointcloud_map_cell;
pointcloud_map_cell.pointcloud = pcd;
pointcloud_map_cell.metadata.cell_id = map_id;
return pointcloud_map_cell;
}
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,8 @@ class DifferentialMapLoaderModule
void differential_area_load(
const autoware_map_msgs::msg::AreaInfo & area_info, const std::vector<std::string> & cached_ids,
const GetDifferentialPointCloudMap::Response::SharedPtr & response) const;
[[nodiscard]] autoware_map_msgs::msg::PointCloudMapCellWithID load_point_cloud_map_cell_with_id(
[[nodiscard]] autoware_map_msgs::msg::PointCloudMapCellWithMetaData
load_point_cloud_map_cell_with_metadata(
const std::string & path, const std::string & map_id) const;
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,14 +42,14 @@ void PartialMapLoaderModule::partial_area_load(
// skip if the pcd file is not within the queried area
if (!is_grid_within_queried_area(area, metadata)) continue;

autoware_map_msgs::msg::PointCloudMapCellWithID pointcloud_map_cell_with_id =
load_point_cloud_map_cell_with_id(path, map_id);
pointcloud_map_cell_with_id.metadata.min_x = metadata.min.x;
pointcloud_map_cell_with_id.metadata.min_y = metadata.min.y;
pointcloud_map_cell_with_id.metadata.max_x = metadata.max.x;
pointcloud_map_cell_with_id.metadata.max_y = metadata.max.y;
autoware_map_msgs::msg::PointCloudMapCellWithMetaData pointcloud_map_cell =
load_point_cloud_map_cell_with_metadata(path, map_id);
pointcloud_map_cell.metadata.min_x = metadata.min.x;
pointcloud_map_cell.metadata.min_y = metadata.min.y;
pointcloud_map_cell.metadata.max_x = metadata.max.x;
pointcloud_map_cell.metadata.max_y = metadata.max.y;

response->new_pointcloud_with_ids.push_back(pointcloud_map_cell_with_id);
response->new_pointcloud_cells.push_back(pointcloud_map_cell);
}
}

Expand All @@ -63,16 +63,16 @@ bool PartialMapLoaderModule::on_service_get_partial_point_cloud_map(
return true;
}

autoware_map_msgs::msg::PointCloudMapCellWithID
PartialMapLoaderModule::load_point_cloud_map_cell_with_id(
autoware_map_msgs::msg::PointCloudMapCellWithMetaData
PartialMapLoaderModule::load_point_cloud_map_cell_with_metadata(
const std::string & path, const std::string & map_id) const
{
sensor_msgs::msg::PointCloud2 pcd;
if (pcl::io::loadPCDFile(path, pcd) == -1) {
RCLCPP_ERROR_STREAM(logger_, "PCD load failed: " << path);
}
autoware_map_msgs::msg::PointCloudMapCellWithID pointcloud_map_cell_with_id;
pointcloud_map_cell_with_id.pointcloud = pcd;
pointcloud_map_cell_with_id.cell_id = map_id;
return pointcloud_map_cell_with_id;
autoware_map_msgs::msg::PointCloudMapCellWithMetaData pointcloud_map_cell;
pointcloud_map_cell.pointcloud = pcd;
pointcloud_map_cell.metadata.cell_id = map_id;
return pointcloud_map_cell;
}
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,8 @@ class PartialMapLoaderModule
void partial_area_load(
const autoware_map_msgs::msg::AreaInfo & area,
const GetPartialPointCloudMap::Response::SharedPtr & response) const;
[[nodiscard]] autoware_map_msgs::msg::PointCloudMapCellWithID load_point_cloud_map_cell_with_id(
[[nodiscard]] autoware_map_msgs::msg::PointCloudMapCellWithMetaData
load_point_cloud_map_cell_with_metadata(
const std::string & path, const std::string & map_id) const;
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,14 +30,14 @@ autoware_map_msgs::msg::PointCloudMapMetaData create_metadata(
// assume that the map ID = map path (for now)
const std::string & map_id = ele.first;

autoware_map_msgs::msg::PointCloudMapCellMetaDataWithID cell_metadata_with_id;
cell_metadata_with_id.cell_id = map_id;
cell_metadata_with_id.metadata.min_x = metadata.min.x;
cell_metadata_with_id.metadata.min_y = metadata.min.y;
cell_metadata_with_id.metadata.max_x = metadata.max.x;
cell_metadata_with_id.metadata.max_y = metadata.max.y;
autoware_map_msgs::msg::PointCloudMapCellMetaData cell_metadata;
cell_metadata.cell_id = map_id;
cell_metadata.min_x = metadata.min.x;
cell_metadata.min_y = metadata.min.y;
cell_metadata.max_x = metadata.max.x;
cell_metadata.max_y = metadata.max.y;

metadata_msg.metadata_list.push_back(cell_metadata_with_id);
metadata_msg.metadata_list.push_back(cell_metadata);
}

return metadata_msg;
Expand Down Expand Up @@ -81,29 +81,29 @@ bool SelectedMapLoaderModule::on_service_get_selected_point_cloud_map(
const std::string & map_id = path;
PCDFileMetadata metadata = requested_selected_map_iterator->second;

autoware_map_msgs::msg::PointCloudMapCellWithID pointcloud_map_cell_with_id =
load_point_cloud_map_cell_with_id(path, map_id);
pointcloud_map_cell_with_id.metadata.min_x = metadata.min.x;
pointcloud_map_cell_with_id.metadata.min_y = metadata.min.y;
pointcloud_map_cell_with_id.metadata.max_x = metadata.max.x;
pointcloud_map_cell_with_id.metadata.max_y = metadata.max.y;
autoware_map_msgs::msg::PointCloudMapCellWithMetaData pointcloud_map_cell =
load_point_cloud_map_cell_with_metadata(path, map_id);
pointcloud_map_cell.metadata.min_x = metadata.min.x;
pointcloud_map_cell.metadata.min_y = metadata.min.y;
pointcloud_map_cell.metadata.max_x = metadata.max.x;
pointcloud_map_cell.metadata.max_y = metadata.max.y;

res->new_pointcloud_with_ids.push_back(pointcloud_map_cell_with_id);
res->new_pointcloud_cells.push_back(pointcloud_map_cell);
}
res->header.frame_id = "map";
return true;
}

autoware_map_msgs::msg::PointCloudMapCellWithID
SelectedMapLoaderModule::load_point_cloud_map_cell_with_id(
autoware_map_msgs::msg::PointCloudMapCellWithMetaData
SelectedMapLoaderModule::load_point_cloud_map_cell_with_metadata(
const std::string & path, const std::string & map_id) const
{
sensor_msgs::msg::PointCloud2 pcd;
if (pcl::io::loadPCDFile(path, pcd) == -1) {
RCLCPP_ERROR_STREAM(logger_, "PCD load failed: " << path);
}
autoware_map_msgs::msg::PointCloudMapCellWithID pointcloud_map_cell_with_id;
pointcloud_map_cell_with_id.pointcloud = pcd;
pointcloud_map_cell_with_id.cell_id = map_id;
return pointcloud_map_cell_with_id;
autoware_map_msgs::msg::PointCloudMapCellWithMetaData pointcloud_map_cell;
pointcloud_map_cell.pointcloud = pcd;
pointcloud_map_cell.metadata.cell_id = map_id;
return pointcloud_map_cell;
}
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,8 @@ class SelectedMapLoaderModule
[[nodiscard]] bool on_service_get_selected_point_cloud_map(
GetSelectedPointCloudMap::Request::SharedPtr req,
GetSelectedPointCloudMap::Response::SharedPtr res) const;
[[nodiscard]] autoware_map_msgs::msg::PointCloudMapCellWithID load_point_cloud_map_cell_with_id(
[[nodiscard]] autoware_map_msgs::msg::PointCloudMapCellWithMetaData
load_point_cloud_map_cell_with_metadata(
const std::string & path, const std::string & map_id) const;
};

Expand Down
4 changes: 2 additions & 2 deletions map/map_loader/test/test_differential_map_loader_module.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -85,8 +85,8 @@ TEST_F(TestDifferentialMapLoaderModule, LoadDifferentialPCDFiles)

// Check the result
auto result = result_future.get();
ASSERT_EQ(static_cast<int>(result->new_pointcloud_with_ids.size()), 1);
EXPECT_EQ(result->new_pointcloud_with_ids[0].cell_id, "/tmp/dummy.pcd");
ASSERT_EQ(static_cast<int>(result->new_pointcloud_cells.size()), 1);
EXPECT_EQ(result->new_pointcloud_cells[0].metadata.cell_id, "/tmp/dummy.pcd");
EXPECT_EQ(static_cast<int>(result->ids_to_remove.size()), 0);
}

Expand Down
4 changes: 2 additions & 2 deletions map/map_loader/test/test_partial_map_loader_module.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -82,8 +82,8 @@ TEST_F(TestPartialMapLoaderModule, LoadPartialPCDFiles)

// Check the result
auto result = result_future.get();
ASSERT_EQ(static_cast<int>(result->new_pointcloud_with_ids.size()), 1);
EXPECT_EQ(result->new_pointcloud_with_ids[0].cell_id, "/tmp/dummy.pcd");
ASSERT_EQ(static_cast<int>(result->new_pointcloud_cells.size()), 1);
EXPECT_EQ(result->new_pointcloud_cells[0].metadata.cell_id, "/tmp/dummy.pcd");
}

int main(int argc, char ** argv)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ class DistanceBasedDynamicMapLoader : public VoxelGridDynamicMapLoader
bool is_close_to_map(const pcl::PointXYZ & point, const double distance_threshold) override;

inline void addMapCellAndFilter(
const autoware_map_msgs::msg::PointCloudMapCellWithID & map_cell_to_add) override
const autoware_map_msgs::msg::PointCloudMapCellWithMetaData & map_cell_to_add) override
{
map_grid_size_x_ = map_cell_to_add.metadata.max_x - map_cell_to_add.metadata.min_x;
map_grid_size_y_ = map_cell_to_add.metadata.max_y - map_cell_to_add.metadata.min_y;
Expand Down Expand Up @@ -95,7 +95,8 @@ class DistanceBasedDynamicMapLoader : public VoxelGridDynamicMapLoader

// add
(*mutex_ptr_).lock();
current_voxel_grid_dict_.insert({map_cell_to_add.cell_id, current_voxel_grid_list_item});
current_voxel_grid_dict_.insert(
{map_cell_to_add.metadata.cell_id, current_voxel_grid_list_item});
(*mutex_ptr_).unlock();
}
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ class VoxelDistanceBasedDynamicMapLoader : public VoxelGridDynamicMapLoader
bool is_close_to_map(const pcl::PointXYZ & point, const double distance_threshold) override;

inline void addMapCellAndFilter(
const autoware_map_msgs::msg::PointCloudMapCellWithID & map_cell_to_add) override
const autoware_map_msgs::msg::PointCloudMapCellWithMetaData & map_cell_to_add) override
{
map_grid_size_x_ = map_cell_to_add.metadata.max_x - map_cell_to_add.metadata.min_x;
map_grid_size_y_ = map_cell_to_add.metadata.max_y - map_cell_to_add.metadata.min_y;
Expand Down Expand Up @@ -118,7 +118,8 @@ class VoxelDistanceBasedDynamicMapLoader : public VoxelGridDynamicMapLoader

// add
(*mutex_ptr_).lock();
current_voxel_grid_dict_.insert({map_cell_to_add.cell_id, current_voxel_grid_list_item});
current_voxel_grid_dict_.insert(
{map_cell_to_add.metadata.cell_id, current_voxel_grid_list_item});
(*mutex_ptr_).unlock();
}
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -453,12 +453,10 @@ void VoxelGridDynamicMapLoader::request_update_map(const geometry_msgs::msg::Poi
}
//
if (status == std::future_status::ready) {
if (
result.get()->new_pointcloud_with_ids.size() == 0 &&
result.get()->ids_to_remove.size() == 0) {
if (result.get()->new_pointcloud_cells.size() == 0 && result.get()->ids_to_remove.size() == 0) {
return;
}
updateDifferentialMapCells(result.get()->new_pointcloud_with_ids, result.get()->ids_to_remove);
updateDifferentialMapCells(result.get()->new_pointcloud_cells, result.get()->ids_to_remove);
if (debug_) {
publish_downsampled_map(getCurrentDownsampledMapPc());
}
Expand Down
Loading

0 comments on commit 98679f8

Please sign in to comment.