region_adjacency_graph.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/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 #ifndef _REGION_ADJACENCY_GRAPH_H_
37 #define _REGION_ADJACENCY_GRAPH_H_
38 
39 // ROS header directives
40 #include <ros/ros.h>
41 #include <ros/console.h>
42 
43 // OpenCV header directives
44 #include <opencv2/imgproc/imgproc.hpp>
45 
46 // PCL header directives
47 #include <pcl/point_cloud.h>
48 #include <pcl/features/vfh.h>
49 
50 // boost header directives
51 #include <boost/graph/adjacency_list.hpp>
52 #include <boost/tuple/tuple.hpp>
53 #include <boost/config.hpp>
54 
55 #include <string>
56 #include <map>
57 
58 namespace jsk_pcl_ros
59 {
60  class RegionAdjacencyGraph
61  {
62  private:
63  struct VertexProperty {
64  int v_index;
65  pcl::PointXYZ v_center;
66  int v_label;
68  int i = -1,
69  pcl::PointXYZ center = pcl::PointXYZ(-1, -1, -1),
70  int label = -1) :
71  v_index(i), v_center(center), v_label(label) {}
72  };
73  typedef boost::property<boost::edge_weight_t, float> EdgeProperty;
74  typedef typename boost::adjacency_list<boost::vecS,
75  boost::vecS,
76  boost::undirectedS,
77  VertexProperty,
79  typedef typename boost::graph_traits<
80  Graph>::adjacency_iterator AdjacencyIterator;
81  typedef typename boost::property_map<
82  Graph, boost::vertex_index_t>::type IndexMap;
83  typedef typename boost::graph_traits<
84  Graph>::edge_descriptor EdgeDescriptor;
85  typedef typename boost::property_map<
86  Graph, boost::edge_weight_t>::type EdgePropertyAccess;
87  typedef typename boost::property_traits<boost::property_map<
88  Graph, boost::edge_weight_t>::const_type>::value_type EdgeValue;
89  typedef typename boost::graph_traits<
90  Graph>::vertex_iterator VertexIterator;
91  typedef typename boost::graph_traits<
92  Graph>::vertex_descriptor VertexDescriptor;
93  typedef pcl::PointXYZRGB PointT;
94  Graph graph_;
95 
97  pcl::PointCloud<PointT>::Ptr,
98  pcl::PointCloud<pcl::Normal>::Ptr,
99  std::vector<Eigen::Vector3f> &,
100  std::vector<Eigen::Vector3f> &,
101  int = 3);
102  template<typename T>
104  const Eigen::Vector3f &,
105  const Eigen::Vector3f &,
106  const Eigen::Vector3f &,
107  const Eigen::Vector3f &);
108  template<typename T>
110  const std::vector<std::vector<Eigen::Vector3f> > &,
111  const std::vector<std::vector<Eigen::Vector3f> > &);
112  float getVectorAngle(
113  const Eigen::Vector3f &,
114  const Eigen::Vector3f &,
115  bool = true);
116  int getCommonNeigbour(
117  const std::vector<int> &,
118  const std::vector<int> &);
120  const pcl::PointCloud<PointT>::Ptr,
121  const pcl::PointCloud<pcl::Normal>::Ptr,
122  cv::Mat &);
123 
124  public:
126  virtual void generateRAG(
127  const std::vector<pcl::PointCloud<PointT>::Ptr> &,
128  const std::vector<pcl::PointCloud<pcl::Normal>::Ptr> &,
129  const pcl::PointCloud<pcl::PointXYZ>::Ptr,
130  std::vector<std::vector<int> > &,
131  const int = RAG_EDGE_WEIGHT_DISTANCE);
132  virtual void splitMergeRAG(const int = 0.0f);
133  virtual void getCloudClusterLabels(
134  std::vector<int> &);
135  virtual void printGraph(
136  const Graph &);
137  enum {
140  };
141  };
142 } // namespace jsk_pcl_ros
143 #endif // _REGION_ADJACENCY_GRAPH_H_
jsk_pcl_ros::RegionAdjacencyGraph::RAG_EDGE_WEIGHT_CONVEX_CRITERIA
@ RAG_EDGE_WEIGHT_CONVEX_CRITERIA
Definition: region_adjacency_graph.h:203
jsk_pcl_ros::RegionAdjacencyGraph::EdgeProperty
boost::property< boost::edge_weight_t, float > EdgeProperty
Definition: region_adjacency_graph.h:137
jsk_pcl_ros::RegionAdjacencyGraph::EdgeDescriptor
boost::graph_traits< Graph >::edge_descriptor EdgeDescriptor
Definition: region_adjacency_graph.h:148
i
int i
ros.h
jsk_pcl_ros::RegionAdjacencyGraph::IndexMap
boost::property_map< Graph, boost::vertex_index_t >::type IndexMap
Definition: region_adjacency_graph.h:146
jsk_pcl_ros::RegionAdjacencyGraph::RAG_EDGE_WEIGHT_DISTANCE
@ RAG_EDGE_WEIGHT_DISTANCE
Definition: region_adjacency_graph.h:202
jsk_pcl_ros::RegionAdjacencyGraph::sampleRandomPointsFromCloudCluster
void sampleRandomPointsFromCloudCluster(pcl::PointCloud< PointT >::Ptr, pcl::PointCloud< pcl::Normal >::Ptr, std::vector< Eigen::Vector3f > &, std::vector< Eigen::Vector3f > &, int=3)
Definition: region_adjacency_graph.cpp:278
jsk_pcl_ros::RegionAdjacencyGraph::VertexIterator
boost::graph_traits< Graph >::vertex_iterator VertexIterator
Definition: region_adjacency_graph.h:154
T
pointer T
jsk_pcl_ros::RegionAdjacencyGraph::convexityCriterion
T convexityCriterion(const Eigen::Vector3f &, const Eigen::Vector3f &, const Eigen::Vector3f &, const Eigen::Vector3f &)
Definition: region_adjacency_graph.cpp:265
jsk_pcl_ros::RegionAdjacencyGraph::AdjacencyIterator
boost::graph_traits< Graph >::adjacency_iterator AdjacencyIterator
Definition: region_adjacency_graph.h:144
jsk_pcl_ros::RegionAdjacencyGraph::VertexProperty::v_label
int v_label
Definition: region_adjacency_graph.h:162
jsk_pcl_ros::RegionAdjacencyGraph::getCloudClusterWeightFunction
T getCloudClusterWeightFunction(const std::vector< std::vector< Eigen::Vector3f > > &, const std::vector< std::vector< Eigen::Vector3f > > &)
Definition: region_adjacency_graph.cpp:200
jsk_pcl_ros::RegionAdjacencyGraph::computeCloudClusterRPYHistogram
void computeCloudClusterRPYHistogram(const pcl::PointCloud< PointT >::Ptr, const pcl::PointCloud< pcl::Normal >::Ptr, cv::Mat &)
Definition: region_adjacency_graph.cpp:379
jsk_pcl_ros::RegionAdjacencyGraph::RegionAdjacencyGraph
RegionAdjacencyGraph()
Definition: region_adjacency_graph.cpp:77
console.h
jsk_pcl_ros::RegionAdjacencyGraph::getCloudClusterLabels
virtual void getCloudClusterLabels(std::vector< int > &)
Definition: region_adjacency_graph.cpp:358
jsk_pcl_ros::RegionAdjacencyGraph::graph_
Graph graph_
Definition: region_adjacency_graph.h:158
jsk_pcl_ros
Definition: add_color_from_image.h:51
jsk_pcl_ros::RegionAdjacencyGraph::VertexDescriptor
boost::graph_traits< Graph >::vertex_descriptor VertexDescriptor
Definition: region_adjacency_graph.h:156
jsk_pcl_ros::RegionAdjacencyGraph::VertexProperty::v_center
pcl::PointXYZ v_center
Definition: region_adjacency_graph.h:161
jsk_pcl_ros::RegionAdjacencyGraph::VertexProperty::VertexProperty
VertexProperty(int i=-1, pcl::PointXYZ center=pcl::PointXYZ(-1, -1, -1), int label=-1)
Definition: region_adjacency_graph.h:163
jsk_pcl_ros::RegionAdjacencyGraph::PointT
pcl::PointXYZRGB PointT
Definition: region_adjacency_graph.h:157
jsk_pcl_ros::RegionAdjacencyGraph::getVectorAngle
float getVectorAngle(const Eigen::Vector3f &, const Eigen::Vector3f &, bool=true)
Definition: region_adjacency_graph.cpp:251
jsk_pcl_ros::RegionAdjacencyGraph::getCommonNeigbour
int getCommonNeigbour(const std::vector< int > &, const std::vector< int > &)
Definition: region_adjacency_graph.cpp:340
dump_depth_error.f
f
Definition: dump_depth_error.py:39
jsk_pcl_ros::RegionAdjacencyGraph::VertexProperty::v_index
int v_index
Definition: region_adjacency_graph.h:160
jsk_pcl_ros::RegionAdjacencyGraph::Graph
boost::adjacency_list< boost::vecS, boost::vecS, boost::undirectedS, VertexProperty, EdgeProperty > Graph
Definition: region_adjacency_graph.h:142
plot_depth_error.label
label
Definition: plot_depth_error.py:37
jsk_pcl_ros::RegionAdjacencyGraph::EdgeValue
boost::property_traits< boost::property_map< Graph, boost::edge_weight_t >::const_type >::value_type EdgeValue
Definition: region_adjacency_graph.h:152
jsk_pcl_ros::RegionAdjacencyGraph::generateRAG
virtual void generateRAG(const std::vector< pcl::PointCloud< PointT >::Ptr > &, const std::vector< pcl::PointCloud< pcl::Normal >::Ptr > &, const pcl::PointCloud< pcl::PointXYZ >::Ptr, std::vector< std::vector< int > > &, const int=RAG_EDGE_WEIGHT_DISTANCE)
Definition: region_adjacency_graph.cpp:82
jsk_pcl_ros::RegionAdjacencyGraph::EdgePropertyAccess
boost::property_map< Graph, boost::edge_weight_t >::type EdgePropertyAccess
Definition: region_adjacency_graph.h:150
jsk_pcl_ros::RegionAdjacencyGraph::splitMergeRAG
virtual void splitMergeRAG(const int=0.0f)
Definition: region_adjacency_graph.cpp:297
jsk_pcl_ros::RegionAdjacencyGraph::printGraph
virtual void printGraph(const Graph &)
Definition: region_adjacency_graph.cpp:368


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