Isis 3 Programmer Reference
Isis::LroWideAngleCameraFocalPlaneMap Class Reference

Distort/undistort focal plane coordinates. More...

#include <LroWideAngleCameraFocalPlaneMap.h>

Inheritance diagram for Isis::LroWideAngleCameraFocalPlaneMap:
Inheritance graph
Collaboration diagram for Isis::LroWideAngleCameraFocalPlaneMap:
Collaboration graph

Classes

struct  TranslationParameters
 

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

 LroWideAngleCameraFocalPlaneMap (Camera *parent, int naifIkCode)
 Camera distortion map constructor.
 
virtual ~LroWideAngleCameraFocalPlaneMap ()
 Destroys the LroWideAngleCameraFocalPlaneMap object.
 
void addFilter (int naifIkCode)
 Add an additional set of parameters for a given LROC/WAC filter.
 
void setBand (int vband)
 Implements band-dependant focal plane parameters.
 
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

Camerap_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.
 

Private Attributes

QVector< TranslationParametersm_transparms
 

Detailed Description

Distort/undistort focal plane coordinates.

Creates a map for adding/removing optical distortions from the focal plane of a camera.

See also
LroWideAngleCamera
Author
2013-03-07 Kris Becker
History
2013-03-07 Kris Becker - Implements new focal plane map allowing for band independent distortions.

Definition at line 33 of file LroWideAngleCameraFocalPlaneMap.h.

Member Enumeration Documentation

◆ FocalPlaneXDependencyType

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.

Constructor & Destructor Documentation

◆ LroWideAngleCameraFocalPlaneMap()

Isis::LroWideAngleCameraFocalPlaneMap::LroWideAngleCameraFocalPlaneMap ( Camera * parent,
int naifIkCode )

Camera distortion map constructor.

Create a camera distortion map. This class maps between distorted and undistorted focal plane x/y's. The default mapping is the identity, that is, the focal plane x/y and undistorted focal plane x/y will be identical.

Parameters
parentthe parent camera that will use this distortion map
zDirectionthe direction of the focal plane Z-axis (either 1 or -1)

Definition at line 33 of file LroWideAngleCameraFocalPlaneMap.cpp.

◆ ~LroWideAngleCameraFocalPlaneMap()

virtual Isis::LroWideAngleCameraFocalPlaneMap::~LroWideAngleCameraFocalPlaneMap ( )
inlinevirtual

Destroys the LroWideAngleCameraFocalPlaneMap object.

Definition at line 38 of file LroWideAngleCameraFocalPlaneMap.h.

Member Function Documentation

◆ addFilter()

void Isis::LroWideAngleCameraFocalPlaneMap::addFilter ( int naifIkCode)

Add an additional set of parameters for a given LROC/WAC filter.

This method will read the parameters for LROC/WAC filter as indicated by the IK code provided. It will create a vector of these parameters and append them to the band list.

The filters added should correspond directly to the order in which the filters are physically stored in the ISIS cube (or the virtually selected bands).

Author
2013-03-07 Kris Becker
Parameters
naifIkCodeNAIF IK code for the desired filter to add.

Definition at line 55 of file LroWideAngleCameraFocalPlaneMap.cpp.

References Isis::Spice::getDouble(), Isis::CameraFocalPlaneMap::p_camera, and Isis::toString().

◆ CenteredDetectorLine()

double Isis::CameraFocalPlaneMap::CenteredDetectorLine ( ) const
inherited
Returns
The centered detector line

Definition at line 279 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_centeredDetectorLine.

◆ CenteredDetectorSample()

double Isis::CameraFocalPlaneMap::CenteredDetectorSample ( ) const
inherited
Returns
The centered detector sample

Definition at line 271 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_centeredDetectorSample.

◆ ComputeCentered()

◆ ComputeUncentered()

◆ DetectorLine()

◆ DetectorLineOffset()

double Isis::CameraFocalPlaneMap::DetectorLineOffset ( ) const
inherited

◆ DetectorLineOrigin()

◆ DetectorSample()

◆ DetectorSampleOffset()

double Isis::CameraFocalPlaneMap::DetectorSampleOffset ( ) const
inherited
Returns
The detector sample offset

Definition at line 342 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_detectorSampleOffset.

◆ DetectorSampleOrigin()

◆ FocalPlaneX()

