USGS

Isis 3.0 Object Programmers' Reference

Home

Isis::Chip Class Reference

A small chip of data used for pattern matching. More...

#include <Chip.h>

Collaboration diagram for Isis::Chip:
Collaboration graph

Public Member Functions

 Chip ()
 Constructs a Chip.
 Chip (const Chip &other)
 Constructs a copy of the passed in chip.
 Chip (const int samples, const int lines)
 Construct a Chip with specified dimensions.
virtual ~Chip ()
 Destroys the Chip object.
void SetSize (const int samples, const int lines)
 Change the size of the Chip.
bool IsInsideChip (double sample, double line)
int Samples () const
 Return the number of samples in the chip.
int Lines () const
 Return the number of lines in the chip.
QString FileName () const
 Returns the expanded filename of the cube from which this chip was chipped.
void SetAllValues (const double &d)
 Single value assignment operator.
void SetValue (int sample, int line, const double &value)
 Sets a value in the chip.
double GetValue (int sample, int line)
 Loads a Chip with a value.
const double GetValue (int sample, int line) const
 Get a value from a Chip.
void TackCube (const double cubeSample, const double cubeLine)
 This sets which cube position will be located at the chip tack position.
int TackSample () const
 Return the fixed tack sample of the chip.
int TackLine () const
 Return the fixed tack line of the chip.
void Load (Cube &cube, const double rotation=0.0, const double scale=1.0, const int band=1)
 Load cube data into the Chip.
void Load (Cube &cube, Chip &match, Cube &matchChipCube, const double scale=1.0, const int band=1)
 Loads cube data into the Chip.
void Load (Cube &cube, const Affine &affine, const bool &keepPoly=true, const int band=1)
 Load a chip using an Affine transform as provided by caller.
void SetChipPosition (const double sample, const double line)
 Compute the position of the cube given a chip coordinate.
double CubeSample () const
 Returns cube sample after invoking SetChipPosition.
double CubeLine () const
 Returns cube line after invoking SetChipPosition.
void SetCubePosition (const double sample, const double line)
 Compute the position of the chip given a cube coordinate.
double ChipSample () const
 Returns chip sample after invoking SetCubePosition.
double ChipLine () const
 Returns chip line after invoking SetCubePosition.
void SetValidRange (const double minimum=Isis::ValidMinimum, const double maximum=Isis::ValidMaximum)
 Set the valid range of data in the chip.
bool IsValid (double percentage)
 Return if the pixel is valid at a particular position.
bool IsValid (int sample, int line)
 Returns whether the value at the given sample, line position is within the valid range.
Chip Extract (int samples, int lines, int samp, int line)
 Extract a sub-chip from a chip.
void Extract (int samp, int line, Chip &output)
 Extract a subchip centered at the designated coordinate.
Isis::StatisticsStatistics ()
 Returns a statistics object of the current data in the chip.
void Extract (Chip &output, Affine &affine)
 Extract a subchip of this chip using an Affine transform.
void Write (const QString &filename)
 Writes the contents of the Chip to a cube.
void SetClipPolygon (const geos::geom::MultiPolygon &clipPolygon)
 Sets the clipping polygon for this chip.
Chipoperator= (const Chip &other)
 Copy assignment operator.
const AffineGetTransform () const
 Returns the Affine transformation of chip-to-cube indices.
void SetTransform (const Affine &affine, const bool &keepPoly=true)
 Sets the internal Affine transform to new translation.
const Interpolator::interpType GetReadInterpolator ()
 Access method that returns the Interpolator Type used for loading a chip.
void SetReadInterpolator (const Interpolator::interpType type)
 Sets Interpolator Type for loading a chip.

Private Member Functions

void Init (const int samples, const int lines)
 Common initialization used by constructors.
void Read (Cube &cube, const int band)
 This method reads data from a cube and puts it into the chip.
std::vector< int > MovePoints (int startSamp, int startLine, int endSamp, int endLine)
 This method is called by Load() to move a control point across the chip.
bool PointsColinear (double x0, double y0, double x1, double y1, double x2, double y2, double tol)
 This method is called by Load() to determine whether the given 3 points are nearly colinear.

Private Attributes

int m_chipSamples
 Number of samples in the chip.
int m_chipLines
 Number of lines in the chip.
std::vector< std::vector
< double > > 
m_buf
 Chip buffer.
int m_tackSample
 Middle sample of the chip.
int m_tackLine
 Middle line of the chip.
