MRPT
2.0.1
|
Parameters for the Brown-Conrady camera lens distortion model.
The parameters obtained for one camera resolution can be used for any other resolution by means of the method TCamera::scaleToResolution()
#include <mrpt/img/TCamera.h>
Public Member Functions | |
TCamera () | |
void | scaleToResolution (unsigned int new_ncols, unsigned int new_nrows) |
Rescale all the parameters for a new camera resolution (it raises an exception if the aspect ratio is modified, which is not permitted). More... | |
void | saveToConfigFile (const std::string §ion, mrpt::config::CConfigFileBase &cfg) const |
Save as a config block: More... | |
void | loadFromConfigFile (const std::string §ion, const mrpt::config::CConfigFileBase &cfg) |
Load all the params from a config source, in the format used in saveToConfigFile(), that is: More... | |
void | loadFromConfigFile (const mrpt::config::CConfigFileBase &cfg, const std::string §ion) |
overload This signature is consistent with the rest of MRPT APIs More... | |
std::string | dumpAsText () const |
Dumps all the parameters as a multi-line string, with the same format than saveToConfigFile. More... | |
void | setIntrinsicParamsFromValues (double fx, double fy, double cx, double cy) |
Set the matrix of intrinsic params of the camera from the individual values of focal length and principal point coordinates (in pixels) More... | |
void | getDistortionParamsVector (mrpt::math::CMatrixDouble15 &distParVector) const |
Get the vector of distortion params of the camera. More... | |
std::vector< double > | getDistortionParamsAsVector () const |
Get a vector with the distortion params of the camera. More... | |
void | setDistortionParamsVector (const mrpt::math::CMatrixDouble15 &distParVector) |
Set the whole vector of distortion params of the camera. More... | |
template<class VECTORLIKE > | |
void | setDistortionParamsVector (const VECTORLIKE &distParVector) |
Set the whole vector of distortion params of the camera from a 4, 5, or 8-vector (see definition of dist for parameter order) More... | |
void | setDistortionParamsFromValues (double k1, double k2, double p1, double p2, double k3=0) |
Set the vector of distortion params of the camera from the individual values of the distortion coefficients. More... | |
double | cx () const |
Get the value of the principal point x-coordinate (in pixels). More... | |
double | cy () const |
Get the value of the principal point y-coordinate (in pixels). More... | |
double | fx () const |
Get the value of the focal length x-value (in pixels). More... | |
double | fy () const |
Get the value of the focal length y-value (in pixels). More... | |
void | cx (double val) |
Set the value of the principal point x-coordinate (in pixels). More... | |
void | cy (double val) |
Set the value of the principal point y-coordinate (in pixels). More... | |
void | fx (double val) |
Set the value of the focal length x-value (in pixels). More... | |
void | fy (double val) |
Set the value of the focal length y-value (in pixels). More... | |
double | k1 () const |
Get the value of the k1 distortion parameter. More... | |
double | k2 () const |
Get the value of the k2 distortion parameter. More... | |
double | p1 () const |
Get the value of the p1 distortion parameter. More... | |
double | p2 () const |
Get the value of the p2 distortion parameter. More... | |
double | k3 () const |
Get the value of the k3 distortion parameter. More... | |
double | k4 () const |
Get the value of the k4 distortion parameter. More... | |
double | k5 () const |
Get the value of the k5 distortion parameter. More... | |
double | k6 () const |
Get the value of the k6 distortion parameter. More... | |
void | k1 (double val) |
Set the value of the k1 distortion parameter. More... | |
void | k2 (double val) |
Set the value of the k2 distortion parameter. More... | |
void | p1 (double val) |
Set the value of the p1 distortion parameter. More... | |
void | p2 (double val) |
Set the value of the p2 distortion parameter. More... | |
void | k3 (double val) |
Set the value of the k3 distortion parameter. More... | |
void | k4 (double val) |
Set the value of the k4 distortion parameter. More... | |
void | k5 (double val) |
Set the value of the k5 distortion parameter. More... | |
void | k6 (double val) |
Set the value of the k6 distortion parameter. More... | |
virtual mxArray * | writeToMatlab () const |
Introduces a pure virtual method responsible for writing to a mxArray Matlab object, typically a MATLAB struct whose contents are documented in each derived class. More... | |
RTTI classes and functions for polymorphic hierarchies | |
mrpt::rtti::CObject::Ptr | duplicateGetSmartPtr () const |
Makes a deep copy of the object and returns a smart pointer to it. More... | |
Public Attributes | |
Camera parameters | |
uint32_t | ncols {640} |
Camera resolution. More... | |
uint32_t | nrows {480} |
mrpt::math::CMatrixDouble33 | intrinsicParams |
Matrix of intrinsic parameters (containing the focal length and principal point coordinates): More... | |
std::array< double, 8 > | dist {{.0, .0, .0, .0, .0, .0, .0, .0}} |
[k1 k2 t1 t2 k3 k4 k5 k6] -> k_i: parameters of radial distortion, t_i: parameters of tangential distortion (default=0) More... | |
double | focalLengthMeters {.0} |
The focal length of the camera, in meters (can be used among 'intrinsicParams' to determine the pixel size). More... | |
Protected Member Functions | |
CSerializable virtual methods | |
uint8_t | serializeGetVersion () const override |
Must return the current versioning number of the object. More... | |
void | serializeTo (mrpt::serialization::CArchive &out) const override |
Pure virtual method for writing (serializing) to an abstract archive. More... | |
void | serializeFrom (mrpt::serialization::CArchive &in, uint8_t serial_version) override |
Pure virtual method for reading (deserializing) from an abstract archive. More... | |
CSerializable virtual methods | |
virtual void | serializeTo (CSchemeArchiveBase &out) const |
Virtual method for writing (serializing) to an abstract schema based archive. More... | |
virtual void | serializeFrom (CSchemeArchiveBase &in) |
Virtual method for reading (deserializing) from an abstract schema based archive. More... | |
RTTI stuff | |
using | Ptr = std::shared_ptr< mrpt::img ::TCamera > |
using | ConstPtr = std::shared_ptr< const mrpt::img ::TCamera > |
using | UniquePtr = std::unique_ptr< mrpt::img ::TCamera > |
using | ConstUniquePtr = std::unique_ptr< const mrpt::img ::TCamera > |
static const mrpt::rtti::TRuntimeClassId | runtimeClassId |
static constexpr const char * | className = "mrpt::img" "::" "TCamera" |
static const mrpt::rtti::TRuntimeClassId * | _GetBaseClass () |
static constexpr auto | getClassName () |
static const mrpt::rtti::TRuntimeClassId & | GetRuntimeClassIdStatic () |
static std::shared_ptr< CObject > | CreateObject () |
template<typename... Args> | |
static Ptr | Create (Args &&... args) |
template<typename Alloc , typename... Args> | |
static Ptr | CreateAlloc (const Alloc &alloc, Args &&... args) |
template<typename... Args> | |
static UniquePtr | CreateUnique (Args &&... args) |
virtual const mrpt::rtti::TRuntimeClassId * | GetRuntimeClass () const override |
Returns information about the class of an object in runtime. More... | |
virtual mrpt::rtti::CObject * | clone () const override |
Returns a deep copy (clone) of the object, indepently of its class. More... | |
using mrpt::img::TCamera::ConstPtr = std::shared_ptr<const mrpt::img :: TCamera > |
using mrpt::img::TCamera::ConstUniquePtr = std::unique_ptr<const mrpt::img :: TCamera > |
using mrpt::img::TCamera::Ptr = std::shared_ptr< mrpt::img :: TCamera > |
using mrpt::img::TCamera::UniquePtr = std::unique_ptr< mrpt::img :: TCamera > |
TCamera::TCamera | ( | ) |
Definition at line 26 of file TCamera.cpp.
|
staticprotected |
|
overridevirtual |
Returns a deep copy (clone) of the object, indepently of its class.
Implements mrpt::rtti::CObject.
|
inlinestatic |
|
inlinestatic |
|
static |
|
inlinestatic |
|
inline |
Get the value of the principal point x-coordinate (in pixels).
Definition at line 171 of file TCamera.h.
References intrinsicParams.
Referenced by mrpt::obs::detail::cam2vec(), mrpt::vision::checkerBoardStereoCalibration(), mrpt::hwdrivers::CKinect::CKinect(), DECLARE_MEXPLUS_FROM(), fillSampleObs(), mrpt::maps::detail::pointmap_traits< CColouredPointsMap >::internal_loadFromRangeScan3D_init(), mrpt::vision::projectMatchedFeatures(), mrpt::vision::pinhole::projectPoint_no_distortion(), mrpt::vision::recompute_errors_and_Jacobians(), setIntrinsicParamsFromValues(), mrpt::vision::StereoObs2BRObs(), mrpt::vision::pinhole::undistort_point(), and mrpt::vision::pinhole::undistort_points().
|
inline |
Set the value of the principal point x-coordinate (in pixels).
Definition at line 179 of file TCamera.h.
References intrinsicParams, and val.
|
inline |
Get the value of the principal point y-coordinate (in pixels).
Definition at line 173 of file TCamera.h.
References intrinsicParams.
Referenced by mrpt::obs::detail::cam2vec(), mrpt::vision::checkerBoardStereoCalibration(), mrpt::hwdrivers::CKinect::CKinect(), DECLARE_MEXPLUS_FROM(), fillSampleObs(), mrpt::maps::detail::pointmap_traits< CColouredPointsMap >::internal_loadFromRangeScan3D_init(), mrpt::vision::projectMatchedFeatures(), mrpt::vision::pinhole::projectPoint_no_distortion(), mrpt::vision::recompute_errors_and_Jacobians(), setIntrinsicParamsFromValues(), mrpt::vision::StereoObs2BRObs(), mrpt::vision::pinhole::undistort_point(), and mrpt::vision::pinhole::undistort_points().
|
inline |
Set the value of the principal point y-coordinate (in pixels).
Definition at line 181 of file TCamera.h.
References intrinsicParams, and val.
std::string TCamera::dumpAsText | ( | ) | const |
Dumps all the parameters as a multi-line string, with the same format than saveToConfigFile.
Definition at line 34 of file TCamera.cpp.
References mrpt::config::CConfigFileMemory::getContent().
Referenced by mrpt::hwdrivers::CMyntEyeCamera::CMyntEyeCamera().
|
inlineinherited |
Makes a deep copy of the object and returns a smart pointer to it.
Definition at line 204 of file CObject.h.
References mrpt::rtti::CObject::clone().
Referenced by mrpt::obs::CRawlog::insert().
|
inline |
Get the value of the focal length x-value (in pixels).
Definition at line 175 of file TCamera.h.
References intrinsicParams.
Referenced by mrpt::obs::detail::cam2vec(), mrpt::vision::checkerBoardStereoCalibration(), mrpt::hwdrivers::CKinect::CKinect(), DECLARE_MEXPLUS_FROM(), fillSampleObs(), mrpt::vision::frameJac(), mrpt::maps::detail::pointmap_traits< CColouredPointsMap >::internal_loadFromRangeScan3D_init(), mrpt::vision::pointJac(), mrpt::vision::projectMatchedFeatures(), mrpt::vision::pinhole::projectPoint_no_distortion(), mrpt::vision::recompute_errors_and_Jacobians(), setIntrinsicParamsFromValues(), mrpt::vision::StereoObs2BRObs(), mrpt::vision::pinhole::undistort_point(), and mrpt::vision::pinhole::undistort_points().
|
inline |
Set the value of the focal length x-value (in pixels).
Definition at line 183 of file TCamera.h.
References intrinsicParams, and val.
|
inline |
Get the value of the focal length y-value (in pixels).
Definition at line 177 of file TCamera.h.
References intrinsicParams.
Referenced by mrpt::obs::detail::cam2vec(), mrpt::vision::checkerBoardStereoCalibration(), mrpt::hwdrivers::CKinect::CKinect(), DECLARE_MEXPLUS_FROM(), fillSampleObs(), mrpt::vision::frameJac(), mrpt::maps::detail::pointmap_traits< CColouredPointsMap >::internal_loadFromRangeScan3D_init(), mrpt::vision::pointJac(), mrpt::vision::pinhole::projectPoint_no_distortion(), mrpt::vision::recompute_errors_and_Jacobians(), setIntrinsicParamsFromValues(), mrpt::vision::pinhole::undistort_point(), and mrpt::vision::pinhole::undistort_points().
|
inline |
Set the value of the focal length y-value (in pixels).
Definition at line 185 of file TCamera.h.
References intrinsicParams, and val.
|
inlinestatic |
|
inline |
Get a vector with the distortion params of the camera.
Definition at line 131 of file TCamera.h.
References dist.
Referenced by mrpt::vision::checkerBoardCameraCalibration().
|
inline |
Get the vector of distortion params of the camera.
Definition at line 123 of file TCamera.h.
References dist, and mrpt::math::CMatrixFixed< T, ROWS, COLS >::size().
|
overridevirtual |
Returns information about the class of an object in runtime.
Reimplemented from mrpt::serialization::CSerializable.
|
static |
|
inline |
Get the value of the k1 distortion parameter.
Definition at line 187 of file TCamera.h.
References dist.
Referenced by mrpt::vision::checkerBoardStereoCalibration(), mrpt::vision::recompute_errors_and_Jacobians(), and setDistortionParamsFromValues().
|
inline |
|
inline |
Get the value of the k2 distortion parameter.
Definition at line 189 of file TCamera.h.
References dist.
Referenced by mrpt::vision::checkerBoardStereoCalibration(), mrpt::vision::recompute_errors_and_Jacobians(), and setDistortionParamsFromValues().
|
inline |
|
inline |
Get the value of the k3 distortion parameter.
Definition at line 195 of file TCamera.h.
References dist.
Referenced by mrpt::vision::checkerBoardStereoCalibration(), mrpt::vision::recompute_errors_and_Jacobians(), and setDistortionParamsFromValues().
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
void TCamera::loadFromConfigFile | ( | const std::string & | section, |
const mrpt::config::CConfigFileBase & | cfg | ||
) |
Load all the params from a config source, in the format used in saveToConfigFile(), that is:
Load all the params from a config source, in the format described in saveToConfigFile()
std::exception | on missing fields |
Definition at line 165 of file TCamera.cpp.
References mrpt::config::CConfigFileBase::read_double(), mrpt::config::CConfigFileBase::read_vector(), mrpt::math::CVectorDynamic< T >::size(), and THROW_EXCEPTION.
Referenced by mrpt::hwdrivers::CRovio::loadConfig(), mrpt::hwdrivers::CSwissRanger3DCamera::loadConfig_sensorSpecific(), and loadFromConfigFile().
|
inline |
overload This signature is consistent with the rest of MRPT APIs
Definition at line 98 of file TCamera.h.
References loadFromConfigFile().
|
inline |
Get the value of the p1 distortion parameter.
Definition at line 191 of file TCamera.h.
References dist.
Referenced by mrpt::vision::checkerBoardStereoCalibration(), mrpt::vision::recompute_errors_and_Jacobians(), and setDistortionParamsFromValues().
|
inline |
|
inline |
Get the value of the p2 distortion parameter.
Definition at line 193 of file TCamera.h.
References dist.
Referenced by mrpt::vision::checkerBoardStereoCalibration(), mrpt::vision::recompute_errors_and_Jacobians(), and setDistortionParamsFromValues().
|
inline |
void TCamera::saveToConfigFile | ( | const std::string & | section, |
mrpt::config::CConfigFileBase & | cfg | ||
) | const |
Save as a config block:
Definition at line 143 of file TCamera.cpp.
References mrpt::format(), and mrpt::config::CConfigFileBase::write().
void TCamera::scaleToResolution | ( | unsigned int | new_ncols, |
unsigned int | new_nrows | ||
) |
Rescale all the parameters for a new camera resolution (it raises an exception if the aspect ratio is modified, which is not permitted).
Definition at line 203 of file TCamera.cpp.
References ASSERT_, and ASSERTMSG_.
Referenced by mrpt::hwdrivers::CSwissRanger3DCamera::getNextObservation(), and mrpt::img::TStereoCamera::scaleToResolution().
|
overrideprotectedvirtual |
Pure virtual method for reading (deserializing) from an abstract archive.
Users don't call this method directly. Instead, use stream >> object;
.
in | The input binary stream where the object data must read from. |
version | The version of the object stored in the stream: use this version number in your code to know how to read the incoming data. |
std::exception | On any I/O error |
Implements mrpt::serialization::CSerializable.
Definition at line 52 of file TCamera.cpp.
References MRPT_THROW_UNKNOWN_SERIALIZATION_VERSION.
|
inlineprotectedvirtualinherited |
Virtual method for reading (deserializing) from an abstract schema based archive.
Definition at line 74 of file CSerializable.h.
References mrpt::serialization::CSerializable::GetRuntimeClass(), and THROW_EXCEPTION.
|
overrideprotectedvirtual |
Must return the current versioning number of the object.
Start in zero for new classes, and increments each time there is a change in the stored format.
Implements mrpt::serialization::CSerializable.
Definition at line 41 of file TCamera.cpp.
|
overrideprotectedvirtual |
Pure virtual method for writing (serializing) to an abstract archive.
Users don't call this method directly. Instead, use stream << object;
.
std::exception | On any I/O error |
Implements mrpt::serialization::CSerializable.
Definition at line 42 of file TCamera.cpp.
References out.
|
inlineprotectedvirtualinherited |
Virtual method for writing (serializing) to an abstract schema based archive.
Definition at line 64 of file CSerializable.h.
References mrpt::serialization::CSerializable::GetRuntimeClass(), and THROW_EXCEPTION.
|
inline |
Set the vector of distortion params of the camera from the individual values of the distortion coefficients.
Definition at line 160 of file TCamera.h.
References dist, k1(), k2(), k3(), p1(), and p2().
Referenced by mrpt::hwdrivers::TCaptureOptions_DUO3D::m_camera_int_params_from_yml(), and mrpt::hwdrivers::CRovio::TOptions::TOptions().
|
inline |
|
inline |
|
inline |
Set the matrix of intrinsic params of the camera from the individual values of focal length and principal point coordinates (in pixels)
Definition at line 111 of file TCamera.h.
References cx(), cy(), fx(), fy(), intrinsicParams, and mrpt::math::MatrixVectorBase< Scalar, Derived >::setZero().
Referenced by mrpt::hwdrivers::CImageGrabber_FlyCapture2::getObservation(), and mrpt::hwdrivers::TCaptureOptions_DUO3D::m_camera_int_params_from_yml().
|
inlinevirtualinherited |
Introduces a pure virtual method responsible for writing to a mxArray
Matlab object, typically a MATLAB struct
whose contents are documented in each derived class.
mxArray
(caller is responsible of memory freeing) or nullptr is class does not support conversion to MATLAB. Definition at line 90 of file CSerializable.h.
|
static |
std::array<double, 8> mrpt::img::TCamera::dist {{.0, .0, .0, .0, .0, .0, .0, .0}} |
[k1 k2 t1 t2 k3 k4 k5 k6] -> k_i: parameters of radial distortion, t_i: parameters of tangential distortion (default=0)
Definition at line 53 of file TCamera.h.
Referenced by mrpt::obs::detail::cam2vec(), mrpt::hwdrivers::CKinect::CKinect(), mrpt::vision::computeStereoRectificationMaps(), mrpt::hwdrivers::CSwissRanger3DCamera::CSwissRanger3DCamera(), DECLARE_MEXPLUS_FROM(), getDistortionParamsAsVector(), getDistortionParamsVector(), k1(), k2(), k3(), k4(), k5(), k6(), mrpt::hwdrivers::TCaptureOptions_DUO3D::m_camera_int_params_from_yml(), mrpt::img::operator==(), p1(), p2(), setDistortionParamsFromValues(), setDistortionParamsVector(), mrpt::vision::CUndistortMap::setFromCamParams(), mrpt::vision::CStereoRectifyMap::setFromCamParams(), mrpt::img::CImage::undistort(), mrpt::obs::CObservation3DRangeScan::undistort(), mrpt::vision::pinhole::undistort_point(), mrpt::vision::pinhole::undistort_points(), and mrpt::obs::detail::vec2cam().
double mrpt::img::TCamera::focalLengthMeters {.0} |
The focal length of the camera, in meters (can be used among 'intrinsicParams' to determine the pixel size).
Definition at line 56 of file TCamera.h.
Referenced by mrpt::img::operator==(), and mrpt::obs::CObservation3DRangeScan::recoverCameraCalibrationParameters().
mrpt::math::CMatrixDouble33 mrpt::img::TCamera::intrinsicParams |
Matrix of intrinsic parameters (containing the focal length and principal point coordinates):
[ fx 0 cx ] A = [ 0 fy cy ] [ 0 0 1 ]
Definition at line 50 of file TCamera.h.
Referenced by mrpt::vision::checkerBoardCameraCalibration(), mrpt::vision::computeStereoRectificationMaps(), mrpt::hwdrivers::CSwissRanger3DCamera::CSwissRanger3DCamera(), cx(), cy(), fx(), fy(), mrpt::maps::CLandmarksMap::loadSiftFeaturesFromImageObservation(), mrpt::maps::CLandmarksMap::loadSiftFeaturesFromStereoImageObservation(), mrpt::hwdrivers::TCaptureOptions_DUO3D::m_camera_int_params_from_yml(), mrpt::img::operator==(), mrpt::obs::CObservation3DRangeScan::recoverCameraCalibrationParameters(), mrpt::vision::CUndistortMap::setFromCamParams(), mrpt::vision::CStereoRectifyMap::setFromCamParams(), setIntrinsicParamsFromValues(), mrpt::hwdrivers::CRovio::TOptions::TOptions(), mrpt::img::CImage::undistort(), mrpt::obs::CObservation3DRangeScan::undistort(), mrpt::vision::pinhole::undistort_points(), and mrpt::obs::detail::vec2cam().
uint32_t mrpt::img::TCamera::ncols {640} |
Camera resolution.
Definition at line 40 of file TCamera.h.
Referenced by mrpt::vision::checkerBoardStereoCalibration(), mrpt::hwdrivers::CKinect::CKinect(), mrpt::hwdrivers::COpenNI2Sensor::cols(), mrpt::hwdrivers::CKinect::cols(), mrpt::vision::computeStereoRectificationMaps(), mrpt::hwdrivers::CSwissRanger3DCamera::CSwissRanger3DCamera(), DECLARE_MEXPLUS_FROM(), do_rectify(), fillSampleObs(), mrpt::hwdrivers::CKinect::getNextObservation(), isValidParameter(), mrpt::hwdrivers::TCaptureOptions_DUO3D::loadOptionsFrom(), mrpt::hwdrivers::CKinect::open(), mrpt::img::operator==(), mrpt::obs::CObservation3DRangeScan::recoverCameraCalibrationParameters(), mrpt::vision::CUndistortMap::setFromCamParams(), and mrpt::vision::CStereoRectifyMap::setFromCamParams().
uint32_t mrpt::img::TCamera::nrows {480} |
Definition at line 40 of file TCamera.h.
Referenced by mrpt::vision::checkerBoardStereoCalibration(), mrpt::hwdrivers::CKinect::CKinect(), mrpt::vision::computeStereoRectificationMaps(), mrpt::hwdrivers::CSwissRanger3DCamera::CSwissRanger3DCamera(), DECLARE_MEXPLUS_FROM(), do_rectify(), fillSampleObs(), mrpt::hwdrivers::CKinect::getNextObservation(), isValidParameter(), mrpt::hwdrivers::TCaptureOptions_DUO3D::loadOptionsFrom(), mrpt::hwdrivers::CKinect::open(), mrpt::img::operator==(), mrpt::obs::CObservation3DRangeScan::recoverCameraCalibrationParameters(), mrpt::hwdrivers::COpenNI2Sensor::rows(), mrpt::hwdrivers::CKinect::rows(), mrpt::vision::CUndistortMap::setFromCamParams(), and mrpt::vision::CStereoRectifyMap::setFromCamParams().
|
staticprotected |
Page generated by Doxygen 1.8.14 for MRPT 2.0.1 Git: 0fef1a6d7 Fri Apr 3 23:00:21 2020 +0200 at vie abr 3 23:20:28 CEST 2020 |