hole_detection_alg.h
Go to the documentation of this file.
00001 // Copyright (C) 2010-2011 Institut de Robotica i Informatica Industrial, CSIC-UPC.
00002 // Author 
00003 // All rights reserved.
00004 //
00005 // This file is part of iri-ros-pkg
00006 // iri-ros-pkg is free software: you can redistribute it and/or modify
00007 // it under the terms of the GNU Lesser General Public License as published by
00008 // the Free Software Foundation, either version 3 of the License, or
00009 // at your option) any later version.
00010 //
00011 // This program is distributed in the hope that it will be useful,
00012 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00013 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00014 // GNU Lesser General Public License for more details.
00015 //
00016 // You should have received a copy of the GNU Lesser General Public License
00017 // along with this program.  If not, see <http://www.gnu.org/licenses/>.
00018 // 
00019 // IMPORTANT NOTE: This code has been generated through a script from the 
00020 // iri_ros_scripts. Please do NOT delete any comments to guarantee the correctness
00021 // of the scripts. ROS topics can be easly add by using those scripts. Please
00022 // refer to the IRI wiki page for more information:
00023 // http://wikiri.upc.es/index.php/Robotics_Lab
00024 
00025 #ifndef _hole_detection_alg_h_
00026 #define _hole_detection_alg_h_
00027 
00028 #include <iri_hole_detection/HoleDetectionConfig.h>
00029 #include "mutex.h"
00030 
00031 #include <pcl_ros/point_cloud.h>
00032 #include <pcl/ros/conversions.h>
00033 #include <pcl/point_types.h>
00034 #include <pcl/impl/point_types.hpp>
00035 
00036 
00037 using namespace pcl;
00038 using namespace std;
00039 //include hole_detection_alg main library
00040 
00046 class HoleDetectionAlgorithm
00047 {
00048   protected:
00055     CMutex alg_mutex_;
00056 
00057     // private attributes and methods
00058     int hole_min_p; 
00059     float box_y_end,box_z_ini,box_x,box_y_ini,box_z_end,Xl,Xc,Xr,Y;
00060     pcl::PointCloud<pcl::PointXYZRGB> cloud_in;
00061     pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_for;   
00062   public:
00069     typedef iri_hole_detection::HoleDetectionConfig Config;
00070 
00077     Config config_;
00078 
00087     HoleDetectionAlgorithm(void);
00088 
00094     void lock(void) { alg_mutex_.enter(); };
00095 
00101     void unlock(void) { alg_mutex_.exit(); };
00102 
00110     bool try_enter(void) { return alg_mutex_.try_enter(); };
00111 
00123     void config_update(Config& new_cfg, uint32_t level=0);
00124 
00125     // here define all hole_detection_alg interface methods to retrieve and set
00126     // the driver parameters
00127 
00134     ~HoleDetectionAlgorithm(void);
00135     
00136      void cloud_all(int hole_min_p, float box_y_end, float box_z_ini, 
00137                     float box_x, float box_y_ini, float box_z_end, 
00138                     float Xl, float Xc, float Xr, float Y, 
00139                     pcl::PointCloud<pcl::PointXYZRGB>& cloud_in, 
00140                     pcl::PointCloud<pcl::PointXYZ>::Ptr& cloud_out);    
00141        
00142 };
00143 
00144 #endif


iri_hole_detection
Author(s): asantamaria
autogenerated on Fri Dec 6 2013 20:21:38