double m_cubeTackSample
 cube sample at the chip tack
double m_cubeTackLine
 cube line at the chip tack
double m_validMinimum
 valid minimum chip pixel value
double m_validMaximum
 valid maximum chip pixel value
double m_chipSample
 chip sample set by SetChip/CubePosition
double m_chipLine
 chip line set by SetChip/CubePosition
double m_cubeSample
 cube sample set by SetCubePosition
double m_cubeLine
 cube line set by SetCubePosition
geos::geom::MultiPolygon * m_clipPolygon
 clipping polygon set by SetClipPolygon
Affine m_affine
 Transform set by SetTransform.
Interpolator::interpType m_readInterpolator
 Interpolator type set by.
QString m_filename
 FileName of loaded cube.

Detailed Description

A small chip of data used for pattern matching.

A chip is a small rectangular area that can be used for pattern matching. Data can be loaded into the chip manually or by reading directly from a cube.

Author
2005-05-05 Jeff Anderson
See Also
AutoReg
AutoRegFactory
History:
2006-07-11 Tracie Sucharski - Added reLoad method to use m_cube instead of cube passed in.
History:
2006-08-03 Tracie Sucharski - Added Load and ReLoad method to apply scale factor to chip.
History:
2006-08-04 Stuart Sides - Added SetClipPolygon method. If the clip polygon is set all pixel values outside the polygon will be set to NULL.
History:
2007-10-01 Steven Koechle - Fixed inc in LoadChip to fix an infinite loop problem when x.size() never grew to be more than 3.
History:
2009-01-19 Steven Koechle - Fixed memory leak
History:
2009-06-02 Stacy Alley - Added a check in the SetSize() method to make sure the given samples and lines are not equal to or less than zero.
History:
2009-08-19 Kris Becker - Added new Extract method that applies an Affine transform to the extract a portion of the chip; added an assigment operator that sets the entire chip to a single value for convenience. Added a getter that returns a const reference to the internal Affine transform of this chip.
History:
2009-08-20 Steven Lambright - Removed local cube pointer and parenthesis operator
History:
2009-08-20 Travis Addair - Added Statistics method
History:
2009-08-28 Kris Becker - Added new Affine setter method to establish a new Affine transform to the chip; added another Load method that uses a new Affine transform to load a chip from a cube.
History:
2009-09-01 Travis Addair - Added valid Min/Max pixel value functionality for Statistics method
History:
2010-01-28 Tracie Sucharski - In the Load method (with match chip) when calculating control points away from the corners, added a linc to move into the center of the chip in a non-linear fashion to prevent control points that fall in a line and cause the matrix inversion to fail.
History:
2010-05-24 Jeannie Walldren - Fixed bug in the Load() method (with match chip). Modified to look for control points from each corner, rather than looping around. Added a method, PointsColinear() to check whether the points added are almost along the same line. Moved the code from Load() that chose new points to a new method, MovePoints().
History:
2010-06-10 Jeannie Walldren - Modified PointsColinear() method to take in user defined tolerance as parameter to allow registration of more narrow search chip areas. Updated documentation, error messages, unitTest.
History:
2010-06-15 Jeannie Walldren - Added set and accessor methods for Read() method's Interpolator::interpType. Updated documentation and unitTest.
History:
2010-09-16 Jeannie Walldren - Updated unitTest, truth file and test cube to run properly with ShapeModel changes to Sensor class.
History:
2011-03-29 Jai Rideout - Added copy constructor and equals operator.
History:
2011-10-02 Kris Becker - Corrected a bug in the Extract(Chip, Affine) method when computing output pixels coordinates.
History:
2015-07-06 David Miller - Modified code to better reflect current Coding Standards. Updated truth data. Fixes #2273

Definition at line 101 of file Chip.h.

Constructor & Destructor Documentation

Isis::Chip::Chip ( )

Constructs a Chip.

The default size is 3x3.

Definition at line 57 of file Chip.cpp.

Isis::Chip::Chip ( const Chip other)

Constructs a copy of the passed in chip.

Parameters
otherthe chip to be copied

Definition at line 66 of file Chip.cpp.

References m_affine, m_buf, m_chipLine, m_chipLines, m_chipSample, m_chipSamples, m_clipPolygon, m_cubeLine, m_cubeSample, m_cubeTackLine, m_cubeTackSample, m_filename, m_readInterpolator, m_tackLine, m_tackSample, m_validMaximum, and m_validMinimum.

