LSST Applications g0b6bd0c080+a72a5dd7e6,g1182afd7b4+2a019aa3bb,g17e5ecfddb+2b8207f7de,g1d67935e3f+06cf436103,g38293774b4+ac198e9f13,g396055baef+6a2097e274,g3b44f30a73+6611e0205b,g480783c3b1+98f8679e14,g48ccf36440+89c08d0516,g4b93dc025c+98f8679e14,g5c4744a4d9+a302e8c7f0,g613e996a0d+e1c447f2e0,g6c8d09e9e7+25247a063c,g7271f0639c+98f8679e14,g7a9cd813b8+124095ede6,g9d27549199+a302e8c7f0,ga1cf026fa3+ac198e9f13,ga32aa97882+7403ac30ac,ga786bb30fb+7a139211af,gaa63f70f4e+9994eb9896,gabf319e997+ade567573c,gba47b54d5d+94dc90c3ea,gbec6a3398f+06cf436103,gc6308e37c7+07dd123edb,gc655b1545f+ade567573c,gcc9029db3c+ab229f5caf,gd01420fc67+06cf436103,gd877ba84e5+06cf436103,gdb4cecd868+6f279b5b48,ge2d134c3d5+cc4dbb2e3f,ge448b5faa6+86d1ceac1d,gecc7e12556+98f8679e14,gf3ee170dca+25247a063c,gf4ac96e456+ade567573c,gf9f5ea5b4d+ac198e9f13,gff490e6085+8c2580be5c,w.2022.27
LSST Data Management Base Package
Namespaces | Classes | Functions
lsst::ip::isr Namespace Reference

Namespaces

namespace  ampOffset
 
namespace  assembleCcdTask
 
namespace  brighterFatterKernel
 
namespace  calibType
 
namespace  crosstalk
 
namespace  defects
 
namespace  fringe
 
namespace  isrFunctions
 
namespace  isrMock
 
namespace  isrQa
 
namespace  isrTask
 
namespace  linearize
 
namespace  masking
 
namespace  overscan
 
namespace  photodiode
 
namespace  photodiodeCorrection
 
namespace  ptcDataset
 
namespace  straylight
 
namespace  version
 
namespace  vignette
 

Classes

class  CountMaskedPixels
 

Functions

template<typename PixelT >
int applyLookupTable (afw::image::Image< PixelT > &image, ndarray::Array< PixelT, 1, 1 > const &table, PixelT indOffset)
 Add the values in a lookup table to an image, e.g. More...
 
template<typename PixelT >
size_t maskNans (afw::image::MaskedImage< PixelT > const &mi, afw::image::MaskPixel maskVal, afw::image::MaskPixel allow=0)
 Mask NANs in an image. More...
 
template<typename ImagePixelT >
std::vector< double > fitOverscanImage (lsst::afw::image::MaskedImage< ImagePixelT > const &overscan, std::vector< std::string > badPixelMask, bool isTransposed)
 
 PYBIND11_MODULE (applyLookupTable, mod)
 
 PYBIND11_MODULE (isr, mod)
 
template int applyLookupTable< float > (afw::image::Image< float > &, ndarray::Array< float, 1, 1 > const &, float)
 
template int applyLookupTable< double > (afw::image::Image< double > &, ndarray::Array< double, 1, 1 > const &, double)
 
std::string between (std::string &s, char ldelim, char rdelim)
 
template std::vector< double > fitOverscanImage< int > (afw::image::MaskedImage< int > const &, std::vector< std::string > badPixelMask, bool isTransposed)
 
template std::vector< double > fitOverscanImage< float > (afw::image::MaskedImage< float > const &, std::vector< std::string > badPixelMask, bool isTransposed)
 
template std::vector< double > fitOverscanImage< double > (afw::image::MaskedImage< double > const &, std::vector< std::string > badPixelMask, bool isTransposed)
 
template size_t maskNans< float > (afw::image::MaskedImage< float > const &, afw::image::MaskPixel, afw::image::MaskPixel)
 
template size_t maskNans< double > (afw::image::MaskedImage< double > const &, afw::image::MaskPixel, afw::image::MaskPixel)
 
template size_t maskNans< int > (afw::image::MaskedImage< int > const &, afw::image::MaskPixel, afw::image::MaskPixel)
 

Function Documentation

◆ applyLookupTable()

template<typename PixelT >
int lsst::ip::isr::applyLookupTable ( afw::image::Image< PixelT > &  image,
ndarray::Array< PixelT, 1, 1 > const &  table,
PixelT  indOffset 
)

Add the values in a lookup table to an image, e.g.

for non-linearity correction

