LSST Applications g0265f82a02+0e5473021a,g02d81e74bb+f5613e8b4f,g1470d8bcf6+190ad2ba91,g14a832a312+311607e4ab,g2079a07aa2+86d27d4dc4,g2305ad1205+a8e3196225,g295015adf3+b67ee847e5,g2bbee38e9b+0e5473021a,g337abbeb29+0e5473021a,g3ddfee87b4+a761f810f3,g487adcacf7+17c8fdbcbd,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+65b5bd823e,g5a732f18d5+53520f316c,g64a986408d+f5613e8b4f,g6c1bc301e9+51106c2951,g858d7b2824+f5613e8b4f,g8a8a8dda67+585e252eca,g99cad8db69+6729933424,g9ddcbc5298+9a081db1e4,ga1e77700b3+15fc3df1f7,ga8c6da7877+ef4e3a5875,gb0e22166c9+60f28cb32d,gb6a65358fc+0e5473021a,gba4ed39666+c2a2e4ac27,gbb8dafda3b+e9bba80f27,gc120e1dc64+eee469a5e5,gc28159a63d+0e5473021a,gcf0d15dbbd+a761f810f3,gdaeeff99f8+f9a426f77a,ge6526c86ff+d4c1d4bfef,ge79ae78c31+0e5473021a,gee10cc3b42+585e252eca,gf1cff7945b+f5613e8b4f,w.2024.16
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Public Attributes | List of all members
lsst::afw::geom::SipApproximation::Grid Struct Reference

Public Member Functions

 Grid (lsst::geom::Extent2I const &shape_, SipApproximation const &parent)
 

Public Attributes

lsst::geom::Extent2I const shape
 
std::vector< lsst::geom::Point2Ddpix1
 
std::vector< lsst::geom::Point2Dsiwc
 
std::vector< lsst::geom::Point2Ddpix2
 

Detailed Description

Definition at line 108 of file SipApproximation.cc.

Constructor & Destructor Documentation

◆ Grid()

lsst::afw::geom::SipApproximation::Grid::Grid ( lsst::geom::Extent2I const & shape_,
SipApproximation const & parent )

Definition at line 159 of file SipApproximation.cc.

159 :
160 shape(shape_),
161 dpix1(makeGrid(parent._bbox, shape)),
162 siwc(parent._pixelToIwc->applyForward(dpix1))
163{
164 // Apply the CRPIX offset to make pix1 into dpix1 (in-place)
165 std::for_each(dpix1.begin(), dpix1.end(), [&parent](lsst::geom::Point2D & p){ p -= parent._crpix; });
166
167 if (parent._useInverse) {
168 // Set from the given inverse of the given pixels-to-iwc transform
169 // Note that at this point, siwc is still just iwc, because the scaling by cdInv is later.
170 dpix2 = parent._pixelToIwc->applyInverse(siwc);
171 // Apply the CRPIX offset to make pix1 into dpix2 (in-place)
172 std::for_each(dpix2.begin(), dpix2.end(), [&parent](lsst::geom::Point2D & p){ p -= parent._crpix; });
173 } else {
174 // Just make dpix2 = dpix1, and hence fit to the true inverse of pixels-to-iwc.
175 dpix2 = dpix1;
176 }
177
178 // Apply the CD^{-1} transform to siwc
179 std::for_each(siwc.begin(), siwc.end(), [&parent](lsst::geom::Point2D & p){ p = parent._cdInv(p); });
180}
T for_each(T... args)
std::vector< lsst::geom::Point2D > dpix1
std::vector< lsst::geom::Point2D > dpix2
std::vector< lsst::geom::Point2D > siwc

Member Data Documentation

◆ dpix1

std::vector<lsst::geom::Point2D> lsst::afw::geom::SipApproximation::Grid::dpix1

Definition at line 114 of file SipApproximation.cc.

◆ dpix2

std::vector<lsst::geom::Point2D> lsst::afw::geom::SipApproximation::Grid::dpix2

Definition at line 116 of file SipApproximation.cc.

◆ shape

lsst::geom::Extent2I const lsst::afw::geom::SipApproximation::Grid::shape

Definition at line 113 of file SipApproximation.cc.

◆ siwc

std::vector<lsst::geom::Point2D> lsst::afw::geom::SipApproximation::Grid::siwc

Definition at line 115 of file SipApproximation.cc.


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