LSSTApplications  20.0.0
LSSTDataManagementBasePackage
kernelSumVisitor.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 <memory>
25 #include <string>
26 
30 
31 namespace py = pybind11;
32 using namespace pybind11::literals;
33 
34 namespace lsst {
35 namespace ip {
36 namespace diffim {
37 namespace detail {
38 
39 namespace {
40 
48 template <typename PixelT>
49 void declareKernelSumVisitor(py::module& mod, std::string const& suffix) {
50  using Class = KernelSumVisitor<PixelT>;
51 
52  py::class_<Class, std::shared_ptr<Class>, afw::math::CandidateVisitor> cls(
53  mod, ("KernelSumVisitor" + suffix).c_str());
54 
55  py::enum_<typename Class::Mode>(cls, "Mode")
56  .value("AGGREGATE", Class::Mode::AGGREGATE)
57  .value("REJECT", Class::Mode::REJECT)
58  .export_values();
59 
60  cls.def(py::init<daf::base::PropertySet const&>(), "ps"_a);
61 
62  cls.def("setMode", &Class::setMode, "mode"_a);
63  cls.def("getNRejected", &Class::getNRejected);
64  cls.def("getkSumMean", &Class::getkSumMean);
65  cls.def("getkSumStd", &Class::getkSumStd);
66  cls.def("getdkSumMax", &Class::getdkSumMax);
67  cls.def("getkSumNpts", &Class::getkSumNpts);
68  cls.def("resetKernelSum", &Class::resetKernelSum);
69  cls.def("processCandidate", &Class::processCandidate, "candidate"_a);
70  cls.def("processKsumDistribution", &Class::processKsumDistribution);
71 
72  mod.def("makeKernelSumVisitor", &makeKernelSumVisitor<PixelT>, "ps"_a);
73 }
74 
75 } // namespace lsst::ip::diffim::detail::<anonymous>
76 
77 PYBIND11_MODULE(kernelSumVisitor, mod) {
78  py::module::import("lsst.afw.math");
79  py::module::import("lsst.daf.base");
80 
81  declareKernelSumVisitor<float>(mod, "F");
82 }
83 
84 } // detail
85 } // diffim
86 } // ip
87 } // lsst
std::string
STL class.
lsst::ip::diffim::detail::makeKernelSumVisitor< PixelT >
template std::shared_ptr< KernelSumVisitor< PixelT > > makeKernelSumVisitor< PixelT >(lsst::daf::base::PropertySet const &)
lsst::afw::geom.transform.transformContinued.cls
cls
Definition: transformContinued.py:33
KernelSumVisitor.h
Declaration of KernelSumVisitor.
SpatialCell.h
PropertySet.h
lsst::ip::diffim::detail::PYBIND11_MODULE
PYBIND11_MODULE(kernelSumVisitor, mod)
Definition: kernelSumVisitor.cc:77
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
pybind11
Definition: _GenericMap.cc:40
lsst::meas::modelfit.psf.psfContinued.module
module
Definition: psfContinued.py:42