LSST Applications g0f08755f38+82efc23009,g12f32b3c4e+e7bdf1200e,g1653933729+a8ce1bb630,g1a0ca8cf93+50eff2b06f,g28da252d5a+52db39f6a5,g2bbee38e9b+37c5a29d61,g2bc492864f+37c5a29d61,g2cdde0e794+c05ff076ad,g3156d2b45e+41e33cbcdc,g347aa1857d+37c5a29d61,g35bb328faa+a8ce1bb630,g3a166c0a6a+37c5a29d61,g3e281a1b8c+fb992f5633,g414038480c+7f03dfc1b0,g41af890bb2+11b950c980,g5fbc88fb19+17cd334064,g6b1c1869cb+12dd639c9a,g781aacb6e4+a8ce1bb630,g80478fca09+72e9651da0,g82479be7b0+04c31367b4,g858d7b2824+82efc23009,g9125e01d80+a8ce1bb630,g9726552aa6+8047e3811d,ga5288a1d22+e532dc0a0b,gae0086650b+a8ce1bb630,gb58c049af0+d64f4d3760,gc28159a63d+37c5a29d61,gcf0d15dbbd+2acd6d4d48,gd7358e8bfb+778a810b6e,gda3e153d99+82efc23009,gda6a2b7d83+2acd6d4d48,gdaeeff99f8+1711a396fd,ge2409df99d+6b12de1076,ge79ae78c31+37c5a29d61,gf0baf85859+d0a5978c5a,gf3967379c6+4954f8c433,gfb92a5be7c+82efc23009,gfec2e1e490+2aaed99252,w.2024.46
LSST Data Management Base Package
Loading...
Searching...
No Matches
CreateWcsWithSip.h
Go to the documentation of this file.
1// -*- LSST-C++ -*-
2
3/*
4 * LSST Data Management System
5 * Copyright 2008, 2009, 2010 LSST Corporation.
6 *
7 * This product includes software developed by the
8 * LSST Project (http://www.lsst.org/).
9 *
10 * This program is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the LSST License Statement and
21 * the GNU General Public License along with this program. If not,
22 * see <http://www.lsstcorp.org/LegalNotices/>.
23 */
24
25#ifndef CREATE_WCS_WITH_SIP
26#define CREATE_WCS_WITH_SIP
27
28#include <memory>
29#include <vector>
30
31#include "lsst/base.h"
32#include "Eigen/Core"
33
35#include "lsst/geom/Angle.h"
36#include "lsst/geom/Box.h"
37
38namespace lsst {
39namespace meas {
40namespace astrom {
41namespace sip {
42
75template <class MatchT>
77public:
80
95 CreateWcsWithSip(std::vector<MatchT> const& matches, afw::geom::SkyWcs const& linearWcs, int const order,
96 geom::Box2I const& bbox = geom::Box2I(), int const ngrid = 0);
97
99
106 double getScatterInPixels() const;
107
115
122 double getLinearScatterInPixels() const;
123
131
133 int getOrder() const { return _sipA.rows(); }
135 int getNPoints() const { return _matches.size(); }
137 int getNGrid() const { return _ngrid; }
138
139 // Return the SIP A matrix
140 Eigen::MatrixXd const getSipA() { return _sipA; }
141 // Return the SIP B matrix
142 Eigen::MatrixXd const getSipB() { return _sipB; }
143 // Return the SIP Ap matrix
144 Eigen::MatrixXd const getSipAp() { return _sipAp; }
145 // Return the SIP Bp matrix
146 Eigen::MatrixXd const getSipBp() { return _sipBp; }
147
148private:
149 std::vector<MatchT> const _matches;
150 geom::Box2I mutable _bbox;
151 int _ngrid; // grid size to calculate inverse SIP coefficients (1-D)
153 // _sipOrder is polynomial order for forward transform.
154 // _reverseSipOrder is order for reverse transform, not necessarily the same.
155 int const _sipOrder, _reverseSipOrder;
156
157 Eigen::MatrixXd _sipA, _sipB;
158 Eigen::MatrixXd _sipAp, _sipBp;
159
161
162 void _calculateForwardMatrices();
163 void _calculateReverseMatrices();
164};
165
167template <class MatchT>
169 afw::geom::SkyWcs const& linearWcs, int const order,
170 geom::Box2I const& bbox = geom::Box2I(), int const ngrid = 0) {
171 return CreateWcsWithSip<MatchT>(matches, linearWcs, order, bbox, ngrid);
172}
173
174} // namespace sip
175} // namespace astrom
176} // namespace meas
177} // namespace lsst
178
179#endif
AmpInfoBoxKey bbox
Definition Amplifier.cc:117
Basic LSST definitions.
A 2-dimensional celestial WCS that transform pixels to ICRS RA/Dec, using the LSST standard for pixel...
Definition SkyWcs.h:117
A class representing an angle.
Definition Angle.h:128
An integer coordinate rectangle.
Definition Box.h:55
Measure the distortions in an image plane and express them a SIP polynomials.
double getLinearScatterInPixels() const
Compute the median radial separation between items in this object's match list.
std::shared_ptr< CreateWcsWithSip > Ptr
std::shared_ptr< CreateWcsWithSip const > ConstPtr
int getNGrid() const
Return the number of grid points (on each axis) used in inverse SIP transform.
int getNPoints() const
Return the number of points in the catalogue.
int getOrder() const
Return the number of terms in the SIP matrix.
double getScatterInPixels() const
Compute the median separation, in pixels, between items in this object's match list.
std::shared_ptr< afw::geom::SkyWcs > getNewWcs()
geom::Angle getScatterOnSky() const
Compute the median on-sky separation between items in this object's match list.
geom::Angle getLinearScatterOnSky() const
Compute the median on-sky separation between items in this object's match list,.
CreateWcsWithSip(std::vector< MatchT > const &matches, afw::geom::SkyWcs const &linearWcs, int const order, geom::Box2I const &bbox=geom::Box2I(), int const ngrid=0)
Construct a CreateWcsWithSip.
CreateWcsWithSip< MatchT > makeCreateWcsWithSip(std::vector< MatchT > const &matches, afw::geom::SkyWcs const &linearWcs, int const order, geom::Box2I const &bbox=geom::Box2I(), int const ngrid=0)
Factory function for CreateWcsWithSip.
T size(T... args)
table::Key< int > order