Isis 3 Programmer Reference
|
IO Handler for Isis Cubes using the tile format. More...
#include <CubeTileHandler.h>
Public Member Functions | |
CubeTileHandler (QFile *dataFile, const QList< int > *virtualBandList, const Pvl &label, bool alreadyOnDisk) | |
Construct a tile handler. | |
~CubeTileHandler () | |
Writes all data from memory to disk. | |
void | updateLabels (Pvl &label) |
Update the cube labels so that this cube indicates what tile size it used. | |
void | read (Buffer &bufferToFill) const |
Read cube data from disk into the buffer. | |
void | write (const Buffer &bufferToWrite) |
Write buffer data into the cube data on disk. | |
void | addCachingAlgorithm (CubeCachingAlgorithm *algorithm) |
This will add the given caching algorithm to the list of attempted caching algorithms. | |
void | clearCache (bool blockForWriteCache=true) const |
Free all cube chunks (cached cube data) from memory and write them to disk. | |
BigInt | getDataSize () const |
void | setVirtualBands (const QList< int > *virtualBandList) |
This changes the virtual band list. | |
QMutex * | dataFileMutex () |
Get the mutex that this IO handler is using around I/Os on the given data file. | |
Protected Member Functions | |
virtual void | readRaw (RawCubeChunk &chunkToFill) |
This needs to populate the chunkToFill with unswapped raw bytes from the disk. | |
virtual void | writeRaw (const RawCubeChunk &chunkToWrite) |
This needs to write the chunkToWrite directly to disk with no modifications to the data itself. | |
int | bandCount () const |
int | getBandCountInChunk () const |
BigInt | getBytesPerChunk () const |
int | getChunkCountInBandDimension () const |
int | getChunkCountInLineDimension () const |
int | getChunkCountInSampleDimension () const |
int | getChunkIndex (const RawCubeChunk &) const |
Given a chunk, what's its index in the file. | |
BigInt | getDataStartByte () const |
QFile * | getDataFile () |
int | lineCount () const |
int | getLineCountInChunk () const |
PixelType | pixelType () const |
int | sampleCount () const |
int | getSampleCountInChunk () const |
void | setChunkSizes (int numSamples, int numLines, int numBands) |
This should be called once from the child constructor. | |
Private Member Functions | |
CubeTileHandler (const CubeTileHandler &other) | |
Disallow copying of this object. | |
CubeTileHandler & | operator= (const CubeTileHandler &other) |
Disallow assignments of this object. | |
int | findGoodSize (int maxSize, int dimensionSize) const |
This is a helper method that tries to compute a good tile size for one of the cube's dimensions (sample or line). | |
BigInt | getTileStartByte (const RawCubeChunk &chunk) const |
This is a helper method that goes from chunk to file position. | |
void | blockUntilThreadPoolEmpty () const |
This blocks (doesn't return) until the number of active runnables in the thread pool goes to 0. | |
QPair< QList< RawCubeChunk * >, QList< int > > | findCubeChunks (int startSample, int numSamples, int startLine, int numLines, int startBand, int numBands) const |
Get the cube chunks that correspond to the given cube area. | |
void | findIntersection (const RawCubeChunk &cube1, const Buffer &cube2, int &startX, int &startY, int &startZ, int &endX, int &endY, int &endZ) const |
Find the intersection between the buffer area and the cube chunk. | |
void | flushWriteCache (bool force=false) const |
This attempts to write the so-far-unwritten buffers from m_writeCache into the cube's RawCubeChunk cache. | |
void | freeChunk (RawCubeChunk *chunkToFree) const |
If the chunk is dirty, then we write it to disk. | |
RawCubeChunk * | getChunk (int chunkIndex, bool allocateIfNecessary) const |
Retrieve the cached chunk at the given chunk index, if there is one. | |
int | getChunkCount () const |
void | getChunkPlacement (int chunkIndex, int &startSample, int &startLine, int &startBand, int &endSample, int &endLine, int &endBand) const |
Get the X/Y/Z (Sample,Line,Band) range of the chunk at the given index. | |
RawCubeChunk * | getNullChunk (int chunkIndex) const |
This creates a chunk filled with NULLs whose placement is at chunkIndex's position. | |
void | minimizeCache (const QList< RawCubeChunk * > &justUsed, const Buffer &justRequested) const |
Apply the caching algorithms and get rid of excess cube data in memory. | |
void | synchronousWrite (const Buffer &bufferToWrite) |
This method takes the given buffer and synchronously puts it into the Cube's cache. | |
void | writeIntoDouble (const RawCubeChunk &chunk, Buffer &output, int startIndex) const |
Write the intersecting area of the chunk into the buffer. | |
void | writeIntoRaw (const Buffer &buffer, RawCubeChunk &output, int index) const |
Write the intersecting area of the buffer into the chunk. | |
void | writeNullDataToDisk () const |
Write all NULL cube chunks that have not yet been accessed to disk. | |
Static Private Member Functions | |
static bool | bufferLessThan (Buffer *const &lhs, Buffer *const &rhs) |
This is used for sorting buffers into the most efficient write order. | |
Private Attributes | |
QFile * | m_dataFile |
The file containing cube data. | |
BigInt | m_startByte |
The start byte of the cube data. | |
PixelType | m_pixelType |
The format of each DN in the cube. | |
double | m_base |
The additive offset of the data on disk. | |
double | m_multiplier |
The multiplicative factor of the data on disk. | |
ByteOrder | m_byteOrder |
The byte order (endianness) of the data on disk. | |
EndianSwapper * | m_byteSwapper |
A helper that swaps byte order to and from file order. | |
int | m_numSamples |
The number of samples in the cube. | |
int | m_numLines |
The number of lines in the cube. | |
int | m_numBands |
The number of physical bands in the cube. | |
QList< CubeCachingAlgorithm * > * | m_cachingAlgorithms |
The caching algorithms to use, in order of priority. | |
QMap< int, RawCubeChunk * > * | m_rawData |
The map from chunk index to chunk for cached data. | |
QMap< int, bool > * | m_dataIsOnDiskMap |
The map from chunk index to on-disk status, all true if not allocated. | |
QList< int > * | m_virtualBands |
Converts from virtual band to physical band. | |
int | m_samplesInChunk |
The number of samples in a cube chunk. | |
int | m_linesInChunk |
The number of lines in a cube chunk. | |
int | m_bandsInChunk |
The number of physical bands in a cube chunk. | |
QList< RawCubeChunk * > * | m_lastProcessByLineChunks |
This is an optimization for process by line. | |
QByteArray * | m_nullChunkData |
A raw cube chunk's data when it was all NULL's. Used for speed. | |
QPair< QMutex *, QList< Buffer * > > * | m_writeCache |
These are the buffers we need to write to raw cube chunks. | |
QThreadPool * | m_ioThreadPool |
This contains threads for doing cube writes (and later maybe cube reads). | |
bool | m_lastOperationWasWrite |
If the last operation was a write then we need to flush the cache when reading. | |
bool | m_useOptimizedCubeWrite |
This is true if the Isis preference for the cube write thread is optimized. | |
QMutex * | m_writeThreadMutex |
This enables us to block while the write thread is working. | |
volatile int | m_idealFlushSize |
Ideal write cache flush size. | |
int | m_consecutiveOverflowCount |
How many times the write cache has overflown in a row. | |
IO Handler for Isis Cubes using the tile format.
This class is used to open, create, read, and write data from Isis cube files.
2007-09-14 Stuart Sides - Fixed bug where pixels from a buffer outside the ns/nl were being transfered to the right most and bottom most tiles
2011-06-16 Jai Rideout and Steven Lambright - Refactored to work with the new parent.
2011-07-18 Jai Rideout and Steven Lambright - Added unimplemented copy constructor and assignment operator.
Definition at line 35 of file CubeTileHandler.h.
Isis::CubeTileHandler::CubeTileHandler | ( | QFile * | dataFile, |
const QList< int > * | virtualBandList, | ||
const Pvl & | labels, | ||
bool | alreadyOnDisk ) |
Construct a tile handler.
This will determine a good chunk size to put into the output cube.
dataFile | The file with cube DN data in it |
virtualBandList | The mapping from virtual band to physical band, see CubeIoHandler's description. |
labels | The Pvl labels for the cube |
alreadyOnDisk | True if the cube is allocated on the disk, false otherwise |
Definition at line 32 of file CubeTileHandler.cpp.
References findGoodSize(), Isis::PvlObject::findObject(), Isis::CubeIoHandler::lineCount(), Isis::CubeIoHandler::pixelType(), Isis::CubeIoHandler::sampleCount(), Isis::CubeIoHandler::setChunkSizes(), and Isis::SizeOf().
Isis::CubeTileHandler::~CubeTileHandler | ( | ) |
Writes all data from memory to disk.
Definition at line 56 of file CubeTileHandler.cpp.
References Isis::CubeIoHandler::clearCache().
|
private |
Disallow copying of this object.
other | The object to copy. |
|
inherited |
This will add the given caching algorithm to the list of attempted caching algorithms.
The algorithms are tried in the opposite order that they were added - the first algorithm added is the last algorithm tried.
This method takes ownership of algorithm.
algorithm | The caching algorithm to add to the Cube for I/O |
Definition at line 364 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_cachingAlgorithms.
Referenced by Isis::Cube::addCachingAlgorithm().
|
protectedinherited |
Definition at line 462 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_numBands.
Referenced by Isis::CubeIoHandler::findCubeChunks().
|
privateinherited |
This blocks (doesn't return) until the number of active runnables in the thread pool goes to 0.
This uses the m_writeThreadMutex, because the thread pool doesn't delete threads immediately, so runnables might actually still exist but are inconsequential/being deleted already.
Definition at line 667 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_ioThreadPool, and Isis::CubeIoHandler::m_writeThreadMutex.
Referenced by Isis::CubeIoHandler::flushWriteCache().
|
staticprivateinherited |
This is used for sorting buffers into the most efficient write order.
lhs | The left hand side of the '<' operator |
rhs | The right hand side of the '<' operator |
Definition at line 681 of file CubeIoHandler.cpp.
References Isis::Displacement::Pixels, and Isis::Distance::Pixels.
|
inherited |
Free all cube chunks (cached cube data) from memory and write them to disk.
Child destructors need to call this method.
This method should only be called otherwise when lots of cubes are in memory and the many caches cause problems with system RAM limitations.
blockForWriteCache | This should be true unless this method is called from the write thread. |
Definition at line 379 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::flushWriteCache(), Isis::CubeIoHandler::m_dataIsOnDiskMap, Isis::CubeIoHandler::m_lastProcessByLineChunks, Isis::CubeIoHandler::m_rawData, and Isis::CubeIoHandler::writeNullDataToDisk().
Referenced by Isis::Cube::clearIoCache(), Isis::Cube::copy(), Isis::CubeIoHandler::minimizeCache(), Isis::CubeBsqHandler::~CubeBsqHandler(), and ~CubeTileHandler().
|
inherited |
Get the mutex that this IO handler is using around I/Os on the given data file.
A lock should be acquired before doing any reads/writes on the data file externally.
Definition at line 455 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_writeThreadMutex.
Referenced by Isis::Cube::read(), Isis::Cube::write(), and Isis::Cube::writeLabels().
|
privateinherited |
Get the cube chunks that correspond to the given cube area.
This will create and initialize the chunks if they are not already in memory.
startSample | The starting sample of the cube data |
numSamples | The number of samples of cube data |
startLine | The starting line of the cube data |
numLines | The number of lines of cube data |
startBand | The starting band of the cube data |
numBands | The number of bands of cube data |
Cube |
---|
-----— |
| | | <---------— Requested Area | | | | | -----— |
But our cube is split into "chunks" which may not line up to what was requested:
| | | || |------------------—|| | -----— | || |—|---—|-------—|| (User requested area intersected with | | | | | || cube chunks) |------------------—||
| 1 | 2 | 3 || |------------------—|| | 4 | 5 | 6 || |------------------—|| (User requested area intersected with | 7 | 8 | 9 || cube chunks) |------------------—||
(In this case we want chunks 4, 5, 7, and 8)
So we want to find which cube chunks line up to the requested area. To do this, we find which chunk intersects the top left of the requested cube area. That chunk is a given that we need it. Then we search in the positive X direction for more chunks that intersect the user-requested area until we no longer do. Then we know all of the chunks that intersect a whole y-range of the requested area. We shrink the requested area (remove the found y-range) and repeat.
Definition at line 730 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::bandCount(), Isis::CubeIoHandler::getChunk(), Isis::CubeIoHandler::getChunkCountInLineDimension(), Isis::CubeIoHandler::getChunkCountInSampleDimension(), Isis::CubeIoHandler::lineCount(), Isis::CubeIoHandler::m_bandsInChunk, Isis::CubeIoHandler::m_linesInChunk, Isis::CubeIoHandler::m_samplesInChunk, Isis::CubeIoHandler::m_virtualBands, and Isis::CubeIoHandler::sampleCount().
Referenced by Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::synchronousWrite().
|
private |
This is a helper method that tries to compute a good tile size for one of the cube's dimensions (sample or line).
Band tile size is always 1 for this format currently.
maxSize | The largest allowed size |
dimensionSize | The cube's size in the dimension we're figuring out (that is, number of samples or number of lines). |
Definition at line 135 of file CubeTileHandler.cpp.
Referenced by CubeTileHandler().
|
privateinherited |
Find the intersection between the buffer area and the cube chunk.
This accounts for virtual bands when considering the buffer and may return an area where all of the bands don't actually intersect due to virtual bands. This is implemented the way it is for performance reasons - so much as returning an Area3D or a QList<int> caused undesirable slowdowns.
cube1 | The cube chunk to intersect |
cube2 | The buffer (in virtual band space) to intersect |
startX | (output) The leftmost sample position (inclusive) |
startY | (output) The topmost line position (inclusive) |
startZ | (output) The frontmost band position (inclusive) |
endX | (output) The rightmost sample position (inclusive) |
endY | (output) The bottommost line position (inclusive) |
endZ | (output) The backmost band position (inclusive) |
Definition at line 875 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_virtualBands.
Referenced by Isis::CubeIoHandler::writeIntoDouble(), and Isis::CubeIoHandler::writeIntoRaw().
|
privateinherited |
This attempts to write the so-far-unwritten buffers from m_writeCache into the cube's RawCubeChunk cache.
This will not do anything if there is a runnable and will block if the write cache grows to be too large.
force | Set to true to force start a flush |
Definition at line 940 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::blockUntilThreadPoolEmpty(), Isis::CubeIoHandler::m_consecutiveOverflowCount, Isis::CubeIoHandler::m_idealFlushSize, Isis::CubeIoHandler::m_ioThreadPool, Isis::CubeIoHandler::m_lastOperationWasWrite, Isis::CubeIoHandler::m_useOptimizedCubeWrite, Isis::CubeIoHandler::m_writeCache, Isis::CubeIoHandler::m_writeThreadMutex, and Isis::CubeIoHandler::synchronousWrite().
Referenced by Isis::CubeIoHandler::clearCache(), Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::write().
|
privateinherited |
If the chunk is dirty, then we write it to disk.
Regardless, we then free it from memory.
chunkToFree | The chunk we're removing from memory |
Definition at line 1017 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::getChunkIndex(), Isis::CubeIoHandler::m_lastProcessByLineChunks, and Isis::CubeIoHandler::m_rawData.
Referenced by Isis::CubeIoHandler::minimizeCache().
|
protectedinherited |
Definition at line 470 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_bandsInChunk.
Referenced by Isis::CubeIoHandler::getChunkIndex(), Isis::CubeIoHandler::getChunkPlacement(), Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::synchronousWrite().
|
protectedinherited |
Definition at line 482 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_bandsInChunk, Isis::CubeIoHandler::m_linesInChunk, Isis::CubeIoHandler::m_pixelType, Isis::CubeIoHandler::m_samplesInChunk, and Isis::SizeOf().
Referenced by Isis::CubeIoHandler::getChunk(), Isis::CubeBsqHandler::getChunkStartByte(), Isis::CubeIoHandler::getDataSize(), Isis::CubeIoHandler::getNullChunk(), getTileStartByte(), and Isis::CubeIoHandler::minimizeCache().
|
privateinherited |
Retrieve the cached chunk at the given chunk index, if there is one.
chunkIndex | The position of the chunk in the cube |
allocateIfNecessary | If true, the chunk will be read into cache when necessary and this method will not return NULL. |
Definition at line 1045 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeIoHandler::getChunkPlacement(), Isis::CubeIoHandler::getNullChunk(), Isis::CubeIoHandler::m_dataIsOnDiskMap, and Isis::CubeIoHandler::m_rawData.
Referenced by Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::synchronousWrite().
|
privateinherited |
Definition at line 1086 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::getChunkCountInBandDimension(), Isis::CubeIoHandler::getChunkCountInLineDimension(), and Isis::CubeIoHandler::getChunkCountInSampleDimension().
Referenced by Isis::CubeIoHandler::writeNullDataToDisk().
|
protectedinherited |
Definition at line 492 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_bandsInChunk, and Isis::CubeIoHandler::m_numBands.
Referenced by Isis::CubeIoHandler::getChunkCount(), and Isis::CubeIoHandler::getDataSize().
|
protectedinherited |
Definition at line 501 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_linesInChunk, and Isis::CubeIoHandler::m_numLines.
Referenced by Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::getChunkCount(), Isis::CubeIoHandler::getChunkIndex(), Isis::CubeIoHandler::getChunkPlacement(), Isis::CubeIoHandler::getDataSize(), Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::synchronousWrite().
|
protectedinherited |
Definition at line 510 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_numSamples, and Isis::CubeIoHandler::m_samplesInChunk.
Referenced by Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::getChunkCount(), Isis::CubeIoHandler::getChunkIndex(), Isis::CubeIoHandler::getChunkPlacement(), Isis::CubeIoHandler::getDataSize(), Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::synchronousWrite().
|
protectedinherited |
Given a chunk, what's its index in the file.
Chunks are ordered from left to right, then top to bottom, then front to back (BSQ). The first chunk is at the top left of band 1 and is index 0, for example. In other words, this is going from the value of m_rawData to the key.
Chunks which sit outside of the cube entirely must not be passed into this method; the results will be wrong.
Definition at line 526 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::getBandCountInChunk(), Isis::CubeIoHandler::getChunkCountInLineDimension(), Isis::CubeIoHandler::getChunkCountInSampleDimension(), Isis::CubeIoHandler::getLineCountInChunk(), and Isis::CubeIoHandler::getSampleCountInChunk().
Referenced by Isis::CubeIoHandler::freeChunk(), Isis::CubeBsqHandler::getChunkStartByte(), and getTileStartByte().
|
privateinherited |
Get the X/Y/Z (Sample,Line,Band) range of the chunk at the given index.
chunkIndex | The chunk number in the cube file |
startSample | (output) The leftmost sample position (inclusive) |
startLine | (output) The topmost line position (inclusive) |
startBand | (output) The frontmost band position (inclusive) |
endSample | (output) The rightmost sample position (inclusive) |
endLine | (output) The bottommost line position (inclusive) |
endBand | (output) The backmost band position (inclusive) |
Definition at line 1104 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::getBandCountInChunk(), Isis::CubeIoHandler::getChunkCountInLineDimension(), Isis::CubeIoHandler::getChunkCountInSampleDimension(), Isis::CubeIoHandler::getLineCountInChunk(), and Isis::CubeIoHandler::getSampleCountInChunk().
Referenced by Isis::CubeIoHandler::getChunk(), Isis::CubeIoHandler::getNullChunk(), Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::synchronousWrite().
|
protectedinherited |
Definition at line 555 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_dataFile.
Referenced by Isis::CubeBsqHandler::readRaw(), readRaw(), Isis::CubeBsqHandler::writeRaw(), and writeRaw().
|
inherited |
Definition at line 421 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeIoHandler::getChunkCountInBandDimension(), Isis::CubeIoHandler::getChunkCountInLineDimension(), and Isis::CubeIoHandler::getChunkCountInSampleDimension().
Referenced by Isis::CubeIoHandler::setChunkSizes(), and Isis::Cube::write().
|
protectedinherited |
Definition at line 544 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_startByte.
Referenced by Isis::CubeBsqHandler::getChunkStartByte(), getTileStartByte(), and Isis::CubeIoHandler::setChunkSizes().
|
protectedinherited |
Definition at line 572 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_linesInChunk.
Referenced by Isis::CubeIoHandler::getChunkIndex(), Isis::CubeIoHandler::getChunkPlacement(), Isis::CubeIoHandler::read(), Isis::CubeIoHandler::synchronousWrite(), and updateLabels().
|
privateinherited |
This creates a chunk filled with NULLs whose placement is at chunkIndex's position.
This is used for getting NULL-filled chunks the first time the chunk is requested.
Ownership of the return value is given to the caller.
chunkIndex | The chunk's index which provides it's positioning. |
Definition at line 1136 of file CubeIoHandler.cpp.
References Isis::RawCubeChunk::bandCount(), Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeIoHandler::getChunkPlacement(), Isis::RawCubeChunk::getRawData(), Isis::RawCubeChunk::getStartBand(), Isis::RawCubeChunk::getStartLine(), Isis::RawCubeChunk::getStartSample(), Isis::RawCubeChunk::lineCount(), Isis::CubeIoHandler::m_nullChunkData, Isis::Null, Isis::RawCubeChunk::sampleCount(), Isis::RawCubeChunk::setDirty(), Isis::RawCubeChunk::setRawData(), and Isis::CubeIoHandler::writeIntoRaw().
Referenced by Isis::CubeIoHandler::getChunk(), and Isis::CubeIoHandler::writeNullDataToDisk().
|
protectedinherited |
Definition at line 597 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_samplesInChunk.
Referenced by Isis::CubeIoHandler::getChunkIndex(), Isis::CubeIoHandler::getChunkPlacement(), Isis::CubeIoHandler::read(), Isis::CubeIoHandler::synchronousWrite(), and updateLabels().
|
private |
This is a helper method that goes from chunk to file position.
chunk | The chunk to locate in the file. |
Definition at line 163 of file CubeTileHandler.cpp.
References Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeIoHandler::getChunkIndex(), and Isis::CubeIoHandler::getDataStartByte().
Referenced by readRaw(), and writeRaw().
|
protectedinherited |
Definition at line 564 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_numLines.
Referenced by Isis::CubeBsqHandler::CubeBsqHandler(), CubeTileHandler(), and Isis::CubeIoHandler::findCubeChunks().
|
privateinherited |
Apply the caching algorithms and get rid of excess cube data in memory.
This is intended to be called after every IO operation.
justUsed | The cube chunks that were used in the IO operation that is calling this method. |
justRequested | The buffer that was used in the IO operation that is calling this method. |
Definition at line 1188 of file CubeIoHandler.cpp.
References Isis::CubeCachingAlgorithm::CacheResult::algorithmUnderstoodData(), Isis::CubeIoHandler::clearCache(), Isis::CubeIoHandler::freeChunk(), Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeCachingAlgorithm::CacheResult::getChunksToFree(), Isis::CubeIoHandler::m_cachingAlgorithms, Isis::CubeIoHandler::m_rawData, and Isis::CubeCachingAlgorithm::recommendChunksToFree().
Referenced by Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::synchronousWrite().
|
private |
Disallow assignments of this object.
other | The CubeTileHandler on the right-hand side of the assignment that we are copying into *this. |
|
protectedinherited |
Definition at line 580 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_pixelType.
Referenced by Isis::CubeBsqHandler::CubeBsqHandler(), and CubeTileHandler().
|
inherited |
Read cube data from disk into the buffer.
This is not const because it caches the read cube chunks from the disk.
bufferToFill | The buffer to populate with cube data. |
Definition at line 226 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::flushWriteCache(), Isis::CubeIoHandler::getBandCountInChunk(), Isis::CubeIoHandler::getChunk(), Isis::CubeIoHandler::getChunkCountInLineDimension(), Isis::CubeIoHandler::getChunkCountInSampleDimension(), Isis::CubeIoHandler::getChunkPlacement(), Isis::CubeIoHandler::getLineCountInChunk(), Isis::CubeIoHandler::getSampleCountInChunk(), Isis::CubeIoHandler::m_bandsInChunk, Isis::CubeIoHandler::m_ioThreadPool, Isis::CubeIoHandler::m_lastOperationWasWrite, Isis::CubeIoHandler::m_linesInChunk, Isis::CubeIoHandler::m_rawData, Isis::CubeIoHandler::m_samplesInChunk, Isis::CubeIoHandler::m_useOptimizedCubeWrite, Isis::CubeIoHandler::m_virtualBands, Isis::CubeIoHandler::m_writeThreadMutex, Isis::CubeIoHandler::minimizeCache(), Isis::Null, and Isis::CubeIoHandler::writeIntoDouble().
Referenced by Isis::Cube::read().
|
protectedvirtual |
This needs to populate the chunkToFill with unswapped raw bytes from the disk.
chunkToFill | The container that needs to be filled with cube data. |
Implements Isis::CubeIoHandler.
Definition at line 77 of file CubeTileHandler.cpp.
References Isis::CubeIoHandler::getDataFile(), getTileStartByte(), and Isis::IException::Io.
|
protectedinherited |
Definition at line 589 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_numSamples.
Referenced by Isis::CubeBsqHandler::CubeBsqHandler(), CubeTileHandler(), Isis::CubeIoHandler::findCubeChunks(), and Isis::CubeIoHandler::synchronousWrite().
|
protectedinherited |
This should be called once from the child constructor.
This determines the chunk sizes used for the cube and often should remain constant for a particular cube (BSQ, for example, doesn't need it to be constant but Tile does). These being large can cause excessive use of disk space that stores no cube data. These being large can also drastically increase the amount of RAM consumed.
numSamples | The chunk size in the sample dimension |
numLines | The chunk size in the line dimension |
numBands | The chunk size in the band dimension |
Definition at line 614 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::getDataSize(), Isis::CubeIoHandler::getDataStartByte(), Isis::CubeIoHandler::m_bandsInChunk, Isis::CubeIoHandler::m_dataFile, Isis::CubeIoHandler::m_dataIsOnDiskMap, Isis::CubeIoHandler::m_linesInChunk, Isis::CubeIoHandler::m_samplesInChunk, and Isis::IException::Programmer.
Referenced by Isis::CubeBsqHandler::CubeBsqHandler(), and CubeTileHandler().
|
inherited |
This changes the virtual band list.
virtualBandList | A list where the indices are the vbands and the values are the physical bands. The values are 1-based. This can be specified as NULL, in which case the vbands are the physical bands. The virtual band list is copied (the pointer provided isn't remembered). |
Definition at line 438 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::m_virtualBands.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), and Isis::Cube::setVirtualBands().
|
privateinherited |
This method takes the given buffer and synchronously puts it into the Cube's cache.
This includes reading missing cache areas and freeing extra cache areas. This is what the non-threaded CubeIoHandler::write used to do.
bufferToWrite | The buffer we're writing into this cube, synchronously |
Definition at line 1237 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::getBandCountInChunk(), Isis::CubeIoHandler::getChunk(), Isis::CubeIoHandler::getChunkCountInLineDimension(), Isis::CubeIoHandler::getChunkCountInSampleDimension(), Isis::CubeIoHandler::getChunkPlacement(), Isis::CubeIoHandler::getLineCountInChunk(), Isis::CubeIoHandler::getSampleCountInChunk(), Isis::CubeIoHandler::m_bandsInChunk, Isis::CubeIoHandler::m_lastProcessByLineChunks, Isis::CubeIoHandler::m_linesInChunk, Isis::CubeIoHandler::m_samplesInChunk, Isis::CubeIoHandler::minimizeCache(), Isis::CubeIoHandler::sampleCount(), and Isis::CubeIoHandler::writeIntoRaw().
Referenced by Isis::CubeIoHandler::flushWriteCache(), and Isis::CubeIoHandler::write().
|
virtual |
Update the cube labels so that this cube indicates what tile size it used.
labels | The "Core" object in this Pvl will be updated |
Implements Isis::CubeIoHandler.
Definition at line 66 of file CubeTileHandler.cpp.
References Isis::PvlObject::findObject(), Isis::CubeIoHandler::getLineCountInChunk(), Isis::CubeIoHandler::getSampleCountInChunk(), and Isis::toString().
|
inherited |
Write buffer data into the cube data on disk.
This could do no IO if the cube chunks required are already in memory and our caching algorithms say to not free any of the cube chunks afterwards.
bufferToWrite | The buffer to get cube data from. |
Definition at line 334 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::flushWriteCache(), Isis::CubeIoHandler::m_ioThreadPool, Isis::CubeIoHandler::m_lastOperationWasWrite, Isis::CubeIoHandler::m_writeCache, Isis::CubeIoHandler::m_writeThreadMutex, and Isis::CubeIoHandler::synchronousWrite().
Referenced by Isis::Cube::write().
|
privateinherited |
Write the intersecting area of the chunk into the buffer.
chunk | The data source |
output | The data destination |
index | int |
Definition at line 1352 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::findIntersection(), Isis::EndianSwapper::Float(), Isis::CubeIoHandler::m_base, Isis::CubeIoHandler::m_byteSwapper, Isis::CubeIoHandler::m_multiplier, Isis::CubeIoHandler::m_pixelType, Isis::EndianSwapper::ShortInt(), Isis::EndianSwapper::Uint32_t(), and Isis::EndianSwapper::UnsignedShortInt().
Referenced by Isis::CubeIoHandler::read().
|
privateinherited |
Write the intersecting area of the buffer into the chunk.
buffer | The data source |
output | The data destination |
index | int |
Definition at line 1552 of file CubeIoHandler.cpp.
References Isis::Buffer::Band(), Isis::Buffer::BandDimension(), Isis::Buffer::DoubleBuffer(), Isis::CubeIoHandler::findIntersection(), Isis::EndianSwapper::Float(), Isis::Buffer::Index(), Isis::CubeIoHandler::m_base, Isis::CubeIoHandler::m_byteSwapper, Isis::CubeIoHandler::m_multiplier, Isis::CubeIoHandler::m_pixelType, Isis::CubeIoHandler::m_virtualBands, Isis::EndianSwapper::ShortInt(), Isis::EndianSwapper::Uint32_t(), and Isis::EndianSwapper::UnsignedShortInt().
Referenced by Isis::CubeIoHandler::getNullChunk(), and Isis::CubeIoHandler::synchronousWrite().
|
privateinherited |
Write all NULL cube chunks that have not yet been accessed to disk.
Definition at line 1831 of file CubeIoHandler.cpp.
References Isis::CubeIoHandler::getChunkCount(), Isis::CubeIoHandler::getNullChunk(), Isis::CubeIoHandler::m_dataIsOnDiskMap, and Isis::IException::Programmer.
Referenced by Isis::CubeIoHandler::clearCache().
|
protectedvirtual |
This needs to write the chunkToWrite directly to disk with no modifications to the data itself.
chunkToWrite | The container that needs to be put on disk. |
Implements Isis::CubeIoHandler.
Definition at line 102 of file CubeTileHandler.cpp.
References Isis::CubeIoHandler::getDataFile(), getTileStartByte(), and Isis::IException::Io.
|
privateinherited |
The number of physical bands in a cube chunk.
Definition at line 323 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::getBandCountInChunk(), Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeIoHandler::getChunkCountInBandDimension(), Isis::CubeIoHandler::read(), Isis::CubeIoHandler::setChunkSizes(), and Isis::CubeIoHandler::synchronousWrite().
|
privateinherited |
The additive offset of the data on disk.
Definition at line 284 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::writeIntoDouble(), and Isis::CubeIoHandler::writeIntoRaw().
|
privateinherited |
The byte order (endianness) of the data on disk.
Definition at line 290 of file CubeIoHandler.h.
|
privateinherited |
A helper that swaps byte order to and from file order.
Definition at line 293 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::writeIntoDouble(), Isis::CubeIoHandler::writeIntoRaw(), and Isis::CubeIoHandler::~CubeIoHandler().
|
privateinherited |
The caching algorithms to use, in order of priority.
Definition at line 305 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::addCachingAlgorithm(), Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::minimizeCache(), and Isis::CubeIoHandler::~CubeIoHandler().
|
mutableprivateinherited |
How many times the write cache has overflown in a row.
Definition at line 362 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), and Isis::CubeIoHandler::flushWriteCache().
|
privateinherited |
The file containing cube data.
Definition at line 271 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::getDataFile(), and Isis::CubeIoHandler::setChunkSizes().
|
mutableprivateinherited |
The map from chunk index to on-disk status, all true if not allocated.
Definition at line 311 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::clearCache(), Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::getChunk(), Isis::CubeIoHandler::setChunkSizes(), Isis::CubeIoHandler::writeNullDataToDisk(), and Isis::CubeIoHandler::~CubeIoHandler().
|
mutableprivateinherited |
Ideal write cache flush size.
Definition at line 359 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), and Isis::CubeIoHandler::flushWriteCache().
|
mutableprivateinherited |
This contains threads for doing cube writes (and later maybe cube reads).
We're using a thread pool so that the same QThread is reused for performance reasons.
Definition at line 342 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::blockUntilThreadPoolEmpty(), Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::flushWriteCache(), Isis::CubeIoHandler::read(), Isis::CubeIoHandler::write(), and Isis::CubeIoHandler::~CubeIoHandler().
|
mutableprivateinherited |
If the last operation was a write then we need to flush the cache when reading.
Keep track of this.
Definition at line 348 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::flushWriteCache(), Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::write().
|
mutableprivateinherited |
This is an optimization for process by line.
It relies on chunks found often being the exact same between multiple reads or multiple writes.
Definition at line 329 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::clearCache(), Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::freeChunk(), Isis::CubeIoHandler::synchronousWrite(), and Isis::CubeIoHandler::~CubeIoHandler().
|
privateinherited |
The number of lines in a cube chunk.
Definition at line 320 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeIoHandler::getChunkCountInLineDimension(), Isis::CubeIoHandler::getLineCountInChunk(), Isis::CubeIoHandler::read(), Isis::CubeIoHandler::setChunkSizes(), and Isis::CubeIoHandler::synchronousWrite().
|
privateinherited |
The multiplicative factor of the data on disk.
Definition at line 287 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::writeIntoDouble(), and Isis::CubeIoHandler::writeIntoRaw().
|
mutableprivateinherited |
A raw cube chunk's data when it was all NULL's. Used for speed.
Definition at line 332 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::getNullChunk(), and Isis::CubeIoHandler::~CubeIoHandler().
|
privateinherited |
The number of physical bands in the cube.
Definition at line 302 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::bandCount(), Isis::CubeIoHandler::CubeIoHandler(), and Isis::CubeIoHandler::getChunkCountInBandDimension().
|
privateinherited |
The number of lines in the cube.
Definition at line 299 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::getChunkCountInLineDimension(), and Isis::CubeIoHandler::lineCount().
|
privateinherited |
The number of samples in the cube.
Definition at line 296 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::getChunkCountInSampleDimension(), and Isis::CubeIoHandler::sampleCount().
|
privateinherited |
The format of each DN in the cube.
Definition at line 281 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeIoHandler::pixelType(), Isis::CubeIoHandler::writeIntoDouble(), and Isis::CubeIoHandler::writeIntoRaw().
|
mutableprivateinherited |
The map from chunk index to chunk for cached data.
Definition at line 308 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::clearCache(), Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::freeChunk(), Isis::CubeIoHandler::getChunk(), Isis::CubeIoHandler::minimizeCache(), Isis::CubeIoHandler::read(), and Isis::CubeIoHandler::~CubeIoHandler().
|
privateinherited |
The number of samples in a cube chunk.
Definition at line 317 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::getBytesPerChunk(), Isis::CubeIoHandler::getChunkCountInSampleDimension(), Isis::CubeIoHandler::getSampleCountInChunk(), Isis::CubeIoHandler::read(), Isis::CubeIoHandler::setChunkSizes(), and Isis::CubeIoHandler::synchronousWrite().
|
privateinherited |
The start byte of the cube data.
This is 0-based (i.e. a value of 0 means write data into the first byte of the file). Usually the label is between 0 and m_startByte.
Definition at line 278 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), and Isis::CubeIoHandler::getDataStartByte().
|
privateinherited |
This is true if the Isis preference for the cube write thread is optimized.
Definition at line 353 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::flushWriteCache(), and Isis::CubeIoHandler::read().
|
privateinherited |
Converts from virtual band to physical band.
Definition at line 314 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::findCubeChunks(), Isis::CubeIoHandler::findIntersection(), Isis::CubeIoHandler::read(), Isis::CubeIoHandler::setVirtualBands(), Isis::CubeIoHandler::writeIntoRaw(), and Isis::CubeIoHandler::~CubeIoHandler().
These are the buffers we need to write to raw cube chunks.
Definition at line 335 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::flushWriteCache(), Isis::CubeIoHandler::write(), and Isis::CubeIoHandler::~CubeIoHandler().
|
privateinherited |
This enables us to block while the write thread is working.
Definition at line 356 of file CubeIoHandler.h.
Referenced by Isis::CubeIoHandler::blockUntilThreadPoolEmpty(), Isis::CubeIoHandler::BufferToChunkWriter::BufferToChunkWriter(), Isis::CubeIoHandler::CubeIoHandler(), Isis::CubeIoHandler::dataFileMutex(), Isis::CubeIoHandler::flushWriteCache(), Isis::CubeIoHandler::read(), Isis::CubeIoHandler::write(), and Isis::CubeIoHandler::~CubeIoHandler().