-
Notifications
You must be signed in to change notification settings - Fork 667
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(ndt_scan_matcher): dynamic map loading (#2339)
* first commit Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * import map update module in core Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * minor fixes. Now map update module launches!!! Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * debugged Signed-off-by: kminoda <koji.minoda@tier4.jp> * revert unnecessary fix Signed-off-by: kminoda <koji.minoda@tier4.jp> * minor fixes Signed-off-by: kminoda <koji.minoda@tier4.jp> * update launch file Signed-off-by: kminoda <koji.minoda@tier4.jp> * update comment Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * update comment Signed-off-by: kminoda <koji.minoda@tier4.jp> * update comment Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * update comment Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * update for ndt_omp Signed-off-by: kminoda <koji.minoda@tier4.jp> * changed parameter names Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * apply pre-commit- * ci(pre-commit): autofix * update readme Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * update readme Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * simplify client implementation Signed-off-by: kminoda <koji.minoda@tier4.jp> * remove unnecessary comments Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * removed unused member variables Signed-off-by: kminoda <koji.minoda@tier4.jp> * set default use_dynamic_map_loading to true Signed-off-by: kminoda <koji.minoda@tier4.jp> * changed readme Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * reflected comments Signed-off-by: kminoda <koji.minoda@tier4.jp> * use std::optional instead of shared_ptr Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * fix parameter description Signed-off-by: kminoda <koji.minoda@tier4.jp> * revert launch output config Signed-off-by: kminoda <koji.minoda@tier4.jp> * change default subscriber name Signed-off-by: kminoda <koji.minoda@tier4.jp> * remove unnecessary setInputSource Signed-off-by: kminoda <koji.minoda@tier4.jp> * add gif Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix * minor fix Signed-off-by: kminoda <koji.minoda@tier4.jp> * Update localization/ndt_scan_matcher/src/map_update_module.cpp Co-authored-by: Daisuke Nishimatsu <42202095+wep21@users.noreply.github.com> * update literals Signed-off-by: kminoda <koji.minoda@tier4.jp> * update map_loader default parameters * update readme Signed-off-by: kminoda <koji.minoda@tier4.jp> * ci(pre-commit): autofix --------- Signed-off-by: kminoda <koji.minoda@tier4.jp> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Daisuke Nishimatsu <42202095+wep21@users.noreply.github.com>
- Loading branch information
1 parent
355783a
commit ace34c6
Showing
13 changed files
with
508 additions
and
20 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
107 changes: 107 additions & 0 deletions
107
localization/ndt_scan_matcher/include/ndt_scan_matcher/map_update_module.hpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
// Copyright 2022 Autoware Foundation | ||
// | ||
// Licensed under the Apache License, Version 2.0 (the "License"); | ||
// you may not use this file except in compliance with the License. | ||
// You may obtain a copy of the License at | ||
// | ||
// http://www.apache.org/licenses/LICENSE-2.0 | ||
// | ||
// Unless required by applicable law or agreed to in writing, software | ||
// distributed under the License is distributed on an "AS IS" BASIS, | ||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
// See the License for the specific language governing permissions and | ||
// limitations under the License. | ||
|
||
#ifndef NDT_SCAN_MATCHER__MAP_UPDATE_MODULE_HPP_ | ||
#define NDT_SCAN_MATCHER__MAP_UPDATE_MODULE_HPP_ | ||
|
||
#include "ndt_scan_matcher/debug.hpp" | ||
#include "ndt_scan_matcher/particle.hpp" | ||
#include "ndt_scan_matcher/tf2_listener_module.hpp" | ||
#include "ndt_scan_matcher/util_func.hpp" | ||
|
||
#include <rclcpp/rclcpp.hpp> | ||
#include <tier4_autoware_utils/ros/marker_helper.hpp> | ||
|
||
#include <autoware_map_msgs/srv/get_differential_point_cloud_map.hpp> | ||
#include <geometry_msgs/msg/pose_with_covariance_stamped.hpp> | ||
#include <nav_msgs/msg/odometry.hpp> | ||
#include <tier4_localization_msgs/srv/pose_with_covariance_stamped.hpp> | ||
#include <visualization_msgs/msg/marker_array.hpp> | ||
|
||
#include <fmt/format.h> | ||
#include <multigrid_pclomp/multigrid_ndt_omp.h> | ||
#include <pcl_conversions/pcl_conversions.h> | ||
|
||
#include <map> | ||
#include <memory> | ||
#include <optional> | ||
#include <string> | ||
#include <vector> | ||
|
||
class MapUpdateModule | ||
{ | ||
using PointSource = pcl::PointXYZ; | ||
using PointTarget = pcl::PointXYZ; | ||
using NormalDistributionsTransform = | ||
pclomp::MultiGridNormalDistributionsTransform<PointSource, PointTarget>; | ||
|
||
public: | ||
MapUpdateModule( | ||
rclcpp::Node * node, std::mutex * ndt_ptr_mutex, | ||
std::shared_ptr<NormalDistributionsTransform> ndt_ptr, | ||
std::shared_ptr<Tf2ListenerModule> tf2_listener_module, std::string map_frame, | ||
rclcpp::CallbackGroup::SharedPtr main_callback_group, | ||
std::shared_ptr<std::map<std::string, std::string>> state_ptr); | ||
|
||
private: | ||
void service_ndt_align( | ||
const tier4_localization_msgs::srv::PoseWithCovarianceStamped::Request::SharedPtr req, | ||
tier4_localization_msgs::srv::PoseWithCovarianceStamped::Response::SharedPtr res); | ||
void callback_ekf_odom(nav_msgs::msg::Odometry::ConstSharedPtr odom_ptr); | ||
void map_update_timer_callback(); | ||
|
||
void update_ndt( | ||
const std::vector<autoware_map_msgs::msg::PointCloudMapCellWithID> & maps_to_add, | ||
const std::vector<std::string> & map_ids_to_remove); | ||
void update_map(const geometry_msgs::msg::Point & position); | ||
bool should_update_map(const geometry_msgs::msg::Point & position) const; | ||
void publish_partial_pcd_map(); | ||
geometry_msgs::msg::PoseWithCovarianceStamped align_using_monte_carlo( | ||
const std::shared_ptr<NormalDistributionsTransform> & ndt_ptr, | ||
const geometry_msgs::msg::PoseWithCovarianceStamped & initial_pose_with_cov); | ||
void publish_point_cloud( | ||
const rclcpp::Time & sensor_ros_time, const std::string & frame_id, | ||
const std::shared_ptr<const pcl::PointCloud<PointSource>> & sensor_points_mapTF_ptr); | ||
|
||
rclcpp::Publisher<sensor_msgs::msg::PointCloud2>::SharedPtr loaded_pcd_pub_; | ||
rclcpp::Publisher<visualization_msgs::msg::MarkerArray>::SharedPtr | ||
ndt_monte_carlo_initial_pose_marker_pub_; | ||
rclcpp::Publisher<sensor_msgs::msg::PointCloud2>::SharedPtr sensor_aligned_pose_pub_; | ||
|
||
rclcpp::Service<tier4_localization_msgs::srv::PoseWithCovarianceStamped>::SharedPtr service_; | ||
rclcpp::Client<autoware_map_msgs::srv::GetDifferentialPointCloudMap>::SharedPtr | ||
pcd_loader_client_; | ||
rclcpp::TimerBase::SharedPtr map_update_timer_; | ||
|
||
rclcpp::Subscription<nav_msgs::msg::Odometry>::SharedPtr ekf_odom_sub_; | ||
|
||
rclcpp::CallbackGroup::SharedPtr map_callback_group_; | ||
|
||
std::shared_ptr<NormalDistributionsTransform> ndt_ptr_; | ||
std::mutex * ndt_ptr_mutex_; | ||
std::string map_frame_; | ||
rclcpp::Logger logger_; | ||
rclcpp::Clock::SharedPtr clock_; | ||
std::shared_ptr<Tf2ListenerModule> tf2_listener_module_; | ||
std::shared_ptr<std::map<std::string, std::string>> state_ptr_; | ||
|
||
int initial_estimate_particles_num_; | ||
std::optional<geometry_msgs::msg::Point> last_update_position_ = std::nullopt; | ||
std::optional<geometry_msgs::msg::Point> current_position_ = std::nullopt; | ||
const double dynamic_map_loading_update_distance_; | ||
const double dynamic_map_loading_map_radius_; | ||
const double lidar_radius_; | ||
}; | ||
|
||
#endif // NDT_SCAN_MATCHER__MAP_UPDATE_MODULE_HPP_ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.