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 _sift_alg_h_ 00026 #define _sift_alg_h_ 00027 00028 #include <iri_sift/SiftConfig.h> 00029 #include "mutex.h" 00030 00031 //include sift_alg main library 00032 00033 // opencv 00034 #include <opencv2/imgproc/imgproc.hpp> 00035 #include <opencv2/features2d/features2d.hpp> 00036 // #include <opencv2/highgui/highgui.hpp> 00037 00038 #if ROS_VERSION_MINIMUM(1, 8, 0) 00039 #include <opencv2/nonfree/nonfree.hpp> 00040 #endif 00041 00042 // msgs 00043 #include <iri_perception_msgs/GeoVwSet.h> 00044 #include <iri_perception_msgs/Descriptor.h> 00045 #include <iri_perception_msgs/DescriptorSet.h> 00046 00052 class SiftAlgorithm 00053 { 00054 protected: 00061 CMutex alg_mutex_; 00062 00063 00064 // private attributes and methods 00065 00066 private: 00067 std::string descriptors_file_; 00068 00069 cv::Mat read_trained_descriptors(); 00070 00071 public: 00078 typedef iri_sift::SiftConfig Config; 00079 00086 Config config_; 00087 00096 SiftAlgorithm(void); 00097 00103 void lock(void) { alg_mutex_.enter(); }; 00104 00110 void unlock(void) { alg_mutex_.exit(); }; 00111 00119 bool try_enter(void) { return alg_mutex_.try_enter(); }; 00120 00132 void config_update(Config& new_cfg, uint32_t level=0); 00133 00134 // here define all sift_alg interface methods to retrieve and set 00135 // the driver parameters 00136 00143 ~SiftAlgorithm(void); 00144 00145 00146 // Descriptors 00147 iri_perception_msgs::DescriptorSet get_descriptors_from_image(cv::Mat &image); 00148 void get_sift_descriptors(cv::Mat const& image, cv::Mat& descriptors, std::vector<cv::KeyPoint>& keypoints); 00149 bool save_descriptors(cv::Mat descriptors); 00150 00151 // vws 00152 iri_perception_msgs::GeoVwSet get_geovw_from_image(cv::Mat& image); 00153 iri_perception_msgs::GeoVwSet get_geo_vw_from_descriptors(cv::Mat descriptors, std::vector<cv::KeyPoint> keypoints); 00154 00155 00156 00157 cv::Mat sift_centroids_; 00158 bool centroids_ready_; 00159 }; 00160 00161 #endif