region_growing_multiple_plane_segmentation.h
Go to the documentation of this file.
1 // -*- mode: c++ -*-
2 /*********************************************************************
3  * Software License Agreement (BSD License)
4  *
5  * Copyright (c) 2014, 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/or 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_REGION_GROWING_MULTIPLE_PLANE_SEGMENTATION_H_
38 #define JSK_PCL_ROS_REGION_GROWING_MULTIPLE_PLANE_SEGMENTATION_H_
39 
40 #include <dynamic_reconfigure/server.h>
41 #include "jsk_pcl_ros/RegionGrowingMultiplePlaneSegmentationConfig.h"
46 #include <jsk_topic_tools/diagnostic_nodelet.h>
48 #include "jsk_recognition_msgs/PolygonArray.h"
49 #include "jsk_recognition_msgs/ClusterPointIndices.h"
50 #include "jsk_recognition_msgs/ModelCoefficientsArray.h"
52 #include <std_msgs/Float32.h>
53 
54 namespace jsk_pcl_ros
55 {
56  class RegionGrowingMultiplePlaneSegmentation:
57  public jsk_topic_tools::DiagnosticNodelet
58  {
59  public:
60  typedef pcl::PointXYZRGB PointT;
61  typedef RegionGrowingMultiplePlaneSegmentationConfig
62  Config;
64  sensor_msgs::PointCloud2,
65  sensor_msgs::PointCloud2 > NormalSyncPolicy;
67  : DiagnosticNodelet("RegionGrowingMultiplePlaneSegmentation"),
68  timer_(10),
69  done_initialization_(false) {}
71  protected:
73  // methods
75  virtual void onInit();
76  virtual void subscribe();
77  virtual void unsubscribe();
78  virtual void segment(
79  const sensor_msgs::PointCloud2::ConstPtr& msg,
80  const sensor_msgs::PointCloud2::ConstPtr& normal_msg);
81  virtual void configCallback (Config &config, uint32_t level);
83  // static methods
85  // static method
87  const double angular_threshold,
88  const double distance_threshold)
89  {
90  global_angular_threshold = angular_threshold;
91  global_distance_threshold = distance_threshold;
92  }
93  virtual void ransacEstimation(
94  const pcl::PointCloud<pcl::PointXYZRGB>::Ptr &cloud,
95  const pcl::PointIndices::Ptr& indices,
96  pcl::PointIndices& inliers,
97  pcl::ModelCoefficients& coefficient);
98 
99  static bool regionGrowingFunction(const pcl::PointXYZRGBNormal& a,
100  const pcl::PointXYZRGBNormal& b,
101  float distance)
102  {
103  if (distance > global_distance_threshold) {
104  return false;
105  }
106  else {
107  Eigen::Vector3f a_normal(a.normal_x, a.normal_y, a.normal_z);
108  Eigen::Vector3f b_normal(b.normal_x, b.normal_y, b.normal_z);
109  double dot = std::abs(a_normal.dot(b_normal));
110  double angle;
111  if (dot > 1.0) {
112  angle = acos(1.0);
113  }
114  else if (dot < -1.0) {
115  angle = acos(-1.0);
116  }
117  else {
118  angle = acos(dot);
119  }
120  //ROS_INFO("angle: %f", angle);
121  if (angle > global_angular_threshold) {
122  return false;
123  }
124  else {
125  return true;
126  }
127  }
128  }
129 
131  // ROS variables
147  // Parameters
149  double angular_threshold_;
151  double max_curvature_;
152  int min_size_;
153  int max_size_;
154  double min_area_;
155  double max_area_;
156  double cluster_tolerance_;
161  // static parameters
164  static double global_distance_threshold;
166  private:
167 
168  };
169 }
170 
171 #endif
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::timer_
jsk_recognition_utils::WallDurationTimer timer_
Definition: region_growing_multiple_plane_segmentation.h:209
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::angular_threshold_
double angular_threshold_
Definition: region_growing_multiple_plane_segmentation.h:213
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::RegionGrowingMultiplePlaneSegmentation
RegionGrowingMultiplePlaneSegmentation()
Definition: region_growing_multiple_plane_segmentation.h:130
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::NormalSyncPolicy
message_filters::sync_policies::ExactTime< sensor_msgs::PointCloud2, sensor_msgs::PointCloud2 > NormalSyncPolicy
Definition: region_growing_multiple_plane_segmentation.h:129
ros::Publisher
message_filters::Synchronizer
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::onInit
virtual void onInit()
Definition: region_growing_multiple_plane_segmentation_nodelet.cpp:79
boost::shared_ptr
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::subscribe
virtual void subscribe()
Definition: region_growing_multiple_plane_segmentation_nodelet.cpp:116
angle
GLfloat angle
geo_util.h
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::setCondifionFunctionParameter
static void setCondifionFunctionParameter(const double angular_threshold, const double distance_threshold)
Definition: region_growing_multiple_plane_segmentation.h:150
time_synchronizer.h
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::pub_average_time_
ros::Publisher pub_average_time_
Definition: region_growing_multiple_plane_segmentation.h:207
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::cluster_tolerance_
double cluster_tolerance_
Definition: region_growing_multiple_plane_segmentation.h:220
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::sub_input_
message_filters::Subscriber< sensor_msgs::PointCloud2 > sub_input_
Definition: region_growing_multiple_plane_segmentation.h:197
jsk_recognition_utils::WallDurationTimer
message_filters::Subscriber< sensor_msgs::PointCloud2 >
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::global_angular_threshold
static double global_angular_threshold
Definition: region_growing_multiple_plane_segmentation.h:227
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::mutex_
boost::mutex mutex_
Definition: region_growing_multiple_plane_segmentation.h:208
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::segment
virtual void segment(const sensor_msgs::PointCloud2::ConstPtr &msg, const sensor_msgs::PointCloud2::ConstPtr &normal_msg)
Definition: region_growing_multiple_plane_segmentation_nodelet.cpp:170
jsk_pcl_ros
Definition: add_color_from_image.h:51
subscriber.h
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::pub_inliers_
ros::Publisher pub_inliers_
Definition: region_growing_multiple_plane_segmentation.h:203
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::max_area_
double max_area_
Definition: region_growing_multiple_plane_segmentation.h:219
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::min_size_
int min_size_
Definition: region_growing_multiple_plane_segmentation.h:216
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::configCallback
virtual void configCallback(Config &config, uint32_t level)
Definition: region_growing_multiple_plane_segmentation_nodelet.cpp:135
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::ransac_refine_outlier_distance_threshold_
double ransac_refine_outlier_distance_threshold_
Definition: region_growing_multiple_plane_segmentation.h:221
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::regionGrowingFunction
static bool regionGrowingFunction(const pcl::PointXYZRGBNormal &a, const pcl::PointXYZRGBNormal &b, float distance)
Definition: region_growing_multiple_plane_segmentation.h:163
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::ransacEstimation
virtual void ransacEstimation(const pcl::PointCloud< pcl::PointXYZRGB >::Ptr &cloud, const pcl::PointIndices::Ptr &indices, pcl::PointIndices &inliers, pcl::ModelCoefficients &coefficient)
Definition: region_growing_multiple_plane_segmentation_nodelet.cpp:153
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::pub_polygons_
ros::Publisher pub_polygons_
Definition: region_growing_multiple_plane_segmentation.h:202
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::sub_normal_
message_filters::Subscriber< sensor_msgs::PointCloud2 > sub_normal_
Definition: region_growing_multiple_plane_segmentation.h:198
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::PointT
pcl::PointXYZRGB PointT
Definition: region_growing_multiple_plane_segmentation.h:124
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::done_initialization_
bool done_initialization_
Definition: region_growing_multiple_plane_segmentation.h:223
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::pub_coefficients_
ros::Publisher pub_coefficients_
Definition: region_growing_multiple_plane_segmentation.h:204
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::pub_latest_time_
ros::Publisher pub_latest_time_
Definition: region_growing_multiple_plane_segmentation.h:206
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::unsubscribe
virtual void unsubscribe()
Definition: region_growing_multiple_plane_segmentation_nodelet.cpp:129
dot
T dot(T *pf1, T *pf2, int length)
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::max_size_
int max_size_
Definition: region_growing_multiple_plane_segmentation.h:217
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::min_area_
double min_area_
Definition: region_growing_multiple_plane_segmentation.h:218
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::Config
RegionGrowingMultiplePlaneSegmentationConfig Config
Definition: region_growing_multiple_plane_segmentation.h:126
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::srv_
boost::shared_ptr< dynamic_reconfigure::Server< Config > > srv_
Definition: region_growing_multiple_plane_segmentation.h:201
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::~RegionGrowingMultiplePlaneSegmentation
virtual ~RegionGrowingMultiplePlaneSegmentation()
Definition: region_growing_multiple_plane_segmentation_nodelet.cpp:105
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::max_curvature_
double max_curvature_
Definition: region_growing_multiple_plane_segmentation.h:215
synchronizer.h
approximate_time.h
mutex
boost::mutex mutex
global mutex.
Definition: depth_camera_error_visualization.cpp:86
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::distance_threshold_
double distance_threshold_
Definition: region_growing_multiple_plane_segmentation.h:214
message_filters::sync_policies::ExactTime
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::global_distance_threshold
static double global_distance_threshold
Definition: region_growing_multiple_plane_segmentation.h:228
time_util.h
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::sync_
boost::shared_ptr< message_filters::Synchronizer< NormalSyncPolicy > > sync_
Definition: region_growing_multiple_plane_segmentation.h:200
a
char a[26]
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::global_custom_condigion_function_mutex
static boost::mutex global_custom_condigion_function_mutex
Definition: region_growing_multiple_plane_segmentation.h:229
pose_with_covariance_sample.msg
msg
Definition: pose_with_covariance_sample.py:22
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::pub_clustering_result_
ros::Publisher pub_clustering_result_
Definition: region_growing_multiple_plane_segmentation.h:205
jsk_pcl_ros::RegionGrowingMultiplePlaneSegmentation::ransac_refine_max_iterations_
int ransac_refine_max_iterations_
Definition: region_growing_multiple_plane_segmentation.h:222


jsk_pcl_ros
Author(s): Yohei Kakiuchi
autogenerated on Tue Jan 7 2025 04:05:45