Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Double Sphere and Extended Unified Camera models to Kalibr #210

Merged
merged 38 commits into from
Aug 15, 2018
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
379cd4b
Added Double Sphere camera. Compiles..
VladyslavUsenko Apr 1, 2018
b2eda03
fix tests
VladyslavUsenko Apr 1, 2018
dcf3df9
Trying to put double sphere into python
VladyslavUsenko Apr 1, 2018
8dd63d9
Fix Double Sphere model for one camera..
VladyslavUsenko Apr 1, 2018
16ebbdf
small fixes
VladyslavUsenko Apr 1, 2018
3f35e42
small fixes
VladyslavUsenko Apr 1, 2018
5deaa3d
wip camera models
NikolausDemmel May 3, 2018
4ce0e33
fix DoubleSphere for aslam_cv_serialization
NikolausDemmel May 3, 2018
08615f8
fix DS initialization
NikolausDemmel May 3, 2018
3174409
NoDistortion doesn't seem to need serialization...
NikolausDemmel May 3, 2018
32a7a64
Merge branch 'niko-devel' into 'double_sphere'
VladyslavUsenko May 3, 2018
d4db4c7
Some more fixes for ds model.
NikolausDemmel May 4, 2018
6ae0b0b
Merge branch 'niko-devel' into 'double_sphere'
VladyslavUsenko May 4, 2018
52b2127
added _fov_parameter
VladyslavUsenko May 5, 2018
f8cedaa
fix _fov_parameter
VladyslavUsenko May 6, 2018
ea791e7
wip
NikolausDemmel May 8, 2018
d4b7868
wip
NikolausDemmel May 18, 2018
0b8b9e8
Removed unified camera model. Compiles.
VladyslavUsenko Jul 24, 2018
9a36bbe
Removed autogenerated files
VladyslavUsenko Jul 24, 2018
9fb2679
Merge remote-tracking branch 'vlad_gitlab/master' into double_sphere
VladyslavUsenko Jul 24, 2018
ff62f3c
small fixes
VladyslavUsenko Jul 24, 2018
7acedda
small fixes
VladyslavUsenko Jul 24, 2018
5b06296
small fixes
VladyslavUsenko Jul 24, 2018
0d10608
small fix
VladyslavUsenko Jul 24, 2018
d1ef68e
fix segfault
VladyslavUsenko Jul 24, 2018
e50ca4c
fix eucm
VladyslavUsenko Jul 25, 2018
52601b7
small fixes
VladyslavUsenko Jul 25, 2018
5c2c196
fix _one_over_2xi2_m_1
VladyslavUsenko Jul 26, 2018
4afc1af
variable renaming
VladyslavUsenko Jul 26, 2018
95863ff
comments and notes
NikolausDemmel Aug 2, 2018
a3878ef
EUCM: fix equality check
NikolausDemmel Aug 2, 2018
45b3151
Fix variable naming
NikolausDemmel Aug 2, 2018
f690292
comments
NikolausDemmel Aug 2, 2018
37358f9
whitespace
NikolausDemmel Aug 2, 2018
933c71f
Merge pull request #3 from VladyslavUsenko/double_sphere_niko
VladyslavUsenko Aug 2, 2018
2efeea0
fix valid point check in estimateTransformation
VladyslavUsenko Aug 3, 2018
72d51db
Check FoV before PnP for omni and pinhole model.
NikolausDemmel Aug 3, 2018
b652b6e
removed unused debug output
VladyslavUsenko Aug 10, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
wip
  • Loading branch information
NikolausDemmel committed May 8, 2018
commit ea791e7b6d3c816c39bbc061a32a138215dfd712
6 changes: 6 additions & 0 deletions Schweizer-Messer/sm_eigen/include/sm/eigen/static_assert.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
#define SM_EIGEN_STATIC_ASSERT_HPP

#include <Eigen/Core>
#include <sm/typetraits.hpp>


// static assertion failing if the type \a TYPE is not a vector type of the given size
#define EIGEN_STATIC_ASSERT_VECTOR_SPECIFIC_SIZE_OR_DYNAMIC(TYPE, SIZE) \
Expand All @@ -13,6 +15,10 @@
EIGEN_STATIC_ASSERT( (TYPE::RowsAtCompileTime==ROWS || TYPE::RowsAtCompileTime==Eigen::Dynamic) && (TYPE::ColsAtCompileTime==COLS || TYPE::RowsAtCompileTime==Eigen::Dynamic), \
THIS_METHOD_IS_ONLY_FOR_MATRICES_OF_A_SPECIFIC_SIZE)

// static assert
#define EIGEN_STATIC_ASSERT_SAME_TYPE(U, V, MSG) \
EIGEN_STATIC_ASSERT( (sm::common::SameType<U, V>::value), MSG )



