LSSTApplications  20.0.0
LSSTDataManagementBasePackage
transmissionCurve.cc
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  * Copyright 2008-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 <memory>
27 
28 #include "ndarray/pybind11.h"
29 
33 
34 namespace py = pybind11;
35 using namespace pybind11::literals;
36 
37 namespace lsst {
38 namespace afw {
39 namespace image {
40 namespace {
41 
42 using PyTransmissionCurve =
43  py::class_<TransmissionCurve, std::shared_ptr<TransmissionCurve>, typehandling::Storable>;
44 
45 PyTransmissionCurve declare(py::module & mod) {
46  return PyTransmissionCurve(mod, "TransmissionCurve");
47 }
48 
49 void define(PyTransmissionCurve & cls) {
51 
52  cls.def_static("makeIdentity", &TransmissionCurve::makeIdentity);
53  cls.def_static("makeSpatiallyConstant", &TransmissionCurve::makeSpatiallyConstant,
54  "throughput"_a, "wavelengths"_a,
55  "throughputAtMin"_a=0.0, "throughputAtMax"_a=0.0);
56  cls.def_static("makeRadial", &TransmissionCurve::makeRadial,
57  "throughput"_a, "wavelengths"_a, "radii"_a,
58  "throughputAtMin"_a=0.0, "throughputAtMax"_a=0.0);
59  cls.def("__mul__", &TransmissionCurve::multipliedBy, py::is_operator());
60  cls.def("multipliedBy", &TransmissionCurve::multipliedBy);
61  cls.def("transformedBy", &TransmissionCurve::transformedBy, "transform"_a);
62  cls.def("getWavelengthBounds", &TransmissionCurve::getWavelengthBounds);
63  cls.def("getThroughputAtBounds", &TransmissionCurve::getThroughputAtBounds);
64  cls.def(
65  "sampleAt",
66  (void (TransmissionCurve::*)(
67  lsst::geom::Point2D const &,
68  ndarray::Array<double const,1,1> const &,
69  ndarray::Array<double,1,1> const &
70  ) const) &TransmissionCurve::sampleAt,
71  "position"_a, "wavelengths"_a, "out"_a
72  );
73  cls.def(
74  "sampleAt",
75  (ndarray::Array<double,1,1> (TransmissionCurve::*)(
76  lsst::geom::Point2D const &,
77  ndarray::Array<double const,1,1> const &
78  ) const) &TransmissionCurve::sampleAt,
79  "position"_a, "wavelengths"_a
80  );
81 }
82 
84  // import inheritance dependencies
85  py::module::import("lsst.afw.typehandling");
86  // then declare classes
87  auto cls = declare(mod);
88  // then import dependencies used in method signatures
89  py::module::import("lsst.afw.geom");
90  // and now we can safely define methods and other attributes
91  define(cls);
92 }
93 
94 }}}} // namespace lsst::afw::image::<anonymous>
95 
lsst::afw::image
Backwards-compatibility support for depersisting the old Calib (FluxMag0/FluxMag0Err) objects.
Definition: imageAlgorithm.dox:1
TransmissionCurve.h
lsst::afw::table::io::python::addPersistableMethods
void addPersistableMethods(pybind11::class_< Class, Args... > &cls)
Add table::io::Persistable and PersistableFacade methods to the pybind11 wrapper for a class.
Definition: python.h:90
transmissionCurve
Key< int > transmissionCurve
Definition: Exposure.cc:71
lsst::afw
Definition: imageAlgorithm.dox:1
lsst::afw::geom.transform.transformContinued.cls
cls
Definition: transformContinued.py:33
Storable.h
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
python.h
lsst::geom::Point< double, 2 >
pybind11
Definition: _GenericMap.cc:40
lsst::pex::exceptions.wrappers.declare
def declare(module, exception_name, base, wrapped_class)
Definition: wrappers.py:153
lsst::meas::modelfit.psf.psfContinued.module
module
Definition: psfContinued.py:42
lsst::afw::cameraGeom::PYBIND11_MODULE
PYBIND11_MODULE(camera, mod)
Definition: camera.cc:133