LSSTApplications  19.0.0-14-gb0260a2+1b9fb4b99f,20.0.0+14a7f838e9,20.0.0+19029f0d82,20.0.0+4c45e9990f,20.0.0+e2e26847c2,20.0.0+e47e9b3a81,20.0.0-1-g253301a+19029f0d82,20.0.0-1-g2b7511a+46a6078777,20.0.0-1-g3dda6ea+81aab9741f,20.0.0-1-g4d801e7+e868bd9c46,20.0.0-1-g5b95a8c+f88803b0ab,20.0.0-1-gc96f8cb+ec36e0f211,20.0.0-1-gedffbd8+974f4d13e0,20.0.0-10-g0891cd99+0db8181fd1,20.0.0-13-gad96b2d30+614f89f815,20.0.0-17-gcdbda88+9866f06e69,20.0.0-2-g4dae9ad+ec36e0f211,20.0.0-2-g52fdb94+046030bafd,20.0.0-2-g61b8584+85c46248f3,20.0.0-2-g8177d33+5b5417f15c,20.0.0-2-gb780d76+f45b7d88f4,20.0.0-2-gf072044+19029f0d82,20.0.0-22-gdf434b7+ec36e0f211,20.0.0-23-g10eeb28+0064d5905c,20.0.0-24-g5395043+51462c573c,20.0.0-3-g1653f94+85c46248f3,20.0.0-3-g4cc78c6+63636aeed8,20.0.0-3-g750bffe+1f8ba646cd,20.0.0-3-gbd60e8c+ff10c6d78d,20.0.0-33-g078e64d5+00a703b33a,20.0.0-4-g97dc21a+51462c573c,20.0.0-4-gfea843c+f45b7d88f4,20.0.0-5-g357b56b+f45b7d88f4,20.0.0-6-g9a5b7a1+02b9007320,20.0.0-63-g7191b3b+8ae2fb2912,20.0.0-7-gcda7bf1+3dbcc0d021,w.2020.44
LSSTDataManagementBasePackage
python.h
Go to the documentation of this file.
1 /*
2  * This file is part of afw.
3  *
4  * Developed for the LSST Data Management System.
5  * This product includes software developed by the LSST Project
6  * (https://www.lsst.org).
7  * See the COPYRIGHT file at the top-level directory of this distribution
8  * for details of code ownership.
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program. If not, see <https://www.gnu.org/licenses/>.
22  */
23 
24 #ifndef LSST_AFW_DETECTION_PYTHON_H
25 #define LSST_AFW_DETECTION_PYTHON_H
26 
27 #include "pybind11/pybind11.h"
28 #include "lsst/afw/detection/Psf.h"
30 
32 
33 namespace lsst {
34 namespace afw {
35 namespace detection {
36 
49 template <typename Base = Psf>
50 class PsfTrampoline : public StorableHelper<Base> {
51 public:
52  using Image = typename Base::Image;
53 
66  template<typename... Args>
67  PsfTrampoline<Base>(Args... args) : StorableHelper<Base>(args...) {}
68 
69  std::shared_ptr<Psf> clone() const override {
70  /* __deepcopy__ takes an optional dict, but PYBIND11_OVERLOAD_* won't
71  * compile unless you give it arguments that work for the C++ method
72  */
73  PYBIND11_OVERLOAD_PURE_NAME(std::shared_ptr<Psf>, Base, "__deepcopy__", clone,);
74  }
75 
76  std::shared_ptr<Psf> resized(int width, int height) const override {
77  PYBIND11_OVERLOAD_PURE(std::shared_ptr<Psf>, Base, resized, width, height);
78  }
79 
81  PYBIND11_OVERLOAD(lsst::geom::Point2D, Base, getAveragePosition,);
82  }
83 
84  // Private and protected c++ members are overloaded to python using underscores.
86  lsst::geom::Point2D const& position,
87  image::Color const& color
88  ) const override {
89  PYBIND11_OVERLOAD_NAME(
90  std::shared_ptr<Image>, Base, "_doComputeImage", doComputeImage, position, color
91  );
92  }
93 
95  lsst::geom::Point2D const& position,
96  image::Color const& color
97  ) const override {
98  PYBIND11_OVERLOAD_PURE_NAME(
99  std::shared_ptr<Image>, Base, "_doComputeKernelImage", doComputeKernelImage, position, color
100  );
101  }
102 
104  double radius, lsst::geom::Point2D const& position,
105  image::Color const& color
106  ) const override {
107  PYBIND11_OVERLOAD_PURE_NAME(
108  double, Base, "_doComputeApertureFlux", doComputeApertureFlux, radius, position, color
109  );
110  }
111 
113  lsst::geom::Point2D const& position,
114  image::Color const& color
115  ) const override {
116  PYBIND11_OVERLOAD_PURE_NAME(
117  geom::ellipses::Quadrupole, Base, "_doComputeShape", doComputeShape, position, color
118  );
119  }
120 
122  lsst::geom::Point2D const& position,
123  image::Color const& color
124  ) const override {
125  PYBIND11_OVERLOAD_PURE_NAME(
126  lsst::geom::Box2I, Base, "_doComputeBBox", doComputeBBox, position, color
127  );
128  }
129 };
130 
131 } // namespace detection
132 } // namespace afw
133 } // namespace lsst
134 
135 #endif
std::shared_ptr
STL class.
Psf.h
lsst::meas::algorithms.psfSelectionFromMatchList.args
list args
Definition: psfSelectionFromMatchList.py:27
lsst::afw::detection::PsfTrampoline::doComputeShape
geom::ellipses::Quadrupole doComputeShape(lsst::geom::Point2D const &position, image::Color const &color) const override
Definition: python.h:112
lsst::afw::detection::PsfTrampoline::doComputeBBox
lsst::geom::Box2I doComputeBBox(lsst::geom::Point2D const &position, image::Color const &color) const override
Definition: python.h:121
lsst::afw::detection::PsfTrampoline::doComputeKernelImage
std::shared_ptr< Image > doComputeKernelImage(lsst::geom::Point2D const &position, image::Color const &color) const override
Definition: python.h:94
lsst::afw
Definition: imageAlgorithm.dox:1
lsst.pipe.tasks.processCcdWithFakes.radius
radius
Definition: processCcdWithFakes.py:345
python.h
lsst::afw::detection::PsfTrampoline::getAveragePosition
lsst::geom::Point2D getAveragePosition() const override
Definition: python.h:80
lsst::afw::detection::PsfTrampoline< ImagePsf >::Image
typename Base::Image Image
Definition: python.h:52
lsst::afw::detection::PsfTrampoline::doComputeApertureFlux
double doComputeApertureFlux(double radius, lsst::geom::Point2D const &position, image::Color const &color) const override
Definition: python.h:103
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
lsst::afw::detection::PsfTrampoline::clone
std::shared_ptr< Psf > clone() const override
Definition: python.h:69
lsst::afw::geom::ellipses::Quadrupole
An ellipse core with quadrupole moments as parameters.
Definition: Quadrupole.h:47
lsst::geom::Point< double, 2 >
lsst::afw::detection::PsfTrampoline
"Trampoline" for Psf to let it be used as a base class in Python.
Definition: python.h:50
lsst::geom::Box2I
An integer coordinate rectangle.
Definition: Box.h:55
lsst::afw::typehandling::StorableHelper
"Trampoline" for Storable to let it be used as a base class in Python.
Definition: python.h:50
lsst::afw::detection::PsfTrampoline::doComputeImage
std::shared_ptr< Image > doComputeImage(lsst::geom::Point2D const &position, image::Color const &color) const override
Definition: python.h:85
lsst::afw::image::Color
Describe the colour of a source.
Definition: Color.h:26
lsst::afw::detection::PsfTrampoline::resized
std::shared_ptr< Psf > resized(int width, int height) const override
Definition: python.h:76