Image Component Library (ICL)
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines
LensUndistortionCalibrator.h
Go to the documentation of this file.
00001 /********************************************************************
00002 **                Image Component Library (ICL)                    **
00003 **                                                                 **
00004 ** Copyright (C) 2006-2013 CITEC, University of Bielefeld          **
00005 **                         Neuroinformatics Group                  **
00006 ** Website: www.iclcv.org and                                      **
00007 **          http://opensource.cit-ec.de/projects/icl               **
00008 **                                                                 **
00009 ** File   : ICLGeom/src/ICLGeom/LensUndistortionCalibrator.h       **
00010 ** Module : ICLGeom                                                **
00011 ** Authors: Christof Elbrechter                                    **
00012 **                                                                 **
00013 **                                                                 **
00014 ** GNU LESSER GENERAL PUBLIC LICENSE                               **
00015 ** This file may be used under the terms of the GNU Lesser General **
00016 ** Public License version 3.0 as published by the                  **
00017 **                                                                 **
00018 ** Free Software Foundation and appearing in the file LICENSE.LGPL **
00019 ** included in the packaging of this file.  Please review the      **
00020 ** following information to ensure the license requirements will   **
00021 ** be met: http://www.gnu.org/licenses/lgpl-3.0.txt                **
00022 **                                                                 **
00023 ** The development of this software was supported by the           **
00024 ** Excellence Cluster EXC 277 Cognitive Interaction Technology.    **
00025 ** The Excellence Cluster EXC 277 is a grant of the Deutsche       **
00026 ** Forschungsgemeinschaft (DFG) in the context of the German       **
00027 ** Excellence Initiative.                                          **
00028 **                                                                 **
00029 ********************************************************************/
00030 #pragma once
00031 
00032 #include <ICLUtils/Point32f.h>
00033 #include <ICLUtils/Uncopyable.h>
00034 #include <ICLUtils/Size.h>
00035 #include <ICLUtils/Size32f.h>
00036 
00037 #include <ICLIO/ImageUndistortion.h>
00038 
00039 #include <vector>
00040 
00041 namespace icl{
00042 
00043   namespace cv{
00044     
00046 
00053     class ICLCV_API LensUndistortionCalibrator : public utils::Uncopyable{
00054       struct Data;  
00055       Data *m_data; 
00056       
00057       public:
00058       
00060       struct ICLCV_API GridDefinition : public std::vector<utils::Point32f>{
00061         
00063         GridDefinition(){}
00064         
00066         GridDefinition(const utils::Size &dims, const utils::Size32f &size);
00067         
00069         GridDefinition(const utils::Size &markerGridDims, 
00070                        const utils::Size32f &markerSize, 
00071                        const utils::Size32f &markerSpacing);
00072         
00074         GridDefinition(const utils::Size &markerGridDims, float markerDim, float markerSpacing);
00075       };
00076       
00078       struct Info{
00079         utils::Size imageSize;  
00080         int numPointsAdded;     
00081         int numPointSetsAdded;  
00082         const GridDefinition &gridDef; 
00083       };
00084 
00085       
00087       LensUndistortionCalibrator();
00088       
00090       LensUndistortionCalibrator(const utils::Size &imagesSize, const GridDefinition &gridDef);
00091       
00093       ~LensUndistortionCalibrator();
00094       
00096       void init(const utils::Size &imagesSize, const GridDefinition &gridDef);
00097 
00099       bool isNull() const;
00100       
00102       void addPoints(const std::vector<utils::Point32f> &imagePoints);
00103 
00105       void addPoints(const std::vector<utils::Point32f> &imagePoints, const std::vector<utils::Point32f> &gridDef);
00106 
00108       void clear();
00109       
00111       Info getInfo();
00112       
00114       io::ImageUndistortion computeUndistortion();
00115       
00116     };
00117   }
00118   
00119 }
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines