34 #include <pcl/point_cloud.h> 35 #include <pcl/point_types.h> 38 #include <sensor_msgs/PointCloud2.h> 39 #include <sensor_msgs/Image.h> 41 #include <sensor_msgs/CameraInfo.h> 42 #include <stereo_msgs/DisparityImage.h> 54 #include <opencv2/highgui/highgui.hpp> 104 bool approxSync =
true;
106 double approxSyncMaxInterval = 0.0;
107 pnh.
param(
"approx_sync", approxSync, approxSync);
108 pnh.
param(
"approx_sync_max_interval", approxSyncMaxInterval, approxSyncMaxInterval);
109 pnh.
param(
"queue_size", queueSize, queueSize);
119 pnh.
param(
"roi_ratios", roiStr, roiStr);
124 ROS_ERROR(
"\"cut_left\" parameter is replaced by \"roi_ratios\". It will be ignored.");
128 ROS_ERROR(
"\"cut_right\" parameter is replaced by \"roi_ratios\". It will be ignored.");
130 if(pnh.
hasParam(
"special_filter_close_object"))
132 ROS_ERROR(
"\"special_filter_close_object\" parameter is removed. This kind of processing " 133 "should be done before or after this nodelet. See old implementation here: " 134 "https://github.com/introlab/rtabmap_ros/blob/f0026b071c7c54fbcc71df778dd7e17f52f78fc4/src/nodelets/point_cloud_xyz.cpp#L178-L201.");
141 std::list<std::string> strValues =
uSplit(roiStr,
' ');
142 if(strValues.size() != 4)
144 ROS_ERROR(
"The number of values must be 4 (\"roi_ratios\"=\"%s\")", roiStr.c_str());
148 std::vector<float> tmpValues(4);
150 for(std::list<std::string>::iterator jter = strValues.begin(); jter!=strValues.end(); ++jter)
156 if(tmpValues[0] >= 0 && tmpValues[0] < 1 && tmpValues[0] < 1.0
f-tmpValues[1] &&
157 tmpValues[1] >= 0 && tmpValues[1] < 1 && tmpValues[1] < 1.0
f-tmpValues[0] &&
158 tmpValues[2] >= 0 && tmpValues[2] < 1 && tmpValues[2] < 1.0
f-tmpValues[3] &&
159 tmpValues[3] >= 0 && tmpValues[3] < 1 && tmpValues[3] < 1.0
f-tmpValues[2])
165 ROS_ERROR(
"The roi ratios are not valid (\"roi_ratios\"=\"%s\")", roiStr.c_str());
170 NODELET_INFO(
"Approximate time sync = %s", approxSync?
"true":
"false");
175 if(approxSyncMaxInterval > 0.0)
180 if(approxSyncMaxInterval > 0.0)
208 const sensor_msgs::ImageConstPtr& depthMsg,
209 const sensor_msgs::CameraInfoConstPtr& cameraInfo)
228 pcl::PointCloud<pcl::PointXYZ>::Ptr pclCloud;
230 cv::Mat depth = imageDepthPtr->image;
245 (roiRgb.width != 0 ||
249 depth = cv::Mat(depth, roiDepth);
252 model = model.
roi(roiRgb);
256 model = model.
roi(roiDepth);
261 NODELET_ERROR(
"Cannot apply ROI ratios [%f,%f,%f,%f] because resulting " 262 "dimension (depth=%dx%d rgb=%dx%d) cannot be divided exactly " 263 "by decimation parameter (%d). Ignoring ROI ratios...",
276 pcl::IndicesPtr indices(
new std::vector<int>);
291 const stereo_msgs::DisparityImageConstPtr& disparityMsg,
292 const sensor_msgs::CameraInfoConstPtr& cameraInfo)
297 NODELET_ERROR(
"Input type must be disparity=32FC1 or 16SC1");
304 disparity = cv::Mat(disparityMsg->image.height, disparityMsg->image.width, CV_32FC1, const_cast<uchar*>(disparityMsg->image.data.data()));
308 disparity = cv::Mat(disparityMsg->image.height, disparityMsg->image.width, CV_16SC1, const_cast<uchar*>(disparityMsg->image.data.data()));
317 pcl::PointCloud<pcl::PointXYZ>::Ptr pclCloud;
321 pcl::IndicesPtr indices(
new std::vector<int>);
323 cv::Mat(disparity, roi),
336 void processAndPublish(pcl::PointCloud<pcl::PointXYZ>::Ptr & pclCloud, pcl::IndicesPtr & indices,
const std_msgs::Header & header)
341 pclCloud->is_dense =
true;
347 if(pclCloud->is_dense)
355 pcl::PointCloud<pcl::PointXYZ>::Ptr tmp(
new pcl::PointCloud<pcl::PointXYZ>);
356 pcl::copyPointCloud(*pclCloud, *indices, *tmp);
360 sensor_msgs::PointCloud2 rosCloud;
361 if(!pclCloud->empty() && (pclCloud->is_dense || !indices->empty()) && (
normalK_ > 0 ||
normalRadius_ > 0.0
f))
365 pcl::PointCloud<pcl::PointNormal>::Ptr pclCloudNormal(
new pcl::PointCloud<pcl::PointNormal>);
366 pcl::concatenateFields(*pclCloud, *normals, *pclCloudNormal);
381 rosCloud.header.stamp = header.stamp;
382 rosCloud.header.frame_id = header.frame_id;
CvImageConstPtr toCvShare(const sensor_msgs::ImageConstPtr &source, const std::string &encoding=std::string())
std::vector< float > roiRatios_
pcl::PointCloud< pcl::PointXYZ >::Ptr RTABMAP_EXP cloudFromDisparity(const cv::Mat &imageDisparity, const StereoCameraModel &model, int decimation=1, float maxDepth=0.0f, float minDepth=0.0f, std::vector< int > *validIndices=0)
void callbackDisparity(const stereo_msgs::DisparityImageConstPtr &disparityMsg, const sensor_msgs::CameraInfoConstPtr &cameraInfo)
const cv::Size & imageSize() const
#define NODELET_ERROR(...)
message_filters::Synchronizer< MyExactSyncDepthPolicy > * exactSyncDepth_
ros::NodeHandle & getNodeHandle() const
double noiseFilterRadius_
pcl::PointCloud< pcl::PointXYZ >::Ptr RTABMAP_EXP removeNaNFromPointCloud(const pcl::PointCloud< pcl::PointXYZ >::Ptr &cloud)
image_transport::SubscriberFilter imageDepthSub_
message_filters::sync_policies::ApproximateTime< stereo_msgs::DisparityImage, sensor_msgs::CameraInfo > MyApproxSyncDisparityPolicy
message_filters::Synchronizer< MyApproxSyncDisparityPolicy > * approxSyncDisparity_
ros::NodeHandle & getPrivateNodeHandle() const
message_filters::Subscriber< sensor_msgs::CameraInfo > disparityCameraInfoSub_
message_filters::Synchronizer< MyExactSyncDisparityPolicy > * exactSyncDisparity_
pcl::PointCloud< pcl::PointXYZ >::Ptr RTABMAP_EXP cloudFromDepth(const cv::Mat &imageDepth, const CameraModel &model, int decimation=1, float maxDepth=0.0f, float minDepth=0.0f, std::vector< int > *validIndices=0)
#define UASSERT(condition)
message_filters::sync_policies::ExactTime< stereo_msgs::DisparityImage, sensor_msgs::CameraInfo > MyExactSyncDisparityPolicy
void processAndPublish(pcl::PointCloud< pcl::PointXYZ >::Ptr &pclCloud, pcl::IndicesPtr &indices, const std_msgs::Header &header)
std::list< std::string > uSplit(const std::string &str, char separator=' ')
bool param(const std::string ¶m_name, T ¶m_val, const T &default_val) const
void publish(const boost::shared_ptr< M > &message) const
message_filters::Subscriber< stereo_msgs::DisparityImage > disparitySub_
message_filters::Synchronizer< MyApproxSyncDepthPolicy > * approxSyncDepth_
const std::string TYPE_32FC1
rtabmap::CameraModel cameraModelFromROS(const sensor_msgs::CameraInfo &camInfo, const rtabmap::Transform &localTransform=rtabmap::Transform::getIdentity())
cv::Rect RTABMAP_EXP computeRoi(const cv::Mat &image, const std::string &roiRatios)
message_filters::Subscriber< sensor_msgs::CameraInfo > cameraInfoSub_
CameraModel roi(const cv::Rect &roi) const
const std::string TYPE_16UC1
cv::Mat RTABMAP_EXP computeNormals(const cv::Mat &laserScan, int searchK, float searchRadius)
std::string resolveName(const std::string &name, bool remap=true) const
Publisher advertise(const std::string &topic, uint32_t queue_size, bool latch=false)
bool hasParam(const std::string &key) const
void subscribe(ImageTransport &it, const std::string &base_topic, uint32_t queue_size, const TransportHints &transport_hints=TransportHints())
pcl::IndicesPtr RTABMAP_EXP radiusFiltering(const pcl::PointCloud< pcl::PointXYZ >::Ptr &cloud, float radiusSearch, int minNeighborsInRadius)
message_filters::sync_policies::ApproximateTime< sensor_msgs::Image, sensor_msgs::CameraInfo > MyApproxSyncDepthPolicy
#define NODELET_INFO(...)
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)
void callback(const sensor_msgs::ImageConstPtr &depthMsg, const sensor_msgs::CameraInfoConstPtr &cameraInfo)
void toROSMsg(const sensor_msgs::PointCloud2 &cloud, sensor_msgs::Image &image)
float uStr2Float(const std::string &str)
PLUGINLIB_EXPORT_CLASS(rtabmap_ros::CoreWrapper, nodelet::Nodelet)
pcl::PointCloud< pcl::PointNormal >::Ptr RTABMAP_EXP removeNaNNormalsFromPointCloud(const pcl::PointCloud< pcl::PointNormal >::Ptr &cloud)
uint32_t getNumSubscribers() const
int noiseFilterMinNeighbors_
pcl::PointCloud< pcl::PointXYZ >::Ptr RTABMAP_EXP voxelize(const pcl::PointCloud< pcl::PointXYZ >::Ptr &cloud, const pcl::IndicesPtr &indices, float voxelSize)
#define NODELET_DEBUG(...)
message_filters::sync_policies::ExactTime< sensor_msgs::Image, sensor_msgs::CameraInfo > MyExactSyncDepthPolicy
const std::string TYPE_16SC1