Isis 3 Programmer Reference
Isis::Brick Class Reference

Buffer for containing a three dimensional section of an image. More...

#include <Brick.h>

Inheritance diagram for Isis::Brick:
Inheritance graph
Collaboration diagram for Isis::Brick:
Collaboration graph

Public Member Functions

 Brick (const int nsamps, const int nlines, const int nbands, const Isis::PixelType type, bool reverse=false)
 Constructs a Brick object.
 
 Brick (const Isis::Cube &cube, const int &bufNumSamples, const int &bufNumLines, const int &bufNumBands, bool reverse=false)
 Constructs a Brick object.
 
 Brick (int maxSamples, int maxLines, int maxBands, int bufNumSamples, int bufNumLines, int bufNumBands, Isis::PixelType type, bool reverse=false)
 Constructs a Brick object of the specified buffer size and area size to map.
 
void SetBasePosition (const int start_sample, const int start_line, const int start_band)
 This method is used to set the base position of the shape buffer.
 
void SetBaseSample (const int start_samp)
 This method is used to set the base sample position of the shape buffer.
 
void SetBaseLine (const int start_line)
 This method is used to set the base line position of the shape buffer.
 
void SetBaseBand (const int start_band)
 This method is used to set the base band position of the shape buffer.
 
void Resize (const int nsamps, const int nlines, const int nbands)
 Resizes the memory buffer to the specified number of samples, lines, and bands.
 
bool SetBrick (const int brick)
 This method is used to set the position of the brick.
 
int Bricks ()
 Returns the number of Bricks in the cube.
 
bool operator++ (int)
 Moves the shape buffer to the next position.
 
BufferManageroperator+= (int i)
 Moves the shape buffer by a certain amount.
 
bool begin ()
 Moves the shape buffer to the first position.
 
bool next ()
 Moves the shape buffer to the next position.
 
bool end () const
 Returns true if the shape buffer has accessed the end of the cube.
 
bool setpos (BigInt map)
 Sets the position of the shape in the cube.
 
void swap (BufferManager &other)
 Swaps the values of this BufferManager with that of another.
 
int SampleDimension () const
 Returns the number of samples in the shape buffer.
 
int LineDimension () const
 Returns the number of lines in the shape buffer.
 
int BandDimension () const
 Returns the number of bands in the shape buffer.
 
int size () const
 Returns the total number of pixels in the shape buffer.
 
int Sample (const int index=0) const
 Returns the sample position associated with a shape buffer index.
 
int Line (const int index=0) const
 Returns the line position associated with a shape buffer index.
 
int Band (const int index=0) const
 Returns the band position associated with a shape buffer index.
 
void Position (const int index, int &i_samp, int &i_line, int &i_band) const
 Returns the sample, line, and band position associated with a shape buffer index.
 
int Index (const int i_samp, const int i_line, const int i_band) const
 Given a sample, line, and band position, this returns the appropriate index in the shape buffer.
 
double at (const int index) const
 Returns the value in the shape buffer at the given index.
 
double & operator[] (const int index)
 Returns the value in the shape buffer at given index.
 
const double & operator[] (const int index) const
 Returns the value in the shape buffer at given index.
 
double * DoubleBuffer () const
 Returns the value of the shape buffer.
 
void Copy (const Buffer &in, bool includeRawBuf=true)
 Allows copying of the buffer contents to another Buffer.
 
bool CopyOverlapFrom (const Buffer &in)
 Allows copying of the buffer contents of a larger buffer to another same size or smaller Buffer, using their base positions to relate data.
 
void * RawBuffer () const
 Returns a void pointer to the raw buffer.
 
Isis::PixelType PixelType () const
 Returns the raw buffer pixel type.
 

Protected Member Functions

int MaxSamples () const
 Returns the number of samples in the cube.
 
int MaxLines () const
 Returns the number of lines in the cube.
 
int MaxBands () const
 Returns the number of bands in the cube.
 
BigInt MaxMaps () const
 Returns the maximum number of positions the shape buffer needs to cover the entire image (see setpos method for more info).
 
void SetIncrements (const int sinc, const int linc, const int binc)
 Sets how the shape is incremented through the cube.
 
void SetOffsets (const int soff, const int loff, const int boff)
 Sets the offset of the buffer.
 