#endif /* SM_EIGEN_STATIC_ASSERT_HPP */
2 changes: 2 additions & 0 deletions aslam_cv/aslam_cameras/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,8 @@ if(CATKIN_ENABLE_TESTING)
test/test_main.cpp
test/PinholeCameraGeometry.cpp
test/OmniCameraGeometry.cpp
test/UnifiedCameraGeometry.cpp
test/ExtendedUnifiedCameraGeometry.cpp
test/DoubleSphereCameraGeometry.cpp
test/RadialTangentialDistortion.cpp
test/EquidistantDistortion.cpp
Expand Down
4 changes: 4 additions & 0 deletions aslam_cv/aslam_cameras/include/aslam/cameras.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@
// Projection models
#include <aslam/cameras/PinholeProjection.hpp>
#include <aslam/cameras/OmniProjection.hpp>
#include <aslam/cameras/UnifiedProjection.hpp>
#include <aslam/cameras/ExtendedUnifiedProjection.hpp>
#include <aslam/cameras/DoubleSphereProjection.hpp>
#include <aslam/cameras/DepthProjection.hpp>

Expand Down Expand Up @@ -43,6 +45,8 @@ typedef CameraGeometry<OmniProjection<EquidistantDistortion>, GlobalShutter,
typedef CameraGeometry<OmniProjection<FovDistortion>, GlobalShutter,
NoMask> FovDistortedOmniCameraGeometry;

typedef CameraGeometry<UnifiedProjection<NoDistortion>, GlobalShutter, NoMask> UnifiedCameraGeometry;
typedef CameraGeometry<ExtendedUnifiedProjection<NoDistortion>, GlobalShutter, NoMask> ExtendedUnifiedCameraGeometry;
typedef CameraGeometry<DoubleSphereProjection<NoDistortion>, GlobalShutter, NoMask> DoubleSphereCameraGeometry;

typedef CameraGeometry<PinholeProjection<NoDistortion>, RollingShutter, NoMask> PinholeRsCameraGeometry;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -190,12 +190,13 @@ class DoubleSphereProjection {
}
;

