Ocean
|
This class implements the abstract base class for all AnyCamera objects. More...
#include <AnyCamera.h>
Public Types | |
typedef T | TScalar |
The scalar data type of this object. | |
Public Member Functions | |
virtual | ~AnyCameraT ()=default |
Destructs the AnyCamera object. | |
virtual AnyCameraType | anyCameraType () const =0 |
Returns the type of this camera. | |
virtual std::string | name () const =0 |
Returns the name of this camera. | |
virtual std::unique_ptr< AnyCameraT< T > > | clone (const unsigned int width=0u, const unsigned int height=0u) const =0 |
Returns a copy of this camera object. | |
virtual std::unique_ptr< AnyCameraT< float > > | cloneToFloat (const unsigned int width=0u, const unsigned int height=0u) const =0 |
Returns a copy of this camera object with float precision. | |
virtual std::unique_ptr< AnyCameraT< double > > | cloneToDouble (const unsigned int width=0u, const unsigned int height=0u) const =0 |
Returns a copy of this camera object with double precision. | |
virtual unsigned int | width () const =0 |
Returns the width of the camera image. | |
virtual unsigned int | height () const =0 |
Returns the height of the camera image. | |
virtual VectorT2< T > | principalPoint () const =0 |
Returns the coordinate of the principal point of the camera image in the pixel domain. | |
virtual T | principalPointX () const =0 |
Returns the x-value of the principal point of the camera image in the pixel domain. | |
virtual T | principalPointY () const =0 |
Returns the y-value of the principal point of the camera image in the pixel domain. | |
virtual T | focalLengthX () const =0 |
Returns the horizontal focal length parameter. | |
virtual T | focalLengthY () const =0 |
Returns the vertical focal length parameter. | |
virtual T | inverseFocalLengthX () const =0 |
Returns the inverse horizontal focal length parameter. | |
virtual T | inverseFocalLengthY () const =0 |
Returns the inverse vertical focal length parameter. | |
virtual T | fovX () const =0 |
Returns the field of view in x direction of the camera. | |
virtual T | fovY () const =0 |
Returns the field of view in x direction of the camera. | |
virtual bool | isInside (const VectorT2< T > &imagePoint, const T signedBorder=T(0)) const =0 |
Returns whether a given 2D image point lies inside the camera frame. | |
virtual VectorT2< T > | projectToImage (const VectorT3< T > &objectPoint) const =0 |
Projects a 3D object point into the camera frame. | |
virtual VectorT2< T > | projectToImage (const HomogenousMatrixT4< T > &world_T_camera, const VectorT3< T > &objectPoint) const =0 |
Projects a 3D object point into the camera frame. | |
virtual void | projectToImage (const VectorT3< T > *objectPoints, const size_t size, VectorT2< T > *imagePoints) const =0 |
Projects several 3D object points into the camera frame at once. | |
virtual void | projectToImage (const HomogenousMatrixT4< T > &world_T_camera, const VectorT3< T > *objectPoints, const size_t size, VectorT2< T > *imagePoints) const =0 |
Projects several 3D object points into the camera frame at once. | |
virtual VectorT2< T > | projectToImageIF (const VectorT3< T > &objectPoint) const =0 |
Projects a 3D object point into the camera frame. | |
virtual VectorT2< T > | projectToImageIF (const HomogenousMatrixT4< T > &flippedCamera_T_world, const VectorT3< T > &objectPoint) const =0 |
Projects a 3D object point into the camera frame. | |
virtual void | projectToImageIF (const VectorT3< T > *objectPoints, const size_t size, VectorT2< T > *imagePoints) const =0 |
Projects several 3D object points into the camera frame at once. | |
virtual void | projectToImageIF (const HomogenousMatrixT4< T > &flippedCamera_T_world, const VectorT3< T > *objectPoints, const size_t size, VectorT2< T > *imagePoints) const =0 |
Projects several 3D object points into the camera frame at once. | |
virtual VectorT3< T > | vector (const VectorT2< T > &distortedImagePoint, const bool makeUnitVector=true) const =0 |
Returns a vector starting at the camera's center and intersecting a given 2D point in the image. | |
virtual void | vector (const VectorT2< T > *distortedImagePoints, const size_t size, VectorT3< T > *vectors, const bool makeUnitVector=true) const =0 |
Determines vectors starting at the camera's center and intersecting given 2D points in the image. | |
virtual VectorT3< T > | vectorIF (const VectorT2< T > &distortedImagePoint, const bool makeUnitVector=true) const =0 |
Returns a vector starting at the camera's center and intersecting a given 2D point in the image. | |
virtual void | vectorIF (const VectorT2< T > *distortedImagePoints, const size_t size, VectorT3< T > *vectors, const bool makeUnitVector=true) const =0 |
Returns vectors starting at the camera's center and intersecting a given 2D points in the image. | |
virtual LineT3< T > | ray (const VectorT2< T > &distortedImagePoint, const HomogenousMatrixT4< T > &world_T_camera) const =0 |
Returns a ray starting at the camera's center and intersecting a given 2D point in the image. | |
virtual LineT3< T > | ray (const VectorT2< T > &distortedImagePoint) const =0 |
Returns a ray starting at the camera's center and intersecting a given 2D point in the image. | |
virtual void | pointJacobian2x3IF (const VectorT3< T > &flippedCameraObjectPoint, T *jx, T *jy) const =0 |
Calculates the 2x3 jacobian matrix for the 3D object point projection into the camera frame. | |
virtual void | pointJacobian2nx3IF (const VectorT3< T > *flippedCameraObjectPoints, const size_t numberObjectPoints, T *jacobians) const =0 |
Calculates the 2n x 3 jacobian matrix for the 3D object point projection into the camera frame. | |
virtual bool | isEqual (const AnyCameraT< T > &anyCamera, const T eps=NumericT< T >::eps()) const =0 |
Returns whether two camera objects are identical up to a given epsilon. | |
virtual bool | isValid () const =0 |
Returns whether this camera is valid. | |
std::shared_ptr< AnyCameraT< float > > | convert (const std::shared_ptr< AnyCameraT< double > > &anyCamera) |
std::shared_ptr< AnyCameraT< double > > | convert (const std::shared_ptr< AnyCameraT< float > > &anyCamera) |
Static Public Member Functions | |
template<typename U > | |
static std::shared_ptr< AnyCameraT< T > > | convert (const std::shared_ptr< AnyCameraT< U > > &anyCamera) |
Converts an AnyCamera object with arbitrary scalar type to another AnyCamera object with arbitrary scalar type. | |
Static Public Member Functions inherited from Ocean::CameraT< T > | |
static T | fovX2Y (const T fovX, const T aspectRatio) |
Calculates the vertical FOV from the horizontal FOV and the aspect ratio of the camera image. | |
static T | fovY2X (const T fovY, const T aspectRatio) |
Calculates the horizontal FOV from the vertical FOV and the aspect ratio of the camera image. | |
static T | fieldOfViewToFocalLength (const unsigned int width, const T fovX) |
Converts field of view (and width) to the corresponding focal length. | |
static VectorT2< T > | objectPoint2normalizedImagePoint (const HomogenousMatrixT4< T > &extrinsic, const VectorT3< T > &objectPoint) |
Calculates the normalized image point (the normalized projected object point) for a of given object point with corresponding extrinsic camera matrix. | |
static VectorT2< T > | objectPoint2normalizedImagePointIF (const HomogenousMatrixT4< T > &iFlippedExtrinsic, const VectorT3< T > &objectPoint) |
Calculates the normalized image point (the normalized projected object point) for a given object point with corresponding inverse and flipped extrinsic camera matrix. | |
static void | objectPoints2normalizedImagePoints (const HomogenousMatrixT4< T > &extrinsic, const VectorT3< T > *objectPoints, const size_t numberObjectPoints, VectorT2< T > *normalizedImagePoints) |
Calculates the normalized image points (the normalized projected object points) for a set of given object points with corresponding extrinsic camera matrix. | |
static void | objectPoints2normalizedImagePointsIF (const HomogenousMatrixT4< T > &iFlippedExtrinsic, const VectorT3< T > *objectPoints, const size_t numberObjectPoints, VectorT2< T > *normalizedImagePoints) |
Calculates the normalized image points (the normalized projected object points) for a set of given object points with corresponding inverse and flipped extrinsic camera matrix. | |
template<typename U = T> | |
static SquareMatrixT3< U > | flipMatrix3 () |
Returns the 3x3 transformation matrix flipping a transformation around the x-axis by 180 deg. | |
template<typename U = T> | |
static HomogenousMatrixT4< U > | flipMatrix4 () |
Returns the 4x4 transformation matrix flipping a transformation around the x-axis by 180 deg. | |
template<typename U = T> | |
static QuaternionT< U > | flipQuaternion () |
Returns the quaternion flipping a rotation around the x-axis by 180 deg. | |
template<typename U > | |
static HomogenousMatrixT4< U > | flippedTransformationLeftSide (const HomogenousMatrixT4< U > &left_T_right) |
Flips a transformation matrix around the x-axis by 180 degree. | |
template<typename U > | |
static HomogenousMatrixT4< U > | flippedTransformationRightSide (const HomogenousMatrixT4< U > &left_T_right) |
Flips a transformation matrix around the x-axis by 180 degree. | |
template<typename U > | |
static HomogenousMatrixT4< U > | flippedTransformationLeftAndRightSide (const HomogenousMatrixT4< U > &left_T_right) |
Flips a transformation matrix around the x-axis by 180 degree. | |
template<typename U > | |
static SquareMatrixT3< U > | flippedTransformationLeftSide (const SquareMatrixT3< U > &left_R_right) |
Flips a 3x3 rotation matrix around the x-axis by 180 degree. | |
template<typename U > | |
static SquareMatrixT3< U > | flippedTransformationRightSide (const SquareMatrixT3< U > &left_R_right) |
Flips a 3x3 rotation matrix around the x-axis by 180 degree. | |
template<typename U > | |
static SquareMatrixT3< U > | flippedTransformationLeftAndRightSide (const SquareMatrixT3< U > &left_R_right) |
Flips a 3x3 rotation matrix around the x-axis by 180 degree. | |
template<typename U > | |
static QuaternionT< U > | flippedTransformationLeftSide (const QuaternionT< U > &left_Q_right) |
Flips a quaternion around the x-axis by 180 degree. | |
template<typename U > | |
static QuaternionT< U > | flippedTransformationRightSide (const QuaternionT< U > &left_Q_right) |
Flips a quaternion around the x-axis by 180 degree. | |
template<typename U > | |
static QuaternionT< U > | flippedTransformationLeftAndRightSide (const QuaternionT< U > &left_Q_right) |
Flips a quaternion around the x-axis by 180 degree. | |
template<typename U > | |
static HomogenousMatrixT4< U > | standard2InvertedFlipped (const HomogenousMatrixT4< U > &world_T_camera) |
Transforms a standard homogenous 4x4 viewing (extrinsic camera) matrix into an inverted and flipped camera pose. | |
template<typename U > | |
static HomogenousMatricesT4< U > | standard2InvertedFlipped (const HomogenousMatrixT4< U > *world_T_cameras, const size_t number) |
Transforms standard homogenous 4x4 viewing (extrinsic camera) matrices into an inverted and flipped camera matrices. | |
template<typename U > | |
static void | standard2InvertedFlipped (const HomogenousMatrixT4< U > *world_T_cameras, HomogenousMatrixT4< U > *flippedCameras_T_world, const size_t number) |
Transforms standard homogenous 4x4 viewing (extrinsic camera) matrices into an inverted and flipped camera matrices. | |
template<typename U > | |
static HomogenousMatricesT4< U > | standard2InvertedFlipped (const HomogenousMatricesT4< U > &world_T_cameras) |
Transforms standard homogenous 4x4 viewing (extrinsic camera) matrices into an inverted and flipped camera matrices. | |
template<typename U > | |
static SquareMatrixT3< U > | standard2InvertedFlipped (const SquareMatrixT3< U > &world_R_camera) |
Transforms a standard 3x3 rotation matrix into an inverted and flipped rotation matrix. | |
template<typename U > | |
static QuaternionT< U > | standard2InvertedFlipped (const QuaternionT< U > &world_Q_camera) |
Transforms a standard rotation quaternion into an inverted and flipped rotation quaternion. | |
template<typename U > | |
static HomogenousMatrixT4< U > | invertedFlipped2Standard (const HomogenousMatrixT4< U > &flippedCamera_T_world) |
Transforms an inverted and flipped camera pose into a standard camera pose. | |
template<typename U > | |
static HomogenousMatricesT4< U > | invertedFlipped2Standard (const HomogenousMatrixT4< U > *flippedCameras_T_world, const size_t number) |
Transforms inverted and flipped camera matrices into standard viewing (extrinsic camera) matrices. | |
template<typename U > | |
static void | invertedFlipped2Standard (const HomogenousMatrixT4< U > *flippedCameras_T_world, HomogenousMatrixT4< U > *world_T_cameras, const size_t number) |
Transforms inverted and flipped camera matrices into standard viewing (extrinsic camera) matrices. | |
template<typename U > | |
static HomogenousMatricesT4< U > | invertedFlipped2Standard (const HomogenousMatricesT4< U > &flippedCameras_T_world) |
Transforms inverted and flipped camera matrices into standard viewing (extrinsic camera) matrices. | |
template<typename U > | |
static SquareMatrixT3< U > | invertedFlipped2Standard (const SquareMatrixT3< U > &flippedCamera_R_world) |
Transforms an inverted and flipped rotation matrix into a standard viewing rotation matrix. | |
template<typename U > | |
static QuaternionT< U > | invertedFlipped2Standard (const QuaternionT< U > &flippedCamera_Q_world) |
Transforms an inverted and flipped rotation quaternion into a standard viewing rotation quaternion. | |
static bool | isObjectPointInFrontIF (const HomogenousMatrixT4< T > &flippedCamera_T_world, const VectorT3< T > &objectPoint, const T epsilon=NumericT< T >::eps()) |
Determines whether a given 3D object point lies in front of a camera while the location of the camera is defined by a 6-DOF pose. | |
static bool | isObjectPointInFrontIF (const SquareMatrixT3< T > &flippedCamera_R_world, const VectorT3< T > &objectPoint, const T epsilon=NumericT< T >::eps()) |
Determines whether a given 3D object point lies in front of a camera while the location of the camera is defined by a 3-DOF orientation. | |
Protected Member Functions | |
AnyCameraT ()=default | |
Protected default constructor. | |
AnyCameraT (const AnyCameraT< T > &anyCamera)=default | |
Protected copy constructor. | |
AnyCameraT (AnyCameraT< T > &&)=delete | |
Disabled move constructor. | |
AnyCameraT & | operator= (const AnyCameraT &)=delete |
Disabled assign operator. | |
AnyCameraT & | operator= (AnyCameraT &&)=delete |
Disabled move operator. | |
This class implements the abstract base class for all AnyCamera objects.
A custom camera object can be implemented by
T | The data type of a scalar, 'float' or 'double' |
typedef T Ocean::AnyCameraT< T >::TScalar |
The scalar data type of this object.
|
virtualdefault |
Destructs the AnyCamera object.
|
protecteddefault |
Protected default constructor.
|
protecteddefault |
Protected copy constructor.
anyCamera | The object to copy |
|
protecteddelete |
Disabled move constructor.
|
pure virtual |
Returns the type of this camera.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns a copy of this camera object.
The image resolution of the cloned camera must have the same aspect ratio as the current image resolution.
width | The width of the cloned camera in pixel, with range [1, infinity), 0 to use the current image resolution |
height | the height of the cloned camera in pixel, with range [1, infinity), 0 to use the current image resolution |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns a copy of this camera object with double precision.
The image resolution of the cloned camera must have the same aspect ratio as the current image resolution.
width | The width of the cloned camera in pixel, with range [1, infinity), 0 to use the current image resolution |
height | the height of the cloned camera in pixel, with range [1, infinity), 0 to use the current image resolution |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns a copy of this camera object with float precision.
The image resolution of the cloned camera must have the same aspect ratio as the current image resolution.
width | The width of the cloned camera in pixel, with range [1, infinity), 0 to use the current image resolution |
height | the height of the cloned camera in pixel, with range [1, infinity), 0 to use the current image resolution |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
inline |
|
inline |
|
static |
Converts an AnyCamera object with arbitrary scalar type to another AnyCamera object with arbitrary scalar type.
In case both scalar types are identical, the object is simply returned. In case both scalar types are different, a clone is returned.
anyCamera | The AnyCamera object to be converted, can be nullptr |
U | The scalar data type of the given AnyCamera object |
|
pure virtual |
Returns the horizontal focal length parameter.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the vertical focal length parameter.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the field of view in x direction of the camera.
The fov is the sum of the left and right part of the camera.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the field of view in x direction of the camera.
The fov is the sum of the top and bottom part of the camera.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the height of the camera image.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the inverse horizontal focal length parameter.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the inverse vertical focal length parameter.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns whether two camera objects are identical up to a given epsilon.
The image resolution must always be identical.
anyCamera | The second camera to be used for comparison, can be invalid |
eps | The epsilon threshold to be used, with range [0, infinity) |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns whether a given 2D image point lies inside the camera frame.
Optional an explicit border can be defined to allow points slightly outside the camera image, or further inside the image.
Defined a negative border size to allow image points outside the camera frame, or a positive border size to prevent points within the camera frame but close to the boundary.
imagePoint | Image point to be checked, must be valid |
signedBorder | The optional border increasing or decreasing the rectangle in which the image point must be located, in pixels, with range (-infinity, std::min(width() / 2, height() / 2) |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns whether this camera is valid.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the name of this camera.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
protecteddelete |
Disabled move operator.
|
protecteddelete |
Disabled assign operator.
|
pure virtual |
Calculates the 2n x 3 jacobian matrix for the 3D object point projection into the camera frame.
The resulting jacobian matrix has the following layout:
| dfu / dx, dfu / dy, dfu / dz | <- for object point 0 | dfv / dx, dfv / dy, dfv / dz | | ... | | dfu / dx, dfu / dy, dfu / dz | <- for object point n - 1 | dfv / dx, dfv / dy, dfv / dz | with projection function q = f(p) q_u = fu(p), q_y = fv(p) with 2D image point q = (q_u, q_v) and 3D object point p = (x, y, z)
flippedCameraObjectPoints | The 3D object points defined in relation to the inverted and flipped camera pose (camera looking into the positive z-space with y-axis pointing down). |
numberObjectPoints | The number of given 3D object points, with range [1, infinity) |
jacobians | The resulting 2n x 3 Jacobian matrix, with 2 * numberObjectPoints * 3 elements, must be valid |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Calculates the 2x3 jacobian matrix for the 3D object point projection into the camera frame.
The resulting jacobian matrix has the following layout:
| dfu / dx, dfu / dy, dfu / dz | | dfv / dx, dfv / dy, dfv / dz | with projection function q = f(p) q_u = fu(p), q_y = fv(p) with 2D image point q = (q_u, q_v) and 3D object point p = (x, y, z)
flippedCameraObjectPoint | The 3D object point defined in relation to the inverted and flipped camera pose (camera looking into the positive z-space with y-axis pointing down). |
jx | The resulting first row of the Jacobian matrix, must contain three elements, must be valid |
jy | The resulting second row of the Jacobian matrix, must contain three elements, must be valid |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the coordinate of the principal point of the camera image in the pixel domain.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the x-value of the principal point of the camera image in the pixel domain.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the y-value of the principal point of the camera image in the pixel domain.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Projects a 3D object point into the camera frame.
world_T_camera | The camera pose, the default camera is looking into the negative z-space with y-axis up, transforming camera to world, must be valid |
objectPoint | The 3D object point to project, defined in world |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Projects several 3D object points into the camera frame at once.
world_T_camera | The camera pose, the default camera is looking into the negative z-space with y-axis up, transforming camera to world, must be valid |
objectPoints | The 3D object points to project, defined in world, must be valid |
size | The number of object points, with range [1, infinity) |
imagePoints | The resulting 2D image points, must be valid |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Projects a 3D object point into the camera frame.
The projection is applied with a default camera pose, the camera is looking into the negative z-space with y-axis up.
objectPoint | The 3D object point to project, defined in world |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Projects several 3D object points into the camera frame at once.
The projection is applied with a default camera pose, the camera is looking into the negative z-space with y-axis up.
objectPoints | The 3D object points to project, defined in world, must be valid |
size | The number of object points, with range [1, infinity) |
imagePoints | The resulting 2D image points, must be valid |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Projects a 3D object point into the camera frame.
flippedCamera_T_world | The inverted and flipped camera pose, the default camera is looking into the positive z-space with y-axis down, transforming world to flipped camera, must be valid |
objectPoint | The 3D object point to project, defined in world |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Projects several 3D object points into the camera frame at once.
flippedCamera_T_world | The inverted and flipped camera pose, the default camera is looking into the positive z-space with y-axis down, transforming world to flipped camera, must be valid |
objectPoints | The 3D object points to project, defined in world, must be valid |
size | The number of object points, with range [1, infinity) |
imagePoints | The resulting 2D image points, must be valid |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Projects a 3D object point into the camera frame.
The projection is applied with a default (inverted) and flipped camera pose, the camera is looking into the positive z-space with y-axis down.
objectPoint | The 3D object point to project, defined in world |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Projects several 3D object points into the camera frame at once.
The projection is applied with a default (inverted) and flipped camera pose, the camera is looking into the positive z-space with y-axis down.
objectPoints | The 3D object points to project, defined in world, must be valid |
size | The number of object points, with range [1, infinity) |
imagePoints | The resulting 2D image points, must be valid |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns a ray starting at the camera's center and intersecting a given 2D point in the image.
The ray is determined for a default camera looking into the negative z-space with y-axis up.
distortedImagePoint | 2D (distorted) position within the image, with range [0, width())x[0, height()) |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns a ray starting at the camera's center and intersecting a given 2D point in the image.
The ray is determined for a default camera looking into the negative z-space with y-axis up.
distortedImagePoint | 2D (distorted) position within the image, with range [0, width())x[0, height()) |
world_T_camera | The pose of the camera, the extrinsic camera matrix, must be valid |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns a vector starting at the camera's center and intersecting a given 2D point in the image.
The vector is determined for a default camera looking into the negative z-space with y-axis up.
distortedImagePoint | 2D (distorted) position within the image, with range [0, width())x[0, height()) |
makeUnitVector | True, to return a vector with length 1; False, to return a vector with any length |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Determines vectors starting at the camera's center and intersecting given 2D points in the image.
The vectors are determined for a default camera looking into the negative z-space with y-axis up.
distortedImagePoints | 2D (distorted) positions within the image, with range [0, width())x[0, height()), must be valid |
size | The number of provided points, with range [1, infinity) |
vectors | The resulting vectors pointing into the negative z-space, one for each image point, must be valid |
makeUnitVector | True, to return a vector with length 1; False, to return a vector with any length |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns a vector starting at the camera's center and intersecting a given 2D point in the image.
The vector is determined for a default camera looking into the positive z-space with y-axis down.
distortedImagePoint | 2D (distorted) position within the image, with range [0, width())x[0, height()) |
makeUnitVector | True, to return a vector with length 1; False, to return a vector with any length |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns vectors starting at the camera's center and intersecting a given 2D points in the image.
The vectors are determined for a default camera looking into the positive z-space with y-axis down.
distortedImagePoints | 2D (distorted) positions within the image, with range [0, width())x[0, height()), must be valid |
size | The number of provided points, with range [1, infinity) |
vectors | The resulting vectors pointing into the positive z-space, one for each image point, must be valid |
makeUnitVector | True, to return a vector with length 1; False, to return a vector with any length |
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.
|
pure virtual |
Returns the width of the camera image.
Implemented in Ocean::AnyCameraWrappingT< T, TCameraWrapper >.