void Allocate ()
 Size or resize the memory buffer.
 

Protected Attributes

int p_sample
 Starting sample to read/write.
 
int p_nsamps
 Number of samples to read/write.
 
int p_line
 Starting line to read/write.
 
int p_nlines
 Number of lines to read/write.
 
int p_band
 Starting band to read/write.
 
int p_nbands
 Number of bands to read/write.
 
int p_npixels
 Number of pixels (nsamps * nlines * nbands)
 
double * p_buf
 Shape buffer allocated to the size of npixels for handling reads/writes.
 
const Isis::PixelType p_pixelType
 The pixel type of the raw buffer.
 
void * p_rawbuf
 The raw dm read from the disk.
 

Private Attributes

int p_maxSamps
 Maximum samples to map.
 
int p_maxLines
 Maximum lines to map.
 
int p_maxBands
 Maximum bands to map.
 
int p_sinc
 Sample increment.
 
int p_linc
 Line increment.
 
int p_binc
 Band increment.
 
int p_soff
 Sample offset.
 
int p_loff
 Line offset.
 
int p_boff
 Band offset.
 
int p_currentSample
 Current sample.
 
int p_currentLine
 Current line.
 
int p_currentBand
 Current band.
 
BigInt p_nmaps
 Total number of objects to map.
 
BigInt p_currentMap
 Current buffer map position.
 
bool p_reverse
 If true the axies are processed in Band, Line, Sample order (e.g., BIL).
 

Detailed Description

Buffer for containing a three dimensional section of an image.

This class is a Buffer. The shape of the buffer is three dimensional in the line, sample, and band directions. This class provides a random access window into a cube. The position can be set to any line, sample and band, including outside the image.

Author
2005-01-18 Jeff Anderson
History

2005-02-25 Elizabeth Ribelin - Modified file to support Doxygen documentation

2006-04-21 Jacob Danton - Modified Brick to extend BufferManager, added new constructor, and two methods, SetBrick and Bricks

2011-11-23 Jai Rideout - Added a new constructor that allows one to specify the shape buffer size as well as the size of the area to be mapped. This is useful for classes such as ProcessByBrick that need to specify an area to be traversed that is bigger than the cube itself.

2017-08-30 Summer Stapleton - Updated documentation. References #4807.

Todo
2005-02-28 Jeff Anderson - add coded and implementation examples to class documentation

Definition at line 45 of file Brick.h.

Constructor & Destructor Documentation

◆ Brick() [1/3]

Isis::Brick::Brick ( const int nsamps,
const int nlines,
const int nbands,
const Isis::PixelType type,
bool reverse = false )
inline

Constructs a Brick object.

Parameters
nsampsNumber of samples in shape buffer
nlinesNumber of lines in shape buffer
nbandsNumber of bands in shape buffer
typeType of pixel in raw buffer
reverseModifies the order of progression this buffer takes through the cube. By default, progresses samples first, then lines, then bands. If reverse = true, then the buffer progresses bands first, then lines, then samples.

Definition at line 60 of file Brick.h.

◆ Brick() [2/3]

Isis::Brick::Brick ( const Isis::Cube & cube,
const int & bufNumSamples,
const int & bufNumLines,
const int & bufNumBands,
bool reverse = false )
inline

Constructs a Brick object.

Parameters
&cubeReference to the cube to calculate a Brick from
&bufNumSamplesReference to the number of samples in shape buffer
&bufNumLinesReference to the number of lines in shape buffer
&bufNumBandsReference to the number of bands in shape buffer
reverseModifies the order of progression this buffer takes through the cube. By default, progresses samples first, then lines, then bands. If reverse = true, then the buffer progresses bands first, then lines, then samples.

Definition at line 79 of file Brick.h.

◆ Brick() [3/3]

Isis::Brick::Brick ( int maxSamples,
int maxLines,
int maxBands,
int bufNumSamples,
int bufNumLines,
int bufNumBands,
Isis::PixelType type,
bool reverse = false )
inline

Constructs a Brick object of the specified buffer size and area size to map.

