LSST Applications g063fba187b+cac8b7c890,g0f08755f38+6aee506743,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g1a2382251a+b4475c5878,g1dcb35cd9c+8f9bc1652e,g20f6ffc8e0+6aee506743,g217e2c1bcf+73dee94bd0,g28da252d5a+1f19c529b9,g2bbee38e9b+3f2625acfc,g2bc492864f+3f2625acfc,g3156d2b45e+6e55a43351,g32e5bea42b+1bb94961c2,g347aa1857d+3f2625acfc,g35bb328faa+a8ce1bb630,g3a166c0a6a+3f2625acfc,g3e281a1b8c+c5dd892a6c,g3e8969e208+a8ce1bb630,g414038480c+5927e1bc1e,g41af890bb2+8a9e676b2a,g7af13505b9+809c143d88,g80478fca09+6ef8b1810f,g82479be7b0+f568feb641,g858d7b2824+6aee506743,g89c8672015+f4add4ffd5,g9125e01d80+a8ce1bb630,ga5288a1d22+2903d499ea,gb58c049af0+d64f4d3760,gc28159a63d+3f2625acfc,gcab2d0539d+b12535109e,gcf0d15dbbd+46a3f46ba9,gda6a2b7d83+46a3f46ba9,gdaeeff99f8+1711a396fd,ge79ae78c31+3f2625acfc,gef2f8181fd+0a71e47438,gf0baf85859+c1f95f4921,gfa517265be+6aee506743,gfa999e8aa5+17cd334064,w.2024.51
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Public Attributes | List of all members
lsst::afw::fits::ImageScale Struct Reference

Scale to apply to image. More...

#include <fitsCompression.h>

Public Member Functions

 ImageScale (int bitpix_, double bscale_, double bzero_)
 Constructor.
 
template<typename T >
std::shared_ptr< detail::PixelArrayBasetoFits (ndarray::Array< T const, 2, 2 > const &image, bool forceNonfiniteRemoval, bool fuzz=true, ndarray::Array< long, 1 > const &tiles=ndarray::Array< long, 1, 1 >(), int seed=1) const
 Convert to an array of pixel values to write to FITS.
 
template<typename T >
ndarray::Array< T, 2, 2 > fromFits (ndarray::Array< T, 2, 2 > const &image) const
 Convert to an array.
 

Public Attributes

int bitpix
 Bits per pixel; negative means floating-point: 8,16,32,64,-32,-64.
 
double bscale
 Scale to apply when reading from FITS.
 
double bzero
 Zero-point to apply when reading from FITS.
 
long blank
 Value for integer images indicating non-finite values.
 

Detailed Description

Scale to apply to image.

Images are scaled to the type implied by the provided BITPIX using the provided scale and zero-point:

value in memory = BZERO + BSCALE * value in FITS

In addition to scaling, a random field of values distributed [0,1) may be added before quantisation ("fuzz"); this preserves the expectation value of the floating-point image, while increasing the variance by 1/12.

Definition at line 262 of file fitsCompression.h.

Constructor & Destructor Documentation

◆ ImageScale()

lsst::afw::fits::ImageScale::ImageScale ( int bitpix_,
double bscale_,
double bzero_ )
inline

Constructor.

We make BZERO an integer multiple of BSCALE, because cfitsio notes: "This helps to ensure the same scaling will be performed if the file undergoes multiple fpack/funpack cycles".

The BLANK is 255 for BITPIX=8 since FITS specifies that uses unsigned char; otherwise it is set to the maximum int for the appropriate signed integer.

Definition at line 276 of file fitsCompression.h.

277 : bitpix(bitpix_),
278 bscale(bscale_),
279 bzero(std::floor(bzero_ / bscale_ + 0.5) * bscale_),
280 blank(bitpix > 0 ? (bitpix == 8 ? 255 : (1L << (bitpix - 1)) - 1) : 0) {}
T floor(T... args)
double bscale
Scale to apply when reading from FITS.
long blank
Value for integer images indicating non-finite values.
int bitpix
Bits per pixel; negative means floating-point: 8,16,32,64,-32,-64.
double bzero
Zero-point to apply when reading from FITS.

Member Function Documentation

◆ fromFits()

template<typename T >
ndarray::Array< T, 2, 2 > lsst::afw::fits::ImageScale::fromFits ( ndarray::Array< T, 2, 2 > const & image) const

Convert to an array.

Use of this method is generally not necessary, since cfitsio automatically applies the scaling on read. However, it may be useful for applying novel scalings (e.g., logarithmic).

Definition at line 494 of file fitsCompression.cc.

494 {
495 ndarray::Array<T, 2, 2> memory = ndarray::allocate(image.getShape());
496 memory.deep() = bscale * image + bzero;
497 return memory;
498}

◆ toFits()

template<typename T >
std::shared_ptr< detail::PixelArrayBase > lsst::afw::fits::ImageScale::toFits ( ndarray::Array< T const, 2, 2 > const & image,
bool forceNonfiniteRemoval,
bool fuzz = true,
ndarray::Array< long, 1 > const & tiles = ndarray::Array<long, 1, 1>(),
int seed = 1 ) const