Isis::Chip::Chip ( const int  samples,
const int  lines 
)

Construct a Chip with specified dimensions.

Parameters
samplesnumber of samples in the chip
linesnumber of lines in the chip

Definition at line 104 of file Chip.cpp.

Isis::Chip::~Chip ( )
virtual

Destroys the Chip object.

Definition at line 110 of file Chip.cpp.

Member Function Documentation

double Isis::Chip::ChipLine ( ) const
inline

Returns chip line after invoking SetCubePosition.

Definition at line 229 of file Chip.h.

References m_chipLine.

Referenced by Isis::ChipViewport::cubeToViewport(), Isis::Gruen::getChipUpdate(), and Isis::AutoReg::SetSubpixelPosition().

double Isis::Chip::ChipSample ( ) const
inline

Returns chip sample after invoking SetCubePosition.

Definition at line 224 of file Chip.h.

References m_chipSample.

Referenced by Isis::ChipViewport::cubeToViewport(), Isis::Gruen::getChipUpdate(), and Isis::AutoReg::SetSubpixelPosition().

Chip Isis::Chip::Extract ( int  samples,
int  lines,
int  samp,
int  line 
)

Extract a sub-chip from a chip.

Parameters
samplesNumber of samples in the extracted chip (must be less than or equal to "this" chip)
linesNumber of lines in the extracted chip (must be less than or equal to "this" chip)
sampInput chip sample to be placed at output chip tack
lineInput chip line to be placed at output chip tack
Returns
Chip Sub-chip extracted from the chip
Exceptions
Isis::IException::Programmer- Chip extraction invalid
History:
2010-06-10 Jeannie Walldren - Modified error message

Definition at line 765 of file Chip.cpp.

References _FILEINFO_, m_affine, m_tackLine, m_tackSample, m_validMaximum, m_validMinimum, Isis::Null, SetValue(), TackLine(), TackSample(), and Isis::toString().

Referenced by Isis::AutoReg::ApplyGradientFilter(), Isis::InterestOperator::InterestByMeasure(), Isis::AutoReg::Match(), Isis::InterestOperator::Operate(), Isis::Gruen::Registration(), and Isis::AutoReg::Registration().

void Isis::Chip::Extract ( int  samp,
int  line,
Chip chipped 
)

Extract a subchip centered at the designated coordinate.

This method extracts a subchip that is centered at the given sample and line coordinate. All appropriate variables in the given chipped parameter are set appropriately prior to return.

Parameters
sampCenter (tack) sample chip coordinate to extract subchip
lineCenter (tack) line chip coordinate to extract subchip
chippedChip to load the subchip in and return to caller

Definition at line 810 of file Chip.cpp.

References Lines(), m_affine, m_tackLine, m_tackSample, m_validMaximum, m_validMinimum, Isis::Null, Samples(), SetValue(), TackLine(), and TackSample().

void Isis::Chip::Extract ( Chip chipped,
Affine affine 
)

Extract a subchip of this chip using an Affine transform.

This method will translate the data in this chip using an Affine transform to the output chip as provided. Note that the Affine transformation is only applied within the confines of this chip. No file I/O is performed.

A proper Affine transform should not deviate too much from the identity as the mapping operation may result in a NULL filled chip. The operation of this affine is added to the existing affine so proper relationship to the input cube (and any affine operations applied at load time) is preserved. This implies that the resulting affine should yield nearly identical results when read directly from the cube.

Bilinear interpolation is applied to surrounding transformed pixels to provide each new output pixel.

The chipped parameter will be updated to fully reflect the state of this original chip. The state of the chipped parameter dictates the size and the tack sample and line coordinates. Upon return, the corresponding cube sample and line coordinate is updated to the tack sample and line chip coordinate.

As such, note that an identity affine transform will yield identical results to the Chip::Extract method specifying the tack sample and line as the location to extract.

The following example demonstrates how to linearly shift a chip one pixel right and one down.

Chip mychip(35,35);
Cube cube("mycube.cub");
mychip.TackCube(200.0,200.0);
mychip.Load(cube);
Affine shift;
shift.Translate(-1.0,-1.0);
Chip ochip(15,15);
mychip.Extract(ochip, shift);
Parameters
chippedInput/output chip containing the transformed subchip
affineAffine transform to apply to extract subchip

Definition at line 884 of file Chip.cpp.