Parameters
maxSamplesMaximum number of samples to map
maxLinesMaximum number of lines to map
maxBandsMaximum number of bands to map
bufNumSamplesNumber of samples in shape buffer
bufNumLinesNumber of lines in shape buffer
bufNumBandsNumber of bands in shape buffer
typeType of pixel in raw buffer
reverseModifies the order of progression this buffer takes through the cube. By default, progresses samples first, then lines, then bands. If reverse = true, then the buffer progresses bands first, then lines, then samples.

Definition at line 104 of file Brick.h.

Member Function Documentation

◆ Allocate()

void Isis::Buffer::Allocate ( )
protectedinherited

Size or resize the memory buffer.

Exceptions
Isis::iException::System- Memory allocation failed

Definition at line 340 of file Buffer.cpp.

References Isis::Message::MemoryAllocationFailed(), Isis::Buffer::p_buf, Isis::Buffer::p_npixels, Isis::Buffer::p_pixelType, Isis::Buffer::p_rawbuf, Isis::SizeOf(), and Isis::IException::Unknown.

Referenced by Isis::Buffer::Buffer(), Isis::Buffer::Buffer(), and Resize().

◆ at()

double Isis::Buffer::at ( const int index) const
inherited

Returns the value in the shape buffer at the given index.

Parameters
indexIndex position in buffer. Out of bounds index is trapped.
Returns
double Buffer value at index
Exceptions
Isis::iException::Programmer- Array Subscript not in range

Definition at line 231 of file Buffer.cpp.

References Isis::Message::ArraySubscriptNotInRange(), Isis::Buffer::p_buf, Isis::Buffer::p_npixels, and Isis::IException::Programmer.

Referenced by Isis::CubeDataThreadTester::BrickChanged(), Isis::ViewportBuffer::fillBuffer(), Isis::CubeDataThreadTester::ReadBrick(), and Isis::CubeDataThreadTester::ReadWriteBrick().

◆ Band()

int Isis::Buffer::Band ( const int index = 0) const
inherited

Returns the band position associated with a shape buffer index.

The shape buffer is one dimensional. Let us assume a nsamps=2, nlines=3, and nbands=2. Therefore the total size of the shape buffer is 12 and valid index values are 0-11. Indexes 0-5 will return band 1 and 6-11 will return band 2.

Parameters
indexShape buffer index to map to a band position. Defaults to 0.
Returns
int The absolute band number based on the buffer index.

Definition at line 162 of file Buffer.cpp.

References Isis::Buffer::p_band, Isis::Buffer::p_nlines, and Isis::Buffer::p_nsamps.

Referenced by Isis::Buffer::CopyOverlapFrom(), Isis::Buffer::Position(), and Isis::CubeIoHandler::writeIntoRaw().

◆ BandDimension()

int Isis::Buffer::BandDimension ( ) const
inlineinherited

Returns the number of bands in the shape buffer.

Returns
int

Definition at line 88 of file Buffer.h.

References Isis::Buffer::p_nbands.

Referenced by Isis::CubeIoHandler::writeIntoRaw().

◆ begin()

bool Isis::BufferManager::begin ( )
inlineinherited

Moves the shape buffer to the first position.

Returns
bool

Definition at line 96 of file BufferManager.h.

References Isis::BufferManager::setpos().

Referenced by Isis::ProcessByBoxcar::StartProcess().

◆ Bricks()

int Isis::Brick::Bricks ( )
inline

Returns the number of Bricks in the cube.

Returns
int

Definition at line 168 of file Brick.h.

References Isis::BufferManager::MaxMaps().

◆ Copy()

void Isis::Buffer::Copy ( const Buffer & in,
bool includeRawBuf = true )
inherited

Allows copying of the buffer contents to another Buffer.

Parameters
inThe Buffer to be copied.
includeRawBufWhether to include raw dm read from disk
Exceptions
Isis::iException::Programmer- Input and Output buffers are not the same size
Isis::iException::Programmer- Input and Output buffers do not use the same pixel type

Definition at line 255 of file Buffer.cpp.

References Isis::Buffer::p_buf, Isis::Buffer::p_npixels, Isis::Buffer::p_pixelType, Isis::Buffer::p_rawbuf, Isis::IException::Programmer, and Isis::SizeOf().

Referenced by Isis::Buffer::Buffer().

◆ CopyOverlapFrom()

