LSST Applications g0f08755f38+9c285cab97,g1635faa6d4+13f3999e92,g1653933729+a8ce1bb630,g1a0ca8cf93+bf6eb00ceb,g28da252d5a+0829b12dee,g29321ee8c0+5700dc9eac,g2bbee38e9b+9634bc57db,g2bc492864f+9634bc57db,g2cdde0e794+c2c89b37c4,g3156d2b45e+41e33cbcdc,g347aa1857d+9634bc57db,g35bb328faa+a8ce1bb630,g3a166c0a6a+9634bc57db,g3e281a1b8c+9f2c4e2fc3,g414038480c+077ccc18e7,g41af890bb2+fde0dd39b6,g5fbc88fb19+17cd334064,g781aacb6e4+a8ce1bb630,g80478fca09+55a9465950,g82479be7b0+d730eedb7d,g858d7b2824+9c285cab97,g9125e01d80+a8ce1bb630,g9726552aa6+10f999ec6a,ga5288a1d22+2a84bb7594,gacf8899fa4+c69c5206e8,gae0086650b+a8ce1bb630,gb58c049af0+d64f4d3760,gc28159a63d+9634bc57db,gcf0d15dbbd+4b7d09cae4,gda3e153d99+9c285cab97,gda6a2b7d83+4b7d09cae4,gdaeeff99f8+1711a396fd,ge2409df99d+5e831397f4,ge79ae78c31+9634bc57db,gf0baf85859+147a0692ba,gf3967379c6+41c94011de,gf3fb38a9a8+8f07a9901b,gfb92a5be7c+9c285cab97,w.2024.46
LSST Data Management Base Package
Loading...
Searching...
No Matches
Functions
lsst::meas::base::python Namespace Reference

Functions

template<class Algorithm , class PyAlg >
std::enable_if<!std::is_abstract< Algorithm >::value, void >::type declareAlgorithmConstructor (PyAlg &cls)
 Wrap the standard algorithm constructor.
 
template<class Algorithm , class PyAlg >
std::enable_if< std::is_abstract< Algorithm >::value, void >::type declareAlgorithmConstructor (PyAlg &cls)
 Dummy function for not wrapping the constructor of an abstract base class.
 
template<class Algorithm , class PyAlg >
void declareAlgorithm (PyAlg &clsAlgorithm)
 Wrap the implicit API used by meas_base's algorithms.
 
template<class Algorithm , class Control , class PyAlg , class PyCtrl >
void declareAlgorithm (PyAlg &clsAlgorithm, PyCtrl &clsControl)
 Wrap the implicit API used by meas_base's algorithm-control pairs (no transform).
 
template<class Algorithm , class Control , class Transform , class PyAlg , class PyCtrl , class PyXform >
void declareAlgorithm (PyAlg &clsAlgorithm, PyCtrl &clsControl, PyXform &clsTransform)
 Wrap the implicit API used by meas_base's algorithm-control-transform triads.
 

Function Documentation

◆ declareAlgorithm() [1/3]

template<class Algorithm , class PyAlg >
void lsst::meas::base::python::declareAlgorithm ( PyAlg & clsAlgorithm)

Wrap the implicit API used by meas_base's algorithms.

This function only initializes constructors, fields, and methods common to all Algorithms.

Template Parameters
AlgorithmThe algorithm class.
PyAlgThe pybind11::class_ class corresponding to Algorithm.
Parameters
[in,out]clsAlgorithmThe pybind11 wrapper for Algorithm.

Definition at line 87 of file python.h.

87 {
88 /* Member types and enums */
89
90 /* Constructors */
91 declareAlgorithmConstructor<Algorithm>(clsAlgorithm);
92
93 /* Operators */
94
95 /* Members */
96 clsAlgorithm.def("fail", &Algorithm::fail, "measRecord"_a, "error"_a = NULL);
97 clsAlgorithm.def("measure", &Algorithm::measure, "record"_a, "exposure"_a);
98}

◆ declareAlgorithm() [2/3]

template<class Algorithm , class Control , class PyAlg , class PyCtrl >
void lsst::meas::base::python::declareAlgorithm ( PyAlg & clsAlgorithm,
PyCtrl & clsControl )

Wrap the implicit API used by meas_base's algorithm-control pairs (no transform).

