LSSTApplications  20.0.0
LSSTDataManagementBasePackage
kernelCandidateDetection.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 #include "pybind11/stl.h"
24 
25 #include <memory>
26 #include <string>
27 
29 
30 namespace py = pybind11;
31 using namespace pybind11::literals;
32 
33 namespace lsst {
34 namespace ip {
35 namespace diffim {
36 
37 namespace {
38 
46 template <typename PixelT>
47 void declareKernelCandidateDetection(py::module &mod, std::string const &suffix) {
48  py::class_<KernelCandidateDetection<PixelT>, std::shared_ptr<KernelCandidateDetection<PixelT>>> cls(
49  mod, ("KernelCandidateDetection" + suffix).c_str());
50 
51  cls.def(py::init<daf::base::PropertySet const &>(), "ps"_a);
52 
53  cls.def("apply", &KernelCandidateDetection<PixelT>::apply, "templateMaskedImage"_a,
54  "scienceMaskedImage"_a);
55  cls.def("growCandidate", &KernelCandidateDetection<PixelT>::growCandidate, "footprint"_a, "fpGrowPix"_a,
56  "templateMaskedImage"_a, "scienceMaskedImage"_a);
57  cls.def("getFootprints", &KernelCandidateDetection<PixelT>::getFootprints);
58 }
59 
60 } // namespace lsst::ip::diffim::<anonymous>
61 
62 PYBIND11_MODULE(kernelCandidateDetection, mod) {
63  py::module::import("lsst.afw.image");
64  py::module::import("lsst.afw.detection");
65  py::module::import("lsst.daf.base");
66 
67  declareKernelCandidateDetection<float>(mod, "F");
68 }
69 
70 } // diffim
71 } // ip
72 } // lsst
std::string
STL class.
std::shared_ptr
STL class.
KernelCandidateDetection.h
Detect candidates for kernels within 2 images.
lsst::afw::geom.transform.transformContinued.cls
cls
Definition: transformContinued.py:33
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
lsst::ip::diffim::PYBIND11_MODULE
PYBIND11_MODULE(kernelCandidateDetection, mod)
Definition: kernelCandidateDetection.cc:62
pybind11
Definition: _GenericMap.cc:40
lsst::meas::modelfit.psf.psfContinued.module
module
Definition: psfContinued.py:42