bool Isis::Buffer::CopyOverlapFrom ( const Buffer & in)
inherited

Allows copying of the buffer contents of a larger buffer to another same size or smaller Buffer, using their base positions to relate data.

This does not copy the raw buffer.

Parameters
inThe Buffer to be copied.
Returns
The operation was successful (the buffers overlapped)

Definition at line 285 of file Buffer.cpp.

References Isis::Buffer::Band(), Isis::Buffer::Line(), Isis::Buffer::p_band, Isis::Buffer::p_line, Isis::Buffer::p_nbands, Isis::Buffer::p_nlines, Isis::Buffer::p_npixels, Isis::Buffer::p_nsamps, Isis::Buffer::p_sample, Isis::Buffer::Sample(), and Isis::Buffer::size().

◆ DoubleBuffer()

double * Isis::Buffer::DoubleBuffer ( ) const
inlineinherited

Returns the value of the shape buffer.

Returns
double* The shape buffer

Definition at line 138 of file Buffer.h.

References Isis::Buffer::p_buf.

Referenced by Isis::AutoReg::ApplyGradientFilter(), Isis::Process::CalculateStatistics(), Isis::Cube::histogram(), Isis::DemShape::localRadius(), Isis::Cube::statistics(), and Isis::CubeIoHandler::writeIntoRaw().

◆ end()

bool Isis::BufferManager::end ( ) const
inlineinherited

Returns true if the shape buffer has accessed the end of the cube.

Returns
bool

Definition at line 115 of file BufferManager.h.

References Isis::BufferManager::p_currentMap, and Isis::BufferManager::p_nmaps.

Referenced by Isis::BufferManager::setpos(), and Isis::ProcessByBoxcar::StartProcess().

◆ Index()

int Isis::Buffer::Index ( const int i_samp,
const int i_line,
const int i_band ) const
inherited

Given a sample, line, and band position, this returns the appropriate index in the shape buffer.

Parameters
i_sampSample position.
i_lineLine position.
i_bandBand position.
Returns
int Index at the specified sample, line and band.
Exceptions
Isis::iException::Programmer- Array Subscript not in range

Definition at line 197 of file Buffer.cpp.

References Isis::Message::ArraySubscriptNotInRange(), Isis::Buffer::p_band, Isis::Buffer::p_line, Isis::Buffer::p_nbands, Isis::Buffer::p_nlines, Isis::Buffer::p_nsamps, Isis::Buffer::p_sample, and Isis::IException::Programmer.

Referenced by Isis::ViewportBuffer::fillBuffer(), and Isis::CubeIoHandler::writeIntoRaw().

◆ Line()

int Isis::Buffer::Line ( const int index = 0) const
inherited

Returns the line position associated with a shape buffer index.

The shape buffer is one dimensional. Let us assume a nsamps=2, nlines=3, and nbands=2. Therefore the total size of the shape buffer is 12 and valid index values are 0-11. Line(0), Line(1), Line(6) and Line(7), will return a 1, Line(2), Line(3), Line(8) and Line(9) will return a 2, and Line(4), Line(5), Line(10), and Line(11) will return a 3.

Parameters
indexShape buffer index to map to a line position. Defaults to 0
Returns
int The absolute line number based on the buffer index

Definition at line 145 of file Buffer.cpp.

References Isis::Buffer::p_line, Isis::Buffer::p_nlines, and Isis::Buffer::p_nsamps.

Referenced by Isis::Buffer::CopyOverlapFrom(), Isis::CubeViewport::cubeDataChanged(), Isis::ViewportBuffer::fillBuffer(), Isis::Buffer::Position(), Isis::QtExporter::writeGrayscale(), and Isis::StreamExporter::writeGrayscale().

◆ LineDimension()

int Isis::Buffer::LineDimension ( ) const
inlineinherited

Returns the number of lines in the shape buffer.

Returns
int

Definition at line 79 of file Buffer.h.

References Isis::Buffer::p_nlines.

Referenced by Isis::CubeViewport::cubeDataChanged(), and Isis::ViewportBuffer::fillBuffer().

◆ MaxBands()

int Isis::BufferManager::MaxBands ( ) const
inlineprotectedinherited

Returns the number of bands in the cube.

Returns
int