The algorithm is as follows: numOutOfRange = 0 For each i,j of the image: lookupInd = int(indOffset + image[i,j]) if lookupInd not in range [0, table.size() - 1]: set lookupInd to nearest edge and increment numOutOfRange image[i,j] += table[lookupInd] return numOutOfRange

Parameters
[in,out]imageimage to which to add the values; modified in place
[in]tablelookup table
[in]indOffsetscalar added to image value before truncating to lookup column
Returns
the number of pixels whose values were out of range

Definition at line 35 of file applyLookupTable.cc.

39 {
40 if (table.size() == 0u) {
41 throw LSST_EXCEPT(
43 "Lookup table has zero size."
44 );
45 }
46 int numOutOfRange = 0;
47 int const maxLookupCol = table.size() - 1;
48 for (int col = 0, imHeight = image.getHeight(); col < imHeight; ++col) {
49 for (auto imPtr = image.row_begin(col), end = image.row_end(col); imPtr != end; ++imPtr) {
50 int lookupCol = indOffset + *imPtr;
51 if (lookupCol < 0) {
52 lookupCol = 0;
53 ++numOutOfRange;
54 } else if (lookupCol > maxLookupCol) {
55 lookupCol = maxLookupCol;
56 ++numOutOfRange;
57 }
58 *imPtr += table[lookupCol];
59 }
60 }
61 return numOutOfRange;
62}
int end
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
Reports attempts to exceed implementation-defined length limits for some classes.
Definition: Runtime.h:76
Backwards-compatibility support for depersisting the old Calib (FluxMag0/FluxMag0Err) objects.
int col
Definition: CR.cc:144

◆ applyLookupTable< double >()

template int lsst::ip::isr::applyLookupTable< double > ( afw::image::Image< double > &  ,
ndarray::Array< double, 1, 1 > const &  ,
double   
)

◆ applyLookupTable< float >()

template int lsst::ip::isr::applyLookupTable< float > ( afw::image::Image< float > &  ,
ndarray::Array< float, 1, 1 > const &  ,
float   
)

◆ between()

std::string lsst::ip::isr::between ( std::string s,
char  ldelim,
char  rdelim 
)

Definition at line 98 of file Isr.cc.

98 {
99 std::string::iterator b(s.begin());
100 std::string::iterator e(s.end());
101 std::string::iterator lp;
102 std::string::iterator rp;
103
105
106 if((lp = std::find(b, e, ldelim)) != e)
107 if((rp = std::find(++lp, e, rdelim)) != e)
108 result = std::string(lp, rp);
109
110 return result;
111}
py::object result
Definition: _schema.cc:429
table::Key< int > b
T begin(T... args)
T end(T... args)
T find(T... args)

◆ fitOverscanImage()

template<typename ImagePixelT >
std::vector< double > lsst::ip::isr::fitOverscanImage ( lsst::afw::image::MaskedImage< ImagePixelT > const &  overscan,
std::vector< std::string badPixelMask,
bool  isTransposed 
)

This is transposed here to match the existing numpy-array ordering. This effectively transposes the image for us.

This is transposed here to match the existing numpy-array ordering. This effectively transposes the image for us.

Definition at line 53 of file Isr.cc.

57 {
58 typedef afw::image::MaskedImage<ImagePixelT> MaskedImage;
59
64 const int height = overscan.getHeight();
65 const int width = overscan.getWidth();
66
67 int length = height;
68 if (isTransposed) {
69 length = width;
70 }
71
73
75 statControl.setAndMask(overscan.getMask()->getPlaneBitMask(badPixelMask));
76
77 const int x0 = overscan.getX0();
78 const int y0 = overscan.getY0();
79 auto origin = geom::Point2I(x0, y0);
80 geom::Extent2I shifter;
81 geom::Extent2I extents;
82 if (isTransposed) {
83 shifter = geom::Extent2I(1, 0);
84 extents = geom::Extent2I(1, height);
85 } else {
86 shifter = geom::Extent2I(0, 1);
87 extents = geom::Extent2I(width, 1);
88 }
89
90 for (int x = 0; x < length; ++x) {
91 MaskedImage mi = MaskedImage(overscan, geom::Box2I(origin, extents));
92 values[x] = afw::math::makeStatistics(mi, afw::math::MEDIAN, statControl).getValue();
93 origin.shift(shifter);
94 }
95 return values;
96}
double x
A class to manipulate images, masks, and variance as a single object.
Definition: MaskedImage.h:73
int getX0() const
Return the image's column-origin.
Definition: MaskedImage.h:1066
int getHeight() const
Return the number of rows in the image.
Definition: MaskedImage.h:1056
int getY0() const
Return the image's row-origin.
Definition: MaskedImage.h:1074
int getWidth() const
Return the number of columns in the image.
Definition: MaskedImage.h:1054
MaskPtr getMask() const
Return a (shared_ptr to) the MaskedImage's mask.
Definition: MaskedImage.h:1030
Pass parameters to a Statistics object.
Definition: Statistics.h:92
double getValue(Property const prop=NOTHING) const
Return the value of the desired property (if specified in the constructor)
Definition: Statistics.cc:1047
An integer coordinate rectangle.
Definition: Box.h:55
Statistics makeStatistics(lsst::afw::image::Image< Pixel > const &img, lsst::afw::image::Mask< image::MaskPixel > const &msk, int const flags, StatisticsControl const &sctrl=StatisticsControl())
Handle a watered-down front-end to the constructor (no variance)
Definition: Statistics.h:359
@ MEDIAN
estimate sample median
Definition: Statistics.h:69
Extent< int, 2 > Extent2I
Definition: Extent.h:397
Point< int, 2 > Point2I
Definition: Point.h:321

