Fawkes API  Fawkes Development Version
multi_color.h
1 
2 /***************************************************************************
3  * multi-color.h - Header for multi color classifier
4  *
5  * Created: Sat Apr 02 09:51:27 2011
6  * Copyright 2005-2011 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_MULTI_COLOR_H_
25 #define __FIREVISION_CLASSIFIERS_MULTI_COLOR_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  MultiColorClassifier(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 
49  virtual std::list< ROI > * classify();
50 
51  virtual void get_mass_point_of_color(ROI *roi, fawkes::upoint_t *massPoint);
52  private:
53  unsigned int consider_neighbourhood(unsigned int x, unsigned int y, color_t what);
54 
55  unsigned int neighbourhood_min_match;
56  unsigned int grow_by;
57 
58  bool modified;
59  unsigned int min_num_points;
60  unsigned int box_extent;
61 
62  bool upward;
63 
64  ScanlineModel *scanline_model;
65  ColorModel *color_model;
66 };
67 
68 } // end namespace firevision
69 
70 #endif
Color model interface.
Definition: colormodel.h:34
Scanline model interface.
Definition: scanlinemodel.h:55
Simple multi-color classifier.
Definition: multi_color.h:38
MultiColorClassifier(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)
Constructor.
Definition: multi_color.cpp:58
Region of interest.
Definition: roi.h:58
virtual std::list< ROI > * classify()
Classify image.
virtual void get_mass_point_of_color(ROI *roi, fawkes::upoint_t *massPoint)
Get mass point of primary color.
Point with cartesian coordinates as unsigned integers.
Definition: types.h:34
Classifier to extract regions of interest.
Definition: classifier.h:37