The EKFslamWrapper class provides the ROS wrapper for EKF SLAM 2d from MRPT libraries. More...
#include <mrpt_ekf_slam_2d_wrapper.h>
Public Member Functions | |
void | computeEllipseOrientationScale2D (tf::Quaternion &orientation, Eigen::Vector2d &scale, const mrpt::math::CMatrixDouble covariance) |
compute the orientation and scale of covariance ellipsoids | |
EKFslamWrapper () | |
constructor | |
void | get_param () |
read the parameters from launch file | |
void | init () |
initialize publishers subscribers and EKF 2d slam | |
bool | is_file_exists (const std::string &name) |
check the existance of the file | |
void | landmarkCallback (const mrpt_msgs::ObservationRangeBearing &_msg) |
callback function for the landmarks | |
void | makeRightHanded (Eigen::Matrix2d &eigenvectors, Eigen::Vector2d &eigenvalues) |
compute the correct orientation and scale of covariance ellipsoids (make sure that we output covariance ellipsoids for right handed system of coordinates) | |
void | odometryForCallback (CObservationOdometry::Ptr &_odometry, const std_msgs::Header &_msg_header) |
get the odometry for received observation | |
void | publishTF () |
publish tf tree | |
bool | rawlogPlay () |
play rawlog file | |
void | updateSensorPose (std::string _frame_id) |
update the pose of the sensor with respect to the robot | |
void | viz_dataAssociation () |
visualize the data associations for the landmarks observed by robot at the each step | |
void | viz_state () |
visualize the covariance ellipsoids for robot and landmarks | |
bool | waitForTransform (mrpt::poses::CPose3D &des, const std::string &target_frame, const std::string &source_frame, const ros::Time &time, const ros::Duration &timeout, const ros::Duration &polling_sleep_duration=ros::Duration(0.01)) |
wait for transform between odometry frame and the robot frame | |
~EKFslamWrapper () | |
destructor | |
Private Attributes | |
std::string | base_frame_id |
robot frame | |
ros::Publisher | data_association_viz_pub_ |
double | ellipse_scale_ |
Scale of covariance ellipses. | |
std::string | global_frame_id |
/map frame | |
std::string | ini_filename |
name of ini file | |
std::map< std::string, mrpt::poses::CPose3D > | landmark_poses_ |
landmark poses with respect to the map | |
tf::TransformListener | listenerTF_ |
transform listener | |
ros::NodeHandle | n_ |
Node handler. | |
std::string | odom_frame_id |
/odom frame | |
std::string | rawlog_filename |
name of rawlog file | |
bool | rawlog_play_ |
true if rawlog file exists | |
double | rawlog_play_delay |
delay of replay from rawlog file | |
std::string | sensor_source |
2D laser scans | |
std::vector< ros::Subscriber > | sensorSub_ |
list of sensors topics | |
ros::Publisher | state_viz_pub_ |
publishers | |
float | t_exec |
the time which take one SLAM update execution | |
tf::TransformBroadcaster | tf_broadcaster_ |
transform broadcaster | |
CTicTac | tictac |
timer for SLAM performance evaluation |
The EKFslamWrapper class provides the ROS wrapper for EKF SLAM 2d from MRPT libraries.
Definition at line 64 of file mrpt_ekf_slam_2d_wrapper.h.
constructor
Definition at line 11 of file mrpt_ekf_slam_2d_wrapper.cpp.
destructor
Definition at line 15 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::computeEllipseOrientationScale2D | ( | tf::Quaternion & | orientation, |
Eigen::Vector2d & | scale, | ||
const mrpt::math::CMatrixDouble | covariance | ||
) |
compute the orientation and scale of covariance ellipsoids
orientation | the orientation of the ellipsoid in Quaternions |
scale | the vector of the eigen values for calculating the size of the ellipse |
covariance | covariance matrix for current landmarks or robot pose |
Definition at line 255 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::get_param | ( | ) |
read the parameters from launch file
Definition at line 21 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::init | ( | ) |
initialize publishers subscribers and EKF 2d slam
Create subscribers///
Definition at line 47 of file mrpt_ekf_slam_2d_wrapper.cpp.
bool EKFslamWrapper::is_file_exists | ( | const std::string & | name | ) |
check the existance of the file
Definition at line 16 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::landmarkCallback | ( | const mrpt_msgs::ObservationRangeBearing & | _msg | ) |
callback function for the landmarks
Given the landmarks wait for odometry, create the pair of action and observation, implement one SLAM update, publish map and pose.
_msg | the landmark message |
Definition at line 148 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::makeRightHanded | ( | Eigen::Matrix2d & | eigenvectors, |
Eigen::Vector2d & | eigenvalues | ||
) |
compute the correct orientation and scale of covariance ellipsoids (make sure that we output covariance ellipsoids for right handed system of coordinates)
eigenvectors | the 2x2 matrix of eigenvectors |
eigenvalues | the 2d vector of eigen values |
Definition at line 231 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::odometryForCallback | ( | CObservationOdometry::Ptr & | _odometry, |
const std_msgs::Header & | _msg_header | ||
) |
get the odometry for received observation
_odometry | odometry for received observation |
_msg_header | timestamp of the observation |
Definition at line 90 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::publishTF | ( | ) |
publish tf tree
Definition at line 441 of file mrpt_ekf_slam_2d_wrapper.cpp.
bool EKFslamWrapper::rawlogPlay | ( | ) |
play rawlog file
Definition at line 187 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::updateSensorPose | ( | std::string | _frame_id | ) |
update the pose of the sensor with respect to the robot
frame_id | the frame of the sensors |
Definition at line 105 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::viz_dataAssociation | ( | ) |
visualize the data associations for the landmarks observed by robot at the each step
Definition at line 298 of file mrpt_ekf_slam_2d_wrapper.cpp.
void EKFslamWrapper::viz_state | ( | ) |
visualize the covariance ellipsoids for robot and landmarks
Definition at line 358 of file mrpt_ekf_slam_2d_wrapper.cpp.
bool EKFslamWrapper::waitForTransform | ( | mrpt::poses::CPose3D & | des, |
const std::string & | target_frame, | ||
const std::string & | source_frame, | ||
const ros::Time & | time, | ||
const ros::Duration & | timeout, | ||
const ros::Duration & | polling_sleep_duration = ros::Duration(0.01) |
||
) |
wait for transform between odometry frame and the robot frame
des | position of the robot with respect to odometry frame |
target_frame | the odometry tf frame |
source_frame | the robot tf frame |
time | timestamp of the observation for which we want to retrieve the position of the robot |
timeout | timeout for odometry waiting |
polling_sleep_duration | timeout for transform wait |
Definition at line 130 of file mrpt_ekf_slam_2d_wrapper.cpp.
std::string EKFslamWrapper::base_frame_id [private] |
robot frame
Definition at line 178 of file mrpt_ekf_slam_2d_wrapper.h.
Definition at line 188 of file mrpt_ekf_slam_2d_wrapper.h.
double EKFslamWrapper::ellipse_scale_ [private] |
Scale of covariance ellipses.
Definition at line 170 of file mrpt_ekf_slam_2d_wrapper.h.
std::string EKFslamWrapper::global_frame_id [private] |
/map frame
Definition at line 176 of file mrpt_ekf_slam_2d_wrapper.h.
std::string EKFslamWrapper::ini_filename [private] |
name of ini file
Definition at line 175 of file mrpt_ekf_slam_2d_wrapper.h.
std::map<std::string, mrpt::poses::CPose3D> EKFslamWrapper::landmark_poses_ [private] |
landmark poses with respect to the map
Definition at line 183 of file mrpt_ekf_slam_2d_wrapper.h.
transform listener
Definition at line 189 of file mrpt_ekf_slam_2d_wrapper.h.
ros::NodeHandle EKFslamWrapper::n_ [private] |
Node handler.
Definition at line 168 of file mrpt_ekf_slam_2d_wrapper.h.
std::string EKFslamWrapper::odom_frame_id [private] |
/odom frame
Definition at line 177 of file mrpt_ekf_slam_2d_wrapper.h.
std::string EKFslamWrapper::rawlog_filename [private] |
name of rawlog file
Definition at line 174 of file mrpt_ekf_slam_2d_wrapper.h.
bool EKFslamWrapper::rawlog_play_ [private] |
true if rawlog file exists
Definition at line 171 of file mrpt_ekf_slam_2d_wrapper.h.
double EKFslamWrapper::rawlog_play_delay [private] |
delay of replay from rawlog file
Definition at line 169 of file mrpt_ekf_slam_2d_wrapper.h.
std::string EKFslamWrapper::sensor_source [private] |
2D laser scans
Definition at line 181 of file mrpt_ekf_slam_2d_wrapper.h.
std::vector<ros::Subscriber> EKFslamWrapper::sensorSub_ [private] |
list of sensors topics
Definition at line 173 of file mrpt_ekf_slam_2d_wrapper.h.
ros::Publisher EKFslamWrapper::state_viz_pub_ [private] |
publishers
Definition at line 188 of file mrpt_ekf_slam_2d_wrapper.h.
float EKFslamWrapper::t_exec [private] |
the time which take one SLAM update execution
Definition at line 186 of file mrpt_ekf_slam_2d_wrapper.h.
transform broadcaster
Definition at line 190 of file mrpt_ekf_slam_2d_wrapper.h.
CTicTac EKFslamWrapper::tictac [private] |
timer for SLAM performance evaluation
Definition at line 185 of file mrpt_ekf_slam_2d_wrapper.h.