bilateral_filter.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/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_BILATERAL_FILTER_H_
38 #define JSK_PCL_ROS_BILATERAL_FILTER_H_
39 
40 #include <pcl_ros/publisher.h>
43 #include <jsk_pcl_ros/BilateralFilterConfig.h>
44 #include <dynamic_reconfigure/server.h>
45 
46 namespace jsk_pcl_ros
47 {
49  // Copied from pcl/point_types_conversion.h
50  // in order to avoid pcl 1.7.1 bug.
51  // It should be solved on pcl 1.7.2.
53  inline void
54  PointXYZRGBtoXYZI (pcl::PointXYZRGB& in,
55  pcl::PointXYZI& out)
56  {
57  out.x = in.x; out.y = in.y; out.z = in.z;
58  out.intensity = 0.299f * static_cast <float> (in.r) + 0.587f * static_cast
59  <float> (in.g) + 0.114f * static_cast <float> (in.b);
60  }
61 
62  inline void
63  PointCloudXYZRGBtoXYZI (pcl::PointCloud<pcl::PointXYZRGB>& in,
64  pcl::PointCloud<pcl::PointXYZI>& out)
65  {
66  out.width = in.width;
67  out.height = in.height;
68  for (size_t i = 0; i < in.points.size (); i++)
69  {
70  pcl::PointXYZI p;
71  PointXYZRGBtoXYZI (in.points[i], p);
72  out.points.push_back (p);
73  }
74  }
75 
76 
78  {
79  public:
81  typedef pcl::PointXYZRGB PointT;
82  typedef BilateralFilterConfig Config;
83  protected:
85  // methods
87  virtual void onInit();
88 
89  virtual void filter(const sensor_msgs::PointCloud2::ConstPtr& msg);
90 
91  virtual void subscribe();
92  virtual void unsubscribe();
93 
94  virtual void configCallback(Config &config, uint32_t level);
95 
97  // ROS variables
103 
105  // parameters for bilateral filter
107  double sigma_s_;
108  double sigma_r_;
109 
110  private:
111 
112 
113  };
114 }
115 
116 
117 #endif
virtual void configCallback(Config &config, uint32_t level)
BilateralFilterConfig Config
boost::shared_ptr< BilateralFilter > Ptr
virtual void filter(const sensor_msgs::PointCloud2::ConstPtr &msg)
boost::shared_ptr< dynamic_reconfigure::Server< Config > > srv_
boost::mutex mutex
global mutex.
void PointCloudXYZRGBtoXYZI(pcl::PointCloud< pcl::PointXYZRGB > &in, pcl::PointCloud< pcl::PointXYZI > &out)
p
void PointXYZRGBtoXYZI(pcl::PointXYZRGB &in, pcl::PointXYZI &out)


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