References Isis::Affine::Compute(), Isis::Affine::Forward(), Isis::Interpolator::HotLine(), Isis::Interpolator::HotSample(), Isis::Interpolator::Interpolate(), Isis::Interpolator::Lines(), Lines(), m_affine, m_chipLine, m_chipSample, m_cubeLine, m_cubeSample, m_cubeTackLine, m_cubeTackSample, m_filename, m_validMaximum, m_validMinimum, Isis::Null, Isis::Interpolator::Samples(), Samples(), SetValue(), TackLine(), TackSample(), Isis::Affine::xp(), and Isis::Affine::yp().

QString Isis::Chip::FileName ( ) const
inline

Returns the expanded filename of the cube from which this chip was chipped.

Definition at line 128 of file Chip.h.

References m_filename.

const Interpolator::interpType Isis::Chip::GetReadInterpolator ( )
inline

Access method that returns the Interpolator Type used for loading a chip.

Returns
const Interpolator::interpType Interpolator used to read data from cube and put it into a chip.
See Also
Read()
SetReadInterpolator()
Author
Jeannie Walldren
History:
2010-06-05 Jeannie Walldren - Original version

Definition at line 304 of file Chip.h.

References m_readInterpolator.

const Affine& Isis::Chip::GetTransform ( ) const
inline

Returns the Affine transformation of chip-to-cube indices.

This method returns the affine transform used to load a chip from the same area as a match cube. It also is used to track the tack point line and sample translations from the chip indices to the absolute cube coordiates.

Returns
const Affine& Transform map from chip coordinates to cube coordinates

Definition at line 270 of file Chip.h.

References m_affine.

const double Isis::Chip::GetValue ( int  sample,
int  line 
) const
inline

Get a value from a Chip.

For example,

Chip c(10,5);
cout << c[3,3] << endl;
Parameters
sampleSample position to get (1-based)
lineLine position to get (1-based)

Definition at line 174 of file Chip.h.

References m_buf.

void Isis::Chip::Init ( const int  samples,
const int  lines 
)
private

Common initialization used by constructors.

Parameters
samplesnumber of samples in the chip
linesnumber of lines in the chip
History:
2010-06-15 Jeannie Walldren - Added call to set Read() method's interpolator default to Cubic Convolution type

Definition at line 138 of file Chip.cpp.

bool Isis::Chip::IsInsideChip ( double  sample,
double  line 
)
Parameters
sample
line
Returns
bool True if the given sample, line is inside the chip

Definition at line 184 of file Chip.cpp.

Referenced by Isis::ChipViewport::cubeToViewport().

bool Isis::Chip::IsValid ( double  percentage)

Return if the pixel is valid at a particular position.

Parameters
samplesample position to test
lineline position to test
Returns
bool - Returns true if the pixel is valid, and false if it is not Return if total number of valid pixels in chip meets a specified percentage of the entire chip.
Parameters
percentageThe percentage that the valid pixels percentage must exceed
Returns
bool Returns true if the percentage of valid pixels is greater than the specified percentage, and false if it is not

Definition at line 739 of file Chip.cpp.

Referenced by Isis::Gruen::algorithm(), Isis::AutoReg::Register(), and Isis::AutoReg::Registration().

bool Isis::Chip::IsValid ( int  sample,
int  line 
)
inline

Returns whether the value at the given sample, line position is within the valid range.

Parameters
sampleSample position
lineLine position

Definition at line 244 of file Chip.h.

References GetValue(), m_validMaximum, and m_validMinimum.

void Isis::Chip::Load ( Cube cube,
const double  rotation = 0.0,
const double  scale = 1.0,
const int  band = 1 
)

Load cube data into the Chip.

The data will be loaded such that the position set using TackCube method will be put at the center of the chip. The data will be loaded to sub-pixel accuracy using the interpolator indicated using SetReadInterpolator() method.

Parameters
cubeThe cube used to put data into the chip
rotationrotation in degrees of data about the cube tack point (default of 0)
scalescale factor (default of 1)
bandBand number to use when loading (default of 1)
See Also
Read()
SetReadInterpolator()
GetReadInterpolator()

Definition at line 225 of file Chip.cpp.

References Isis::Cube::fileName().

Referenced by Isis::ChipViewport::geomChip(), Isis::InterestOperator::InterestByMeasure(), Isis::ChipViewport::nogeomChip(), Isis::InterestOperator::Operate(), Isis::ControlPointEdit::registerPoint(), Isis::ChipViewport::reloadChip(), Isis::ChipViewport::rotateChip(), Isis::ControlPointEdit::setLeftMeasure(), and Isis::ControlPointEdit::setRightMeasure().

