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 DOG_H 00021 #define DOG_H 00022 00023 #include <cvd/image.h> 00024 #include <cvd/byte.h> 00025 #include <vector> 00026 #include <utility> 00027 00028 #include "detectors.h" 00029 00030 ///Class wrapping the Difference of Gaussians detector. 00031 ///@ingroup gDetect 00032 struct dog: public DetectN 00033 { 00034 ///Detect corners 00035 ///@param i Image in which to detect corners 00036 ///@param c Detected corners are inserted in to this container 00037 ///@param N Number of corners to detect 00038 virtual void operator()(const CVD::Image<CVD::byte>& i, std::vector<CVD::ImageRef>& c, unsigned int N) const; 00039 }; 00040 00041 ///Class wrapping the Harris-Laplace detector. 00042 ///@ingroup gDetect 00043 struct harrisdog: public DetectN 00044 { 00045 ///Detecto corners 00046 ///@param i Image in which to detect corners 00047 ///@param c Detected corners are inserted in to this container 00048 ///@param N Number of corners to detect 00049 virtual void operator()(const CVD::Image<CVD::byte>& i, std::vector<CVD::ImageRef>& c, unsigned int N) const; 00050 }; 00051 00052 #endif