libidx
/home/rex/ebltrunk/core/libidx/include/padder.h
00001 /***************************************************************************
00002  *   Copyright (C) 2011 by Pierre Sermanet *
00003  *   pierre.sermanet@gmail.com *
00004  *   All rights reserved.
00005  *
00006  * Redistribution and use in source and binary forms, with or without
00007  * modification, are permitted provided that the following conditions are met:
00008  *     * Redistributions of source code must retain the above copyright
00009  *       notice, this list of conditions and the following disclaimer.
00010  *     * Redistributions in binary form must reproduce the above copyright
00011  *       notice, this list of conditions and the following disclaimer in the
00012  *       documentation and/or other materials provided with the distribution.
00013  *     * Redistribution under a license not approved by the Open Source
00014  *       Initiative (http://www.opensource.org) must display the
00015  *       following acknowledgement in all advertising material:
00016  *        This product includes software developed at the Courant
00017  *        Institute of Mathematical Sciences (http://cims.nyu.edu).
00018  *     * The names of the authors may not be used to endorse or promote products
00019  *       derived from this software without specific prior written permission.
00020  *
00021  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
00022  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00023  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00024  * DISCLAIMED. IN NO EVENT SHALL ThE AUTHORS BE LIABLE FOR ANY
00025  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00026  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00027  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00028  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00029  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00030  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00031  ***************************************************************************/
00032 
00033 #ifndef PADDER_H_
00034 #define PADDER_H_
00035 
00036 #include "idx.h"
00037 #include "geometry.h"
00038 
00039 namespace ebl {
00040   
00042   // padder
00043 
00045   template <typename T> class padder {
00046   public:
00049     padder(const idxdim &kerdims, bool mirror = true);
00050     virtual ~padder();
00053     virtual idx<T> pad(idx<T> &in);
00056     virtual void pad(idx<T> &in, idx<T> &out);
00057     
00058   protected:
00060     virtual void mirror(idx<T> &in, idx<T> &padded);
00061     
00062   protected: // members ////////////////////////////////////////////////////////
00063     int nrow, ncol, nrow2, ncol2;
00064     bool bmirror;
00065   };
00066 
00068   // padding utilities
00069   
00076   template<typename T>
00077     idx<T> image_region_to_rect(idx<T> &im, const rect<int> &r, uint h,
00078                                 uint w, rect<int> *cropped = NULL,
00079                                 uint dh = 0, uint dw = 1);
00081   template<typename T>
00082     void image_paste_center(idx<T> &in, idx<T> &out);  
00083   
00084 } // end namespace ebl
00085 
00086 #include "padder.hpp"
00087 
00088 #endif /* PADDER_H_ */