void Isis::Chip::Load ( Cube cube,
Chip match,
Cube matchChipCube,
const double  scale = 1.0,
const int  band = 1 
)

Loads cube data into the Chip.

The data will be loaded such that the position set using TackCube method will be put at the center of the chip. The data will be loaded to sub-pixel accuracy using the interpolator indicated using SetReadInterpolator() method. Additionally, the data will be loaded such that it matches the camera and/or projective geometry of a given Chip.

Parameters
cubeThe cube used to put data into the chip
matchMatch the geometry of this chip
matchChipCubeThe cube used to put data into the match chip
scalescale factor (default of 1)
bandBand number to use when loading (default of 1)
Exceptions
Isis::iException::Programmer- Chip cube is not a camera or map projection
Isis::iException::Programmer- Match chip cube is not a camera or map projection
Isis::iException::Programmer- Cannot find enough points to perform Affine transformation.
See Also
Read()
SetReadInterpolator()
GetReadInterpolator()
History:
2010-01-28 Tracie Sucharski - When calculating control points away from corners, added a linc to move into the center of the chip in a non-linear fashion to prevent control points that fall in a line and cause the matrix inversion to fail.
History:
2010-05-24 Jeannie Walldren - Modified code when looking for control points for affine to start at each corner and move inward rather than looping around the corners. This lessens the likelyhood that the points will be too linear for the transform to work properly. A check was also added to ensure that we do not choose colinear points.
History:
2010-06-10 Jeannie Walldren - Modified error message and added tolerance to linearity check. Fixed error messages.

Definition at line 322 of file Chip.cpp.

References _FILEINFO_, Isis::IException::append(), Isis::Cube::camera(), CubeLine(), CubeSample(), Isis::Cube::fileName(), Isis::Sensor::HasSurfaceIntersection(), Isis::Projection::IsGood(), Isis::Camera::Line(), Isis::Cube::projection(), Isis::Camera::Sample(), SetChipPosition(), Isis::Camera::SetImage(), Isis::Camera::SetUniversalGround(), Isis::Projection::SetUniversalGround(), Isis::Projection::SetWorld(), TackLine(), TackSample(), Isis::Sensor::UniversalLatitude(), Isis::TProjection::UniversalLatitude(), Isis::Sensor::UniversalLongitude(), Isis::TProjection::UniversalLongitude(), Isis::Projection::WorldX(), and Isis::Projection::WorldY().

void Isis::Chip::Load ( Cube cube,
const Affine affine,
const bool &  keepPoly = true,
const int  band = 1 
)

Load a chip using an Affine transform as provided by caller.

This method will load data from a cube using an established Affine transform as provided by the caller. It is up to the caller to set up the affine appropriately.

For example, the first thing this method will do is set the chip tack point to the transformed cube location by replacing the existing affine transform with the one passed in and then calling SetChipPosition providing the chip tack point as the argument. This establishes which cube pixel is located at the chip tack point.

The data will be loaded to sub-pixel accuracy using the interpolator indicated using SetReadInterpolator() method.

Parameters
cubeCube to load the data from
affineAffine transform to set for chip load/operations
keepPolyIndicates whether clipping polygon should be kept or removed (default of true)
bandBand number to read data from (default of 1)
See Also
Read()
SetReadInterpolator()
GetReadInterpolator()

Definition at line 266 of file Chip.cpp.

References Isis::Cube::fileName().

vector< int > Isis::Chip::MovePoints ( int  startSamp,
int  startLine,
int  endSamp,
int  endLine 
)
private

This method is called by Load() to move a control point across the chip.

Parameters
*startSampSample value to be increased, or moved right.
*startLineLine value to be increased, or moved downward.
*endSampSample value to be decreased, or moved left.
*endLineLine value to be decreased, or moved upward.
Returns
vector < int > Vector containing the new sample and line values in the same order as the parameters passed into the method.
Author
Tracie Sucharski
History:
2010-05-24 Jeannie Walldren - Moved from Load() method to its own method since this code needed to be repeated several times.

Definition at line 637 of file Chip.cpp.

Chip & Isis::Chip::operator= ( const Chip other)

Copy assignment operator.

Parameters
otherchip to be copied to this

Definition at line 1057 of file Chip.cpp.

