Isis 3 Programmer Reference
|
Convert between distorted focal plane and detector coordinates. More...
#include <CameraFocalPlaneMap.h>
Public Types | |
enum | FocalPlaneXDependencyType { Sample = 1 , Line = 2 } |
Focal plane x dependency indicates whether the x value of the focal plane coordinate maps to a sample or a line. More... | |
Public Member Functions | |
CameraFocalPlaneMap (Camera *parent, const int naifIkCode) | |
Construct mapping between detectors and focal plane x/y. | |
CameraFocalPlaneMap (const int naifIkCode) | |
Construct mapping between detectors and focal plane x/y. | |
CameraFocalPlaneMap (Camera *parent, Affine &affine) | |
Added new method to allow programmer to pass in affine coefficients. | |
virtual | ~CameraFocalPlaneMap () |
Destructor. | |
virtual bool | SetDetector (const double sample, const double line) |
Compute distorted focal plane coordinate from detector position (sampel,line) | |
virtual bool | SetFocalPlane (const double dx, const double dy) |
Compute detector position (sample,line) from focal plane coordinates. | |
double | FocalPlaneX () const |
double | FocalPlaneY () const |
double | DetectorSample () const |
double | DetectorLine () const |
double | CenteredDetectorSample () const |
double | CenteredDetectorLine () const |
void | SetDetectorOrigin (const double sample, const double line) |
Set the detector origin. | |
double | DetectorLineOrigin () const |
double | DetectorSampleOrigin () const |
void | SetDetectorOffset (const double sampleOffset, const double lineOffset) |
Set the detector offset. | |
double | DetectorLineOffset () const |
double | DetectorSampleOffset () const |
void | SetTransL (const QVector< double > transL) |
Set the affine coefficients for converting destorted (x,y) to a detector Line. | |
void | SetTransS (const QVector< double > transS) |
Set the affine coefficients for converting destorted (x,y) to a detector Sample. | |
void | SetTransX (const QVector< double > transX) |
Set the affine coefficients for converting detector (sample,line) to a distorted X. | |
void | SetTransY (const QVector< double > transY) |
Set the affine coefficients for converting detector (sample,line) to a distorted Y. | |
const double * | TransL () const |
const double * | TransS () const |
const double * | TransX () const |
const double * | TransY () const |
int | FocalPlaneXDependency () |
Return the focal plane x dependency variable. | |
double | SignMostSigX () |
Return the sign of the p_transx coefficient with the greatest magnitude. | |
double | SignMostSigY () |
Return the sign of the p_transy coefficient with the greatest magnitude. | |
Protected Member Functions | |
void | ComputeCentered () |
Convenience method to center detector origin (use when inheriting) | |
void | ComputeUncentered () |
Convenience method to center detector origin (use when inheriting) | |
Protected Attributes | |
Camera * | p_camera |
Camera of the image. | |
double | p_detectorLineOrigin |
The origin line of the detector. | |
double | p_detectorSampleOrigin |
The origin sample of the detector. | |
double | p_focalPlaneX |
x value of focal plane coordinate | |
double | p_focalPlaneY |
y value of focal plane coordinate | |
double | p_detectorLine |
line value of the detector | |
double | p_detectorSample |
sample value of the detector | |
double | p_centeredDetectorSample |
Detector sample position. | |
double | p_centeredDetectorLine |
Detector line position. | |
double | p_detectorLineOffset |
Offset of the detector origin line from the average. | |
double | p_detectorSampleOffset |
offset of the detector origin sample from the average | |
double | p_transx [3] |
The x transition from detector to distorted. | |
double | p_transy [3] |
The y transition from detector to distorted. | |
double | p_itranss [3] |
The x transition from distorted to detector. | |
double | p_itransl [3] |
The y transition from distorted to detector. | |
Private Member Functions | |
void | Init (Camera *parent, const int naifIkCode) |
Initialize the focal plane map to its default state. | |
Convert between distorted focal plane and detector coordinates.
This base class is used to convert between distorted focal plane coordinates (x/y) in millimeters and detector coordinates in pixels. The class expects to find a set of coefficients in the naif instrument (or instrument addendum) kernel that describe the transform from detector to focal plane and vice versa. The transform from detector to focal plane is:
Likewise, the inverse transform is:
2007-02-13 Debbie A. Cook - Added methods SignMostSigX() and SignMostSigY()
2011-05-25 Janet Barrett and Steven Lambright - Spice::GetDouble is no longer static.
2012-07-06 Debbie A. Cook, Updated Spice members to be more compliant with Isis coding standards. References #972.
2012-11-21 Jeannie Backer - Added accesssor methods: TransX(), TransY(), TransS(), and TransL(). These are tested by application hideal2pds since no unitTest exists. Fixed indentation of history entries, order of includes, moved method implementations to cpp, and fixed control statement padding to be more compliant with Isis standards. Added documentation to member variables.References #678.
2014-03-27 Jeff Anderson - Added constructor which takes an Affine transform instead of only reading from NAIF kernels to obtain the transform. This is required for non-NAIF instruments such as Aerial photos.
2017-08-30 Summer Stapleton - Updated documentation. References #4807.
Definition at line 85 of file CameraFocalPlaneMap.h.
Focal plane x dependency indicates whether the x value of the focal plane coordinate maps to a sample or a line.
Enumerator | |
---|---|
Sample | The x value of the focal plane maps to a sample. |
Line | The x value of the focal plane maps to a line. |
Definition at line 123 of file CameraFocalPlaneMap.h.
Isis::CameraFocalPlaneMap::CameraFocalPlaneMap | ( | Camera * | parent, |
const int | naifIkCode ) |
Construct mapping between detectors and focal plane x/y.
parent | parent camera that will use this map |
naifIkCode | code of the naif instrument for reading coefficients |
Definition at line 25 of file CameraFocalPlaneMap.cpp.
References Init().
Isis::CameraFocalPlaneMap::CameraFocalPlaneMap | ( | const int | naifIkCode | ) |
Construct mapping between detectors and focal plane x/y.
naifIkCode | code of the naif instrument for reading coefficients |
Definition at line 35 of file CameraFocalPlaneMap.cpp.
References Init().
Added new method to allow programmer to pass in affine coefficients.
parent | Parent camera |
affine | Affine transform containing the coefficients for both transforms to (samp,line) to (x,y) and reverse |
Definition at line 49 of file CameraFocalPlaneMap.cpp.
References p_camera, p_detectorLineOffset, p_detectorLineOrigin, p_detectorSampleOffset, p_detectorSampleOrigin, p_itransl, p_itranss, p_transx, p_transy, and Isis::Camera::SetFocalPlaneMap().
|
virtual |
Destructor.
Definition at line 82 of file CameraFocalPlaneMap.cpp.
double Isis::CameraFocalPlaneMap::CenteredDetectorLine | ( | ) | const |
Definition at line 279 of file CameraFocalPlaneMap.cpp.
References p_centeredDetectorLine.
double Isis::CameraFocalPlaneMap::CenteredDetectorSample | ( | ) | const |
Definition at line 271 of file CameraFocalPlaneMap.cpp.
References p_centeredDetectorSample.
|
protected |
Convenience method to center detector origin (use when inheriting)
Definition at line 428 of file CameraFocalPlaneMap.cpp.
References p_centeredDetectorLine, p_centeredDetectorSample, p_detectorLine, p_detectorLineOrigin, p_detectorSample, and p_detectorSampleOrigin.
Referenced by SetDetector().
|
protected |
Convenience method to center detector origin (use when inheriting)
Definition at line 435 of file CameraFocalPlaneMap.cpp.
References p_centeredDetectorLine, p_centeredDetectorSample, p_detectorLine, p_detectorLineOrigin, p_detectorSample, and p_detectorSampleOrigin.
Referenced by SetFocalPlane().
double Isis::CameraFocalPlaneMap::DetectorLine | ( | ) | const |
Definition at line 263 of file CameraFocalPlaneMap.cpp.
References p_detectorLine.
Referenced by LineOffsetFunctor::operator()(), Isis::Camera::RawFocalPlanetoImage(), Isis::LoMediumDistortionMap::SetDistortion(), Isis::LoMediumDistortionMap::SetFocalPlane(), Isis::OsirisRexOcamsDistortionMap::SetFocalPlane(), Isis::Camera::SetRightAscensionDeclination(), Isis::LoMediumDistortionMap::SetUndistortedFocalPlane(), and Isis::OsirisRexOcamsDistortionMap::SetUndistortedFocalPlane().
double Isis::CameraFocalPlaneMap::DetectorLineOffset | ( | ) | const |
Definition at line 334 of file CameraFocalPlaneMap.cpp.
References p_detectorLineOffset.
Referenced by LineOffsetFunctor::operator()(), Isis::LineScanCameraDetectorMap::SetParent(), Isis::VariableLineScanCameraDetectorMap::SetParent(), and Isis::LineScanCameraSkyMap::SetSky().
double Isis::CameraFocalPlaneMap::DetectorLineOrigin | ( | ) | const |
Definition at line 302 of file CameraFocalPlaneMap.cpp.
References p_detectorLineOrigin.
Referenced by Isis::OsirisRexDistortionMap::OsirisRexDistortionMap(), Isis::OsirisRexOcamsDistortionMap::OsirisRexOcamsDistortionMap(), Isis::ReseauDistortionMap::SetFocalPlane(), and Isis::ReseauDistortionMap::SetUndistortedFocalPlane().
double Isis::CameraFocalPlaneMap::DetectorSample | ( | ) | const |
Definition at line 255 of file CameraFocalPlaneMap.cpp.
References p_detectorSample.
Referenced by Isis::Camera::RawFocalPlanetoImage(), Isis::LoMediumDistortionMap::SetDistortion(), Isis::LoMediumDistortionMap::SetFocalPlane(), Isis::OsirisRexOcamsDistortionMap::SetFocalPlane(), Isis::Camera::SetRightAscensionDeclination(), Isis::LoMediumDistortionMap::SetUndistortedFocalPlane(), and Isis::OsirisRexOcamsDistortionMap::SetUndistortedFocalPlane().
double Isis::CameraFocalPlaneMap::DetectorSampleOffset | ( | ) | const |
Definition at line 342 of file CameraFocalPlaneMap.cpp.
References p_detectorSampleOffset.
double Isis::CameraFocalPlaneMap::DetectorSampleOrigin | ( | ) | const |
Definition at line 310 of file CameraFocalPlaneMap.cpp.
References p_detectorSampleOrigin.
Referenced by Isis::OsirisRexDistortionMap::OsirisRexDistortionMap(), Isis::OsirisRexOcamsDistortionMap::OsirisRexOcamsDistortionMap(), Isis::ReseauDistortionMap::SetFocalPlane(), and Isis::ReseauDistortionMap::SetUndistortedFocalPlane().
double Isis::CameraFocalPlaneMap::FocalPlaneX | ( | ) | const |
Definition at line 239 of file CameraFocalPlaneMap.cpp.
References p_focalPlaneX.
Referenced by Isis::LoMediumDistortionMap::SetFocalPlane(), Isis::Camera::SetImage(), Isis::Camera::SetImage(), Isis::LoMediumDistortionMap::SetUndistortedFocalPlane(), and Isis::AdvancedTrackTool::updateRow().
int Isis::CameraFocalPlaneMap::FocalPlaneXDependency | ( | ) |
Return the focal plane x dependency variable.
This method returns the image variable (sample or line) on which the focal plane x depends.
Definition at line 182 of file CameraFocalPlaneMap.cpp.
double Isis::CameraFocalPlaneMap::FocalPlaneY | ( | ) | const |
Definition at line 247 of file CameraFocalPlaneMap.cpp.
References p_focalPlaneY.
Referenced by Isis::LoMediumDistortionMap::SetFocalPlane(), Isis::Camera::SetImage(), Isis::Camera::SetImage(), and Isis::LoMediumDistortionMap::SetUndistortedFocalPlane().
|
private |
Initialize the focal plane map to its default state.
parent | Parent camera |
naifIkCode | code of the naif instrument for reading coefficients |
Definition at line 92 of file CameraFocalPlaneMap.cpp.
References Isis::Spice::getDouble(), p_camera, p_detectorLineOffset, p_detectorLineOrigin, p_detectorSampleOffset, p_detectorSampleOrigin, p_itransl, p_itranss, p_transx, p_transy, Isis::Camera::SetFocalPlaneMap(), and Isis::toString().
Referenced by CameraFocalPlaneMap(), and CameraFocalPlaneMap().
|
virtual |
Compute distorted focal plane coordinate from detector position (sampel,line)
This method will compute both the distorted focal plane x/y and centered detector position given a detector position
sample | undistorted focal plane x in millimeters |
line | undistorted focal plane y in millimeters |
Definition at line 164 of file CameraFocalPlaneMap.cpp.
References ComputeCentered(), p_centeredDetectorLine, p_centeredDetectorSample, p_detectorLine, p_detectorSample, p_focalPlaneX, p_focalPlaneY, p_transx, and p_transy.
Referenced by Isis::PushFrameCameraGroundMap::FindDistance(), Isis::LoMediumDistortionMap::SetFocalPlane(), Isis::Camera::SetImage(), Isis::Camera::SetImage(), and Isis::LoMediumDistortionMap::SetUndistortedFocalPlane().
void Isis::CameraFocalPlaneMap::SetDetectorOffset | ( | const double | sampleOffset, |
const double | lineOffset ) |
Set the detector offset.
This is used to set the offset between the detector origin and the average location in detector pixels where the image is being viewed. If not set the offset are both 0.0
sampleOffset | sample offset in pixels |
lineOffset | sample offset in lines |
Definition at line 324 of file CameraFocalPlaneMap.cpp.
References p_detectorLineOffset, and p_detectorSampleOffset.
Referenced by Isis::ApolloPanoramicCamera::ApolloPanoramicCamera(), and Isis::ThemisIrCamera::SetBand().
void Isis::CameraFocalPlaneMap::SetDetectorOrigin | ( | const double | sample, |
const double | line ) |
Set the detector origin.
This is used to set the origin of the detector. Typically the middle of the detector. For example, a 512x512 dectector would have the origin at (256.5,256.5). If not set both are 0.
sample | detector sample at the origin |
line | detector line at the origin |
Definition at line 293 of file CameraFocalPlaneMap.cpp.
References p_detectorLineOrigin, and p_detectorSampleOrigin.
Referenced by Isis::ApolloMetricCamera::ApolloMetricCamera(), Isis::ApolloPanoramicCamera::ApolloPanoramicCamera(), Isis::DawnVirCamera::DawnVirCamera(), Isis::HrscCamera::HrscCamera(), Isis::MarciCamera::MarciCamera(), Isis::RosettaVirtisCamera::RosettaVirtisCamera(), Isis::LroWideAngleCamera::SetBand(), and Isis::ThemisIrCamera::SetBand().
|
virtual |
Compute detector position (sample,line) from focal plane coordinates.
NOTE: This is detector (sample, line) not necessarily image (sample, line). If the image was reformatted from what was collected the two differ. See the New Horizons LEISA camera for an example (LEISA is a frame camera being treated as a line scan camera).
This method will compute both the centered and normal detector position given a distorted focal plane coordinate.
dx | distorted focal plane x in millimeters |
dy | distorted focal plane y in millimeters |
Definition at line 143 of file CameraFocalPlaneMap.cpp.
References ComputeUncentered(), p_centeredDetectorLine, p_centeredDetectorSample, p_focalPlaneX, p_focalPlaneY, p_itransl, and p_itranss.
Referenced by LineOffsetFunctor::operator()(), Isis::Camera::RawFocalPlanetoImage(), Isis::LoMediumDistortionMap::SetDistortion(), Isis::LoMediumDistortionMap::SetFocalPlane(), Isis::Camera::SetRightAscensionDeclination(), and Isis::LoMediumDistortionMap::SetUndistortedFocalPlane().
void Isis::CameraFocalPlaneMap::SetTransL | ( | const QVector< double > | transL | ) |
Set the affine coefficients for converting destorted (x,y) to a detector Line.
transL | Vector of the affine coefficients |
Definition at line 352 of file CameraFocalPlaneMap.cpp.
References p_itransl.
Referenced by Isis::NewHorizonsLeisaCamera::SetBand().
void Isis::CameraFocalPlaneMap::SetTransS | ( | const QVector< double > | transS | ) |
Set the affine coefficients for converting destorted (x,y) to a detector Sample.
transS | Vector of the affine coefficients |
Definition at line 364 of file CameraFocalPlaneMap.cpp.
References p_itranss.
Referenced by Isis::NewHorizonsLeisaCamera::SetBand().
void Isis::CameraFocalPlaneMap::SetTransX | ( | const QVector< double > | transX | ) |
Set the affine coefficients for converting detector (sample,line) to a distorted X.
transX | Vector of the affine coefficients |
Definition at line 376 of file CameraFocalPlaneMap.cpp.
References p_transx.
Referenced by Isis::NewHorizonsLeisaCamera::SetBand().
void Isis::CameraFocalPlaneMap::SetTransY | ( | const QVector< double > | transY | ) |
Set the affine coefficients for converting detector (sample,line) to a distorted Y.
transY | Vector of the affine coefficients |
Definition at line 388 of file CameraFocalPlaneMap.cpp.
References p_transy.
Referenced by Isis::NewHorizonsLeisaCamera::SetBand().
double Isis::CameraFocalPlaneMap::SignMostSigX | ( | ) |
Return the sign of the p_transx coefficient with the greatest magnitude.
This method returns a +1. or -1. based on the sign of the p_transx coefficient with the greatest magnitude. Only p_transx[1] and p_transx[2] are compared since p_transx[0] is used as a constant in the affine transformation.
Definition at line 201 of file CameraFocalPlaneMap.cpp.
References p_transx.
double Isis::CameraFocalPlaneMap::SignMostSigY | ( | ) |
Return the sign of the p_transy coefficient with the greatest magnitude.
This method returns a +1 or -1 based on the sign of the p_transy coefficient with the greatest magnitude. Only p_transy[1] and p_transy[2] are compared since p_transy[0] is used as a constant in the affine transformation.
Definition at line 223 of file CameraFocalPlaneMap.cpp.
References p_transy.
const double * Isis::CameraFocalPlaneMap::TransL | ( | ) | const |
Definition at line 422 of file CameraFocalPlaneMap.cpp.
References p_itransl.
const double * Isis::CameraFocalPlaneMap::TransS | ( | ) | const |
Definition at line 414 of file CameraFocalPlaneMap.cpp.
References p_itranss.
const double * Isis::CameraFocalPlaneMap::TransX | ( | ) | const |
Definition at line 398 of file CameraFocalPlaneMap.cpp.
References p_transx.
const double * Isis::CameraFocalPlaneMap::TransY | ( | ) | const |
Definition at line 406 of file CameraFocalPlaneMap.cpp.
References p_transy.
|
protected |
Camera of the image.
Definition at line 137 of file CameraFocalPlaneMap.h.
Referenced by Isis::LroWideAngleCameraFocalPlaneMap::addFilter(), CameraFocalPlaneMap(), and Init().
|
protected |
Detector line position.
Definition at line 147 of file CameraFocalPlaneMap.h.
Referenced by CenteredDetectorLine(), ComputeCentered(), ComputeUncentered(), SetDetector(), and SetFocalPlane().
|
protected |
Detector sample position.
Definition at line 146 of file CameraFocalPlaneMap.h.
Referenced by CenteredDetectorSample(), ComputeCentered(), ComputeUncentered(), SetDetector(), and SetFocalPlane().
|
protected |
line value of the detector
Definition at line 144 of file CameraFocalPlaneMap.h.
Referenced by ComputeCentered(), ComputeUncentered(), DetectorLine(), and SetDetector().
|
protected |
Offset of the detector origin line from the average.
Definition at line 149 of file CameraFocalPlaneMap.h.
Referenced by CameraFocalPlaneMap(), DetectorLineOffset(), Init(), and SetDetectorOffset().
|
protected |
The origin line of the detector.
Definition at line 139 of file CameraFocalPlaneMap.h.
Referenced by CameraFocalPlaneMap(), ComputeCentered(), ComputeUncentered(), DetectorLineOrigin(), Init(), and SetDetectorOrigin().
|
protected |
sample value of the detector
Definition at line 145 of file CameraFocalPlaneMap.h.
Referenced by ComputeCentered(), ComputeUncentered(), DetectorSample(), and SetDetector().
|
protected |
offset of the detector origin sample from the average
Definition at line 150 of file CameraFocalPlaneMap.h.
Referenced by CameraFocalPlaneMap(), DetectorSampleOffset(), Init(), and SetDetectorOffset().
|
protected |
The origin sample of the detector.
Definition at line 140 of file CameraFocalPlaneMap.h.
Referenced by CameraFocalPlaneMap(), ComputeCentered(), ComputeUncentered(), DetectorSampleOrigin(), Init(), and SetDetectorOrigin().
|
protected |
x value of focal plane coordinate
Definition at line 142 of file CameraFocalPlaneMap.h.
Referenced by FocalPlaneX(), SetDetector(), and SetFocalPlane().
|
protected |
y value of focal plane coordinate
Definition at line 143 of file CameraFocalPlaneMap.h.
Referenced by FocalPlaneY(), SetDetector(), and SetFocalPlane().
|
protected |
The y transition from distorted to detector.
Definition at line 155 of file CameraFocalPlaneMap.h.
Referenced by CameraFocalPlaneMap(), Init(), Isis::LroWideAngleCameraFocalPlaneMap::setBand(), SetFocalPlane(), SetTransL(), and TransL().
|
protected |
The x transition from distorted to detector.
Definition at line 154 of file CameraFocalPlaneMap.h.
Referenced by CameraFocalPlaneMap(), Init(), Isis::LroWideAngleCameraFocalPlaneMap::setBand(), SetFocalPlane(), SetTransS(), and TransS().
|
protected |
The x transition from detector to distorted.
Definition at line 152 of file CameraFocalPlaneMap.h.
Referenced by CameraFocalPlaneMap(), FocalPlaneXDependency(), Init(), Isis::LroWideAngleCameraFocalPlaneMap::setBand(), SetDetector(), SetTransX(), SignMostSigX(), and TransX().
|
protected |
The y transition from detector to distorted.
Definition at line 153 of file CameraFocalPlaneMap.h.
Referenced by CameraFocalPlaneMap(), Init(), Isis::LroWideAngleCameraFocalPlaneMap::setBand(), SetDetector(), SetTransY(), SignMostSigY(), and TransY().