double Isis::CameraFocalPlaneMap::FocalPlaneX ( ) const
inherited

◆ FocalPlaneXDependency()

int Isis::CameraFocalPlaneMap::FocalPlaneXDependency ( )
inherited

Return the focal plane x dependency variable.

This method returns the image variable (sample or line) on which the focal plane x depends.

Returns
dependency variable

Definition at line 182 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::Line, Isis::CameraFocalPlaneMap::p_transx, and Isis::CameraFocalPlaneMap::Sample.

◆ FocalPlaneY()

double Isis::CameraFocalPlaneMap::FocalPlaneY ( ) const
inherited

◆ Init()

◆ setBand()

void Isis::LroWideAngleCameraFocalPlaneMap::setBand ( int vband)

Implements band-dependant focal plane parameters.

This method should be used to switch to another band's set of distortion parameters. See the addFilter() method to add additional band parameters to this object. Note that the band number should correspond with the same order as they were added in the addFilter() method.

Author
2013-03-07 Kris Becker
Parameters
vbandBand number to select. Range is 1 to Bands.

Definition at line 86 of file LroWideAngleCameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_itransl, Isis::CameraFocalPlaneMap::p_itranss, Isis::CameraFocalPlaneMap::p_transx, Isis::CameraFocalPlaneMap::p_transy, and Isis::IException::Programmer.

◆ SetDetector()

bool Isis::CameraFocalPlaneMap::SetDetector ( const double sample,
const double line )
virtualinherited

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

Parameters
sampleundistorted focal plane x in millimeters
lineundistorted focal plane y in millimeters
Returns
conversion was successful

Definition at line 164 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::ComputeCentered(), Isis::CameraFocalPlaneMap::p_centeredDetectorLine, Isis::CameraFocalPlaneMap::p_centeredDetectorSample, Isis::CameraFocalPlaneMap::p_detectorLine, Isis::CameraFocalPlaneMap::p_detectorSample, Isis::CameraFocalPlaneMap::p_focalPlaneX, Isis::CameraFocalPlaneMap::p_focalPlaneY, Isis::CameraFocalPlaneMap::p_transx, and Isis::CameraFocalPlaneMap::p_transy.

Referenced by Isis::PushFrameCameraGroundMap::FindDistance(), Isis::LoMediumDistortionMap::SetFocalPlane(), Isis::Camera::SetImage(), Isis::Camera::SetImage(), and Isis::LoMediumDistortionMap::SetUndistortedFocalPlane().

◆ SetDetectorOffset()

void Isis::CameraFocalPlaneMap::SetDetectorOffset ( const double sampleOffset,
const double lineOffset )
inherited

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

Parameters
sampleOffsetsample offset in pixels
lineOffsetsample offset in lines

Definition at line 324 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_detectorLineOffset, and Isis::CameraFocalPlaneMap::p_detectorSampleOffset.

Referenced by Isis::ApolloPanoramicCamera::ApolloPanoramicCamera(), and Isis::ThemisIrCamera::SetBand().

◆ SetDetectorOrigin()

void Isis::CameraFocalPlaneMap::SetDetectorOrigin ( const double sample,
const double line )
inherited

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.

Parameters
sampledetector sample at the origin
linedetector line at the origin

Definition at line 293 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_detectorLineOrigin, and Isis::CameraFocalPlaneMap::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().

◆ SetFocalPlane()

bool Isis::CameraFocalPlaneMap::SetFocalPlane ( const double dx,
const double dy )
virtualinherited

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.

Parameters
dxdistorted focal plane x in millimeters
dydistorted focal plane y in millimeters
Returns
conversion was successful

Definition at line 143 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::ComputeUncentered(), Isis::CameraFocalPlaneMap::p_centeredDetectorLine, Isis::CameraFocalPlaneMap::p_centeredDetectorSample, Isis::CameraFocalPlaneMap::p_focalPlaneX, Isis::CameraFocalPlaneMap::p_focalPlaneY, Isis::CameraFocalPlaneMap::p_itransl, and Isis::CameraFocalPlaneMap::p_itranss.

Referenced by LineOffsetFunctor::operator()(), Isis::Camera::RawFocalPlanetoImage(), Isis::LoMediumDistortionMap::SetDistortion(), Isis::LoMediumDistortionMap::SetFocalPlane(), Isis::Camera::SetRightAscensionDeclination(), and Isis::LoMediumDistortionMap::SetUndistortedFocalPlane().