References m_affine, m_buf, m_chipLine, m_chipLines, m_chipSample, m_chipSamples, m_clipPolygon, m_cubeLine, m_cubeSample, m_cubeTackLine, m_cubeTackSample, m_filename, m_readInterpolator, m_tackLine, m_tackSample, m_validMaximum, and m_validMinimum.

bool Isis::Chip::PointsColinear ( double  x0,
double  y0,
double  x1,
double  y1,
double  x2,
double  y2,
double  tol 
)
private

This method is called by Load() to determine whether the given 3 points are nearly colinear.

This is done by considering the triangle composed of these points. The method returns true if all angles of the triangle are greater than the tolerance angle and less than 180 degrees, minus the tolerance angle.

Parameters
x0The x-value of the first point
y0The y-value of the first point
x1The x-value of the second point
y1The y-value of the second point
x2The x-value of the third point
y2The y-value of the third point
tolMinimum tolerance angle in degrees
Returns
bool True if 3 given points are nearly colinear
Author
Jeannie Walldren
History:
2010-05-24 Jeannie Walldren - Original version.
History:
2010-06-10 Jeannie Walldren - Modified to take in user defined tolerance as parameter to allow registration of narrow search chip areas

Definition at line 568 of file Chip.cpp.

References Isis::PI().

void Isis::Chip::Read ( Cube cube,
const int  band 
)
private

This method reads data from a cube and puts it into the chip.

The affine transform is used in the SetChipPosition routine, so the geom of the chip is automatic. This method uses a default interpolator type of Cubic Convolution. This can be changed using SetReadInterpolator().

Parameters
cubeCube to read data from
bandBand number to read data from
See Also
SetReadInterpolator
Todo:
We could modify the affine class to return the coefficients and then compute the derivative of the change in cube sample and line with respect to chip sample or line. The change might make the geom run a bit faster.
See Also
SetReadInterpolator()
GetReadInterpolator()
History:
2010-06-15 Jeannie Walldren - Modified to allow any interpolator type except "None"

Definition at line 977 of file Chip.cpp.

References Isis::Interpolator::HotLine(), Isis::Interpolator::HotSample(), Isis::Interpolator::Interpolate(), Isis::Cube::lineCount(), Isis::Interpolator::Lines(), Isis::Cube::pixelType(), Isis::Cube::read(), Isis::Cube::sampleCount(), and Isis::Interpolator::Samples().

void Isis::Chip::SetAllValues ( const double &  d)

Single value assignment operator.

Sets the entire chip to a constant

Parameters
dValue to set the chip to

Definition at line 122 of file Chip.cpp.

void Isis::Chip::SetChipPosition ( const double  sample,
const double  line 
)

Compute the position of the cube given a chip coordinate.

Any rotation or geometric matching done during the Load process will be taken into account. Use CubeSample and CubeLine methods to obtain results. Note the results could be outside of the cube

Parameters
samplechip sample coordinate
linechip line coordinate

Definition at line 665 of file Chip.cpp.

Referenced by Isis::Gruen::getChipUpdate(), Isis::InterestOperator::InterestByMeasure(), Load(), Isis::ChipViewport::mousePressEvent(), Isis::InterestOperator::Operate(), Isis::ChipViewport::panDown(), Isis::ChipViewport::panLeft(), Isis::ChipViewport::panUp(), Isis::AutoReg::Register(), Isis::Gruen::Registration(), Isis::AutoReg::Registration(), Isis::ChipViewport::tackLine(), and Isis::ChipViewport::tackSample().

void Isis::Chip::SetClipPolygon ( const geos::geom::MultiPolygon &  clipPolygon)

Sets the clipping polygon for this chip.

The coordinates must be in (sample,line) order. All Pixel values outside this polygon will be set to Null8. The cubic convolution interpolation is allowed to uses valid pixels outside the clipping area.

Parameters
clipPolygonThe polygons used to clip the chip

Definition at line 1046 of file Chip.cpp.

Referenced by Isis::InterestOperator::InterestByMeasure(), and Isis::InterestOperator::Operate().

void Isis::Chip::SetCubePosition ( const double  sample,
const double  line 
)

Compute the position of the chip given a cube coordinate.

Any rotation or geometric matching done during the Load process will be taken into account. Use ChipSample and ChipLine methods to obtain results. Note that the results could be outside of the chip.

Parameters
samplechip sample coordinate
linechip line coordinate

Definition at line 682 of file Chip.cpp.

Referenced by Isis::ChipViewport::cubeToViewport().

void Isis::Chip::SetReadInterpolator ( const Interpolator::interpType  type)
inline

