Isis 3 Programmer Reference
|
Convert between undistorted focal plane and ground coordinates. More...
#include <CameraGroundMap.h>
Public Types | |
enum | PartialType { WRT_Latitude , WRT_Longitude , WRT_Radius , WRT_MajorAxis , WRT_MinorAxis , WRT_PolarAxis } |
Radius axes types to use when computing partials. More... | |
Public Member Functions | |
CameraGroundMap (Camera *parent) | |
Constructor. | |
virtual | ~CameraGroundMap () |
Destructor. | |
virtual bool | SetFocalPlane (const double ux, const double uy, const double uz) |
Compute ground position from focal plane coordinate. | |
virtual bool | SetGround (const Latitude &lat, const Longitude &lon) |
Compute undistorted focal plane coordinate from ground position. | |
virtual bool | SetGround (const SurfacePoint &surfacePoint) |
Compute undistorted focal plane coordinate from ground position that includes a local radius. | |
virtual bool | GetXY (const SurfacePoint &spoint, double *cudx, double *cudy, bool test=true) |
Compute undistorted focal plane coordinate from ground position using current Spice from SetImage call. | |
virtual bool | GetXY (const double lat, const double lon, const double radius, double *cudx, double *cudy) |
Compute undistorted focal plane coordinate from ground position using current Spice from SetImage call. | |
virtual bool | GetdXYdPosition (const SpicePosition::PartialType varType, int coefIndex, double *cudx, double *cudy) |
Compute derivative w/r to position of focal plane coordinate from ground position using current Spice from SetImage call. | |
virtual bool | GetdXYdOrientation (const SpiceRotation::PartialType varType, int coefIndex, double *cudx, double *cudy) |
Compute derivative of focal plane coordinate w/r to instrument using current state from SetImage call. | |
virtual bool | GetdXYdTOrientation (const SpiceRotation::PartialType varType, int coefIndex, double *cudx, double *cudy) |
Compute derivative of focal plane coordinate w/r to target body using current state. | |
virtual bool | GetdXYdPoint (std::vector< double > d_pB, double *dx, double *dy) |
Compute derivative of focal plane coordinate w/r to ground point using current state. | |
std::vector< double > | PointPartial (SurfacePoint spoint, PartialType wrt) |
Compute derivative with respect to indicated variable of conversion function from lat/lon/rad to rectangular coord. | |
std::vector< double > | EllipsoidPartial (SurfacePoint spoint, PartialType raxis) |
Compute derivative of focal plane coordinate w/r to one of the ellipsoidal radii (a, b, or c) | |
std::vector< double > | MeanRadiusPartial (SurfacePoint spoint, Distance meanRadius) |
Compute derivative of focal plane coordinate w/r to mean of the ellipsoidal radii (a, b, c) | |
double | DQuotient (std::vector< double > &look, std::vector< double > &dlook, int index) |
Convenience method for quotient rule applied to look vector. | |
double | FocalPlaneX () const |
double | FocalPlaneY () const |
Protected Member Functions | |
void | LookCtoFocalPlaneXY () |
Calculate focalplane x/y from lookvector in camera. | |
Protected Attributes | |
Camera * | p_camera |
Camera. | |
double | p_focalPlaneX |
Camera's x focal plane coordinate. | |
double | p_focalPlaneY |
Camera's y focal plane coordinate. | |
std::vector< double > | m_pB |
Surface point calculated from ground coordinates in GetXY and used for partials. | |
std::vector< double > | m_lookJ |
Look vector in J2000 calculated from ground coordinates in GetXY and used for partials. | |
Convert between undistorted focal plane and ground coordinates.
This base class is used to convert between undistorted focal plane coordinates (x/y) in millimeters and ground coordinates lat/lon. This class handles the case of framing cameras.
2005-11-16 Jeff Anderson Fixed bug in SetGround not setting the proper boolean return value
2007-06-11 Debbie A. Cook - Added overloaded method SetGround that includes a radius argument and the method LookCtoFocalPlaneXY() to handle the common functionality between the SetGround methods
2008-07-14 Steven Lambright Added NaifStatus calls
2009-10-14 Debbie A. Cook Added new virtual method GetXY(lat,lon,radius, lookJ)
2009-11-27 Debbie A. Cook Modified virtual method GetXY(lat,lon,radius,lookJ,cudx,cudy)
2010-03-19 Debbie A. Cook Modified virtual method to return cudx and cudy; added methods GetdXYdPosition, GetdXYdOrientation, GetdXYdPoint, PointPartial, and DQuotient; and added members PartialType (from BundleAdjust) and p_lookJ.
2010-08-05 Debbie A. Cook Added another version of GetXY to support changes from binary control net upgrade
2010-11-22 Debbie A. Cook Moved PointPartial call out of GetdXYdPoint to allow BundleAdjust to avoid multiple calls for every measure. The application must call PointPartial to get the body-fixed look vector derivative prior to calling this method.
2011-02-09 Steven Lambright SetGround now uses the Latitude, Longitude and SurfacePoint classes.
2011-03-18 Debbie A. Cook Added reference to surface point in GetXY
2012-07-06 Debbie A. Cook Updated Spice members to be more compliant with Isis coding standards. References #972.
2012-10-10 Debbie A. Cook Modified to use new Target class. References Mantis ticket #775 and #1114.
2013-02-22 Debbie A. Cook Fixed LookCtoFocalPlaneXY method to properly handle instruments with a look direction along the negative z axis. Fixes Mantis ticket #1524
2014-04-17 Jeannie Backer - Replaced local variable names with more descriptive names. References #1659.
2015-07-24 Debbie A. Cook - Added new methods GetdXYdTOrientation(), EllipsoidPartial() and MeanRadiusPartial() along with new member p_pB. References Mantis ticket TBD.
2016-06-27 Ian Humphrey - Updated documentation and coding standards. Fixes #3971.
2017-08-30 Summer Stapleton - Updated documentation. References #4807.
2019-04-15 Debbie A. Cook - Added optional bool argument to main GetXY method to allow the bundle adjustment to skip the back of planet test during iterations. Also changed the name of the angle variable to cosangle to be more descriptive. References #2591.
2018-07-26 Kris Becker - Move all local variables and methods to protected scope so derived objects can be developed properly
Definition at line 77 of file CameraGroundMap.h.
Radius axes types to use when computing partials.
When computing partials, this enum represents the "with respect to" variable in the computation.
Definition at line 91 of file CameraGroundMap.h.
Isis::CameraGroundMap::CameraGroundMap | ( | Camera * | parent | ) |
Constructor.
parent | Pointer to camera to be used for mapping with ground |
Definition at line 31 of file CameraGroundMap.cpp.
References p_camera, and Isis::Camera::SetGroundMap().
|
inlinevirtual |
Destructor.
Definition at line 82 of file CameraGroundMap.h.
double Isis::CameraGroundMap::DQuotient | ( | std::vector< double > & | look, |
std::vector< double > & | dlook, | ||
int | index ) |
Convenience method for quotient rule applied to look vector.
This method will compute the derivative of the following function (coordinate x or y) / (coordinate z)
look | look vector in camera frame |
dlook | derivative of look vector in camera frame |
index | vector value to differentiate |
Definition at line 550 of file CameraGroundMap.cpp.
Referenced by GetdXYdOrientation(), GetdXYdPoint(), GetdXYdPosition(), and GetdXYdTOrientation().
vector< double > Isis::CameraGroundMap::EllipsoidPartial | ( | SurfacePoint | spoint, |
PartialType | raxis ) |
Compute derivative of focal plane coordinate w/r to one of the ellipsoidal radii (a, b, or c)
This method will compute the derivative of the undistorted focal plane coordinate for a ground position with respect to the a (major axis), b (minor axis), or c (polar axis) radius, using the current Spice settings (time and kernels) without resetting the current point values for lat/lon/radius/x/y.
spoint | Surface point whose derivative is to be evalutated |
raxis | Radius axis enumerated partial type (definitions in this header) |
IException::Programmer | "Invalid partial type for this method" |
Definition at line 436 of file CameraGroundMap.cpp.
References Isis::IException::Programmer.
|
inline |
Definition at line 126 of file CameraGroundMap.h.
References p_focalPlaneX.
Referenced by Isis::Camera::RawFocalPlanetoImage().
|
inline |
Definition at line 133 of file CameraGroundMap.h.
References p_focalPlaneY.
Referenced by Isis::Camera::RawFocalPlanetoImage().
|
virtual |
Compute derivative of focal plane coordinate w/r to instrument using current state from SetImage call.
This method will compute the derivative of the undistorted focal plane coordinate for a ground position with respect to the instrument orientation, using the current Spice settings (time and kernels) without resetting the current point values for lat/lon/radius/x/y.
varType | enumerated partial type (definitions in SpicePosition) |
coefIndex | coefficient index of fit polynomial |
*dx | out] pointer to partial derivative of undistorted focal plane x |
*dy | [out] pointer to partial derivative of undistorted focal plane y |
Definition at line 318 of file CameraGroundMap.cpp.
References Isis::Camera::DistortionMap(), DQuotient(), Isis::Spice::instrumentRotation(), m_lookJ, p_camera, and Isis::CameraDistortionMap::UndistortedFocalPlaneZ().
Referenced by Isis::IsisBundleObservation::computeImagePartials().
|
virtual |
Compute derivative of focal plane coordinate w/r to ground point using current state.
This method will compute the derivative of the undistorted focal plane coordinate for a ground position with respect to lat, lon, or radius, using the current Spice settings (time and kernels) without resetting the current point values for lat/lon/radius/x/y.
d_pB | Point vector |
*dx | [out] pointer to partial derivative of undistorted focal plane x |
*dy | [out] pointer to partial derivative of undistorted focal plane y |
Reimplemented in Isis::RadarGroundMap.
Definition at line 398 of file CameraGroundMap.cpp.
References Isis::Spice::bodyRotation(), Isis::Camera::DistortionMap(), DQuotient(), Isis::Spice::instrumentRotation(), m_lookJ, p_camera, and Isis::CameraDistortionMap::UndistortedFocalPlaneZ().
|
virtual |
Compute derivative w/r to position of focal plane coordinate from ground position using current Spice from SetImage call.
This method will compute the derivative of the undistorted focal plane coordinate for a ground position with respect to a spacecraft position coordinate, using the current Spice settings (time and kernels) without resetting the current point values for lat/lon/radius/x/y.
varType | enumerated partial type (definitions in SpicePosition) |
coefIndex | coefficient index of fit polynomial |
*dx | [out] pointer to partial derivative of undistorted focal plane x |
*dy | [out] pointer to partial derivative of undistorted focal plane y |
Reimplemented in Isis::RadarGroundMap.
Definition at line 279 of file CameraGroundMap.cpp.
References Isis::Camera::DistortionMap(), DQuotient(), Isis::Spice::instrumentPosition(), Isis::Spice::instrumentRotation(), m_lookJ, p_camera, and Isis::CameraDistortionMap::UndistortedFocalPlaneZ().
Referenced by Isis::IsisBundleObservation::computeImagePartials().
|
virtual |
Compute derivative of focal plane coordinate w/r to target body using current state.
This method will compute the derivative of the undistorted focal plane coordinate for a ground position with respect to the target body orientation, using the current Spice settings (time and kernels) without resetting the current point values for lat/lon/radius/x/y.
varType | enumerated partial type (definitions in SpicePosition) |
coefIndex | coefficient index of fit polynomial |
*dx | [out] pointer to partial derivative of undistorted focal plane x |
*dy | [out] pointer to partial derivative of undistorted focal plane y |
Definition at line 354 of file CameraGroundMap.cpp.
References Isis::Spice::bodyRotation(), Isis::Camera::DistortionMap(), DQuotient(), Isis::Spice::instrumentRotation(), m_lookJ, m_pB, p_camera, and Isis::CameraDistortionMap::UndistortedFocalPlaneZ().
|
virtual |
Compute undistorted focal plane coordinate from ground position using current Spice from SetImage call.
This method will compute the undistorted focal plane coordinate for a ground position, using the current Spice settings (time and kernels) without resetting the current point values for lat/lon/radius/m_pB/x/y. The class value for m_lookJ is set by this method.
lat | Latitude in degrees |
lon | Longitude in degrees |
radius | Radius in meters |
cudx | [out] Pointer to computed undistored x focal plane coordinate |
cudy | [out] Pointer to computed undistored y focal plane coordinate |
Definition at line 254 of file CameraGroundMap.cpp.
References Isis::Angle::Degrees, GetXY(), and Isis::Distance::Meters.
|
virtual |
Compute undistorted focal plane coordinate from ground position using current Spice from SetImage call.
This method will compute the undistorted focal plane coordinate for a ground position, using the current Spice settings (time and kernels) without resetting the current point values for lat/lon/radius/m_pB/x/y. The class value for m_lookJ is set by this method.
point | Surface point (ground position) |
cudx | [out] Pointer to computed undistorted x focal plane coordinate |
cudy | [out] Pointer to computed undistorted y focal plane coordinate |
test | Optional parameter to indicate whether to do the back-of-planet test. |
Reimplemented in Isis::RadarGroundMap.
Definition at line 152 of file CameraGroundMap.cpp.
References Isis::Spice::bodyRotation(), Isis::Camera::DistortionMap(), Isis::Spice::instrumentPosition(), Isis::Spice::instrumentRotation(), Isis::Displacement::kilometers(), m_lookJ, m_pB, p_camera, Isis::PI, Isis::Spice::target(), and Isis::CameraDistortionMap::UndistortedFocalPlaneZ().
Referenced by GetXY(), and Isis::IrregularBodyCameraGroundMap::GetXY().
|
protected |
Calculate focalplane x/y from lookvector in camera.
Compute undistorted focal plane coordinate from camera look vector.
Definition at line 106 of file CameraGroundMap.cpp.
References Isis::Camera::DistortionMap(), p_camera, p_focalPlaneX, p_focalPlaneY, and Isis::CameraDistortionMap::UndistortedFocalPlaneZ().
Referenced by SetGround(), and SetGround().
vector< double > Isis::CameraGroundMap::MeanRadiusPartial | ( | SurfacePoint | spoint, |
Distance | meanRadius ) |
Compute derivative of focal plane coordinate w/r to mean of the ellipsoidal radii (a, b, c)
This method will compute the derivative of the undistorted focal plane coordinate for a ground position with respect to the mean of the a (major axis), b (minor axis), and c (polar axis) radius, using the current Spice settings (time and kernels) without resetting the current point values for lat/lon/radius/x/y.
spoint | Surface point whose derivative is to be evalutated |
meanRadius | Computed mean of radii |
Definition at line 486 of file CameraGroundMap.cpp.
References Isis::Distance::kilometers().
vector< double > Isis::CameraGroundMap::PointPartial | ( | SurfacePoint | spoint, |
PartialType | wrt ) |
Compute derivative with respect to indicated variable of conversion function from lat/lon/rad to rectangular coord.
spoint | Surface point (ground position) |
wrt | take derivative with respect to this value |
Definition at line 508 of file CameraGroundMap.cpp.
|
virtual |
Compute ground position from focal plane coordinate.
This method will compute the ground position given an undistorted focal plane coordinate. Note that the latitude/longitude value can be obtained from the camera pointer passed into the constructor.
ux | undistorted focal plane x in millimeters |
uy | undistorted focal plane y in millimeters |
uz | undistorted focal plane z in millimeters |
Reimplemented in Isis::RadarGroundMap, and Isis::VimsGroundMap.
Definition at line 50 of file CameraGroundMap.cpp.
References Isis::NaifStatus::CheckErrors(), p_camera, and Isis::Sensor::SetLookDirection().
Referenced by Isis::Camera::SetImage(), and Isis::Camera::SetImage().
Compute undistorted focal plane coordinate from ground position.
lat | planetocentric latitude in degrees |
lon | planetocentric longitude in degrees |
Reimplemented in Isis::LineScanCameraGroundMap, Isis::PushFrameCameraGroundMap, Isis::RadarGroundMap, and Isis::VimsGroundMap.
Definition at line 76 of file CameraGroundMap.cpp.
References Isis::Angle::Degrees, Isis::Sensor::LocalRadius(), LookCtoFocalPlaneXY(), Isis::Distance::Meters, p_camera, and Isis::Spice::target().
Referenced by Isis::PushFrameCameraGroundMap::SetGround(), Isis::Camera::SetGround(), Isis::Camera::SetUniversalGround(), and Isis::Camera::SetUniversalGround().
|
virtual |
Compute undistorted focal plane coordinate from ground position that includes a local radius.
surfacePoint | Surface point (ground position) |
Reimplemented in Isis::LineScanCameraGroundMap, Isis::RadarGroundMap, Isis::VimsGroundMap, and Isis::PushFrameCameraGroundMap.
Definition at line 126 of file CameraGroundMap.cpp.
References LookCtoFocalPlaneXY(), and p_camera.
|
protected |
Look vector in J2000 calculated from ground coordinates in GetXY and used for partials.
Definition at line 146 of file CameraGroundMap.h.
Referenced by GetdXYdOrientation(), GetdXYdPoint(), GetdXYdPosition(), GetdXYdTOrientation(), and GetXY().
|
protected |
Surface point calculated from ground coordinates in GetXY and used for partials.
Definition at line 144 of file CameraGroundMap.h.
Referenced by GetdXYdTOrientation(), and GetXY().
|
protected |
Definition at line 138 of file CameraGroundMap.h.
Referenced by CameraGroundMap(), Isis::PushFrameCameraGroundMap::FindDistance(), Isis::PushFrameCameraGroundMap::FindSpacecraftDistance(), GetdXYdOrientation(), GetdXYdPoint(), GetdXYdPosition(), GetdXYdTOrientation(), GetXY(), Isis::VimsGroundMap::Init(), LookCtoFocalPlaneXY(), SetFocalPlane(), Isis::VimsGroundMap::SetFocalPlane(), SetGround(), Isis::LineScanCameraGroundMap::SetGround(), Isis::PushFrameCameraGroundMap::SetGround(), Isis::VimsGroundMap::SetGround(), and SetGround().
|
protected |
Camera's x focal plane coordinate.
Definition at line 139 of file CameraGroundMap.h.
Referenced by FocalPlaneX(), LookCtoFocalPlaneXY(), and Isis::VimsGroundMap::SetGround().
|
protected |
Camera's y focal plane coordinate.
Definition at line 140 of file CameraGroundMap.h.
Referenced by FocalPlaneY(), LookCtoFocalPlaneXY(), and Isis::VimsGroundMap::SetGround().