Convert to an array of pixel values to write to FITS.

Parameters
[in]imageImage to scale
[in]forceNonfiniteRemovalForce removal of non-finite values? This is useful for lossless compression, because cfitsio doesn't mask out non-finite values, and they end up contaminating the entire tile.
[in]fuzzAdd random values before quantising?
[in]tilesTile dimensions
[in]seedSeed for random number generator
Returns
Array of pixel values, appropriately scaled.

Definition at line 417 of file fitsCompression.cc.

420 {
422 if (bitpix != detail::Bitpix<T>::value) {
423 throw LSST_EXCEPT(pex::exceptions::InvalidParameterError,
424 "Floating-point images may not be converted to different floating-point types");
425 }
426 if (bscale != 1.0 || bzero != 0.0) {
427 throw LSST_EXCEPT(pex::exceptions::InvalidParameterError,
428 "Scaling may not be applied to floating-point images");
429 }
430 }
431
432 if (bitpix < 0 || (bitpix == 0 && !std::numeric_limits<T>::is_integer) ||
433 (bscale == 1.0 && bzero == 0.0 && !fuzz)) {
434 if (!forceNonfiniteRemoval) {
435 // Type conversion only
436 return detail::makePixelArray(bitpix, ndarray::Array<T const, 1, 1>(ndarray::flatten<1>(image)));
437 }
439 ndarray::Array<T, 1, 1> out = ndarray::allocate(image.getNumElements());
440 auto outIter = out.begin();
441 auto const& flatImage = ndarray::flatten<1>(image);
442 for (auto inIter = flatImage.begin(); inIter != flatImage.end(); ++inIter, ++outIter) {
443 *outIter = std::isfinite(*inIter) ? *inIter : std::numeric_limits<T>::max();
444 }
445 return detail::makePixelArray(bitpix, out);
446 }
447 // Fall through for explicit scaling
448 }
449
450 // Note: BITPIX=8 treated differently, since it uses unsigned values; the rest use signed */
451 double min = bitpix == 8 ? 0 : -std::pow(2.0, bitpix - 1);
452 double max = bitpix == 8 ? 255 : (std::pow(2.0, bitpix - 1) - 1.0);
453
455 // cfitsio saves space for N_RESERVED_VALUES=10 values at the low end
457 }
458
459 double const scale = 1.0 / bscale;
460 std::size_t const num = image.getNumElements();
461 bool const applyFuzz = fuzz && !std::numeric_limits<T>::is_integer && bitpix > 0;
462 ndarray::Array<double, 1, 1> out;
463 if (applyFuzz) {
464 if (tiles.isEmpty()) {
465 throw LSST_EXCEPT(pex::exceptions::InvalidParameterError,
466 "Tile sizes must be provided if fuzzing is desired");
467 }
468 out = CfitsioRandom(seed).forImage<double>(image.getShape(), tiles);
469 } else {
470 out = ndarray::allocate(num);
471 out.deep() = 0;
472 }
473 auto outIter = out.begin();
474 auto const& flatImage = ndarray::flatten<1>(image);
475 for (auto inIter = flatImage.begin(); inIter != flatImage.end(); ++inIter, ++outIter) {
476 double value = (*inIter - bzero) * scale;
477 if (!std::isfinite(value)) {
478 // This choice of "max" for non-finite and overflow pixels is mainly cosmetic --- it has to be
479 // something, and "min" would produce holes in the cores of bright stars.
480 *outIter = blank;
481 continue;
482 }
483 if (applyFuzz) {
484 // Add random factor [0.0,1.0): adds a variance of 1/12,
485 // but preserves the expectation value given the floor()
486 value += *outIter;
487 }
488 *outIter = (value < min ? blank : (value > max ? blank : std::floor(value)));
489 }
490 return detail::makePixelArray(bitpix, out);
491}
int min
int max
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition Exception.h:48
int const N_RESERVED_VALUES
T isfinite(T... args)
T max(T... args)
scale(algorithm, min, max=None, frame=None)
Definition ds9.py:108
std::shared_ptr< PixelArrayBase > makePixelArray(int bitpix, ndarray::Array< T, 1, 1 > const &array)
Create a PixelArray suitable for an image with the nominated BITPIX.
T pow(T... args)

Member Data Documentation

◆ bitpix

int lsst::afw::fits::ImageScale::bitpix

Bits per pixel; negative means floating-point: 8,16,32,64,-32,-64.

Definition at line 263 of file fitsCompression.h.

◆ blank

long lsst::afw::fits::ImageScale::blank

Value for integer images indicating non-finite values.

Definition at line 266 of file fitsCompression.h.

◆ bscale

double lsst::afw::fits::ImageScale::bscale

Scale to apply when reading from FITS.

Definition at line 264 of file fitsCompression.h.

◆ bzero

double lsst::afw::fits::ImageScale::bzero

Zero-point to apply when reading from FITS.

Definition at line 265 of file fitsCompression.h.


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