Sets Interpolator Type for loading a chip.

This type is used in the Read() method.

Parameters
typeInterpolator type to be used.
Exceptions
IException::Programmer- Invalid Interpolator Type
See Also
Read()
SetReadInterpolator()
Author
Jeannie Walldren
History:
2010-06-05 Jeannie Walldren - Original version

Definition at line 318 of file Chip.h.

References _FILEINFO_, m_readInterpolator, Isis::IException::Programmer, and Isis::toString().

void Isis::Chip::SetSize ( const int  samples,
const int  lines 
)

Change the size of the Chip.

Parameters
samplesnumber of samples in the chip
linesnumber of lines in the chip
Exceptions
Isis::iException::User- Samples and lines must be greater than zero.
History:
2010-06-10 Jeannie Walldren - Modified error message

Definition at line 156 of file Chip.cpp.

References _FILEINFO_, and Isis::toString().

Referenced by Isis::AutoReg::Match(), and Isis::Gruen::Registration().

void Isis::Chip::SetTransform ( const Affine affine,
const bool &  keepPoly = true 
)
inline

Sets the internal Affine transform to new translation.

Provides the ability to establish a new affine transformation without overhead of, say, loading the chip with a new translation. The caller also has the option to specify the disposition of an established polygon.

Parameters
affineNew affine tranform to set for this chip
keepPolyIndicates whether an existing polygon clipper should be kept (default of true)

Definition at line 285 of file Chip.h.

References m_affine, and m_clipPolygon.

void Isis::Chip::SetValidRange ( const double  minimum = Isis::ValidMinimum,
const double  maximum = Isis::ValidMaximum 
)

Set the valid range of data in the chip.

If never called all data in the chip is consider valid (other than special pixels).

Parameters
minimumminimum valid pixel value (default of Isis::ValidMinimum)
maximummaximum valid pixel value (default of Isis::ValidMaximum)
Exceptions
Isis::iException::Programmer- First parameter must be smaller than the second.
History:
2010-06-10 Jeannie Walldren - Modified error message

Definition at line 703 of file Chip.cpp.

References _FILEINFO_, and Isis::toString().

void Isis::Chip::SetValue ( int  sample,
int  line,
const double &  value 
)
inline

Sets a value in the chip.

Parameters
sampleSample position to load (1-based)
lineLine position to load (1-based)
valueValue to set

Definition at line 141 of file Chip.h.

References m_buf.

Referenced by Isis::AutoReg::ApplyGradientFilter(), Isis::CentroidApolloPan::elipticalReduction(), Extract(), Isis::AutoReg::Match(), Isis::AutoReg::Reduce(), and Isis::AutoReg::SetSubpixelPosition().

Isis::Statistics * Isis::Chip::Statistics ( )

Returns a statistics object of the current data in the chip.

The caller takes ownership of the returned instance.

Returns
Isis::Statistics* Statistics of the data in the chip

Definition at line 947 of file Chip.cpp.

References Isis::Statistics::AddData().

void Isis::Chip::TackCube ( const double  cubeSample,
const double  cubeLine 
)

This sets which cube position will be located at the chip tack position.

Parameters
cubeSamplethe cube sample value to tack
cubeLinethe cube line value to tack

Definition at line 204 of file Chip.cpp.

Referenced by Isis::Gruen::getChipUpdate(), Isis::InterestOperator::InterestByMeasure(), Isis::InterestOperator::Operate(), Isis::ControlPointEdit::registerPoint(), Isis::ChipViewport::reloadChip(), Isis::ControlPointEdit::setLeftMeasure(), and Isis::ControlPointEdit::setRightMeasure().

int Isis::Chip::TackLine ( ) const
inline

Return the fixed tack line of the chip.

This method returns a chip's fixed tack line; the middle of the chip. It is a chip coordinate, not a cube coordinate. For example, a chip with 5 lines will return 3, the middle pixel. A chip with 4 lines will return 2.

Definition at line 198 of file Chip.h.

References m_tackLine.

Referenced by Isis::Gruen::algorithm(), Extract(), Isis::Gruen::getChipUpdate(), Load(), Isis::ChipViewport::panDown(), Isis::ChipViewport::panLeft(), Isis::ChipViewport::panUp(), Isis::AutoReg::Register(), Isis::Gruen::Registration(), Isis::ChipViewport::tackLine(), and Isis::ChipViewport::tackSample().

int Isis::Chip::TackSample ( ) const
inline