◆ SetTransL()

void Isis::CameraFocalPlaneMap::SetTransL ( const QVector< double > transL)
inherited

Set the affine coefficients for converting destorted (x,y) to a detector Line.

Parameters
transLVector of the affine coefficients

Definition at line 352 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_itransl.

Referenced by Isis::NewHorizonsLeisaCamera::SetBand().

◆ SetTransS()

void Isis::CameraFocalPlaneMap::SetTransS ( const QVector< double > transS)
inherited

Set the affine coefficients for converting destorted (x,y) to a detector Sample.

Parameters
transSVector of the affine coefficients

Definition at line 364 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_itranss.

Referenced by Isis::NewHorizonsLeisaCamera::SetBand().

◆ SetTransX()

void Isis::CameraFocalPlaneMap::SetTransX ( const QVector< double > transX)
inherited

Set the affine coefficients for converting detector (sample,line) to a distorted X.

Parameters
transXVector of the affine coefficients

Definition at line 376 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_transx.

Referenced by Isis::NewHorizonsLeisaCamera::SetBand().

◆ SetTransY()

void Isis::CameraFocalPlaneMap::SetTransY ( const QVector< double > transY)
inherited

Set the affine coefficients for converting detector (sample,line) to a distorted Y.

Parameters
transYVector of the affine coefficients

Definition at line 388 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_transy.

Referenced by Isis::NewHorizonsLeisaCamera::SetBand().

◆ SignMostSigX()

double Isis::CameraFocalPlaneMap::SignMostSigX ( )
inherited

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.

Returns
sign of most significant coefficient

Definition at line 201 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_transx.

◆ SignMostSigY()

double Isis::CameraFocalPlaneMap::SignMostSigY ( )
inherited

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.

Returns
sign of most significant coefficient

Definition at line 223 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_transy.

◆ TransL()

const double * Isis::CameraFocalPlaneMap::TransL ( ) const
inherited
Returns
The affine coefficients for converting distorted (x,y) to a detector Line

Definition at line 422 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_itransl.

◆ TransS()

const double * Isis::CameraFocalPlaneMap::TransS ( ) const
inherited
Returns
The affine coefficients for converting distorted (x,y) to a detector Sample

Definition at line 414 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_itranss.

◆ TransX()

const double * Isis::CameraFocalPlaneMap::TransX ( ) const
inherited
Returns
The affine coefficients for converting detector (sample,line) to a distorted X

Definition at line 398 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_transx.

◆ TransY()

const double * Isis::CameraFocalPlaneMap::TransY ( ) const
inherited
Returns
The affine coefficients for converting detector (sample,line) to distorted Y

Definition at line 406 of file CameraFocalPlaneMap.cpp.

References Isis::CameraFocalPlaneMap::p_transy.

Member Data Documentation

◆ m_transparms

QVector<TranslationParameters> Isis::LroWideAngleCameraFocalPlaneMap::m_transparms
private

Definition at line 50 of file LroWideAngleCameraFocalPlaneMap.h.

◆ p_camera

Camera* Isis::CameraFocalPlaneMap::p_camera
protectedinherited

◆ p_centeredDetectorLine

◆ p_centeredDetectorSample

◆ p_detectorLine

double Isis::CameraFocalPlaneMap::p_detectorLine
protectedinherited

◆ p_detectorLineOffset

double Isis::CameraFocalPlaneMap::p_detectorLineOffset
protectedinherited

◆ p_detectorLineOrigin

◆ p_detectorSample

double Isis::CameraFocalPlaneMap::p_detectorSample
protectedinherited

◆ p_detectorSampleOffset

double Isis::CameraFocalPlaneMap::p_detectorSampleOffset
protectedinherited

◆ p_detectorSampleOrigin

◆ p_focalPlaneX

double Isis::CameraFocalPlaneMap::p_focalPlaneX
protectedinherited

◆ p_focalPlaneY

double Isis::CameraFocalPlaneMap::p_focalPlaneY
protectedinherited

◆ p_itransl

double Isis::CameraFocalPlaneMap::p_itransl[3]
protectedinherited

◆ p_itranss

double Isis::CameraFocalPlaneMap::p_itranss[3]
protectedinherited

◆ p_transx

◆ p_transy


The documentation for this class was generated from the following files: