IVT
Rectification.cpp
Go to the documentation of this file.
1 // ****************************************************************************
2 // This file is part of the Integrating Vision Toolkit (IVT).
3 //
4 // The IVT is maintained by the Karlsruhe Institute of Technology (KIT)
5 // (www.kit.edu) in cooperation with the company Keyetech (www.keyetech.de).
6 //
7 // Copyright (C) 2014 Karlsruhe Institute of Technology (KIT).
8 // All rights reserved.
9 //
10 // Redistribution and use in source and binary forms, with or without
11 // modification, are permitted provided that the following conditions are met:
12 //
13 // 1. Redistributions of source code must retain the above copyright
14 // notice, this list of conditions and the following disclaimer.
15 //
16 // 2. Redistributions in binary form must reproduce the above copyright
17 // notice, this list of conditions and the following disclaimer in the
18 // documentation and/or other materials provided with the distribution.
19 //
20 // 3. Neither the name of the KIT nor the names of its contributors may be
21 // used to endorse or promote products derived from this software
22 // without specific prior written permission.
23 //
24 // THIS SOFTWARE IS PROVIDED BY THE KIT AND CONTRIBUTORS “AS IS” AND ANY
25 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
26 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
27 // DISCLAIMED. IN NO EVENT SHALL THE KIT OR CONTRIBUTORS BE LIABLE FOR ANY
28 // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
29 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
30 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
31 // ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
33 // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 // ****************************************************************************
35 // ****************************************************************************
36 // Filename: Rectification.cpp
37 // Author: Pedram Azad
38 // Date: 04.10.2008
39 // ****************************************************************************
40 
41 
42 // ****************************************************************************
43 // Includes
44 // ****************************************************************************
45 
46 #include <new> // for explicitly using correct new/delete operators on VC DSPs
47 
48 #include "Rectification.h"
49 
50 #include "Image/ByteImage.h"
53 
54 #include <stdio.h>
55 
56 
57 
58 // ****************************************************************************
59 // class CRectification::CRectificationMapper
60 // ****************************************************************************
61 
62 void CRectification::CRectificationMapper::Init(const Mat3d &homography, const CCalibration *pCalibration)
63 {
64  m_pCalibration = pCalibration;
65  Math3d::SetMat(m_homography, homography);
66 
67  ComputeMap(m_pCalibration->GetCameraParameters().width, m_pCalibration->GetCameraParameters().height);
68 }
69 
70 void CRectification::CRectificationMapper::ComputeOriginalCoordinates(const Vec2d &newCoordinates, Vec2d &originalCoordinates)
71 {
72  Math2d::ApplyHomography(m_homography, newCoordinates, originalCoordinates);
73 
74  if (m_bUndistort)
75  {
76  // this is not a bug to distort; mapping needs inverse function!
77  m_pCalibration->DistortImageCoordinates(originalCoordinates, originalCoordinates);
78  }
79 }
80 
81 
82 
83 // ****************************************************************************
84 // Constructor / Destructor
85 // ****************************************************************************
86 
87 CRectification::CRectification(bool bInterpolate, bool bUndistort)
88 {
89  m_pStereoCalibration = new CStereoCalibration();
90  m_pUsedStereoCalibration = 0;
91 
92  m_pRectificationMapperLeft = new CRectificationMapper(bInterpolate, bUndistort);
93  m_pRectificationMapperRight = new CRectificationMapper(bInterpolate, bUndistort);
94 }
95 
97 {
98  delete m_pStereoCalibration;
99 
100  delete m_pRectificationMapperLeft;
101  delete m_pRectificationMapperRight;
102 }
103 
104 
105 // ****************************************************************************
106 // methods
107 // ****************************************************************************
108 
109 bool CRectification::Init(const char *pCameraParameterFileName)
110 {
111  if (m_pStereoCalibration->LoadCameraParameters(pCameraParameterFileName))
112  {
113  m_pUsedStereoCalibration = m_pStereoCalibration;
114 
115  UpdateMaps();
116 
117  return true;
118  }
119 
120  return false;
121 }
122 
123 void CRectification::Init(const CStereoCalibration *pStereoCalibration)
124 {
125  m_pUsedStereoCalibration = pStereoCalibration;
126 
127  UpdateMaps();
128 }
129 
130 
132 {
133  if (!m_pUsedStereoCalibration)
134  {
135  printf("error: CRectification object has not been initialized for CRectification::UpdateMaps\n");
136  return;
137  }
138 
139  m_pRectificationMapperLeft->Init(m_pUsedStereoCalibration->rectificationHomographyLeft, m_pUsedStereoCalibration->GetLeftCalibration());
140  m_pRectificationMapperRight->Init(m_pUsedStereoCalibration->rectificationHomographyRight, m_pUsedStereoCalibration->GetRightCalibration());
141 }
142 
143 void CRectification::Rectify(const CByteImage * const *ppInputImages, CByteImage **ppOutputImages)
144 {
145  m_pRectificationMapperLeft->PerformMapping(ppInputImages[0], ppOutputImages[0]);
146  m_pRectificationMapperRight->PerformMapping(ppInputImages[1], ppOutputImages[1]);
147 }
const CCalibration * GetRightCalibration() const
Access to the instance of CCalibration for the camera model of the right camera.
CRectification(bool bInterpolate=true, bool bUndistort=true)
void ApplyHomography(const Mat3d &A, const Vec2d &p, Vec2d &result)
Definition: Math2d.cpp:253
Data structure for the representation of a 2D vector.
Definition: Math2d.h:82
void Rectify(const CByteImage *const *ppInputImages, CByteImage **ppOutputImages)
bool LoadCameraParameters(const char *pCameraParameterFileName, bool bTransformLeftCameraToIdentity=true)
Initializes the stereo camera model, given a file path to a stereo camera parameter file...
bool Init(const char *pCameraParameterFileName)
const CCalibration * GetLeftCalibration() const
Access to the instance of CCalibration for the camera model of the left camera.
void SetMat(Mat3d &matrix, float r1, float r2, float r3, float r4, float r5, float r6, float r7, float r8, float r9)
Definition: Math3d.cpp:257
Camera model parameters and functions for a single camera.
Definition: Calibration.h:125
Mat3d rectificationHomographyRight
The homography for the rectification mapping of the right image.
Data structure for the representation of a 3x3 matrix.
Definition: Math3d.h:93
Data structure for the representation of 8-bit grayscale images and 24-bit RGB (or HSV) color images ...
Definition: ByteImage.h:80
Camera model and functions for a stereo camera system.
Mat3d rectificationHomographyLeft
The homography for the rectification mapping of the right image.