Definition at line 152 of file BufferManager.h.

References Isis::BufferManager::p_maxBands.

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

◆ MaxLines()

int Isis::BufferManager::MaxLines ( ) const
inlineprotectedinherited

Returns the number of lines in the cube.

Returns
int

Definition at line 143 of file BufferManager.h.

References Isis::BufferManager::p_maxLines.

Referenced by Isis::LineManager::SetLine().

◆ MaxMaps()

BigInt Isis::BufferManager::MaxMaps ( ) const
inlineprotectedinherited

Returns the maximum number of positions the shape buffer needs to cover the entire image (see setpos method for more info).

Returns
int

Definition at line 162 of file BufferManager.h.

References Isis::BufferManager::p_nmaps.

Referenced by Bricks(), and Isis::TileManager::Tiles().

◆ MaxSamples()

int Isis::BufferManager::MaxSamples ( ) const
inlineprotectedinherited

Returns the number of samples in the cube.

Returns
int

Definition at line 134 of file BufferManager.h.

References Isis::BufferManager::p_maxSamps.

Referenced by Isis::SampleManager::SetSample().

◆ next()

bool Isis::BufferManager::next ( )
inlineinherited

Moves the shape buffer to the next position.

Returns true if the next position is valid.

Returns
bool

Definition at line 106 of file BufferManager.h.

References Isis::BufferManager::p_currentMap, and Isis::BufferManager::setpos().

Referenced by Isis::BufferManager::operator++(), and Isis::ProcessByBoxcar::StartProcess().

◆ operator++()

bool Isis::BufferManager::operator++ ( int )
inlineinherited

Moves the shape buffer to the next position.

Returns true if the next position is valid.

Returns
bool

Definition at line 73 of file BufferManager.h.

References Isis::BufferManager::next().

◆ operator+=()

BufferManager & Isis::BufferManager::operator+= ( int i)
inlineinherited

Moves the shape buffer by a certain amount.

Returns a pointer to the BufferManager it was called on.

Parameters
iHow far to shift the shape buffer
Returns
BufferManager

Definition at line 86 of file BufferManager.h.

References Isis::BufferManager::p_currentMap, and Isis::BufferManager::setpos().

◆ operator[]() [1/2]

double & Isis::Buffer::operator[] ( const int index)
inlineinherited

Returns the value in the shape buffer at given index.

Parameters
indexIndex position in buffer. No out of bounds index is checked
Returns
double&

Definition at line 118 of file Buffer.h.

References Isis::Buffer::p_buf.

◆ operator[]() [2/2]

const double & Isis::Buffer::operator[] ( const int index) const
inlineinherited

Returns the value in the shape buffer at given index.

Parameters
indexIndex position in buffer. No out of bounds index is checked
Returns
double

Definition at line 129 of file Buffer.h.

References Isis::Buffer::p_buf.

◆ PixelType()

Isis::PixelType Isis::Buffer::PixelType ( ) const
inlineinherited

Returns the raw buffer pixel type.

Returns
Isis::PixelType

Definition at line 160 of file Buffer.h.

References Isis::Buffer::p_pixelType.

◆ Position()

void Isis::Buffer::Position ( const int index,
int & i_samp,
int & i_line,
int & i_band ) const
inherited

Returns the sample, line, and band position associated with a shape buffer index.

Performs the same function as the Sample, Line, and Band methods.

Parameters
indexShape buffer index to map to a band position.
i_sampSample position in shape buffer at index.
i_lineLine position in shape buffer at index
i_bandBand position in shape buffer at index.

Definition at line 177 of file Buffer.cpp.

References Isis::Buffer::Band(), Isis::Buffer::Line(), and Isis::Buffer::Sample().

◆ RawBuffer()

void * Isis::Buffer::RawBuffer ( ) const
inlineinherited

Returns a void pointer to the raw buffer.

Cast this void pointer using information from the PixelType() method

Returns
void* Pointer to the raw buffer

Definition at line 151 of file Buffer.h.

References Isis::Buffer::p_rawbuf.

◆ Resize()

void Isis::Brick::Resize ( const int nsamps,
const int nlines,
const int nbands )

Resizes the memory buffer to the specified number of samples, lines, and bands.

