LSST Applications  21.0.0-172-gfb10e10a+18fedfabac,22.0.0+297cba6710,22.0.0+80564b0ff1,22.0.0+8d77f4f51a,22.0.0+a28f4c53b1,22.0.0+dcf3732eb2,22.0.1-1-g7d6de66+2a20fdde0d,22.0.1-1-g8e32f31+297cba6710,22.0.1-1-geca5380+7fa3b7d9b6,22.0.1-12-g44dc1dc+2a20fdde0d,22.0.1-15-g6a90155+515f58c32b,22.0.1-16-g9282f48+790f5f2caa,22.0.1-2-g92698f7+dcf3732eb2,22.0.1-2-ga9b0f51+7fa3b7d9b6,22.0.1-2-gd1925c9+bf4f0e694f,22.0.1-24-g1ad7a390+a9625a72a8,22.0.1-25-g5bf6245+3ad8ecd50b,22.0.1-25-gb120d7b+8b5510f75f,22.0.1-27-g97737f7+2a20fdde0d,22.0.1-32-gf62ce7b1+aa4237961e,22.0.1-4-g0b3f228+2a20fdde0d,22.0.1-4-g243d05b+871c1b8305,22.0.1-4-g3a563be+32dcf1063f,22.0.1-4-g44f2e3d+9e4ab0f4fa,22.0.1-42-gca6935d93+ba5e5ca3eb,22.0.1-5-g15c806e+85460ae5f3,22.0.1-5-g58711c4+611d128589,22.0.1-5-g75bb458+99c117b92f,22.0.1-6-g1c63a23+7fa3b7d9b6,22.0.1-6-g50866e6+84ff5a128b,22.0.1-6-g8d3140d+720564cf76,22.0.1-6-gd805d02+cc5644f571,22.0.1-8-ge5750ce+85460ae5f3,master-g6e05de7fdc+babf819c66,master-g99da0e417a+8d77f4f51a,w.2021.48
LSST Data Management Base Package
Public Types | Public Member Functions | Public Attributes | List of all members
lsst::afw::fits::ImageCompressionOptions Struct Reference

Options for tile compression of image pixels. More...

#include <fitsCompression.h>

Public Types

enum  CompressionAlgorithm {
  NONE , GZIP , GZIP_SHUFFLE , RICE ,
  PLIO
}
 Compression algorithms. More...
 
using Tiles = ndarray::Array< long, 1, 1 >
 

Public Member Functions

 ImageCompressionOptions (CompressionAlgorithm algorithm_, Tiles tiles_, float quantizeLevel_=0.0)
 Custom compression. More...
 
 ImageCompressionOptions (CompressionAlgorithm algorithm_, std::vector< long > tiles_, float quantizeLevel_=0.0)
 
 ImageCompressionOptions (CompressionAlgorithm algorithm_, int rows=1, float quantizeLevel_=0.0)
 Compression by rows or entire image. More...
 
template<typename T >
 ImageCompressionOptions (image::Image< T > const &image)
 Default compression for a particular style of image. More...
 
template<typename T >
 ImageCompressionOptions (image::Mask< T > const &mask)
 
 ImageCompressionOptions (image::Image< std::int64_t > const &image)
 
 ImageCompressionOptions (image::Mask< std::int64_t > const &mask)
 
 ImageCompressionOptions (image::Image< std::uint64_t > const &image)
 
 ImageCompressionOptions (image::Mask< std::uint64_t > const &mask)
 

Public Attributes

CompressionAlgorithm algorithm
 Compresion algorithm to use. More...
 
Tiles tiles
 Tile size; a dimension with 0 means infinite (e.g., to specify one row: 0,1) More...
 
float quantizeLevel
 quantization level: 0.0 = none requires use of GZIP or GZIP_SHUFFLE More...
 

Detailed Description

Options for tile compression of image pixels.

Tile compression is a feature provided by cfitsio, where contiguous parts of the image ("tiles", e.g., rows, multiple rows, blocks or the entire image) are compressed separately. The aim of this struct is to hold the parameters used to configure the compression.

Floating-point images can be losslessly compressed (quantizeLevel=0.0) using (only) the GZIP or GZIP_SHUFFLE compression algorithms, but the compression factor so achieved is modest (e.g., ~ 10% compression). Better compression factors can be achieved if floating-point images are first quantised into integer images. This can be done by cfitsio (through the quantizeLevel parameter) or through use of the ImageScalingOptions.

The Compression is specified by:

Due to bugs, cfitsio may require setting the quantizeLevel to a value other than zero when compressing integer data, but in this case it should have no effect.

Definition at line 180 of file fitsCompression.h.

Member Typedef Documentation

◆ Tiles

using lsst::afw::fits::ImageCompressionOptions::Tiles = ndarray::Array<long, 1, 1>

Definition at line 194 of file fitsCompression.h.

Member Enumeration Documentation

◆ CompressionAlgorithm

Compression algorithms.

cfitsio's compression algorithms are #defines; these have a namespace.

We deliberately don't support HCOMPRESS: it doesn't appear to be useful to us (e.g., lossy) and it requires extra configuration.

