Image Component Library (ICL)
WienerOp.h
Go to the documentation of this file.
1 /********************************************************************
2 ** Image Component Library (ICL) **
3 ** **
4 ** Copyright (C) 2006-2013 CITEC, University of Bielefeld **
5 ** Neuroinformatics Group **
6 ** Website: www.iclcv.org and **
7 ** http://opensource.cit-ec.de/projects/icl **
8 ** **
9 ** File : ICLFilter/src/ICLFilter/WienerOp.h **
10 ** Module : ICLFilter **
11 ** Authors: Christof Elbrechter, Robert Haschke, Andre Justus **
12 ** **
13 ** **
14 ** GNU LESSER GENERAL PUBLIC LICENSE **
15 ** This file may be used under the terms of the GNU Lesser General **
16 ** Public License version 3.0 as published by the **
17 ** **
18 ** Free Software Foundation and appearing in the file LICENSE.LGPL **
19 ** included in the packaging of this file. Please review the **
20 ** following information to ensure the license requirements will **
21 ** be met: http://www.gnu.org/licenses/lgpl-3.0.txt **
22 ** **
23 ** The development of this software was supported by the **
24 ** Excellence Cluster EXC 277 Cognitive Interaction Technology. **
25 ** The Excellence Cluster EXC 277 is a grant of the Deutsche **
26 ** Forschungsgemeinschaft (DFG) in the context of the German **
27 ** Excellence Initiative. **
28 ** **
29 ********************************************************************/
30 
31 #pragma once
32 
34 #include <vector>
35 
36 namespace icl {
37  namespace filter{
39 
54  class WienerOp : public NeighborhoodOp {
55  public:
56 
58 
62  WienerOp (const utils::Size &maskSize, icl32f noise=0): NeighborhoodOp(maskSize),m_fNoise(noise){}
63 
65 
68  ICLFilter_API void apply (const core::ImgBase *poSrc, core::ImgBase **ppoDst);
69 
72 
74 
75  icl32f getNoise() const { return m_fNoise; }
76 
78 
79  void setNoise(icl32f noise) { m_fNoise = noise; }
80 
81  private:
83  std::vector<icl8u> m_vecBuffer;
84 
87  };
88  } // namespace filter
89 } // namespace icl
90 
undocument this line if you encounter any issues!
Definition: Any.h:37
icl32f getNoise() const
returns the current noise factor
Definition: WienerOp.h:75
std::vector< icl8u > m_vecBuffer
internal buffer for applying the wiener operation
Definition: WienerOp.h:83
icl32f m_fNoise
internal storage for the current noise factor
Definition: WienerOp.h:86
Ipp32f icl32f
32Bit floating point type for the ICL
Definition: BasicTypes.h:55
Size class of the ICL.
Definition: Size.h:61
void setNoise(icl32f noise)
sets up a new noise factor
Definition: WienerOp.h:79
ICLQt_API core::Img< T > filter(const core::Img< T > &image, const std::string &filter)
applies a filter operation on the source image (affinity for float)
unary operators that work on each pixels neighborhood \
Definition: NeighborhoodOp.h:59
Class for Wiener Filter .
Definition: WienerOp.h:54
ICLFilter_API void apply(const core::ImgBase *poSrc, core::ImgBase **ppoDst)
Filters an image using the Wiener algorithm.
WienerOp(const utils::Size &maskSize, icl32f noise=0)
Constructor that creates a wiener filter object, with specified mask size.
Definition: WienerOp.h:62
#define ICLFilter_API
Definition: CompatMacros.h:175
virtual void apply(const core::ImgBase *operand1, core::ImgBase **dst)=0
pure virtual apply function, that must be implemented in all derived classes
ImgBase is the Image-Interface class that provides save access to underlying Img-template .
Definition: ImgBase.h:131