OKVIS ROS
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
DistortionBase.hpp
Go to the documentation of this file.
1 /*********************************************************************************
2  * OKVIS - Open Keyframe-based Visual-Inertial SLAM
3  * Copyright (c) 2015, Autonomous Systems Lab / ETH Zurich
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * * Redistributions of source code must retain the above copyright notice,
9  * this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright notice,
11  * this list of conditions and the following disclaimer in the documentation
12  * and/or other materials provided with the distribution.
13  * * Neither the name of Autonomous Systems Lab / ETH Zurich nor the names of
14  * its contributors may be used to endorse or promote products derived from
15  * this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27  * POSSIBILITY OF SUCH DAMAGE.
28  *
29  * Created on: Jan 29, 2015
30  * Author: Stefan Leutenegger (s.leutenegger@imperial.ac.uk)
31  *********************************************************************************/
32 
39 #ifndef INCLUDE_OKVIS_CAMERAS_DISTORTIONBASE_HPP_
40 #define INCLUDE_OKVIS_CAMERAS_DISTORTIONBASE_HPP_
41 
42 #include <Eigen/Core>
44 
46 namespace okvis {
48 namespace cameras {
49 
53 {
54  public:
55  EIGEN_MAKE_ALIGNED_OPERATOR_NEW
56 
58  virtual ~DistortionBase()
59  {
60  }
61 
65 
69  virtual bool setParameters(const Eigen::VectorXd & parameters) = 0;
70 
72  virtual bool getParameters(Eigen::VectorXd & parameters) const = 0;
73 
75  virtual std::string type() const = 0;
76 
78  virtual int numDistortionIntrinsics() const = 0;
80 
84 
89  virtual bool distort(const Eigen::Vector2d & pointUndistorted,
90  Eigen::Vector2d * pointDistorted) const = 0;
91 
98  virtual bool distort(const Eigen::Vector2d & pointUndistorted,
99  Eigen::Vector2d * pointDistorted,
100  Eigen::Matrix2d * pointJacobian,
101  Eigen::Matrix2Xd * parameterJacobian = NULL) const = 0;
102 
110  virtual bool distortWithExternalParameters(
111  const Eigen::Vector2d & pointUndistorted,
112  const Eigen::VectorXd & parameters, Eigen::Vector2d * pointDistorted,
113  Eigen::Matrix2d * pointJacobian = NULL,
114  Eigen::Matrix2Xd * parameterJacobian = NULL) const = 0;
116 
120 
125  virtual bool undistort(const Eigen::Vector2d & pointDistorted,
126  Eigen::Vector2d * pointUndistorted) const = 0;
127 
133  virtual bool undistort(const Eigen::Vector2d & pointDistorted,
134  Eigen::Vector2d * pointUndistorted,
135  Eigen::Matrix2d * pointJacobian) const = 0;
137 };
138 
139 } // namespace cameras
140 } // namespace okvis
141 
142 #endif /* INCLUDE_OKVIS_CAMERAS_DISTORTIONBASE_HPP_ */
virtual std::string type() const =0
The derived class type.
virtual EIGEN_MAKE_ALIGNED_OPERATOR_NEW ~DistortionBase()
Destructor – not doing anything.
Definition: DistortionBase.hpp:58
virtual bool undistort(const Eigen::Vector2d &pointDistorted, Eigen::Vector2d *pointUndistorted) const =0
Undistortion only.
virtual bool distortWithExternalParameters(const Eigen::Vector2d &pointUndistorted, const Eigen::VectorXd &parameters, Eigen::Vector2d *pointDistorted, Eigen::Matrix2d *pointJacobian=NULL, Eigen::Matrix2Xd *parameterJacobian=NULL) const =0
Distortion and Jacobians using external distortion intrinsics parameters.
virtual int numDistortionIntrinsics() const =0
Number of derived class distortion parameters.
Header file for the CameraBase class.
Base class for all distortion models.
Definition: DistortionBase.hpp:52
virtual bool setParameters(const Eigen::VectorXd &parameters)=0
set the generic parameters
virtual bool getParameters(Eigen::VectorXd &parameters) const =0
Obtain the generic parameters.
virtual bool distort(const Eigen::Vector2d &pointUndistorted, Eigen::Vector2d *pointDistorted) const =0
Distortion only.