lsst.meas.algorithms  13.0-20-g02a2147
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
coaddPsf.cc
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  *
4  * This product includes software developed by the
5  * LSST Project (http://www.lsst.org/).
6  * See the COPYRIGHT file
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 #include "pybind11/pybind11.h"
23 
24 #include "lsst/afw/table/io/python.h"
26 #include "lsst/pex/config/python.h" // for LSST_DECLARE_CONTROL_FIELD
27 
28 namespace py = pybind11;
29 using namespace pybind11::literals;
30 
31 namespace lsst {
32 namespace meas {
33 namespace algorithms {
34 
35 PYBIND11_PLUGIN(coaddPsf) {
36  py::module mod("coaddPsf");
37 
38  /* CoaddPsfControl */
39  py::class_<CoaddPsfControl, std::shared_ptr<CoaddPsfControl>> clsControl(mod, "CoaddPsfControl");
40  clsControl.def(py::init<std::string, int>(), "warpingKernelName"_a="lanczos3", "cacheSize"_a=10000);
41  LSST_DECLARE_CONTROL_FIELD(clsControl, CoaddPsfControl, warpingKernelName);
42  LSST_DECLARE_CONTROL_FIELD(clsControl, CoaddPsfControl, cacheSize);
43 
44  /* CoaddPsf */
45  afw::table::io::python::declarePersistableFacade<CoaddPsf>(mod, "CoaddPsf");
46 
47  py::class_<CoaddPsf, std::shared_ptr<CoaddPsf>, afw::table::io::PersistableFacade<CoaddPsf>, ImagePsf>
48  clsCoaddPsf(mod, "CoaddPsf");
49 
50  /* Constructors */
51  clsCoaddPsf.def(py::init<afw::table::ExposureCatalog const &, afw::image::Wcs const &,
52  std::string const &, std::string const &, int>(),
53  "catalog"_a, "coaddWcs"_a, "weightFieldName"_a = "weight",
54  "warpingKernelName"_a = "lanczos3", "cacheSize"_a = 10000);
55  clsCoaddPsf.def(py::init<afw::table::ExposureCatalog const &, afw::image::Wcs const &,
56  CoaddPsfControl const &, std::string const &>(),
57  "catalog"_a, "coaddWcs"_a, "ctrl"_a, "weightFieldName"_a = "weight");
58 
59  /* Members */
60  clsCoaddPsf.def("clone", &CoaddPsf::clone);
61  clsCoaddPsf.def("getAveragePosition", &CoaddPsf::getAveragePosition);
62  clsCoaddPsf.def("getCoaddWcs", &CoaddPsf::getCoaddWcs);
63  clsCoaddPsf.def("getComponentCount", &CoaddPsf::getComponentCount);
64  clsCoaddPsf.def("getPsf", &CoaddPsf::getPsf);
65  clsCoaddPsf.def("getWcs", &CoaddPsf::getWcs);
66  clsCoaddPsf.def("getWeight", &CoaddPsf::getWeight);
67  clsCoaddPsf.def("getId", &CoaddPsf::getId);
68  clsCoaddPsf.def("getBBox", &CoaddPsf::getBBox);
69  clsCoaddPsf.def("getValidPolygon", &CoaddPsf::getValidPolygon);
70  clsCoaddPsf.def("isPersistable", &CoaddPsf::isPersistable);
71 
72  return mod.ptr();
73 }
74 
75 } // algorithms
76 } // meas
77 } // lsst
tbl::Key< int > cacheSize
Definition: CoaddPsf.cc:355
PYBIND11_PLUGIN(binnedWcs)
Definition: binnedWcs.cc:33
tbl::Key< std::string > warpingKernelName
Definition: CoaddPsf.cc:357
An intermediate base class for Psfs that use an image representation.
Definition: ImagePsf.h:37