LSSTApplications  20.0.0
LSSTDataManagementBasePackage
transformBoundedField.cc
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  * Copyright 2017 AURA/LSST.
4  *
5  * This product includes software developed by the
6  * LSST Project (http://www.lsst.org/).
7  *
8  * This program is free software: you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation, either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the LSST License Statement and
19  * the GNU General Public License along with this program. If not,
20  * see <https://www.lsstcorp.org/LegalNotices/>.
21  */
22 
23 #include <pybind11/pybind11.h>
24 #include <pybind11/stl.h>
25 
26 #include "ndarray/pybind11.h"
27 
28 #include "lsst/pex/config/python.h" // defines LSST_DECLARE_CONTROL_FIELD
29 #include "lsst/afw/table/io/python.h" // for addPersistableMethods
30 
33 
34 namespace py = pybind11;
35 using namespace py::literals;
36 
37 namespace lsst {
38 namespace afw {
39 namespace math {
40 namespace {
41 
42 using ClsField = py::class_<TransformBoundedField, std::shared_ptr<TransformBoundedField>, BoundedField>;
43 
44 PYBIND11_MODULE(transformBoundedField, mod) {
45  /* Module level */
46  ClsField cls(mod, "TransformBoundedField");
47 
48  cls.def(py::init<lsst::geom::Box2I const &, TransformBoundedField::Transform const &>(), "bbox"_a,
49  "transform"_a);
50 
51  table::io::python::addPersistableMethods<TransformBoundedField>(cls);
52 
53  cls.def("__mul__", &TransformBoundedField::operator*, py::is_operator());
54  cls.def("__eq__", &TransformBoundedField::operator==, py::is_operator());
55 
56  cls.def("getTransform", &TransformBoundedField::getTransform);
57  cls.def("evaluate", (double (BoundedField::*)(double, double) const) & BoundedField::evaluate);
58  cls.def("evaluate",
59  (ndarray::Array<double, 1, 1>(TransformBoundedField::*)(
60  ndarray::Array<double const, 1> const &, ndarray::Array<double const, 1> const &) const) &
61  TransformBoundedField::evaluate);
62  cls.def("evaluate", (double (TransformBoundedField::*)(lsst::geom::Point2D const &) const) &
63  TransformBoundedField::evaluate);
64 }
65 
66 } // namespace
67 } // namespace math
68 } // namespace afw
69 } // namespace lsst
TransformBoundedField.h
lsst::afw
Definition: imageAlgorithm.dox:1
lsst::afw::geom.transform.transformContinued.cls
cls
Definition: transformContinued.py:33
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
python.h
python.h
ClsField
py::class_< ChebyshevBoundedField, std::shared_ptr< ChebyshevBoundedField >, BoundedField > ClsField
Definition: chebyshevBoundedField.cc:41
lsst::geom::Point< double, 2 >
pybind11
Definition: _GenericMap.cc:40
BoundedField.h
lsst::afw::cameraGeom::PYBIND11_MODULE
PYBIND11_MODULE(camera, mod)
Definition: camera.cc:133