Fawkes API  Fawkes Development Version
simple.h
1 
2 /***************************************************************************
3  * simple.h - Header for ReallySimpleClassifier
4  *
5  * Created: Wed May 18 11:39:10 2005
6  * Copyright 2005-2007 Tim Niemueller [www.niemueller.de]
7  *
8  ****************************************************************************/
9 
10 /* This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version. A runtime exception applies to
14  * this software (see LICENSE.GPL_WRE file mentioned below for details).
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19  * GNU Library General Public License for more details.
20  *
21  * Read the full text in the LICENSE.GPL_WRE file in the doc directory.
22  */
23 
24 #ifndef __FIREVISION_CLASSIFIERS_SIMPLE_H_
25 #define __FIREVISION_CLASSIFIERS_SIMPLE_H_
26 
27 #include <fvclassifiers/classifier.h>
28 #include <fvutils/base/types.h>
29 
30 namespace firevision {
31 #if 0 /* just to make Emacs auto-indent happy */
32 }
33 #endif
34 
35 class ScanlineModel;
36 class ColorModel;
37 
39 {
40  public:
41  SimpleColorClassifier(ScanlineModel *scanline_model,
42  ColorModel *color_model,
43  unsigned int min_num_points=6,
44  unsigned int box_extent = 50,
45  bool upward = false,
46  unsigned int neighbourhood_min_match = 8,
47  unsigned int grow_by = 10,
48  color_t color = C_ORANGE);
49 
50  virtual std::list< ROI > * classify();
51 
52  virtual void get_mass_point_of_color(ROI *roi, fawkes::upoint_t *massPoint);
53  private:
54  unsigned int consider_neighbourhood(unsigned int x, unsigned int y, color_t what);
55 
56  unsigned int neighbourhood_min_match;
57  unsigned int grow_by;
58 
59  bool modified;
60  unsigned int min_num_points;
61  unsigned int box_extent;
62 
63  bool upward;
64 
65  ScanlineModel *scanline_model;
66  ColorModel *color_model;
67 
68  const color_t color;
69 };
70 
71 } // end namespace firevision
72 
73 #endif
Color model interface.
Definition: colormodel.h:34
virtual void get_mass_point_of_color(ROI *roi, fawkes::upoint_t *massPoint)
Get mass point of primary color.
Definition: simple.cpp:288
Scanline model interface.
Definition: scanlinemodel.h:55
Region of interest.
Definition: roi.h:58
SimpleColorClassifier(ScanlineModel *scanline_model, ColorModel *color_model, unsigned int min_num_points=6, unsigned int box_extent=50, bool upward=false, unsigned int neighbourhood_min_match=8, unsigned int grow_by=10, color_t color=C_ORANGE)
Constructor.
Definition: simple.cpp:58
virtual std::list< ROI > * classify()
Classify image.
Definition: simple.cpp:135
Simple classifier.
Definition: simple.h:38
Point with cartesian coordinates as unsigned integers.
Definition: types.h:34
Classifier to extract regions of interest.
Definition: classifier.h:37