LSST Applications 26.0.0,g0265f82a02+6660c170cc,g07994bdeae+30b05a742e,g0a0026dc87+17526d298f,g0a60f58ba1+17526d298f,g0e4bf8285c+96dd2c2ea9,g0ecae5effc+c266a536c8,g1e7d6db67d+6f7cb1f4bb,g26482f50c6+6346c0633c,g2bbee38e9b+6660c170cc,g2cc88a2952+0a4e78cd49,g3273194fdb+f6908454ef,g337abbeb29+6660c170cc,g337c41fc51+9a8f8f0815,g37c6e7c3d5+7bbafe9d37,g44018dc512+6660c170cc,g4a941329ef+4f7594a38e,g4c90b7bd52+5145c320d2,g58be5f913a+bea990ba40,g635b316a6c+8d6b3a3e56,g67924a670a+bfead8c487,g6ae5381d9b+81bc2a20b4,g93c4d6e787+26b17396bd,g98cecbdb62+ed2cb6d659,g98ffbb4407+81bc2a20b4,g9ddcbc5298+7f7571301f,ga1e77700b3+99e9273977,gae46bcf261+6660c170cc,gb2715bf1a1+17526d298f,gc86a011abf+17526d298f,gcf0d15dbbd+96dd2c2ea9,gdaeeff99f8+0d8dbea60f,gdb4ec4c597+6660c170cc,ge23793e450+96dd2c2ea9,gf041782ebf+171108ac67
LSST Data Management Base Package
Loading...
Searching...
No Matches
transforms.py
Go to the documentation of this file.
1# This file is part of meas_base.
2#
3# Developed for the LSST Data Management System.
4# This product includes software developed by the LSST Project
5# (https://www.lsst.org).
6# See the COPYRIGHT file at the top-level directory of this distribution
7# for details of code ownership.
8#
9# This program is free software: you can redistribute it and/or modify
10# it under the terms of the GNU General Public License as published by
11# the Free Software Foundation, either version 3 of the License, or
12# (at your option) any later version.
13#
14# This program is distributed in the hope that it will be useful,
15# but WITHOUT ANY WARRANTY; without even the implied warranty of
16# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17# GNU General Public License for more details.
18#
19# You should have received a copy of the GNU General Public License
20# along with this program. If not, see <https://www.gnu.org/licenses/>.
21
22"""Measurement transformations.
23
24When a measurement plugin is run, it provides raw, uncalibrated outputs such
25as pixel positions. A transformation may be run as a post-processing step to
26convert those outputs to calibrated quantities, such as celestial coordinates.
27
28At construction, the transformation is passed the configuration and name of
29the plugin whose outputs it will be transformaing (all fields in the input
30table produced by that plugin will have their field names prefixed by the
31plugin name) and a `~lsst.afw.table.SchemaMapper` which holds the schemata for
32the input and output catalogs and which may be used to directly map fields
33between the catalogs.
34
35When a transformer is called, it is handed a `~lsst.afw.table.SourceCatalog`
36containing the measurements to be transformed, a `~lsst.afw.table.BaseCatalog`
37in which to store results, and information about the WCS and calibration of
38the data. It may be safely assumed that both are contiguous in memory, thus a
39``ColumnView`` may be used for efficient processing. If the transformation is
40not possible, it should be aborted by throwing an exception; if this happens,
41the caller should assume that the contents of the output catalog are
42inconsistent.
43
44Transformations can be defined in Python or in C++. Python code should inherit
45from `MeasurementTransform`, following its interface.
46"""
47
48from lsst.afw.table import CoordKey
49from lsst.pex.exceptions import LengthError
50from ._measBaseLib import CentroidResultKey
51
52__all__ = ("MeasurementTransform", "NullTransform", "PassThroughTransform", "SimpleCentroidTransform")
53
54
56 """Base class for measurement transformations.
57
58 Parameters
59 ----------
60 config : subclass of `BasePluginConfig`
61 The configuration of the measurement plugin whose outputs are being
62 transformed.
63 name : `str`
64 The name of the measurement plugin whose outputs are being
65 transformed.
67 Mapping between the input (pre-transformation) and output
68 (transformed) catalogs.
69
70 Notes
71 -----
72 Create transformations by deriving from this class, implementing
73 `__call__()` and (optionally) augmenting `__init__()`.
74 """
75
76 def __init__(self, config, name, mapper):
77 self.name = name
78 self.config = config
79
80 def __call__(self, inputCatalog, outputCatalog, wcs, photoCalib):
81 raise NotImplementedError()
82
83 @staticmethod
84 def _checkCatalogSize(cat1, cat2):
85 if len(cat1) != len(cat2):
86 raise LengthError("Catalog size mismatch")
87
88
90 """Null transform which transfers no data from input to output.
91
92 This is intended as the default for measurements for which no other
93 transformation is specified.
94
95 Parameters
96 ----------
97 config : subclass of `BasePluginConfig`
98 The configuration of the measurement plugin whose outputs are being
99 transformed.
100 name : `str`
101 The name of the measurement plugin whose outputs are being
102 transformed.
104 Mapping between the input (pre-transformation) and output
105 (transformed) catalogs.
106 """
107
108 def __call__(self, inputCatalog, outputCatalog, wcs, photoCalib):
109 self._checkCatalogSize(inputCatalog, outputCatalog)
110
111
113 """Copy fields from input to output without transformation.
114
115 Parameters
116 ----------
117 config : subclass of `BasePluginConfig`
118 The configuration of the measurement plugin whose outputs are being
119 transformed.
120 name : `str`
121 The name of the measurement plugin whose outputs are being
122 transformed.
124 Mapping between the input (pre-transformation) and output
125 (transformed) catalogs.
126 """
127
128 def __init__(self, config, name, mapper):
129 MeasurementTransform.__init__(self, config, name, mapper)
130 for key, field in mapper.getInputSchema().extract(name + "*").values():
131 mapper.addMapping(key)
132
133 def __call__(self, inputCatalog, outputCatalog, wcs, photoCalib):
134 self._checkCatalogSize(inputCatalog, outputCatalog)
135
136
138 """Transform pixel centroid, without uncertainty, to celestial coordinates.
139
140 Parameters
141 ----------
142 config : subclass of `BasePluginConfig`
143 The configuration of the measurement plugin whose outputs are being
144 transformed.
145 name : `str`
146 The name of the measurement plugin whose outputs are being
147 transformed.
149 Mapping between the input (pre-transformation) and output
150 (transformed) catalogs.
151 """
152
153 def __init__(self, config, name, mapper):
154 MeasurementTransform.__init__(self, config, name, mapper)
155 self.coordKey = CoordKey.addFields(mapper.editOutputSchema(), name, "Position from " + name)
156
157 def __call__(self, inputCatalog, outputCatalog, wcs, photoCalib):
158 self._checkCatalogSize(inputCatalog, outputCatalog)
159 centroidResultKey = CentroidResultKey(inputCatalog.schema[self.name])
160 for inSrc, outSrc in zip(inputCatalog, outputCatalog):
161 self.coordKey.set(outSrc, wcs.pixelToSky(centroidResultKey.get(inSrc).getCentroid()))
A mapping between the keys of two Schemas, used to copy data between them.
__call__(self, inputCatalog, outputCatalog, wcs, photoCalib)
Definition transforms.py:80
__call__(self, inputCatalog, outputCatalog, wcs, photoCalib)
__call__(self, inputCatalog, outputCatalog, wcs, photoCalib)
__call__(self, inputCatalog, outputCatalog, wcs, photoCalib)
Reports attempts to exceed implementation-defined length limits for some classes.
Definition Runtime.h:76
daf::base::PropertySet * set
Definition fits.cc:927