LTI-Lib latest version v1.9 - last update 10 Apr 2010

ltiLinearMapperFunctor.h

00001 /*
00002  * Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005, 2006
00003  * Lehrstuhl fuer Technische Informatik, RWTH-Aachen, Germany
00004  *
00005  * This file is part of the LTI-Computer Vision Library (LTI-Lib)
00006  *
00007  * The LTI-Lib is free software; you can redistribute it and/or
00008  * modify it under the terms of the GNU Lesser General Public License (LGPL)
00009  * as published by the Free Software Foundation; either version 2.1 of
00010  * the License, or (at your option) any later version.
00011  *
00012  * The LTI-Lib is distributed in the hope that it will be
00013  * useful, but WITHOUT ANY WARRANTY; without even the implied warranty
00014  * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00015  * GNU Lesser General Public License for more details.
00016  *
00017  * You should have received a copy of the GNU Lesser General Public
00018  * License along with the LTI-Lib; see the file LICENSE.  If
00019  * not, write to the Free Software Foundation, Inc., 59 Temple Place -
00020  * Suite 330, Boston, MA 02111-1307, USA.
00021  */
00022 
00023 
00024 /*----------------------------------------------------------------
00025  * project ....: LTI Digital Image/Signal Processing Library
00026  * file .......: ltiLinearMapperFunctor.h
00027  * authors ....: Pablo Alvarado
00028  * organization: LTI, RWTH Aachen
00029  * creation ...: 10.7.2000
00030  * revisions ..: $Id: ltiLinearMapperFunctor.h,v 1.8 2006/02/08 12:30:48 ltilib Exp $
00031  */
00032 
00033 #ifndef _LTI_LINEAR_MAPPER_FUNCTOR_H_
00034 #define _LTI_LINEAR_MAPPER_FUNCTOR_H_
00035 
00036 #include "ltiObject.h"
00037 #include "ltiMapperFunctor.h"
00038 
00039 namespace lti {
00040 
00041   /**
00042    * This %functor maps a %vector space of type Tin into another %vector
00043    * space of type Tout.  The dimensionality and boundaries of both spaces
00044    * can be specified through the lti::mapperFunctor::parameters
00045    * class.
00046    *
00047    * The mapping-function is linear.  If an input point is outer bounds, the
00048    * output point will be also outer bounds
00049    *
00050    * For the following example a chromaticity %histogram will be created with
00051    * 10 cells for the red and 16 cells for the green channel
00052    *
00053    * \code
00054    *   lti::image img; // the image to be analysed
00055    *   // ...          // load or create the image to be analysed
00056    *   lti::splitImageTorgI splitter;
00057    *   lti::channel r,g,I;
00058    *
00059    *   splitter.apply(r,g,I); // get chromaticity channels
00060    *
00061    *   lti::histogram2D histo(10,16);  // a two dimensional histogram
00062    *   // the mapper functor
00063    *   lti::linearMapperFunctor<lti::channel::value_type> mapper;
00064    *   lti::linearMapperFunctor<lti::channel::value_type>::parameters mapParam;
00065    *
00066    *   mapParam.generateFrom(histo);
00067    *   mapParam.lowerLimitsInput.fill(0.0f);
00068    *   mapParam.upperLimitsInput.fill(1.0f);
00069    *
00070    *   mapper.setParameters(mapParam);
00071    *
00072    *   lti::point p,q;
00073    *
00074    *   // for each pixel in the channels
00075    *   for (p.y=0;p.y<r.rows();p.y++) {
00076    *     for (p.x=0;p.x<g.rows();p.x++) {
00077    *       histo.put(mapper.apply(r.at(p),g.at(p),q));
00078    *     }
00079    *   }
00080    * \endcode
00081    */
00082   template <class Tin, class Tout=int>
00083     class linearMapperFunctor : public mapperFunctor<Tin,Tout> {
00084     public:
00085     /**
00086      * the parameters for the class linearMapperFunctor
00087      */
00088     class parameters : public mapperFunctor<Tin,Tout>::parameters {
00089       public:
00090       /**
00091        * default constructor
00092        */
00093       parameters() : mapperFunctor<Tin,Tout>::parameters() {
00094       };
00095 
00096       /**
00097        * copy constructor
00098        * @param other the parameters object to be copied
00099        */
00100       parameters(const parameters& other) {
00101         copy(other);
00102       };
00103 
00104       /**
00105        * destructor
00106        */
00107       ~parameters() {};
00108 
00109       /**
00110        * returns name of this type
00111        */
00112       const char* getTypeName() const {
00113         return "linearMapperFunctor::parameters";
00114       };
00115 
00116       /**
00117        * copy the contents of a parameters object
00118        * @param other the parameters object to be copied
00119        * @return a reference to this parameters object
00120        */
00121       parameters& copy(const parameters& other)  {
00122 #     ifndef _LTI_MSC_6
00123         // MS Visual C++ 6 is not able to compile this...
00124         mapperFunctor<Tin,Tout>::parameters::copy(other);
00125 #     else
00126         // ...so we have to use this workaround.
00127         // Conditional on that, copy may not be virtual.
00128         mapperFunctor<Tin,Tout>::parameters&
00129           (mapperFunctor<Tin,Tout>::parameters::* p_copy)
00130           (const mapperFunctor<Tin,Tout>::parameters&) =
00131           mapperFunctor<Tin,Tout>::parameters::copy;
00132         (this->*p_copy)(other);
00133 #     endif
00134 
00135         return *this;
00136       };
00137 
00138       /**
00139        * returns a pointer to a clone of the parameters
00140        */
00141       virtual functor::parameters* clone() const {
00142         return new parameters(*this);
00143       };
00144 
00145     };
00146 
00147     /**
00148      * default constructor
00149      */
00150     linearMapperFunctor();
00151 
00152     /**
00153      * copy constructor
00154      * @param other the object to be copied
00155      */
00156     linearMapperFunctor(const linearMapperFunctor& other);
00157 
00158     /**
00159      * destructor
00160      */
00161     virtual ~linearMapperFunctor();
00162 
00163     /**
00164      * returns the name of this type ("linearMapperFunctor")
00165      */
00166     virtual const char* getTypeName() const;
00167 
00168     /**
00169      * Map the input vector src in the output vector dest.
00170      * @param src vector<Tin> with the source data.
00171      * @param dest vector<Tout> where the result will be left.
00172      * @result a reference to the <code>dest</code>.
00173      */
00174     virtual vector<Tout>& apply(const vector<Tin>& src,
00175                                       vector<Tout>& dest) const;
00176 
00177     /**
00178      * For the two dimensional case, maps a two dimensional vector in a
00179      * integer vector coded as a point
00180      * @param src ivector with the source data.
00181      * @param dest point where the result will be left.
00182      * @result a reference to the <code>dest</code>.
00183      */
00184     point& apply(const vector<Tin>& src,point& dest) const;
00185 
00186     /**
00187      * For the two dimensional case, maps a two dimensional vector in a
00188      * integer vector coded as a point
00189      * @param src0 the first element of the input vector
00190      * @param src1 the second element of the input vector
00191      * @param dest point where the result will be left.
00192      * @result a reference to the <code>dest</code>.
00193      */
00194     point& apply(const Tin& src0,const Tin& src1,
00195                  point& dest) const;
00196 
00197     /**
00198      * For the two dimensional case, maps a two dimensional integer vector in a
00199      * integer vectorm, both coded as a points
00200      * @param src the two dimensional point representing the input vector
00201      * @param dest point where the result will be left.
00202      * @result a reference to the <code>dest</code>.
00203      */
00204     point& apply(const point& src,point& dest) const;
00205 
00206     /**
00207      * For the one dimensional case, maps the input vector into a one
00208      * dimensional vector of type Tout.
00209      * @param src int with the source data.
00210      * @param dest int where the result will be left.
00211      * @result a reference to the <code>dest</code>.
00212      */
00213     Tout& apply(const vector<Tin>& src,Tout& dest) const;
00214 
00215     /**
00216      * For the one dimensional case, maps a one dimensional vector in a
00217      * output vector
00218      * @param src one-dimensional vector with the source data.
00219      * @param dest one-dimensional vector where the result will be left.
00220      * @result a reference to the <code>dest</code>.
00221      */
00222     Tout& apply(const Tin& src,Tout& dest) const;
00223 
00224     /**
00225      * copy data of "other" functor.
00226      * @param other the functor to be copied
00227      * @return a reference to this functor object
00228      */
00229     linearMapperFunctor& copy(const linearMapperFunctor& other);
00230 
00231     /**
00232      * returns a pointer to a clone of this functor.
00233      */
00234     virtual functor* clone() const;
00235 
00236     /**
00237      * returns used parameters
00238      */
00239     const parameters& getParameters() const;
00240 
00241     /**
00242      * set the parameters and check them for correctness
00243      */
00244     virtual bool updateParameters();
00245 
00246   protected:
00247     /**
00248      * slopes of the mapping lines.
00249      *
00250      * These are calculated when setParameters
00251      * is called
00252      */
00253     fvector slope;
00254 
00255     /**
00256      * offset of the mapping lines.
00257      *
00258      * These are calculated when setParameters
00259      * is called
00260      */
00261     fvector b;
00262 
00263   };
00264 }
00265 
00266 #include "ltiLinearMapperFunctor_template.h"
00267 
00268 #endif

Generated on Sat Apr 10 15:25:44 2010 for LTI-Lib by Doxygen 1.6.1