Merge branch 'develop' into feature/LPSolver
						commit
						bcb5ca97e0
					
				|  | @ -0,0 +1,31 @@ | |||
| /* ----------------------------------------------------------------------------
 | ||||
| 
 | ||||
|  * GTSAM Copyright 2010, Georgia Tech Research Corporation, | ||||
|  * Atlanta, Georgia 30332-0415 | ||||
|  * All Rights Reserved | ||||
|  * Authors: Frank Dellaert, et al. (see THANKS for the full author list) | ||||
| 
 | ||||
|  * See LICENSE for the license information | ||||
| 
 | ||||
|  * -------------------------------------------------------------------------- */ | ||||
| 
 | ||||
| /**
 | ||||
|  * @brief common macros used by handwritten exports of the python module | ||||
|  * @author Ellon Paiva Mendes (LAAS-CNRS) | ||||
|  **/ | ||||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
|  /* Fix to avoid registration warnings */ | ||||
| // Solution taken from https://github.com/BVLC/caffe/pull/4069/commits/673e8cfc0b8f05f9fa3ebbad7cc6202822e5d9c5 
 | ||||
| #define REGISTER_SHARED_PTR_TO_PYTHON(PTR) do { \ | ||||
|   const boost::python::type_info info = \ | ||||
|     boost::python::type_id<boost::shared_ptr<PTR > >(); \ | ||||
|   const boost::python::converter::registration* reg = \ | ||||
|     boost::python::converter::registry::query(info); \ | ||||
|   if (reg == NULL) { \ | ||||
|     boost::python::register_ptr_to_python<boost::shared_ptr<PTR > >(); \ | ||||
|   } else if ((*reg).m_to_python == NULL) { \ | ||||
|     boost::python::register_ptr_to_python<boost::shared_ptr<PTR > >(); \ | ||||
|   } \ | ||||
| } while (0) | ||||
|  | @ -28,6 +28,8 @@ | |||
| 
 | ||||
| #include "gtsam/linear/NoiseModel.h" | ||||
| 
 | ||||
| #include "python/handwritten/common.h" | ||||
| 
 | ||||
| using namespace boost::python; | ||||
| using namespace gtsam; | ||||
| using namespace gtsam::noiseModel; | ||||
|  | @ -110,7 +112,7 @@ void exportNoiseModels(){ | |||
|     .def("Covariance",&Gaussian::Covariance, Gaussian_Covariance_overloads()) | ||||
|     .staticmethod("Covariance") | ||||
|   ; | ||||
|   register_ptr_to_python< boost::shared_ptr<Gaussian> >(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(Gaussian); | ||||
|    | ||||
|   class_<Diagonal, boost::shared_ptr<Diagonal>, bases<Gaussian> >("Diagonal", no_init) | ||||
|     .def("Sigmas",&Diagonal::Sigmas, Diagonal_Sigmas_overloads()) | ||||
|  | @ -120,7 +122,7 @@ void exportNoiseModels(){ | |||
|     .def("Precisions",&Diagonal::Precisions, Diagonal_Precisions_overloads()) | ||||
|     .staticmethod("Precisions") | ||||
|   ; | ||||
|   register_ptr_to_python< boost::shared_ptr<Diagonal> >(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(Diagonal); | ||||
|    | ||||
|   class_<Isotropic, boost::shared_ptr<Isotropic>, bases<Diagonal> >("Isotropic", no_init) | ||||
|     .def("Sigma",&Isotropic::Sigma, Isotropic_Sigma_overloads()) | ||||
|  | @ -130,12 +132,12 @@ void exportNoiseModels(){ | |||
|     .def("Precision",&Isotropic::Precision, Isotropic_Precision_overloads()) | ||||
|     .staticmethod("Precision") | ||||
|   ; | ||||
|   register_ptr_to_python< boost::shared_ptr<Isotropic> >(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(Isotropic); | ||||
|    | ||||
|   class_<Unit, boost::shared_ptr<Unit>, bases<Isotropic> >("Unit", no_init) | ||||
|     .def("Create",&Unit::Create) | ||||
|     .staticmethod("Create") | ||||
|   ; | ||||
| 
 | ||||
|   register_ptr_to_python< boost::shared_ptr<Unit> >(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(Unit); | ||||
| } | ||||
|  |  | |||
|  | @ -22,6 +22,8 @@ | |||
| #include "gtsam/navigation/ImuFactor.h" | ||||
| #include "gtsam/navigation/GPSFactor.h" | ||||
| 
 | ||||
| #include "python/handwritten/common.h" | ||||
| 
 | ||||
| using namespace boost::python; | ||||
| using namespace gtsam; | ||||
| 
 | ||||
|  | @ -78,7 +80,7 @@ void exportImuFactor() { | |||
|       .staticmethod("MakeSharedU"); | ||||
| 
 | ||||
|   // NOTE(frank): https://mail.python.org/pipermail/cplusplus-sig/2016-January/017362.html
 | ||||
|   register_ptr_to_python< boost::shared_ptr<PreintegrationParams> >(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(PreintegrationParams); | ||||
| 
 | ||||
|   class_<PreintegrationType>( | ||||
| #ifdef GTSAM_TANGENT_PREINTEGRATION | ||||
|  | @ -105,21 +107,21 @@ void exportImuFactor() { | |||
|       .def("error", &ImuFactor::error) | ||||
|       .def(init<Key, Key, Key, Key, Key, const PreintegratedImuMeasurements&>()) | ||||
|       .def(repr(self)); | ||||
|   register_ptr_to_python<boost::shared_ptr<ImuFactor>>(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(ImuFactor); | ||||
| 
 | ||||
|   class_<ImuFactor2, bases<NonlinearFactor>, boost::shared_ptr<ImuFactor2>>("ImuFactor2") | ||||
|       .def("error", &ImuFactor2::error) | ||||
|       .def(init<Key, Key, Key, const PreintegratedImuMeasurements&>()) | ||||
|       .def(repr(self)); | ||||
|   register_ptr_to_python<boost::shared_ptr<ImuFactor2>>(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(ImuFactor2); | ||||
| 
 | ||||
|   class_<GPSFactor, bases<NonlinearFactor>, boost::shared_ptr<GPSFactor>>("GPSFactor") | ||||
|       .def("error", &GPSFactor::error) | ||||
|       .def(init<Key, const Point3&, noiseModel::Base::shared_ptr>()); | ||||
|   register_ptr_to_python<boost::shared_ptr<GPSFactor>>(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(GPSFactor); | ||||
| 
 | ||||
|   class_<GPSFactor2, bases<NonlinearFactor>, boost::shared_ptr<GPSFactor2>>("GPSFactor2") | ||||
|       .def("error", &GPSFactor2::error) | ||||
|       .def(init<Key, const Point3&, noiseModel::Base::shared_ptr>()); | ||||
|   register_ptr_to_python<boost::shared_ptr<GPSFactor2>>(); | ||||
|   REGISTER_SHARED_PTR_TO_PYTHON(GPSFactor2); | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue