32 #include <pcl/point_cloud.h> 33 #include <pcl/point_types.h> 35 #include <pcl/io/pcd_io.h> 41 #include <sensor_msgs/PointCloud2.h> 102 pnh.
param(
"queue_size", queueSize, queueSize);
105 pnh.
param(
"approx_sync", approx, approx);
106 pnh.
param(
"count", count, count);
111 std::string subscribedTopicsMsg;
126 subscribedTopicsMsg =
uFormat(
"\n%s subscribed to (%s sync):\n %s,\n %s,\n %s,\n %s",
128 approx?
"approx":
"exact",
147 subscribedTopicsMsg =
uFormat(
"\n%s subscribed to (%s sync):\n %s,\n %s,\n %s",
149 approx?
"approx":
"exact",
166 subscribedTopicsMsg =
uFormat(
"\n%s subscribed to (%s sync):\n %s,\n %s",
168 approx?
"approx":
"exact",
180 const sensor_msgs::PointCloud2ConstPtr & cloudMsg_2,
181 const sensor_msgs::PointCloud2ConstPtr & cloudMsg_3,
182 const sensor_msgs::PointCloud2ConstPtr & cloudMsg_4)
184 std::vector<sensor_msgs::PointCloud2ConstPtr> clouds;
185 clouds.push_back(cloudMsg_1);
186 clouds.push_back(cloudMsg_2);
187 clouds.push_back(cloudMsg_3);
188 clouds.push_back(cloudMsg_4);
193 const sensor_msgs::PointCloud2ConstPtr & cloudMsg_2,
194 const sensor_msgs::PointCloud2ConstPtr & cloudMsg_3)
196 std::vector<sensor_msgs::PointCloud2ConstPtr> clouds;
197 clouds.push_back(cloudMsg_1);
198 clouds.push_back(cloudMsg_2);
199 clouds.push_back(cloudMsg_3);
204 const sensor_msgs::PointCloud2ConstPtr & cloudMsg_2)
206 std::vector<sensor_msgs::PointCloud2ConstPtr> clouds;
207 clouds.push_back(cloudMsg_1);
208 clouds.push_back(cloudMsg_2);
212 void combineClouds(
const std::vector<sensor_msgs::PointCloud2ConstPtr> & cloudMsgs)
218 pcl::PCLPointCloud2 output;
221 if(!frameId.empty() && frameId.compare(cloudMsgs[0]->header.frame_id) != 0)
223 sensor_msgs::PointCloud2 tmp;
230 frameId = cloudMsgs[0]->header.frame_id;
233 for(
unsigned int i=1; i<cloudMsgs.size(); ++i)
236 bool notsync =
false;
238 cloudMsgs[0]->header.stamp != cloudMsgs[i]->header.stamp)
244 cloudMsgs[i]->header.stamp,
245 cloudMsgs[0]->header.stamp,
251 pcl::PCLPointCloud2 cloud2;
252 if(frameId.compare(cloudMsgs[i]->header.frame_id) != 0)
254 sensor_msgs::PointCloud2 tmp;
256 if(!cloudDisplacement.
isNull())
258 sensor_msgs::PointCloud2 tmp2;
270 if(!cloudDisplacement.
isNull())
272 sensor_msgs::PointCloud2 tmp;
282 pcl::PCLPointCloud2 tmp_output;
287 sensor_msgs::PointCloud2 rosCloud;
289 rosCloud.header.stamp = cloudMsgs[0]->header.stamp;
290 rosCloud.header.frame_id =
frameId;
295 void warningLoop(
const std::string & subscribedTopicsMsg,
bool approxSync)
303 ROS_WARN(
"%s: Did not receive data since 5 seconds! Make sure the input topics are " 304 "published (\"$ rostopic hz my_topic\") and the timestamps in their " 305 "header are set. %s%s",
307 approxSync?
"":
"Parameter \"approx_sync\" is false, which means that input " 308 "topics should have all the exact timestamp for the callback to be called.",
309 subscribedTopicsMsg.c_str());
message_filters::Synchronizer< ExactSync4Policy > * exactSync4_
std::string getTopic() const
message_filters::Subscriber< sensor_msgs::PointCloud2 > cloudSub_2_
std::string uFormat(const char *fmt,...)
void publish(const boost::shared_ptr< M > &message) const
message_filters::Subscriber< sensor_msgs::PointCloud2 > cloudSub_3_
message_filters::sync_policies::ExactTime< sensor_msgs::PointCloud2, sensor_msgs::PointCloud2, sensor_msgs::PointCloud2 > ExactSync3Policy
const std::string & getName() const
message_filters::Synchronizer< ExactSync2Policy > * exactSync2_
void clouds3_callback(const sensor_msgs::PointCloud2ConstPtr &cloudMsg_1, const sensor_msgs::PointCloud2ConstPtr &cloudMsg_2, const sensor_msgs::PointCloud2ConstPtr &cloudMsg_3)
rtabmap::Transform getTransform(const std::string &fromFrameId, const std::string &toFrameId, const ros::Time &stamp, tf::TransformListener &listener, double waitForTransform)
message_filters::Synchronizer< ApproxSync3Policy > * approxSync3_
boost::thread * warningThread_
ros::NodeHandle & getPrivateNodeHandle() const
void combineClouds(const std::vector< sensor_msgs::PointCloud2ConstPtr > &cloudMsgs)
void clouds4_callback(const sensor_msgs::PointCloud2ConstPtr &cloudMsg_1, const sensor_msgs::PointCloud2ConstPtr &cloudMsg_2, const sensor_msgs::PointCloud2ConstPtr &cloudMsg_3, const sensor_msgs::PointCloud2ConstPtr &cloudMsg_4)
virtual ~PointCloudAggregator()
std::string fixedFrameId_
message_filters::sync_policies::ApproximateTime< sensor_msgs::PointCloud2, sensor_msgs::PointCloud2 > ApproxSync2Policy
message_filters::Synchronizer< ExactSync3Policy > * exactSync3_
bool param(const std::string ¶m_name, T ¶m_val, const T &default_val) const
Publisher advertise(const std::string &topic, uint32_t queue_size, bool latch=false)
ros::NodeHandle & getNodeHandle() const
message_filters::sync_policies::ExactTime< sensor_msgs::PointCloud2, sensor_msgs::PointCloud2 > ExactSync2Policy
bool concatenatePointCloud(const sensor_msgs::PointCloud2 &cloud1, const sensor_msgs::PointCloud2 &cloud2, sensor_msgs::PointCloud2 &cloud_out)
#define NODELET_INFO(...)
uint32_t getNumSubscribers() const
void subscribe(ros::NodeHandle &nh, const std::string &topic, uint32_t queue_size, const ros::TransportHints &transport_hints=ros::TransportHints(), ros::CallbackQueueInterface *callback_queue=0)
tf::TransformListener tfListener_
void transformPointCloud(const pcl::PointCloud< PointT > &cloud_in, pcl::PointCloud< PointT > &cloud_out, const tf::Transform &transform)
message_filters::sync_policies::ApproximateTime< sensor_msgs::PointCloud2, sensor_msgs::PointCloud2, sensor_msgs::PointCloud2 > ApproxSync3Policy
message_filters::sync_policies::ExactTime< sensor_msgs::PointCloud2, sensor_msgs::PointCloud2, sensor_msgs::PointCloud2, sensor_msgs::PointCloud2 > ExactSync4Policy
PLUGINLIB_EXPORT_CLASS(rtabmap_ros::CoreWrapper, nodelet::Nodelet)
void moveFromPCL(pcl::PCLImage &pcl_image, sensor_msgs::Image &image)
void clouds2_callback(const sensor_msgs::PointCloud2ConstPtr &cloudMsg_1, const sensor_msgs::PointCloud2ConstPtr &cloudMsg_2)
message_filters::Synchronizer< ApproxSync2Policy > * approxSync2_
message_filters::sync_policies::ApproximateTime< sensor_msgs::PointCloud2, sensor_msgs::PointCloud2, sensor_msgs::PointCloud2, sensor_msgs::PointCloud2 > ApproxSync4Policy
void warningLoop(const std::string &subscribedTopicsMsg, bool approxSync)
message_filters::Subscriber< sensor_msgs::PointCloud2 > cloudSub_4_
void toPCL(const ros::Time &stamp, pcl::uint64_t &pcl_stamp)
message_filters::Subscriber< sensor_msgs::PointCloud2 > cloudSub_1_
message_filters::Synchronizer< ApproxSync4Policy > * approxSync4_