namespace mrpt::ros1bridge
ROS message: http://docs.ros.org/api/sensor_msgs/html/msg/NavSatFix.html MRPT message: https://github.com/MRPT/mrpt/blob/master/libs/obs/include/mrpt/obs/CObservationGPS.h.
ROS message : http://docs.ros.org/api/sensor_msgs/html/msg/Range.html MRPT message: https://github.com/MRPT/mrpt/blob/master/libs/obs/include/mrpt/obs/CObservationRange.h.
ROS message: http://docs.ros.org/api/sensor_msgs/html/msg/Imu.html MRPT message: https://github.com/MRPT/mrpt/blob/master/libs/obs/include/mrpt/obs/CObservationIMU.h.
Conversion functions between ROS 1 <-> MRPT types.
namespace ros1bridge { // classes class MapHdl; // global functions bool fromROS(const nav_msgs::OccupancyGrid& src, mrpt::maps::COccupancyGridMap2D& des); bool toROS(const mrpt::maps::COccupancyGridMap2D& src, nav_msgs::OccupancyGrid& msg, const std_msgs::Header& header); bool toROS(const mrpt::maps::COccupancyGridMap2D& src, nav_msgs::OccupancyGrid& msg); bool fromROS(const sensor_msgs::PointCloud& msg, mrpt::maps::CSimplePointsMap& obj); bool toROS( const mrpt::maps::CSimplePointsMap& obj, const std_msgs::Header& msg_header, sensor_msgs::PointCloud& msg ); bool fromROS(const sensor_msgs::PointCloud2& msg, mrpt::maps::CSimplePointsMap& obj); bool fromROS( const sensor_msgs::PointCloud2& msg, mrpt::maps::CPointsMapXYZI& obj ); bool fromROS( const sensor_msgs::PointCloud2& m, mrpt::obs::CObservationRotatingScan& o, const mrpt::poses::CPose3D& sensorPoseOnRobot, unsigned int num_azimuth_divisions = 360 ); std::set<std::string> extractFields(const sensor_msgs::PointCloud2& msg); bool toROS( const mrpt::maps::CSimplePointsMap& obj, const std_msgs::Header& msg_header, sensor_msgs::PointCloud2& msg ); bool fromROS(const sensor_msgs::NavSatFix& msg, mrpt::obs::CObservationGPS& obj); bool toROS( const mrpt::obs::CObservationGPS& obj, const std_msgs::Header& msg_header, sensor_msgs::NavSatFix& msg ); mrpt::img::CImage fromROS(const sensor_msgs::Image& i); sensor_msgs::Image toROS(const mrpt::img::CImage& i, const std_msgs::Header& msg_header); bool fromROS(const sensor_msgs::Imu& msg, mrpt::obs::CObservationIMU& obj); bool toROS(const mrpt::obs::CObservationIMU& obj, const std_msgs::Header& msg_header, sensor_msgs::Imu& msg); bool fromROS(const sensor_msgs::LaserScan& msg, const mrpt::poses::CPose3D& pose, mrpt::obs::CObservation2DRangeScan& obj); bool toROS(const mrpt::obs::CObservation2DRangeScan& obj, sensor_msgs::LaserScan& msg); bool toROS(const mrpt::obs::CObservation2DRangeScan& obj, sensor_msgs::LaserScan& msg, geometry_msgs::Pose& pose); tf2::Matrix3x3 toROS(const mrpt::math::CMatrixDouble33& src); tf2::Transform toROS_tfTransform(const mrpt::poses::CPose2D& src); geometry_msgs::Pose toROS_Pose(const mrpt::poses::CPose2D& src); tf2::Transform toROS_tfTransform(const mrpt::math::TPose2D& src); geometry_msgs::Pose toROS_Pose(const mrpt::math::TPose2D& src); tf2::Transform toROS_tfTransform(const mrpt::poses::CPose3D& src); geometry_msgs::Pose toROS_Pose(const mrpt::poses::CPose3D& src); tf2::Transform toROS_tfTransform(const mrpt::math::TPose3D& src); geometry_msgs::Pose toROS_Pose(const mrpt::math::TPose3D& src); geometry_msgs::PoseWithCovariance toROS_Pose(const mrpt::poses::CPose3DPDFGaussian& src); geometry_msgs::PoseWithCovariance toROS(const mrpt::poses::CPose3DPDFGaussianInf& src); geometry_msgs::PoseWithCovariance toROS(const mrpt::poses::CPosePDFGaussian& src); geometry_msgs::PoseWithCovariance toROS(const mrpt::poses::CPosePDFGaussianInf& src); geometry_msgs::Quaternion toROS(const mrpt::math::CQuaternionDouble& src); mrpt::poses::CPose3D fromROS(const tf2::Transform& src); mrpt::math::CMatrixDouble33 fromROS(const tf2::Matrix3x3& src); mrpt::poses::CPose3D fromROS(const geometry_msgs::Pose& src); mrpt::poses::CPose3DPDFGaussian fromROS(const geometry_msgs::PoseWithCovariance& src); mrpt::math::CQuaternionDouble fromROS(const geometry_msgs::Quaternion& src); bool fromROS(const sensor_msgs::Range& msg, mrpt::obs::CObservationRange& obj); bool toROS(const mrpt::obs::CObservationRange& obj, const std_msgs::Header& msg_header, sensor_msgs::Range* msg); bool toROS( const mrpt::obs::CObservationStereoImages& obj, const std_msgs::Header& msg_header, sensor_msgs::Image& left, sensor_msgs::Image& right, stereo_msgs::DisparityImage& disparity ); mrpt::system::TTimeStamp fromROS(const ros::Time& src); ros::Time toROS(const mrpt::system::TTimeStamp& src); bool convert( const sensor_msgs::LaserScan& msg, const mrpt::poses::CPose3D& pose, mrpt::obs::CObservation2DRangeScan& obj ); static bool check_field( const sensor_msgs::PointField& input_field, std::string check_name, const sensor_msgs::PointField** output ); static void get_float_from_field( const sensor_msgs::PointField* field, const unsigned char* data, float& output ); static void get_uint16_from_field( const sensor_msgs::PointField* field, const unsigned char* data, uint16_t& output ); } // namespace ros1bridge