Parameters
nsampsNumber of samples
nlinesNumber of lines
nbandsNumber of bands

Definition at line 19 of file Brick.cpp.

References Isis::Buffer::Allocate(), Isis::Buffer::p_buf, Isis::Buffer::p_nbands, Isis::Buffer::p_nlines, Isis::Buffer::p_npixels, Isis::Buffer::p_nsamps, and Isis::Buffer::p_rawbuf.

◆ Sample()

int Isis::Buffer::Sample ( const int index = 0) const
inherited

Returns the sample position associated with a shape buffer index.

The shape buffer is one dimensional. Let us assume a nsamps=2, nlines=3, and nbands=2. Therefore the total size of the shape buffer is 12 and valid index values are 0-11. Sample(0), Sample(2), Sample(4), etc will return a 1 while Sample(1), Sample(3), Sample(5), etc will return a 2.

Parameters
indexShape buffer index to map to a sample position. Defaults to 0.
Returns
int The absolute sample number based on the buffer index.

Definition at line 127 of file Buffer.cpp.

References Isis::Buffer::p_nsamps, and Isis::Buffer::p_sample.

Referenced by Isis::Buffer::CopyOverlapFrom(), Isis::CubeViewport::cubeDataChanged(), Isis::ViewportBuffer::fillBuffer(), Isis::CubeDataThread::OverlapIndex(), and Isis::Buffer::Position().

◆ SampleDimension()

int Isis::Buffer::SampleDimension ( ) const
inlineinherited

Returns the number of samples in the shape buffer.

Returns
int

Definition at line 70 of file Buffer.h.

References Isis::Buffer::p_nsamps.

Referenced by Isis::CubeViewport::cubeDataChanged(), and Isis::ViewportBuffer::fillBuffer().

◆ SetBaseBand()

void Isis::Brick::SetBaseBand ( const int start_band)
inline

This method is used to set the base band position of the shape buffer.

Parameters
start_bandStarting band to set

Definition at line 148 of file Brick.h.

References Isis::Buffer::SetBaseBand().

◆ SetBaseLine()

void Isis::Brick::SetBaseLine ( const int start_line)
inline

This method is used to set the base line position of the shape buffer.

Parameters
start_lineStarting line to set

Definition at line 139 of file Brick.h.

References Isis::Buffer::SetBaseLine().

◆ SetBasePosition()

void Isis::Brick::SetBasePosition ( const int start_sample,
const int start_line,
const int start_band )
inline

This method is used to set the base position of the shape buffer.

It is used to progress sequentially through a cube by brick.

Parameters
start_sampleStarting sample to set.
start_lineStarting line to set.
start_bandStarting band to set.

Definition at line 120 of file Brick.h.

References Isis::Buffer::SetBasePosition().

Referenced by Isis::CubeViewport::bluePixel(), Isis::ProcessPolygons::FillPolygon(), Isis::CubeViewport::grayPixel(), Isis::CubeViewport::greenPixel(), Isis::CubeViewport::redPixel(), and Isis::ImagePolygon::SetImage().

◆ SetBaseSample()

void Isis::Brick::SetBaseSample ( const int start_samp)
inline

This method is used to set the base sample position of the shape buffer.

Parameters
start_sampStarting sample to set

Definition at line 130 of file Brick.h.

References Isis::Buffer::SetBaseSample().

◆ SetBrick()

bool Isis::Brick::SetBrick ( const int brick)

This method is used to set the position of the brick.

Sets the current brick as requested.

Parameters
brickBrick number to move to.
Returns
bool Is the brick at the end of the cube?
Parameters
brickThe brick number within a cube. This number starts with the upper left corner of the cube and proceedes across the samples then down the lines and lastly through the bands. The first brick starts at (1,1,1). The last brick contains the point (cubeSamples,cubeLines,cubeBands).
Returns
bool
Exceptions
Isis::iException::Programmer- invalid argument value

Definition at line 42 of file Brick.cpp.

References Isis::IException::Programmer, and Isis::BufferManager::setpos().

◆ SetIncrements()

void Isis::BufferManager::SetIncrements ( const int sinc,
const int linc,
const int binc )
protectedinherited

Sets how the shape is incremented through the cube.