/// \brief the xi1 parameter that controls the spherical projection.
double xi1() const {
return _xi1;
} /// \brief the xi2 parameter that controls the spherical projection.
double xi2() const {
return _xi2;
/// \brief the xi parameter corresponding to distance between spheres.
double xi() const {
return _xi;
}
/// \brief the alpha parameter that relates second sphere and pinhole projection.
double alpha() const {
return _alpha;
}
/// \brief The horizontal focal length in pixels.
double fu() const {
Expand Down Expand Up @@ -252,12 +253,10 @@ class DoubleSphereProjection {
static DoubleSphereProjection<distortion_t> getTestProjection();
private:

// FIXME @demmeln: rename xi1 and xi2 to xi and alpha

/// \brief the xi1 parameter that controls the spherical projection.
double _xi1;
/// \brief the xi2 parameter that controls the spherical projection.
double _xi2;
/// \brief the xi parameter corresponding to distance between spheres.
double _xi;
/// \brief the alpha parameter that relates second sphere and pinhole projection.
double _alpha;
/// \brief The horizontal focal length in pixels.
double _fu;
/// \brief The vertical focal length in pixels.
Expand All @@ -277,9 +276,8 @@ class DoubleSphereProjection {
double _recip_fu;
double _recip_fv;
double _fu_over_fv;
double _one_over_2xi2_m_1;
double _fov_parameter; //PM: is = xi for xi=<1, = 1/xi for x>1. Used for determining valid projections. Better name?
double _fov_parameter2;
double _one_over_2alpha_m_1;
double _fov_parameter; //!< parameter related to the valid region of the camera model

distortion_t _distortion;

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,294 @@
#ifndef ASLAM_CAMERAS_DOUBLE_SPHERE_PROJECTION_HPP
#define ASLAM_CAMERAS_DOUBLE_SPHERE_PROJECTION_HPP

#include "StaticAssert.hpp"
#include "FiniteDifferences.hpp"
#include <sm/PropertyTree.hpp>
#include <boost/serialization/split_member.hpp>
#include <boost/serialization/version.hpp>
#include <sm/boost/serialization.hpp>
#include <sm/kinematics/Transformation.hpp>
#include <aslam/cameras/GridCalibration_targetObservation.hpp>
#include <opencv2/calib3d/calib3d.hpp>
#include <sm/logging.hpp>

namespace aslam {
namespace cameras {

template<typename DISTORTION_T>
class DoubleSphereProjection {
public:

enum {
KeypointDimension = 2
};
enum {
IntrinsicsDimension = 6
};
enum {
DesignVariableDimension = IntrinsicsDimension
};

typedef DISTORTION_T distortion_t;
typedef Eigen::Matrix<double, KeypointDimension, 1> keypoint_t;
typedef Eigen::Matrix<double, KeypointDimension, IntrinsicsDimension> jacobian_intrinsics_t;

/// \brief Default constructor
DoubleSphereProjection();

DoubleSphereProjection(double xi1, double xi2, double focalLengthU, double focalLengthV,
double imageCenterU, double imageCenterV, int resolutionU,
int resolutionV, distortion_t distortion);

DoubleSphereProjection(double xi1, double xi2, double focalLengthU, double focalLengthV,
double imageCenterU, double imageCenterV, int resolutionU,
int resolutionV);

DoubleSphereProjection(const sm::PropertyTree & config);

/// \brief destructor.
virtual ~DoubleSphereProjection();

/// \brief resize the intrinsics based on a scaling of the image.
void resizeIntrinsics(double scale);

template<typename DERIVED_P, typename DERIVED_K>
bool euclideanToKeypoint(
const Eigen::MatrixBase<DERIVED_P> & p,
const Eigen::MatrixBase<DERIVED_K> & outKeypoint) const;

template<typename DERIVED_P, typename DERIVED_K, typename DERIVED_JP>
bool euclideanToKeypoint(const Eigen::MatrixBase<DERIVED_P> & p,
const Eigen::MatrixBase<DERIVED_K> & outKeypoint,
const Eigen::MatrixBase<DERIVED_JP> & outJp) const;

template<typename DERIVED_P, typename DERIVED_K>
bool homogeneousToKeypoint(
const Eigen::MatrixBase<DERIVED_P> & p,
const Eigen::MatrixBase<DERIVED_K> & outKeypoint) const;

template<typename DERIVED_P, typename DERIVED_K, typename DERIVED_JP>
bool homogeneousToKeypoint(const Eigen::MatrixBase<DERIVED_P> & p,
const Eigen::MatrixBase<DERIVED_K> & outKeypoint,
const Eigen::MatrixBase<DERIVED_JP> & outJp) const;

template<typename DERIVED_K, typename DERIVED_P>
bool keypointToEuclidean(const Eigen::MatrixBase<DERIVED_K> & keypoint,
const Eigen::MatrixBase<DERIVED_P> & outPoint) const;

template<typename DERIVED_K, typename DERIVED_P, typename DERIVED_JK>
bool keypointToEuclidean(const Eigen::MatrixBase<DERIVED_K> & keypoint,
const Eigen::MatrixBase<DERIVED_P> & outPoint,
const Eigen::MatrixBase<DERIVED_JK> & outJk) const;

template<typename DERIVED_K, typename DERIVED_P>
bool keypointToHomogeneous(
const Eigen::MatrixBase<DERIVED_K> & keypoint,
const Eigen::MatrixBase<DERIVED_P> & outPoint) const;

template<typename DERIVED_K, typename DERIVED_P, typename DERIVED_JK>
bool keypointToHomogeneous(const Eigen::MatrixBase<DERIVED_K> & keypoint,
const Eigen::MatrixBase<DERIVED_P> & outPoint,
const Eigen::MatrixBase<DERIVED_JK> & outJk) const;

template<typename DERIVED_P, typename DERIVED_JI>
void euclideanToKeypointIntrinsicsJacobian(
const Eigen::MatrixBase<DERIVED_P> & p,
const Eigen::MatrixBase<DERIVED_JI> & outJi) const;

template<typename DERIVED_P, typename DERIVED_JD>
void euclideanToKeypointDistortionJacobian(
const Eigen::MatrixBase<DERIVED_P> & p,
const Eigen::MatrixBase<DERIVED_JD> & outJd) const;

template<typename DERIVED_P, typename DERIVED_JI>
void homogeneousToKeypointIntrinsicsJacobian(
const Eigen::MatrixBase<DERIVED_P> & p,
const Eigen::MatrixBase<DERIVED_JI> & outJi) const;

template<typename DERIVED_P, typename DERIVED_JD>
void homogeneousToKeypointDistortionJacobian(
const Eigen::MatrixBase<DERIVED_P> & p,
const Eigen::MatrixBase<DERIVED_JD> & outJd) const;

template<typename DERIVED_K>
bool isValid(const Eigen::MatrixBase<DERIVED_K> & keypoint) const;

template<typename DERIVED_K>
bool isLiftable(const Eigen::MatrixBase<DERIVED_K> & keypoint) const;

bool isUndistortedKeypointValid(const double rho2_d) const;

template<typename DERIVED_P>
bool isEuclideanVisible(const Eigen::MatrixBase<DERIVED_P> & p) const;

template<typename DERIVED_P>
bool isHomogeneousVisible(const Eigen::MatrixBase<DERIVED_P> & ph) const;

/// \brief initialize the intrinsics based on one view of a gridded calibration _target
/// \return true on success
bool initializeIntrinsics(const std::vector<GridCalibration_targetObservation> &observations);

/// \brief estimate the transformation of the camera with respect to the calibration _target
/// On success out_T_t_c is filled in with the transformation that takes points from
/// the camera frame to the _target frame
/// \return true on success
bool estimateTransformation(const GridCalibration_targetObservation & obs,
sm::kinematics::Transformation & out_T_t_c) const;

/// \brief compute the reprojection error based on a checkerboard observation.
/// \return the number of corners successfully observed and projected
size_t computeReprojectionError(
const GridCalibration_targetObservation & obs,
const sm::kinematics::Transformation & T__target_camera,
double & outErr) const;

// aslam::backend compatibility
void update(const double * v);
int minimalDimensions() const;
void getParameters(Eigen::MatrixXd & P) const;
void setParameters(const Eigen::MatrixXd & P);
Eigen::Vector2i parameterSize() const;

enum {
CLASS_SERIALIZATION_VERSION = 0
};BOOST_SERIALIZATION_SPLIT_MEMBER();
template<class Archive>
void load(Archive & ar, const unsigned int version);
template<class Archive>
void save(Archive & ar, const unsigned int version) const;

/// \brief creates a random valid keypoint.
virtual Eigen::VectorXd createRandomKeypoint() const;

/// \brief creates a random visible point. Negative depth means random between 0 and 100 meters.
virtual Eigen::Vector3d createRandomVisiblePoint(double depth = -1.0) const;

/// \brief is the projection invertible?
bool isProjectionInvertible() const {
return false;
}

/// \brief set the distortion model.
void setDistortion(const distortion_t & distortion) {
_distortion = distortion;
}
/// \brief returns a reference to the distortion model
distortion_t & distortion() {
return _distortion;
}
;
const distortion_t & distortion() const {
return _distortion;
}
;

Eigen::Matrix3d getCameraMatrix() {
Eigen::Matrix3d K;
K << _fu, 0.0, _cu, 0.0, _fv, _cv, 0.0, 0.0, 1.0;
return K;
}
;

/// \brief the xi1 parameter that controls the spherical projection.
double xi1() const {
return _xi1;
} /// \brief the xi2 parameter that controls the spherical projection.
double xi2() const {
return _xi2;
}
/// \brief The horizontal focal length in pixels.
double fu() const {
return _fu;
}
/// \brief The vertical focal length in pixels.
double fv() const {
return _fv;
}
/// \brief The horizontal image center in pixels.
double cu() const {
return _cu;
}
/// \brief The vertical image center in pixels.
double cv() const {
return _cv;
}
/// \brief The horizontal resolution in pixels.
int ru() const {
return _ru;
}
/// \brief The vertical resolution in pixels.
int rv() const {
return _rv;
}
/// \brief The horizontal resolution in pixels.
int width() const {
return _ru;
}
/// \brief The vertical resolution in pixels.
int height() const {
return _rv;
}

double focalLengthCol() const {
return _fu;
}
double focalLengthRow() const {
return _fv;
}
double opticalCenterCol() const {
return _cu;
}
double opticalCenterRow() const {
return _cv;
}

int keypointDimension() const {
return KeypointDimension;
}

bool isBinaryEqual(const DoubleSphereProjection<distortion_t> & rhs) const;

static DoubleSphereProjection<distortion_t> getTestProjection();
private:

// FIXME @demmeln: rename xi1 and xi2 to xi and alpha

/// \brief the xi1 parameter that controls the spherical projection.
double _xi1;
/// \brief the xi2 parameter that controls the spherical projection.
double _xi2;
/// \brief The horizontal focal length in pixels.
double _fu;
/// \brief The vertical focal length in pixels.
double _fv;
/// \brief The horizontal image center in pixels.
double _cu;
/// \brief The vertical image center in pixels.
double _cv;
/// \brief The horizontal resolution in pixels.
int _ru;
/// \brief The vertical resolution in pixels.
int _rv;

/// \brief A computed value for speeding up computation.
void updateTemporaries();

double _recip_fu;
double _recip_fv;
double _fu_over_fv;
double _one_over_2xi2_m_1;
double _fov_parameter; //!< parameter related to the valid region of the camera model

distortion_t _distortion;

};

} // namespace cameras
} // namespace aslam

#include "implementation/DoubleSphereProjection.hpp"

SM_BOOST_CLASS_VERSION_T1 (aslam::cameras::DoubleSphereProjection);

#endif /* ASLAM_CAMERAS_DOUBLE_SPHERE_PROJECTION_HPP */
Loading
  NODES
COMMUNITY 2
Idea 7
idea 7
Note 2
Project 66
USERS 1