Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members | Related Pages

StandardDeviationImage.H

Go to the documentation of this file.
00001 /*---------------------------------------------------------------------+
00002  | Library QgarLib, graphics analysis and recognition                  |
00003  | Copyright (C) 2002  Qgar Project, LORIA                             |
00004  |                                                                     |
00005  | This library is free software; you can redistribute it and/or       |
00006  | modify it under the terms of the GNU Lesser General Public          |
00007  | License version 2.1, as published by the Free Software Foundation.  |
00008  |                                                                     |
00009  | This library is distributed in the hope that it will be useful,     |
00010  | but WITHOUT ANY WARRANTY; without even the implied warranty of      |
00011  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.                |
00012  | See the GNU Lesser General Public License for more details.         |
00013  |                                                                     |
00014  | The GNU Lesser General Public License is included in the file       |
00015  | LICENSE.LGPL, in the root directory of the Qgar packaging. See      |
00016  | http://www.gnu.org/licenses/lgpl.html for the terms of the licence. |
00017  | To receive a paper copy, write to the Free Software Foundation,     |
00018  | Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.       |
00019  |                                                                     |
00020  | Contact Project Qgar for any information:                           |
00021  |   LORIA - équipe Qgar                                               |
00022  |   B.P. 239, 54506 Vandoeuvre-lès-Nancy Cedex, France                |
00023  |   email: qgar-contact@loria.fr                                      |
00024  |   http://www.qgar.org/                                              |
00025  *---------------------------------------------------------------------*/
00026 
00027 
00028 #ifndef __STANDARDDEVIATIONIMAGE_H_INCLUDED__
00029 #define __STANDARDDEVIATIONIMAGE_H_INCLUDED__
00030 
00031 
00032 /**
00033  * @file     StandardDeviationImage.H
00034  * @brief    Header file of class qgar::StandardDeviationImage.
00035  *
00036  * @author   <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Karl Tombre">Karl Tombre</a>
00037  * @date     July 3, 2001  15:38
00038  * @since    Qgar 1.0
00039  */
00040 
00041 
00042 // For RCS/CVS use: Do not delete
00043 /* $Id: StandardDeviationImage.H,v 1.13 2005/10/14 17:05:48 masini Exp $ */
00044 
00045 
00046 
00047 // QGAR
00048 #include <qgarlib/GenImage.H>
00049 #include <qgarlib/QgarErrorInvalidArg.H>
00050 
00051 
00052 
00053 namespace qgar
00054 {
00055 
00056 /**
00057  * @ingroup IMGPROC_CONVOL
00058  *
00059  * @class StandardDeviationImage StandardDeviationImage.H "qgarlib/StandardDeviationImage.H"
00060  *
00061  * @brief Image of standard deviation.
00062  *
00063  * Each pixel is the standard deviation computed from the given image
00064  * and the mean image. The mean is computed over a neighbourhood
00065  * as a byproduct of the given image.
00066  *
00067  * @author   <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Karl Tombre">Karl Tombre</a>
00068  * @date     July 3, 2001  15:38
00069  * @since    Qgar 1.0
00070 */
00071 class StandardDeviationImage
00072 
00073   : public FloatImage
00074 
00075 {
00076 // -------------------------------------------------------------------
00077 // T Y P E   D E F I N I T I O N S
00078 // -------------------------------------------------------------------
00079 public:
00080 
00081   /** @name Types */
00082   //        =====
00083   //@{
00084 
00085   /**
00086    * @brief Type of the elements stored in the pixmap.
00087    */
00088   typedef FloatImage::value_type value_type;
00089 
00090   /**
00091    * @brief Reference to qgar::GenImage::value_type.
00092    */
00093   typedef value_type& reference;
00094 
00095   /**
00096    * @brief Constant reference to qgar::GenImage::value_type.
00097    */
00098   typedef const value_type& const_reference;
00099 
00100   /**
00101    * @brief Pointer to qgar::GenImage::value_type.
00102    */
00103   typedef value_type* pointer;
00104 
00105   /**
00106    * @brief Constant pointer to qgar::GenImage::value_type.
00107    */
00108   typedef const value_type* const_pointer;
00109 
00110   //@}
00111 
00112 
00113 // -------------------------------------------------------------------
00114 // P U B L I C    M E M B E R S
00115 // -------------------------------------------------------------------
00116 public:
00117 
00118   /** @name Constructors */
00119   //        ============
00120   //@{
00121 
00122   /**
00123    * @brief Construct from given float image.
00124    *
00125    * The mean is computed over a <b>aMaskSize X aMaskSize</b>
00126    * neighborhood, and is stored in image pointed by <b>aMeanImg</b>.
00127    *
00128    * @param anImg      initial image
00129    * @param aMeanImg   image to store the standard deviation
00130    * @param aMaskSize  mask size (default <b>3</b>)
00131    *
00132    * @warning
00133    * Mask size must be odd.
00134    *
00135    * @exception qgar::QgarErrorInvalidArg
00136    * (mask size must be an odd value)
00137    */
00138   StandardDeviationImage(const FloatImage& anImg,
00139                          FloatImage*& aMeanImg,
00140                          const unsigned int aMaskSize = 3)
00141     throw(QgarErrorInvalidArg);
00142 
00143   //@}
00144 
00145 // ----------------------------------------------------------------------
00146 }; // class StandardDeviationImage
00147 
00148 } // namespace qgar 
00149 
00150 
00151 #endif /* __STANDARDDEVIATIONIMAGE_H_INCLUDED__ */