pointcloud_localization.h
Go to the documentation of this file.
1 // -*- mode: c++ -*-
2 /*********************************************************************
3  * Software License Agreement (BSD License)
4  *
5  * Copyright (c) 2015, JSK Lab
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/o2r other materials provided
17  * with the distribution.
18  * * Neither the name of the JSK Lab nor the names of its
19  * contributors may be used to endorse or promote products derived
20  * from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  *********************************************************************/
35 
36 
37 #ifndef JSK_PCL_ROS_POINTCLOUD_LOCALIZATION
38 #define JSK_PCL_ROS_POINTCLOUD_LOCALIZATION
43 #include <std_srvs/Empty.h>
44 #include <sensor_msgs/PointCloud2.h>
45 #include <geometry_msgs/PoseStamped.h>
46 #include <pcl/point_cloud.h>
47 #include <pcl/point_types.h>
48 #include <jsk_recognition_msgs/UpdateOffset.h>
49 
50 namespace jsk_pcl_ros
51 {
53  {
54  public:
56  first_time_(true), localize_requested_(false),
57  DiagnosticNodelet("PointCloudLocalization") {}
58  protected:
59  virtual void onInit();
60  virtual void subscribe();
61  virtual void unsubscribe();
62 
67  virtual void cloudCallback(
68  const sensor_msgs::PointCloud2::ConstPtr& cloud_msg);
69 
74  virtual bool localizationRequest(
75  std_srvs::Empty::Request& req,
76  std_srvs::Empty::Response& res);
77 
82  virtual void cloudTimerCallback(
83  const ros::TimerEvent& event);
84 
89  virtual void tfTimerCallback(
90  const ros::TimerEvent& event);
91 
96  virtual bool isFirstTime();
97 
102  virtual bool updateOffsetCallback(
103  jsk_recognition_msgs::UpdateOffset::Request& req,
104  jsk_recognition_msgs::UpdateOffset::Response& res);
105 
106  virtual void applyDownsampling(
107  pcl::PointCloud<pcl::PointNormal>::Ptr in_cloud,
108  pcl::PointCloud<pcl::PointNormal>& out_cloud);
109 
119  pcl::PointCloud<pcl::PointNormal>::Ptr all_cloud_;
120  sensor_msgs::PointCloud2::ConstPtr latest_cloud_;
123  std::string sensor_frame_;
126  std::string initialize_tf_;
131  std::string global_frame_;
132  std::string odom_frame_;
133 
139  double leaf_size_;
142  private:
143 
144  };
145 }
146 
147 #endif
virtual void cloudCallback(const sensor_msgs::PointCloud2::ConstPtr &cloud_msg)
callback function of ~input topic.
DiagnosticNodelet(const std::string &name)
virtual void applyDownsampling(pcl::PointCloud< pcl::PointNormal >::Ptr in_cloud, pcl::PointCloud< pcl::PointNormal > &out_cloud)
pcl::PointCloud< pcl::PointNormal >::Ptr all_cloud_
sensor_msgs::PointCloud2::ConstPtr latest_cloud_
virtual bool localizationRequest(std_srvs::Empty::Request &req, std_srvs::Empty::Response &res)
callback function of ~localize service.
bool use_normal_
Resolution of voxel grid.
std::string global_frame_
Publishes tf transformation of global_frame_ -> odom_frame_.
virtual void cloudTimerCallback(const ros::TimerEvent &event)
cloud periodic timer callback
boost::mutex mutex
global mutex.
virtual bool isFirstTime()
return true if it is the first time to localize
virtual bool updateOffsetCallback(jsk_recognition_msgs::UpdateOffset::Request &req, jsk_recognition_msgs::UpdateOffset::Response &res)
callback function for ~update_offset service
virtual void tfTimerCallback(const ros::TimerEvent &event)
tf periodic timer callback


jsk_pcl_ros
Author(s): Yohei Kakiuchi
autogenerated on Mon May 3 2021 03:03:47