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
Trying to put double sphere into python
  • Loading branch information
VladyslavUsenko committed Apr 1, 2018
commit dcf3df9e5432b3f525f49911f31d487500b853f2
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@

#include <aslam/cameras/OmniProjection.hpp>

namespace aslam {

namespace cameras {
Expand Down Expand Up @@ -472,7 +475,6 @@ void DoubleSphereProjection<DISTORTION_T>::euclideanToKeypointIntrinsicsJacobian

const double d1_2 = r2 + zz;
const double d1 = std::sqrt(d1_2);
const double d1_inv = double(1.0) / d1;

const double k = _xi1 * d1 + z;
const double kk = k * k;
Expand Down Expand Up @@ -520,6 +522,7 @@ void DoubleSphereProjection<DISTORTION_T>::euclideanToKeypointDistortionJacobian
Eigen::MatrixBase<DERIVED_JD> & J =
const_cast<Eigen::MatrixBase<DERIVED_JD> &>(outJd);

(void)(p);
J.setZero();


Expand Down Expand Up @@ -797,12 +800,22 @@ bool DoubleSphereProjection<DISTORTION_T>::initializeIntrinsics(const std::vecto
SM_DEFINE_EXCEPTION(Exception, std::runtime_error);
SM_ASSERT_TRUE(Exception, observations.size() != 0, "Need min. one observation");

bool success = true;


OmniProjection<DISTORTION_T> omni(1, _fu, _fv, _cu, _cv, _ru, _rv);
bool success = omni.initializeIntrinsics(observations);

if(success) {
_xi1 = 0;
_xi2 = 0.5 * omni.xi();
_fu = 0.5 * omni.fu();
_fv = 0.5 * omni.fv();
_cu = omni.cu();
_cv = omni.cv();

updateTemporaries();
}

//set the parameters
// _fu = gamma0;
// _fv = gamma0;
updateTemporaries();
return success;
} // initializeIntrinsics()

Expand Down
4 changes: 4 additions & 0 deletions aslam_cv/aslam_cameras/src/CameraGeometryBase.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,10 @@ boost::shared_ptr<CameraGeometryBase> CameraGeometryBase::create(
rval.reset(
new CameraGeometry<OmniProjection<EquidistantDistortion>, GlobalShutter,
NoMask>(config));
} else if (type == "DoubleSphere") {
rval.reset(
new CameraGeometry<DoubleSphereProjection<NoDistortion>, GlobalShutter, NoMask>(
config));
} else if (type == "PinholeRs") {
rval.reset(
new CameraGeometry<PinholeProjection<NoDistortion>, RollingShutter,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -86,3 +86,14 @@ class FovPinhole(CameraModel):
distortionType = aslam_cv.FovDistortion
shutterType = aslam_cv.GlobalShutter
frameType = aslam_cv.FovDistortedPinholeFrame

class DoubleSphere(CameraModel):
geometry = aslam_cv.DoubleSphereCameraGeometry
reprojectionError = DoubleSphereReprojectionError
reprojectionErrorSimple = DoubleSphereReprojectionErrorSimple
designVariable = DoubleSphereCameraGeometryDesignVariable
projectionType = aslam_cv.DoubleSphereProjection
distortionType = aslam_cv.NoDistortion
shutterType = aslam_cv.GlobalShutter
frameType = aslam_cv.DoubleSphereFrame

6 changes: 6 additions & 0 deletions aslam_cv/aslam_cv_backend_python/src/module.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,8 @@ BOOST_PYTHON_MODULE(libaslam_cv_backend_python)
aslam::python::exportReprojectionErrors<FovDistortedPinholeRsCameraGeometry>("FovDistortedPinholeRs");
aslam::python::exportCovarianceReprojectionError<FovDistortedPinholeRsCameraGeometry>("FovDistortedPinholeRs");

aslam::python::exportReprojectionErrors<DoubleSphereCameraGeometry>("DoubleSphere");

aslam::python::exportReprojectionErrors<OmniCameraGeometry>("Omni");
aslam::python::exportReprojectionErrors<OmniRsCameraGeometry>("OmniRs");
aslam::python::exportCovarianceReprojectionError<OmniRsCameraGeometry>("OmniRs");
Expand Down Expand Up @@ -74,6 +76,8 @@ BOOST_PYTHON_MODULE(libaslam_cv_backend_python)
exportCameraDesignVariables<EquidistantDistortedOmniRsCameraGeometry>("EquidistantDistortedOmniRsCameraGeometry");
exportCameraDesignVariables<FovDistortedOmniRsCameraGeometry>("FovDistortedOmniRsCameraGeometry");

exportCameraDesignVariables<DoubleSphereCameraGeometry>("DoubleSphereCameraGeometry");

exportCameraDesignVariables<OmniCameraGeometry>("OmniCameraGeometry");
exportCameraDesignVariables<DistortedOmniCameraGeometry>("DistortedOmniCameraGeometry");
exportCameraDesignVariables<EquidistantDistortedOmniCameraGeometry>("EquidistantDistortedOmniCameraGeometry");
Expand Down Expand Up @@ -115,6 +119,8 @@ BOOST_PYTHON_MODULE(libaslam_cv_backend_python)
exportGenericProjectionDesignVariable< PinholeProjection<EquidistantDistortion> >("EquidistantDistortedPinholeProjection");
exportGenericProjectionDesignVariable< PinholeProjection<FovDistortion> >("FovDistortedPinholeProjection");

exportGenericProjectionDesignVariable< DoubleSphereProjection<NoDistortion> >("DoubleSphereProjection");

exportGenericProjectionDesignVariable< OmniProjection<NoDistortion> >("OmniProjection");
exportGenericProjectionDesignVariable< OmniProjection<RadialTangentialDistortion> >("DistortedOmniProjection");
exportGenericProjectionDesignVariable< OmniProjection<EquidistantDistortion> >("EquidistantDistortedOmniProjection");
Expand Down
3 changes: 3 additions & 0 deletions aslam_cv/aslam_cv_python/src/CameraGeometries.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,9 @@ void exportCameraGeometries() {
exportCameraGeometry<FovDistortedOmniRsCameraGeometry>(
"FovDistortedOmniRsCameraGeometry");


exportCameraGeometry<DoubleSphereCameraGeometry>("DoubleSphereCameraGeometry");

exportCameraGeometry<OmniCameraGeometry>("OmniCameraGeometry");
exportCameraGeometry<DistortedOmniCameraGeometry>(
"DistortedOmniCameraGeometry");
Expand Down
50 changes: 50 additions & 0 deletions aslam_cv/aslam_cv_python/src/CameraProjections.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
#include <numpy_eigen/boost_python_headers.hpp>
#include <aslam/cameras/PinholeProjection.hpp>
#include <aslam/cameras/OmniProjection.hpp>
#include <aslam/cameras/DoubleSphereProjection.hpp>
#include <aslam/cameras/NoDistortion.hpp>
#include <aslam/cameras/EquidistantDistortion.hpp>
#include <aslam/cameras/FovDistortion.hpp>
Expand Down Expand Up @@ -289,6 +290,52 @@ void exportOmniProjection(std::string name) {

}

template<typename D>
void exportDoubleSphereProjection(std::string name) {

D & (DoubleSphereProjection<D>::*omnidistortion)() = &DoubleSphereProjection<D>::distortion;

class_<DoubleSphereProjection<D>, boost::shared_ptr<DoubleSphereProjection<D> > > doubleSphereProjection(
name.c_str(), init<>());
sm::python::unique_register_ptr_to_python<boost::shared_ptr<DoubleSphereProjection<D> > >();

doubleSphereProjection.def(init<>((name + "(distortion_t distortion)").c_str())).def(
init<double, double, double, double, double, double, int, int, D>(
(name
+ "(double xi1, double xi2, double focalLengthU, double focalLengthV, double imageCenterU, double imageCenterV, int resolutionU, int resolutionV, distortion_t distortion)")
.c_str())).def(
init<double, double, double, double, double, double, int, int>(
(name
+ "(double xi1, double xi2, double focalLengthU, double focalLengthV, double imageCenterU, double imageCenterV, int resolutionU, int resolutionV)")
.c_str()))
/// \brief the xi parameter that controls the spherical projection.
.def("xi1", &DoubleSphereProjection<D>::xi1)
/// \brief the xi parameter that controls the spherical projection.
.def("xi2", &DoubleSphereProjection<D>::xi2)
/// \brief The horizontal focal length in pixels.
.def("fu", &DoubleSphereProjection<D>::fu)
/// \brief The vertical focal length in pixels.
.def("fv", &DoubleSphereProjection<D>::fv)
/// \brief The horizontal image center in pixels.
.def("cu", &DoubleSphereProjection<D>::cu)
/// \brief The vertical image center in pixels.
.def("cv", &DoubleSphereProjection<D>::cv)
/// \brief The horizontal resolution in pixels.
.def("ru", &DoubleSphereProjection<D>::ru)
/// \brief The vertical resolution in pixels.
.def("rv", &DoubleSphereProjection<D>::rv).def("focalLengthCol",
&DoubleSphereProjection<D>::focalLengthCol)
.def("focalLengthRow", &DoubleSphereProjection<D>::focalLengthRow).def(
"opticalCenterCol", &DoubleSphereProjection<D>::opticalCenterCol).def(
"opticalCenterRow", &DoubleSphereProjection<D>::opticalCenterRow).def(
"distortion", omnidistortion, return_internal_reference<>()).def(
"setDistortion", &DoubleSphereProjection<D>::setDistortion).def_pickle(
sm::python::pickle_suite<DoubleSphereProjection<D> >());
exportGenericProjectionFunctions<DoubleSphereProjection<D> >(doubleSphereProjection);
//exportGenericProjectionDesignVariable< OmniProjection<D> >(name);

}

template<typename D>
void exportPinholeProjection(std::string name) {

Expand Down Expand Up @@ -368,6 +415,9 @@ void exportCameraProjections() {
exportOmniProjection<RadialTangentialDistortion>("DistortedOmniProjection");
exportOmniProjection<FovDistortion>("FovOmniProjection");

exportDoubleSphereProjection<NoDistortion>("DoubleSphereProjection");


// distortion:
// exportAPrioriInformationError<aslam::backend::DesignVariableAdapter< RadialTangentialDistortion > >("RadialTangentialDistortionAPrioriInformationError");
// exportAPrioriInformationError<aslam::backend::DesignVariableAdapter< PinholeProjection<RadialTangentialDistortion> > >("DistortedPinholeProjectionAPrioriInformationError");
Expand Down
2 changes: 2 additions & 0 deletions aslam_cv/aslam_cv_python/src/Frame.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -184,6 +184,8 @@ void exportFrame() {

//aslam::python::exportCovarianceReprojectionError<DistortedPinholeRsCameraGeometry>("DistortedPinholeRsFrameCovarianceReprojectionError");

aslam::python::exportFrame<DoubleSphereCameraGeometry>("DoubleSphereFrame");

aslam::python::exportFrame<OmniCameraGeometry>("OmniFrame");
aslam::python::exportFrame<DistortedOmniCameraGeometry>("DistortedOmniFrame");
aslam::python::exportFrame<MaskedDistortedOmniCameraGeometry>(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,8 @@ def initBagDataset(bagfile, topic, from_to):
cameraModels = { 'pinhole-radtan': acvb.DistortedPinhole,
'pinhole-equi': acvb.EquidistantPinhole,
'pinhole-fov': acvb.FovPinhole,
'omni-radtan': acvb.DistortedOmni }
'omni-radtan': acvb.DistortedOmni,
'ds': acvb.DoubleSphere}

def signal_exit(signal, frame):
sm.logWarn("Shutdown requested! (CTRL+C)")
Expand Down
  NODES
COMMUNITY 2
Idea 2
idea 2
INTERN 1
Note 2
Project 93
USERS 1