merge_maps_kinematic.hpp
Go to the documentation of this file.
1 /*
2  * Author
3  * Copyright (c) 2018, Simbe Robotics, Inc.
4  *
5  * THE WORK (AS DEFINED BELOW) IS PROVIDED UNDER THE TERMS OF THIS CREATIVE
6  * COMMONS PUBLIC LICENSE ("CCPL" OR "LICENSE"). THE WORK IS PROTECTED BY
7  * COPYRIGHT AND/OR OTHER APPLICABLE LAW. ANY USE OF THE WORK OTHER THAN AS
8  * AUTHORIZED UNDER THIS LICENSE OR COPYRIGHT LAW IS PROHIBITED.
9  *
10  * BY EXERCISING ANY RIGHTS TO THE WORK PROVIDED HERE, YOU ACCEPT AND AGREE TO
11  * BE BOUND BY THE TERMS OF THIS LICENSE. THE LICENSOR GRANTS YOU THE RIGHTS
12  * CONTAINED HERE IN CONSIDERATION OF YOUR ACCEPTANCE OF SUCH TERMS AND
13  * CONDITIONS.
14  *
15  */
16 
17 /* Author: Steven Macenski */
18 
19 #ifndef SLAM_TOOLBOX_MERGE_MAPS_KINEMATIC_H_
20 #define SLAM_TOOLBOX_MERGE_MAPS_KINEMATIC_H_
21 
22 #include <string>
23 #include <map>
24 #include <memory>
25 #include <vector>
26 #include <sys/stat.h>
27 #include <unistd.h>
28 #include <fstream>
29 #include <boost/thread.hpp>
30 
31 #include "ros/ros.h"
36 #include "tf2_ros/message_filter.h"
39 #include "tf2/utils.h"
40 
41 #include "karto_sdk/Mapper.h"
45 
46 using namespace toolbox_types;
47 
49 {
50 typedef std::vector<karto::LocalizedRangeScanVector>::iterator LocalizedRangeScansVecIt;
51 typedef karto::LocalizedRangeScanVector::iterator LocalizedRangeScansIt;
52 
53 public:
56 
57 private:
58 
59  // setup
60  void setup();
61 
62  // callback
63  bool mergeMapCallback(slam_toolbox_msgs::MergeMaps::Request& req, slam_toolbox_msgs::MergeMaps::Response& resp);
64  bool addSubmapCallback(slam_toolbox_msgs::AddSubmap::Request& req, slam_toolbox_msgs::AddSubmap::Response& resp);
65  void processInteractiveFeedback(const visualization_msgs::InteractiveMarkerFeedbackConstPtr& feedback);
66  void kartoToROSOccupancyGrid(const karto::LocalizedRangeScanVector& scans, nav_msgs::GetMap::Response& map);
67  void transformScan(LocalizedRangeScansIt iter, tf2::Transform& submap_correction);
68 
69  //apply transformation to correct pose
70  karto::Pose2 applyCorrection(const karto::Pose2& pose, const tf2::Transform& submap_correction);
71  karto::Vector2<kt_double> applyCorrection(const karto::Vector2<kt_double>& pose, const tf2::Transform& submap_correction);
72 
73  // ROS-y-ness
75  std::vector<ros::Publisher> sstS_, sstmS_;
77 
78  //karto bookkeeping
79  std::map<std::string, laser_utils::LaserMetadata> lasers_;
80  std::vector<std::unique_ptr<karto::Dataset> > dataset_vec_;
81 
82  // TF
83  std::unique_ptr<tf2_ros::TransformBroadcaster> tfB_;
84 
85  // visualization
86  std::unique_ptr<interactive_markers::InteractiveMarkerServer> interactive_server_;
87 
88  // state
89  std::map<int, Eigen::Vector3d> submap_locations_;
90  std::vector<karto::LocalizedRangeScanVector> scans_vec_;
91  std::map<int, tf2::Transform> submap_marker_transform_;
92  double resolution_;
94 };
95 
96 #endif //SLAM_TOOLBOX_MERGE_MAPS_KINEMATIC_H_
ros::ServiceServer ssSubmap_
std::vector< karto::LocalizedRangeScanVector >::iterator LocalizedRangeScansVecIt
std::map< int, tf2::Transform > submap_marker_transform_
std::unique_ptr< tf2_ros::TransformBroadcaster > tfB_
std::map< std::string, laser_utils::LaserMetadata > lasers_
karto::LocalizedRangeScanVector::iterator LocalizedRangeScansIt
std::vector< std::unique_ptr< karto::Dataset > > dataset_vec_
std::vector< karto::LocalizedRangeScanVector > scans_vec_
std::unique_ptr< interactive_markers::InteractiveMarkerServer > interactive_server_
std::map< int, Eigen::Vector3d > submap_locations_
std::vector< LocalizedRangeScan * > LocalizedRangeScanVector
Definition: Karto.h:5877
std::vector< ros::Publisher > sstS_


slam_toolbox
Author(s): Steve Macenski
autogenerated on Mon Feb 28 2022 23:46:49