By default (if this method is not invoked) shapes are moved sequentially through the cube with no overlap. For example, assume a 3 sample by 3 line tile buffer. It would first move across the image from left-to-right starting at sample 1, line 1, and band 1. Upon an increment it would be positioned at sample 4, line 1, and band 1. Each successive increment would cause the sample position to increase by 3 until it exceeds the number of samples in the cube. At that point the shape buffer would be positioned at sample 1, line 4, and band 1 (effectively moving to the next row of tiles). The shape would then continue moving across the cube until it reaches the edge again. Then the next row of tiles would be accessed until the shape reached the bottom of the cube. This default management can be overridden using this method. For example, by setting the increments to (6,3,1) we effectively skip every other tile. By setting them to (6,6,1) we skip every other tile and every other row of tiles. By setting them to (1,1,1) we essentially have NSxNLxNB positions in the cube and the 3x3 tile is managed such that the top left corner of the tile is moved over by 1 sample until it reaches the end of the line then down 1 line and so on until the end of the cube is reached.

Parameters
sincSample increment
lincLine increment
bincBand increment

Definition at line 139 of file BufferManager.cpp.

References Isis::BufferManager::p_binc, Isis::BufferManager::p_boff, Isis::BufferManager::p_currentBand, Isis::BufferManager::p_currentLine, Isis::BufferManager::p_currentMap, Isis::BufferManager::p_currentSample, Isis::BufferManager::p_linc, Isis::BufferManager::p_loff, Isis::BufferManager::p_maxBands, Isis::BufferManager::p_maxLines, Isis::BufferManager::p_maxSamps, Isis::BufferManager::p_nmaps, Isis::BufferManager::p_sinc, and Isis::BufferManager::p_soff.

Referenced by Isis::BoxcarManager::BoxcarManager(), and Isis::BufferManager::BufferManager().

◆ SetOffsets()

void Isis::BufferManager::SetOffsets ( const int soff,
const int loff,
const int boff )
protectedinherited

Sets the offset of the buffer.

By default (if this method is not invoked) the offsets are (0,0,0). Offsets are applied when computing the top-left corner of the shape buffer. When used in conjunction with the SetIncrements method, this allows for centering shape buffers around a pixel when passing in negative offsets. For example,with a 3x3x1 shape and offsets of (-1,-1,0) and increments of (1,1,1) would cause the manager to walk a 3x3 buffer through the entire image. Setting the manager position the beginning causes the 3x3 window to be positioned such that sample 1, line 1 of the cube would be at the center of the window and increment would cause sample 2, line 1 to be at the center of the window. Successive increments will move the window in the sample direction until the end of line is reached at which time the buffer would be centered on sample 1, line 2.

Parameters
soffSample offset
loffLine offset
boffBand offset

Definition at line 178 of file BufferManager.cpp.

References Isis::BufferManager::p_boff, Isis::BufferManager::p_loff, and Isis::BufferManager::p_soff.

Referenced by Isis::BoxcarManager::BoxcarManager().

◆ setpos()

bool Isis::BufferManager::setpos ( BigInt map)
inherited

Sets the position of the shape in the cube.

This shape fits into the cube a specific number of times.

When p_reverse is left false: (default) For example, a line shape on a 100 sample, 200 line, and 2 band cube would have 200*2 or 400 different positions as there are 400 total lines in the cube. Performing setpos(0) would position the shape at sample 1, line 1, and band 1. While setpos(200) would position the shape at sample 1, line 1, and band 2. Finally, setpos(399) would position the shape at sample 1, line 400, and band 2. Setpos returns true if it was sucessfully in setting the position, and false if the shape is at the end of the cube (beyond index 399 in the case of our example).

When p_reverse is set to true: Following the above cube with 100 samples, 200 lines, and 2 bands, performing the setpos(0) would still position the shape at sample 1, line 1, and band 1. However, setpos(1) would position the shape at sample 1, line 1, band 2, while setpos(200) would position the spame at sample 1, line 100, band 1. Setpos returns true of it was sucessfully in setting the position, and false if the shape is at the end of the cube(beyond final index).

Parameters
mapShape buffer position value
Returns
bool True or False depending on whether the shape is at the end of the cube or not.
Exceptions
Isis::iException::Programmer- Invalid value for map argument