Return the fixed tack sample of the chip.

This method returns a chip's fixed tack sample; the middle of the chip. It is a chip coordinate, not a cube coordinate. For example, a chip with 5 samples will return 3, the middle pixel. A chip with 4 samples will return 2.

Definition at line 187 of file Chip.h.

References m_tackSample.

Referenced by Isis::Gruen::algorithm(), Extract(), Isis::Gruen::getChipUpdate(), Load(), Isis::ChipViewport::panDown(), Isis::ChipViewport::panLeft(), Isis::ChipViewport::panUp(), Isis::AutoReg::Register(), Isis::Gruen::Registration(), Isis::ChipViewport::tackLine(), and Isis::ChipViewport::tackSample().

void Isis::Chip::Write ( const QString &  filename)

Writes the contents of the Chip to a cube.

Parameters
filenameName of the cube to create

Definition at line 1023 of file Chip.cpp.

References Isis::Cube::close(), Isis::Cube::create(), Isis::Cube::setDimensions(), Isis::LineManager::SetLine(), and Isis::Cube::write().

Referenced by Isis::Gruen::Registration(), and Isis::ControlPointEdit::saveChips().

Member Data Documentation

Affine Isis::Chip::m_affine
private

Transform set by SetTransform.

Definition at line 361 of file Chip.h.

Referenced by Chip(), Extract(), GetTransform(), operator=(), and SetTransform().

std::vector< std::vector<double> > Isis::Chip::m_buf
private

Chip buffer.

Definition at line 343 of file Chip.h.

Referenced by Chip(), GetValue(), operator=(), and SetValue().

double Isis::Chip::m_chipLine
private

chip line set by SetChip/CubePosition

Definition at line 354 of file Chip.h.

Referenced by Chip(), ChipLine(), Extract(), and operator=().

int Isis::Chip::m_chipLines
private

Number of lines in the chip.

Definition at line 342 of file Chip.h.

Referenced by Chip(), Lines(), and operator=().

double Isis::Chip::m_chipSample
private

chip sample set by SetChip/CubePosition

Definition at line 353 of file Chip.h.

Referenced by Chip(), ChipSample(), Extract(), and operator=().

int Isis::Chip::m_chipSamples
private

Number of samples in the chip.

Definition at line 341 of file Chip.h.

Referenced by Chip(), operator=(), and Samples().

geos::geom::MultiPolygon* Isis::Chip::m_clipPolygon
private

clipping polygon set by SetClipPolygon

Definition at line 358 of file Chip.h.

Referenced by Chip(), operator=(), and SetTransform().

double Isis::Chip::m_cubeLine
private

cube line set by SetCubePosition

Definition at line 356 of file Chip.h.

Referenced by Chip(), CubeLine(), Extract(), and operator=().

double Isis::Chip::m_cubeSample
private

cube sample set by SetCubePosition

Definition at line 355 of file Chip.h.

Referenced by Chip(), CubeSample(), Extract(), and operator=().

double Isis::Chip::m_cubeTackLine
private

cube line at the chip tack

Definition at line 348 of file Chip.h.

Referenced by Chip(), Extract(), and operator=().

double Isis::Chip::m_cubeTackSample
private

cube sample at the chip tack

Definition at line 347 of file Chip.h.

Referenced by Chip(), Extract(), and operator=().

QString Isis::Chip::m_filename
private

FileName of loaded cube.

Definition at line 368 of file Chip.h.

Referenced by Chip(), Extract(), FileName(), and operator=().

Interpolator::interpType Isis::Chip::m_readInterpolator
private

Interpolator type set by.

Definition at line 364 of file Chip.h.

Referenced by Chip(), GetReadInterpolator(), operator=(), and SetReadInterpolator().

int Isis::Chip::m_tackLine
private

Middle line of the chip.

Definition at line 345 of file Chip.h.

Referenced by Chip(), Extract(), operator=(), and TackLine().

int Isis::Chip::m_tackSample
private

Middle sample of the chip.

Definition at line 344 of file Chip.h.

Referenced by Chip(), Extract(), operator=(), and TackSample().

double Isis::Chip::m_validMaximum
private

valid maximum chip pixel value

Definition at line 351 of file Chip.h.

Referenced by Chip(), Extract(), IsValid(), and operator=().

double Isis::Chip::m_validMinimum
private

valid minimum chip pixel value

Definition at line 350 of file Chip.h.

Referenced by Chip(), Extract(), IsValid(), and operator=().


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