Enumerator
NONE 

No compression.

GZIP 

Standard GZIP compression.

GZIP_SHUFFLE 

GZIP compression with shuffle (most-significant byte first)

RICE 

RICE compression.

PLIO 

PLIO compression.

Definition at line 187 of file fitsCompression.h.

187  {
188  NONE,
189  GZIP,
190  GZIP_SHUFFLE,
191  RICE,
192  PLIO,
193  };
@ GZIP_SHUFFLE
GZIP compression with shuffle (most-significant byte first)

Constructor & Destructor Documentation

◆ ImageCompressionOptions() [1/9]

lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( CompressionAlgorithm  algorithm_,
Tiles  tiles_,
float  quantizeLevel_ = 0.0 
)
inlineexplicit

Custom compression.

Definition at line 201 of file fitsCompression.h.

203  : algorithm(algorithm_), tiles(ndarray::copy(tiles_)), quantizeLevel(quantizeLevel_) {}
float quantizeLevel
quantization level: 0.0 = none requires use of GZIP or GZIP_SHUFFLE
CompressionAlgorithm algorithm
Compresion algorithm to use.
Tiles tiles
Tile size; a dimension with 0 means infinite (e.g., to specify one row: 0,1)

◆ ImageCompressionOptions() [2/9]

lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( CompressionAlgorithm  algorithm_,
std::vector< long >  tiles_,
float  quantizeLevel_ = 0.0 
)
inlineexplicit

Definition at line 205 of file fitsCompression.h.

207  : algorithm(algorithm_), tiles(ndarray::allocate(tiles_.size())), quantizeLevel(quantizeLevel_) {
208  std::copy(tiles_.cbegin(), tiles_.cend(), tiles.begin());
209  }
T cbegin(T... args)
T copy(T... args)
T cend(T... args)
T size(T... args)

◆ ImageCompressionOptions() [3/9]

lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( ImageCompressionOptions::CompressionAlgorithm  algorithm_,
int  rows = 1,
float  quantizeLevel_ = 0.0 
)
explicit

Compression by rows or entire image.

Parameters
[in]algorithm_Compression algorithm to use
[in]rowsNumber of rows per tile (0 = entire image)
[in]quantizeLevel_cfitsio quantization level

Definition at line 90 of file fitsCompression.cc.

92  : algorithm(algorithm_), tiles(ndarray::allocate(MAX_COMPRESS_DIM)), quantizeLevel(quantizeLevel_) {
93  tiles[0] = 0;
94  tiles[1] = rows;
95  for (int ii = 2; ii < MAX_COMPRESS_DIM; ++ii) tiles[ii] = 1;
96 }

◆ ImageCompressionOptions() [4/9]

template<typename T >
lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( image::Image< T > const &  image)
inlineexplicit

Default compression for a particular style of image.

Currently defaults to NONE; change to GZIP_SHUFFLE once use of compression by default has been approved (RFC-378).

Definition at line 224 of file fitsCompression.h.

225  : ImageCompressionOptions(image.getBBox().getArea() > 0 ? NONE : NONE) {}
Backwards-compatibility support for depersisting the old Calib (FluxMag0/FluxMag0Err) objects.
ImageCompressionOptions(CompressionAlgorithm algorithm_, Tiles tiles_, float quantizeLevel_=0.0)
Custom compression.

◆ ImageCompressionOptions() [5/9]

template<typename T >
lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( image::Mask< T > const &  mask)
inlineexplicit

Definition at line 227 of file fitsCompression.h.

228  : ImageCompressionOptions(mask.getBBox().getArea() > 0 ? NONE : NONE) {}
afw::table::Key< afw::table::Array< MaskPixelT > > mask

◆ ImageCompressionOptions() [6/9]

lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( image::Image< std::int64_t > const &  image)
inlineexplicit

Definition at line 231 of file fitsCompression.h.

◆ ImageCompressionOptions() [7/9]

lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( image::Mask< std::int64_t > const &  mask)
inlineexplicit

Definition at line 233 of file fitsCompression.h.

◆ ImageCompressionOptions() [8/9]

lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( image::Image< std::uint64_t > const &  image)
inlineexplicit

Definition at line 234 of file fitsCompression.h.

◆ ImageCompressionOptions() [9/9]

lsst::afw::fits::ImageCompressionOptions::ImageCompressionOptions ( image::Mask< std::uint64_t > const &  mask)
inlineexplicit

Definition at line 236 of file fitsCompression.h.

Member Data Documentation

◆ algorithm

CompressionAlgorithm lsst::afw::fits::ImageCompressionOptions::algorithm

Compresion algorithm to use.

Definition at line 196 of file fitsCompression.h.

◆ quantizeLevel

float lsst::afw::fits::ImageCompressionOptions::quantizeLevel

quantization level: 0.0 = none requires use of GZIP or GZIP_SHUFFLE

Definition at line 198 of file fitsCompression.h.

◆ tiles

Tiles lsst::afw::fits::ImageCompressionOptions::tiles

Tile size; a dimension with 0 means infinite (e.g., to specify one row: 0,1)

Definition at line 197 of file fitsCompression.h.


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