Definition at line 218 of file BufferManager.cpp.

References Isis::BufferManager::end(), Isis::BufferManager::p_binc, Isis::BufferManager::p_boff, Isis::BufferManager::p_currentBand, Isis::BufferManager::p_currentLine, Isis::BufferManager::p_currentMap, Isis::BufferManager::p_currentSample, Isis::BufferManager::p_linc, Isis::BufferManager::p_loff, Isis::BufferManager::p_maxBands, Isis::BufferManager::p_maxLines, Isis::BufferManager::p_maxSamps, Isis::BufferManager::p_reverse, Isis::BufferManager::p_sinc, Isis::BufferManager::p_soff, Isis::IException::Programmer, and Isis::Buffer::SetBasePosition().

Referenced by Isis::BufferManager::begin(), Isis::BufferManager::next(), Isis::BufferManager::operator+=(), Isis::BandManager::SetBand(), SetBrick(), Isis::LineManager::SetLine(), Isis::SampleManager::SetSample(), and Isis::TileManager::SetTile().

◆ size()

◆ swap()

Member Data Documentation

◆ p_band

int Isis::Buffer::p_band
protectedinherited

◆ p_binc

int Isis::BufferManager::p_binc
privateinherited

◆ p_boff

int Isis::BufferManager::p_boff
privateinherited

◆ p_buf

double* Isis::Buffer::p_buf
protectedinherited

◆ p_currentBand

int Isis::BufferManager::p_currentBand
privateinherited

◆ p_currentLine

int Isis::BufferManager::p_currentLine
privateinherited

◆ p_currentMap

BigInt Isis::BufferManager::p_currentMap
privateinherited

◆ p_currentSample

int Isis::BufferManager::p_currentSample
privateinherited

◆ p_linc

int Isis::BufferManager::p_linc
privateinherited

◆ p_line

int Isis::Buffer::p_line
protectedinherited

◆ p_loff

int Isis::BufferManager::p_loff
privateinherited

◆ p_maxBands

int Isis::BufferManager::p_maxBands
privateinherited

◆ p_maxLines

int Isis::BufferManager::p_maxLines
privateinherited

◆ p_maxSamps

int Isis::BufferManager::p_maxSamps
privateinherited

◆ p_nbands

int Isis::Buffer::p_nbands
protectedinherited

Number of bands to read/write.

Definition at line 205 of file Buffer.h.

Referenced by Isis::Buffer::BandDimension(), Isis::Buffer::Buffer(), Isis::Buffer::CopyOverlapFrom(), Isis::Buffer::Index(), and Resize().

◆ p_nlines

int Isis::Buffer::p_nlines
protectedinherited

◆ p_nmaps

BigInt Isis::BufferManager::p_nmaps
privateinherited

◆ p_npixels

int Isis::Buffer::p_npixels
protectedinherited

◆ p_nsamps

int Isis::Buffer::p_nsamps
protectedinherited

◆ p_pixelType

const Isis::PixelType Isis::Buffer::p_pixelType
protectedinherited

The pixel type of the raw buffer.

Definition at line 211 of file Buffer.h.

Referenced by Isis::Buffer::Allocate(), Isis::Buffer::Copy(), and Isis::Buffer::PixelType().

◆ p_rawbuf

void* Isis::Buffer::p_rawbuf
protectedinherited

The raw dm read from the disk.

Definition at line 212 of file Buffer.h.

Referenced by Isis::Buffer::Allocate(), Isis::Buffer::Copy(), Isis::Buffer::RawBuffer(), Resize(), and Isis::Buffer::~Buffer().

◆ p_reverse

bool Isis::BufferManager::p_reverse
privateinherited

If true the axies are processed in Band, Line, Sample order (e.g., BIL).

If left false, the axies are processed in the Sample, Line, Band order (e.g., BSQ, BIP).

Definition at line 194 of file BufferManager.h.

Referenced by Isis::BufferManager::BufferManager(), Isis::BufferManager::setpos(), and Isis::BufferManager::swap().

◆ p_sample

int Isis::Buffer::p_sample
protectedinherited

◆ p_sinc

int Isis::BufferManager::p_sinc
privateinherited

◆ p_soff

int Isis::BufferManager::p_soff
privateinherited

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