This function only initializes constructors, fields, and methods common to all Algorithms and Controls.

Template Parameters
AlgorithmThe algorithm class.
ControlThe control class. Must equal Algorithm::Control and Transform::Control.
PyAlgThe pybind11::class_ class corresponding to Algorithm.
PyCtrlThe pybind11::class_ class corresponding to Control.
Parameters
[in,out]clsAlgorithm,clsControlThe pybind11 wrappers for the respective C++ classes.

Definition at line 116 of file python.h.

116 {
117 declareAlgorithm<Algorithm>(clsAlgorithm);
118
119 /* Member types and enums */
120
121 /* Constructors */
122 clsControl.def(py::init<>());
123
124 /* Operators */
125
126 /* Members */
127}

◆ declareAlgorithm() [3/3]

template<class Algorithm , class Control , class Transform , class PyAlg , class PyCtrl , class PyXform >
void lsst::meas::base::python::declareAlgorithm ( PyAlg & clsAlgorithm,
PyCtrl & clsControl,
PyXform & clsTransform )

Wrap the implicit API used by meas_base's algorithm-control-transform triads.

This function only initializes constructors, fields, and methods common to all Algorithms, Controls, and Transforms.

Template Parameters
AlgorithmThe algorithm class.
ControlThe control class. Must equal Algorithm::Control and Transform::Control.
TransformThe transform class.
PyAlgThe pybind11::class_ class corresponding to Algorithm.
PyCtrlThe pybind11::class_ class corresponding to Control.
PyXformThe pybind11::class_ class corresponding to Transform.
Parameters
[in,out]clsAlgorithm,clsControl,clsTransformThe pybind11 wrappers for the respective C++ classes.

Definition at line 148 of file python.h.

148 {
149 declareAlgorithm<Algorithm, Control>(clsAlgorithm, clsControl);
150
151 /* Member types and enums */
152
153 /* Constructors */
154 clsTransform.def(
155 py::init<typename Transform::Control const &, std::string const &, afw::table::SchemaMapper &>(),
156 "ctrl"_a, "name"_a, "mapper"_a);
157
158 /* Operators */
159 clsTransform.def("__call__",
160 [](Transform const &self, afw::table::SourceCatalog const &inputCatalog,
161 afw::table::BaseCatalog &outputCatalog, afw::geom::SkyWcs const &wcs,
162 afw::image::PhotoCalib const &photoCalib) {
163 return self(inputCatalog, outputCatalog, wcs, photoCalib);
164 },
165 "inputCatalog"_a, "outputCatalog"_a, "wcs"_a, "photoCalib"_a);
166
167 /* Members */
168}
A 2-dimensional celestial WCS that transform pixels to ICRS RA/Dec, using the LSST standard for pixel...
Definition SkyWcs.h:117
The photometric calibration of an exposure.
Definition PhotoCalib.h:114

◆ declareAlgorithmConstructor() [1/2]

template<class Algorithm , class PyAlg >
std::enable_if<!std::is_abstract< Algorithm >::value, void >::type lsst::meas::base::python::declareAlgorithmConstructor ( PyAlg & cls)

Wrap the standard algorithm constructor.

Template Parameters
AlgorithmThe algorithm class.
PyAlgThe pybind11::class_ class corresponding to Algorithm.
Parameters
[in,out]clsThe pybind11 wrapper for Algorithm.

Definition at line 55 of file python.h.

56 {
57 cls.def(py::init<typename Algorithm::Control const &, std::string const &, afw::table::Schema &>(),
58 "ctrl"_a, "name"_a, "schema"_a);
59}

◆ declareAlgorithmConstructor() [2/2]

template<class Algorithm , class PyAlg >
std::enable_if< std::is_abstract< Algorithm >::value, void >::type lsst::meas::base::python::declareAlgorithmConstructor ( PyAlg & cls)

Dummy function for not wrapping the constructor of an abstract base class.

Pybind11 cannot wrap such constructors, and there is no reason to call them from Python anyway.

Template Parameters
AlgorithmThe algorithm class.
PyAlgThe pybind11::class_ class corresponding to Algorithm.
Parameters
[in,out]clsThe pybind11 wrapper for Algorithm.

Definition at line 72 of file python.h.

73 {}