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

TTBinaryImage.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 __TTBINARYIMAGE_H_INCLUDED__
00029 #define __TRIERTAXTBINARYIMAGE_H_INCLUDED__
00030 
00031 
00032 /**
00033  * @file     TTBinaryImage.H
00034  * @brief    Header file of class qgar::TTBinaryImage.
00035  *
00036  * @author <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Gérald Masini">Gérald Masini</a>
00037  * @date   July 18, 2005  15:15
00038  * @since  Qgar 2.2
00039  */
00040 
00041 
00042 // For RCS/CVS use: Do not delete
00043 /* $Id: TTBinaryImage.H,v 1.3 2005/09/15 18:19:35 masini Exp $ */
00044 
00045 
00046 
00047 // QGAR
00048 #include <qgarlib/GenImage.H>
00049 
00050 
00051 
00052 namespace qgar
00053 {
00054 
00055 
00056 /**
00057  * @class TTBinaryImage TTBinaryImage.H "qgarlib/TTBinaryImage.H"
00058  * @ingroup IMGPROC_BIN
00059  *
00060  * @brief Binary image created from a grey-level image, using binarization
00061  * method designed by Trier and Taxt
00062  * [<a href="Bibliography.html#Trier-and-Taxt-1995">Trier&nbsp;and&nbsp;Taxt,&nbsp;1995</a>]
00063  * from White and Rohrer's method.
00064  *
00065  * Canny's operator, instead of Sobel's one, is used for edges detection.
00066  *
00067  * @warning
00068  * <ul>
00069  * <li>The image to be binarized must have at least 3 rows and
00070  * 3 columns.</li>
00071  * <li>As the first and last rows (resp. first and last columns) of the
00072  * image are arbitrarily set to <b>white</b> by the algorithm used to
00073  * construct connected components (see class qgar::ConnectedComponents),
00074  * they are filled with a copy of their adjacent row (resp. column)
00075  * in the binarized image.</li>
00076  * </ul>
00077  *
00078  * @todo
00079  * Introduce BLACK and WHITE values as parameters of the computation
00080  * of the connected components: In this way, there will be no need
00081  * to duplicate an image if 4-connected black components are needed.
00082  *
00083  * @author <a href="mailto:qgar-develop@loria.fr?subject=Qgar fwd Gérald Masini">Gérald Masini</a>
00084  * @date   July 18, 2005  15:15
00085  * @since  Qgar 2.2
00086  */
00087 class TTBinaryImage
00088 
00089   : public BinaryImage
00090 
00091 {
00092 // -------------------------------------------------------------------
00093 // T Y P E   D E F I N I T I O N S
00094 // -------------------------------------------------------------------
00095 public:
00096 
00097 
00098   /** @name Types */
00099   //        =====
00100   //@{
00101 
00102   /**
00103    * @brief Type of the elements stored in the pixmap.
00104    */
00105   typedef BinaryImage::value_type value_type;
00106 
00107   /**
00108    * @brief Reference to qgar::TTBinaryImage::value_type.
00109    */
00110   typedef value_type& reference;
00111 
00112   /**
00113    * @brief Constant reference to qgar::TTBinaryImage::value_type.
00114    */
00115   typedef const value_type& const_reference;
00116 
00117   /**
00118    * @brief Pointer to qgar::TTBinaryImage::value_type.
00119    */
00120   typedef value_type* pointer;
00121 
00122   /**
00123    * @brief Constant pointer to qgar::TTBinaryImage::value_type.
00124    */
00125   typedef const value_type* const_pointer;
00126 
00127   //@}
00128 
00129 
00130 // -------------------------------------------------------------------
00131 // P U B L I C    M E M B E R S
00132 // -------------------------------------------------------------------
00133 public:
00134 
00135   /** @name Constructors */
00136   //        ============
00137   //@{
00138 
00139   /**
00140    * @brief Construct a binary image from a given grey-level image.
00141    *
00142    * See the referenced paper for details.
00143    *
00144    * @param aGreyLevelImg  a grey-level image
00145    * @param aSigma         smoothing coefficient    (default <b>1.</b>, i.e. none)
00146    * @param anActThrs      activity threshold       (default <b>40.</b>)
00147    * @param aPostThrs      postprocessing threshold (default <b>30.</b>)
00148    */
00149   TTBinaryImage(const GreyLevelImage& aGreyLevelImg, 
00150                 const double aSigma     =  1.0,
00151                 const double anActThrs  = 40.0,
00152                 const double aPostThrs  = 30.0); 
00153 
00154   //@}
00155 
00156 // -------------------------------------------------------------------
00157 }; // class TTBinaryImage
00158 
00159 
00160 } // namespace qgar 
00161 
00162 
00163 #endif /* TTBINARYIMAGE_H_INCLUDED */