LSSTApplications  20.0.0
LSSTDataManagementBasePackage
_wcsUtils.cc
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 #include <memory>
25 #include <vector>
26 
27 #include "pybind11/pybind11.h"
28 #include "pybind11/stl.h"
29 
30 #include "lsst/utils/python.h"
31 
32 #include "lsst/afw/table/fwd.h"
33 #include "lsst/afw/table/Simple.h"
34 #include "lsst/afw/table/Source.h"
36 
37 namespace py = pybind11;
38 using namespace pybind11::literals;
39 
40 namespace lsst {
41 namespace afw {
42 namespace table {
43 
44 using utils::python::WrapperCollection;
45 
46 namespace {
47 
48 template <typename ReferenceCollection>
49 void declareUpdateRefCentroids(WrapperCollection &wrappers) {
50  wrappers.wrap([](auto &mod) {
51  mod.def("updateRefCentroids", updateRefCentroids<ReferenceCollection>, "wcs"_a, "refList"_a);
52  });
53 }
54 
55 template <typename SourceCollection>
56 void declareUpdateSourceCoords(WrapperCollection &wrappers) {
57  wrappers.wrap([](auto &mod) {
58  mod.def("updateSourceCoords", updateSourceCoords<SourceCollection>, "wcs"_a, "sourceList"_a);
59  });
60 }
61 
62 } // namespace
63 
65  declareUpdateRefCentroids<std::vector<std::shared_ptr<lsst::afw::table::SimpleRecord>>>(wrappers);
66  declareUpdateRefCentroids<lsst::afw::table::SimpleCatalog>(wrappers);
67 
68  declareUpdateSourceCoords<std::vector<std::shared_ptr<lsst::afw::table::SourceRecord>>>(wrappers);
69  declareUpdateSourceCoords<lsst::afw::table::SourceCatalog>(wrappers);
70 }
71 
72 } // namespace table
73 } // namespace afw
74 } // namespace lsst
Simple.h
lsst::afw
Definition: imageAlgorithm.dox:1
fwd.h
wcsUtils.h
lsst::utils::python::WrapperCollection
A helper class for subdividing pybind11 module across multiple translation units (i....
Definition: python.h:242
Source.h
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
python.h
pybind11
Definition: _GenericMap.cc:40
lsst::afw::table::wrapWcsUtils
void wrapWcsUtils(WrapperCollection &)
Definition: _wcsUtils.cc:64