00001 /* 00002 00003 This file is part of the FAST-ER machine learning system. 00004 Copyright (C) 2008 Edward Rosten and Los Alamos National Laboratory 00005 00006 This program is free software; you can redistribute it and/or modify 00007 it under the terms of the GNU General Public License as published by 00008 the Free Software Foundation; either version 2 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 General Public License for more details. 00015 00016 You should have received a copy of the GNU General Public License along 00017 with this program; if not, write to the Free Software Foundation, Inc., 00018 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. 00019 */ 00020 #ifndef DETECTORS_H 00021 #define DETECTORS_H 00022 00023 #include <cvd/image.h> 00024 #include <cvd/byte.h> 00025 #include <vector> 00026 #include <memory> 00027 #include <string> 00028 00029 ///A corner detector object which is passed a target number of corners to detect. 00030 ///@ingroup gDetect 00031 struct DetectN 00032 { 00033 ///Detect corners 00034 ///@param i Image in which to detect corners 00035 ///@param c Detected corners are inserted in to this container 00036 ///@param N Number of corners to detect 00037 virtual void operator()(const CVD::Image<CVD::byte>& i, std::vector<CVD::ImageRef>& c, unsigned int N)const =0; 00038 ///Destroy to object 00039 virtual ~DetectN(){} 00040 }; 00041 00042 ///A corner detector object which is passed a threshold. These can be wrapped with a 00043 ///searching algorithm to turn them in to a ::DetectN, specifically ::SearchThreshold 00044 ///@ingroup gDetect 00045 struct DetectT 00046 { 00047 ///Detect corners 00048 ///@param i Image in which to detect corners 00049 ///@param c Detected corners are inserted in to this container 00050 ///@param N Threshold used to detect corners 00051 virtual void operator()(const CVD::Image<CVD::byte>& i, std::vector<CVD::ImageRef>& c, unsigned int N)const =0; 00052 ///Destroy to object 00053 virtual ~DetectT(){} 00054 }; 00055 00056 ///Get a corner detector. The detector is read from the GVars3 database 00057 ///as the <code>detector</code> variable. 00058 std::auto_ptr<DetectN> get_detector(); 00059 00060 #endif