casacore
|
Tiled access to an array in a file. More...
#include <TiledFileAccess.h>
Public Member Functions | |
TiledFileAccess (const String &fileName, Int64 fileOffset, const IPosition &shape, const IPosition &tileShape, DataType dataType, const TSMOption &=TSMOption(), Bool writable=False) | |
Create a TiledFileAccess object. More... | |
TiledFileAccess (const String &fileName, Int64 fileOffset, const IPosition &shape, const IPosition &tileShape, DataType dataType, const TSMOption &, Bool writable, Bool bigEndian) | |
Create a TiledFileAccess object. More... | |
~TiledFileAccess () | |
Bool | isWritable () const |
Is the file writable? More... | |
DataType | dataType () const |
Array< Bool > | getBool (const Slicer §ion) |
Get part of the array. More... | |
Array< uChar > | getUChar (const Slicer §ion) |
Array< Short > | getShort (const Slicer §ion) |
Array< Int > | getInt (const Slicer §ion) |
Array< Float > | getFloat (const Slicer §ion) |
Array< Double > | getDouble (const Slicer §ion) |
Array< Complex > | getComplex (const Slicer §ion) |
Array< DComplex > | getDComplex (const Slicer §ion) |
void | get (Array< Bool > &, const Slicer §ion) |
void | get (Array< uChar > &, const Slicer §ion) |
void | get (Array< Short > &, const Slicer §ion) |
void | get (Array< Int > &, const Slicer §ion) |
void | get (Array< Float > &, const Slicer §ion) |
void | get (Array< Double > &, const Slicer §ion) |
void | get (Array< Complex > &, const Slicer §ion) |
void | get (Array< DComplex > &, const Slicer §ion) |
Array< Float > | getFloat (const Slicer §ion, Float scale, Float offset, uChar deleteValue, Bool examineForDeleteValues=True) |
Get the array and scale/offset the data using the given values. More... | |
Array< Float > | getFloat (const Slicer §ion, Float scale, Float offset, Short deleteValue, Bool examineForDeleteValues=True) |
Array< Float > | getFloat (const Slicer §ion, Float scale, Float offset, Int deleteValue, Bool examineForDeleteValues=True) |
void | get (Array< Float > &, const Slicer §ion, Float scale, Float offset, uChar deleteValue, Bool examineForDeleteValues=True) |
void | get (Array< Float > &, const Slicer §ion, Float scale, Float offset, Short deleteValue, Bool examineForDeleteValues=True) |
void | get (Array< Float > &, const Slicer §ion, Float scale, Float offset, Int deleteValue, Bool examineForDeleteValues=True) |
void | put (const Array< Bool > &, const Slicer §ion) |
Put part of the array. More... | |
void | put (const Array< uChar > &, const Slicer §ion) |
void | put (const Array< Short > &, const Slicer §ion) |
void | put (const Array< Int > &, const Slicer §ion) |
void | put (const Array< Float > &, const Slicer §ion) |
void | put (const Array< Double > &, const Slicer §ion) |
void | put (const Array< Complex > &, const Slicer §ion) |
void | put (const Array< DComplex > &, const Slicer §ion) |
void | flush () |
Flush the cache. More... | |
void | clearCache () |
Empty the cache. More... | |
void | showCacheStatistics (ostream &os) const |
Show the cache statistics. More... | |
const IPosition & | shape () const |
Get the shape of the array. More... | |
const IPosition & | tileShape () const |
Get the shape of the tiles. More... | |
void | setMaximumCacheSize (uInt64 nbytes) |
Set the maximum cache size (in bytes). More... | |
uInt64 | maximumCacheSize () const |
Get the maximum cache size (in bytes). More... | |
uInt | cacheSize () const |
Get the current cache size (in buckets). More... | |
void | setCacheSize (const IPosition &sliceShape, const IPosition &axisPath, Bool forceSmaller=True) |
Set the cache size using the given access pattern. More... | |
void | setCacheSize (const IPosition &sliceShape, const IPosition &windowStart, const IPosition &windowLength, const IPosition &axisPath, Bool forceSmaller=True) |
void | setCacheSize (uInt nbuckets, Bool forceSmaller=True) |
Set the cache size for accessing the data. More... | |
Static Public Member Functions | |
static IPosition | makeTileShape (const IPosition &arrayShape, uInt nrPixelsPerTile=32768) |
Make a tile shape from the array shape to fit as closely as possible the number of pixels in the tile. More... | |
Private Member Functions | |
TiledFileAccess (const TiledFileAccess &) | |
Forbid copy constructor and assignment. More... | |
TiledFileAccess & | operator= (const TiledFileAccess &) |
Private Attributes | |
TSMCube * | itsCube |
TiledFileHelper * | itsTSM |
uInt | itsLocalPixelSize |
Bool | itsWritable |
DataType | itsDataType |
Tiled access to an array in a file.
Public interface
TiledFileAccess is a class that makes it possible to access an arbitrary array in a file using the tiled storage manager classes. It can handle arrays of any type supported by the tiled storage managers. The array can be in big or little endian canonical format.
See ROTiledStManAccessor for a more detailed discussion.
This class makes it possible to access an image in a FITS file.
Definition at line 92 of file TiledFileAccess.h.
casacore::TiledFileAccess::TiledFileAccess | ( | const String & | fileName, |
Int64 | fileOffset, | ||
const IPosition & | shape, | ||
const IPosition & | tileShape, | ||
DataType | dataType, | ||
const TSMOption & | = TSMOption() , |
||
Bool | writable = False |
||
) |
Create a TiledFileAccess object.
The data is assumed to be in local canonical format (thus big endian on e.g. SUN and little endian on e.g. PC). The TSMOption determines how the file is accessed.
casacore::TiledFileAccess::TiledFileAccess | ( | const String & | fileName, |
Int64 | fileOffset, | ||
const IPosition & | shape, | ||
const IPosition & | tileShape, | ||
DataType | dataType, | ||
const TSMOption & | , | ||
Bool | writable, | ||
Bool | bigEndian | ||
) |
Create a TiledFileAccess object.
The endian format of the data is explicitly given.
casacore::TiledFileAccess::~TiledFileAccess | ( | ) |
|
private |
Forbid copy constructor and assignment.
|
inline |
Get the current cache size (in buckets).
Definition at line 208 of file TiledFileAccess.h.
References casacore::TSMCube::cacheSize(), and itsCube.
|
inline |
Empty the cache.
It will flush the cache as needed and remove all buckets from it resulting in a possibly large drop in memory used. It'll also clear the userSetCache_p
flag.
Definition at line 185 of file TiledFileAccess.h.
References casacore::TSMCube::emptyCache(), and itsCube.
|
inline |
Definition at line 119 of file TiledFileAccess.h.
References itsDataType.
|
inline |
Flush the cache.
Definition at line 178 of file TiledFileAccess.h.
References casacore::TSMCube::flushCache(), and itsCube.
void casacore::TiledFileAccess::get | ( | Array< Float > & | , |
const Slicer & | section, | ||
Float | scale, | ||
Float | offset, | ||
uChar | deleteValue, | ||
Bool | examineForDeleteValues = True |
||
) |
void casacore::TiledFileAccess::get | ( | Array< Float > & | , |
const Slicer & | section, | ||
Float | scale, | ||
Float | offset, | ||
Short | deleteValue, | ||
Bool | examineForDeleteValues = True |
||
) |
void casacore::TiledFileAccess::get | ( | Array< Float > & | , |
const Slicer & | section, | ||
Float | scale, | ||
Float | offset, | ||
Int | deleteValue, | ||
Bool | examineForDeleteValues = True |
||
) |
Get part of the array.
The Array object is resized if needed.
Array<Float> casacore::TiledFileAccess::getFloat | ( | const Slicer & | section, |
Float | scale, | ||
Float | offset, | ||
uChar | deleteValue, | ||
Bool | examineForDeleteValues = True |
||
) |
Get the array and scale/offset the data using the given values.
It is meant for FITS, so for now they can only be used for TpUChar, TpShort or TpInt TiledFileAccess objects. A deleteValue is set to a NaN without being scaled.
Array<Float> casacore::TiledFileAccess::getFloat | ( | const Slicer & | section, |
Float | scale, | ||
Float | offset, | ||
Short | deleteValue, | ||
Bool | examineForDeleteValues = True |
||
) |
Array<Float> casacore::TiledFileAccess::getFloat | ( | const Slicer & | section, |
Float | scale, | ||
Float | offset, | ||
Int | deleteValue, | ||
Bool | examineForDeleteValues = True |
||
) |
|
inline |
|
static |
Make a tile shape from the array shape to fit as closely as possible the number of pixels in the tile.
uInt64 casacore::TiledFileAccess::maximumCacheSize | ( | ) | const |
Get the maximum cache size (in bytes).
|
private |
Put part of the array.
|
inline |
Set the cache size using the given access pattern.
Definition at line 213 of file TiledFileAccess.h.
References itsCube, casacore::TSMCube::setCacheSize(), and casacore::True.
|
inline |
Definition at line 218 of file TiledFileAccess.h.
References itsCube, casacore::TSMCube::setCacheSize(), and casacore::True.
Set the cache size for accessing the data.
When the give cache size exceeds the maximum cache size with more than 10%, the maximum cache size is used instead.
When forceSmaller is False, the cache is not resized when the new size is smaller.
Definition at line 232 of file TiledFileAccess.h.
References itsCube, casacore::TSMCube::setCacheSize(), and casacore::True.
void casacore::TiledFileAccess::setMaximumCacheSize | ( | uInt64 | nbytes | ) |
Set the maximum cache size (in bytes).
0 means no maximum.
|
inline |
Get the shape of the array.
Definition at line 193 of file TiledFileAccess.h.
References casacore::TSMCube::cubeShape(), and itsCube.
|
inline |
Show the cache statistics.
Definition at line 189 of file TiledFileAccess.h.
References itsCube, and casacore::TSMCube::showCacheStatistics().
|
inline |
Get the shape of the tiles.
Definition at line 197 of file TiledFileAccess.h.
References itsCube, and casacore::TSMCube::tileShape().
|
private |
Definition at line 249 of file TiledFileAccess.h.
Referenced by cacheSize(), clearCache(), flush(), setCacheSize(), shape(), showCacheStatistics(), and tileShape().
|
private |
Definition at line 253 of file TiledFileAccess.h.
Referenced by dataType().
|
private |
Definition at line 251 of file TiledFileAccess.h.
|
private |
Definition at line 250 of file TiledFileAccess.h.
|
private |
Definition at line 252 of file TiledFileAccess.h.
Referenced by isWritable().