◆ fitOverscanImage< double >()

template std::vector< double > lsst::ip::isr::fitOverscanImage< double > ( afw::image::MaskedImage< double > const &  ,
std::vector< std::string badPixelMask,
bool  isTransposed 
)

◆ fitOverscanImage< float >()

template std::vector< double > lsst::ip::isr::fitOverscanImage< float > ( afw::image::MaskedImage< float > const &  ,
std::vector< std::string badPixelMask,
bool  isTransposed 
)

◆ fitOverscanImage< int >()

template std::vector< double > lsst::ip::isr::fitOverscanImage< int > ( afw::image::MaskedImage< int > const &  ,
std::vector< std::string badPixelMask,
bool  isTransposed 
)

◆ maskNans()

template<typename PixelT >
size_t lsst::ip::isr::maskNans ( afw::image::MaskedImage< PixelT > const &  mi,
afw::image::MaskPixel  maskVal,
afw::image::MaskPixel  allow = 0 
)

Mask NANs in an image.

NANs in the image or variance that are not already masked by the 'allow' value are masked with the 'maskVal'.

Returns
Number of pixels masked
Parameters
miInput image
maskValBit mask value to give a NaN
allowRetain NANs with this bit mask (0 to mask all NANs)

Definition at line 35 of file Isr.cc.

37{
38 typedef typename afw::image::MaskedImage<PixelT>::x_iterator x_iterator;
39 size_t nPix = 0;
40 for (int y = 0; y != mi.getHeight(); ++y) {
41 for (x_iterator ptr = mi.row_begin(y), end = mi.row_end(y); ptr != end; ++ptr) {
42 if (!(ptr.mask() & allow) && (!std::isfinite(ptr.image()) ||
43 !std::isfinite(ptr.variance()))) {
44 nPix += 1;
45 ptr.mask() |= maskVal;
46 }
47 }
48 }
49 return nPix;
50}
uint64_t * ptr
Definition: RangeSet.cc:88
int y
Definition: SpanSet.cc:48
x_iterator row_end(int y) const
Return an x_iterator to the end of the image.
Definition: MaskedImage.cc:631
x_iterator row_begin(int y) const
Return an x_iterator to the start of the image.
Definition: MaskedImage.cc:621
T isfinite(T... args)

◆ maskNans< double >()

template size_t lsst::ip::isr::maskNans< double > ( afw::image::MaskedImage< double > const &  ,
afw::image::MaskPixel  ,
afw::image::MaskPixel   
)

◆ maskNans< float >()

template size_t lsst::ip::isr::maskNans< float > ( afw::image::MaskedImage< float > const &  ,
afw::image::MaskPixel  ,
afw::image::MaskPixel   
)

◆ maskNans< int >()

template size_t lsst::ip::isr::maskNans< int > ( afw::image::MaskedImage< int > const &  ,
afw::image::MaskPixel  ,
afw::image::MaskPixel   
)

◆ PYBIND11_MODULE() [1/2]

lsst::ip::isr::PYBIND11_MODULE ( applyLookupTable  ,
mod   
)

Definition at line 45 of file applyLookupTable.cc.

45 {
46 declareApplyLookupTable<float>(mod);
47 declareApplyLookupTable<double>(mod);
48}

◆ PYBIND11_MODULE() [2/2]

lsst::ip::isr::PYBIND11_MODULE ( isr  ,
mod   
)

Definition at line 69 of file isr.cc.

69 {
70 declareAll<float>(mod, "F");
71 declareAll<double>(mod, "D");
72 declareAll<int>(mod, "I");
73}