Skip to content

Commit

Permalink
added service to export trajectory
Browse files Browse the repository at this point in the history
  • Loading branch information
rdube committed Apr 18, 2017
1 parent ce2ae33 commit 3a3fbba
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 0 deletions.
4 changes: 4 additions & 0 deletions laser_slam_ros/include/laser_slam_ros/laser_slam_worker.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
#include <pcl/filters/voxel_grid.h>
#include <pcl/point_types.h>
#include <sensor_msgs/PointCloud2.h>
#include <std_srvs/Empty.h>
#include <tf/transform_listener.h>

#include "laser_slam_ros/GetLaserTrackSrv.h"
Expand Down Expand Up @@ -66,6 +67,8 @@ class LaserSlamWorker {

void exportTrajectoryHead(laser_slam::Time head_duration_ns, const std::string& filename) const;

bool exportTrajectoryServiceCall(std_srvs::Empty::Request& req, std_srvs::Empty::Response& res);

private:
// Convert a tf::StampedTransform to a laser_slam::Pose.
laser_slam::Pose tfTransformToPose(const tf::StampedTransform& tf_transform);
Expand Down Expand Up @@ -117,6 +120,7 @@ class LaserSlamWorker {

// Services.
ros::ServiceServer get_laser_track_srv_;
ros::ServiceServer export_trajectory_srv_;

tf::TransformListener tf_listener_;

Expand Down
10 changes: 10 additions & 0 deletions laser_slam_ros/src/laser_slam_worker.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,9 @@ void LaserSlamWorker::init(
get_laser_track_srv_ = nh.advertiseService(
params_.get_laser_track_srv_topic,
&LaserSlamWorker::getLaserTracksServiceCall, this);
export_trajectory_srv_ = nh.advertiseService(
"export_trajectory",
&LaserSlamWorker::exportTrajectoryServiceCall, this);

voxel_filter_.setLeafSize(params_.voxel_size_m, params_.voxel_size_m,
params_.voxel_size_m);
Expand Down Expand Up @@ -594,4 +597,11 @@ void LaserSlamWorker::exportTrajectoryHead(laser_slam::Time head_duration_ns,
LOG(INFO) << "Exported " << i << " trajectory poses to " << filename << ".";
}

bool LaserSlamWorker::exportTrajectoryServiceCall(std_srvs::Empty::Request& req,
std_srvs::Empty::Response& res) {
exportTrajectoryHead(laser_track_->getMaxTime(),
"/tmp/online_matcher/trajectory.csv");
return true;
}

} // namespace laser_slam_ros

0 comments on commit 3a3fbba

Please sign in to comment.