WhiteBlackGrid.h
Go to the documentation of this file.
00001 /*********************************************************************
00002 *  Software License Agreement (BSD License)
00003 *  Copyright (c) 2013, Intelligent Robotics Lab, DLUT.
00004 *  All rights reserved.
00005 *  Author:Intelligent Robotics Lab, DLUT.
00006 *  Redistribution and use in source and binary forms, with or without
00007 *  modification, are permitted provided that the following conditions
00008 *  are met:
00009 *
00010 *   * Redistributions of source code must retain the above copyright
00011 *     notice, this list of conditions and the following disclaimer.
00012 *   * Redistributions in binary form must reproduce the above
00013 *     copyright notice, this list of conditions and the following
00014 *     disclaimer in the documentation and/or other materials provided
00015 *     with the distribution.
00016 *   * Neither the name of the Intelligent Robotics Lab nor the names of its
00017 *     contributors may be used to endorse or promote products derived
00018 *     from this software without specific prior written permission.
00019 *
00020 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00021 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00022 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00023 *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00024 *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00025 *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00026 *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00027 *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00028 *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00029 *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00030 *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00031 *  POSSIBILITY OF SUCH DAMAGE.
00032 *********************************************************************/
00033 #pragma once
00034 #include "basicData/Point3d.h"
00035 #include <stdio.h>
00036 #include <iostream>
00037 #include <string>
00038 #include <fstream>
00039 #include <sstream>
00040 #include <vector>
00041 
00042 #include <eigen3/Eigen/Dense>   //matirx relation
00043 
00044 #define N 3
00045 
00046 using namespace std;
00047 using namespace Eigen;
00048 
00049 
00050 struct BinIndex                 //Binary matrix index struct
00051 {
00052   size_t bin_i;
00053   size_t bin_j;
00054 };
00055 
00056 class CWhiteBlackGrid
00057 {
00058 public:
00059   std::vector < std::vector < int > >bin_vec_;   // Binary matrix
00060     std::vector < CPoint3d > node_vec_; //Checkerboard corners which are detected initially
00061     std::vector < CPoint3d > match_pair_vec_;   //Checkerboard corners which are detected 
00062     std::vector < CPoint3d > standard_vec_;     //Constructed standard model 
00063 
00064 private:
00065   int scene_cnt_;               //The number of scene
00066   bool m_scan_mode_;            //scan types 1:pitching,0:horizontal 
00067 
00068 public:
00069     CWhiteBlackGrid (void);
00070    ~CWhiteBlackGrid (void);
00071 
00072 public:
00073 
00074   void whgRegisterScanMode (bool scan_mode);
00075   void whgNodeDetect (int _m, int _n, float *_parameters, std::vector < std::vector < CPoint3d > >&laser_data_vec);     // Detect checkerboard corners
00076   void whgNodeModify (void);    //Revise the corners we detect.
00077 
00078   BinIndex whgAverageof4index (BinIndex bi1, BinIndex bi2, BinIndex bi3, BinIndex bi4); //Calculate the average of 4 indexs
00079 
00080   void whgCalculateTransformationRT (void);     //Calculate the RT
00081   void whgTransform (MatrixXd matrix_R, VectorXd vector_t, std::vector < CPoint3d > &laser_point_vec);
00082 
00083 
00084 };


camera_laser_calibration
Author(s): Zhao Cilang,Yan Fei,Zhuang Yan/zhuang@dlut.edu.cn
autogenerated on Sun Jan 5 2014 11:05:02