LSSTApplications  18.1.0
LSSTDataManagementBasePackage
skyFrame.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 <memory>
23 #include <vector>
24 
25 #include <pybind11/pybind11.h>
26 #include <pybind11/stl.h>
27 
28 #include "astshim/Frame.h"
29 #include "astshim/Mapping.h"
30 #include "astshim/SkyFrame.h"
31 
32 namespace py = pybind11;
33 using namespace pybind11::literals;
34 
35 namespace ast {
36 namespace {
37 
39  py::module::import("astshim.frame");
40 
41  py::class_<SkyFrame, std::shared_ptr<SkyFrame>, Frame> cls(mod, "SkyFrame");
42 
43  cls.def(py::init<std::string const &>(), "options"_a = "");
44  cls.def(py::init<SkyFrame const &>());
45 
46  cls.def("copy", &SkyFrame::copy);
47 
48  cls.def_property("alignOffset", &SkyFrame::getAlignOffset, &SkyFrame::setAlignOffset);
49  cls.def_property("asTime", [](SkyFrame const &self) {
50  return std::make_pair(self.getAsTime(1), self.getAsTime(2));
51  },
52  [](SkyFrame &self, std::pair<bool, bool> asTime) {
53  self.setAsTime(1, asTime.first);
54  self.setAsTime(2, asTime.second);
55  });
56  cls.def_property("alignOffset", &SkyFrame::getAlignOffset, &SkyFrame::setAlignOffset);
57  cls.def_property("equinox", &SkyFrame::getEquinox, &SkyFrame::setEquinox);
58  cls.def_property_readonly("latAxis", &SkyFrame::getLatAxis);
59  cls.def_property_readonly("lonAxis", &SkyFrame::getLonAxis);
60  cls.def_property("negLon", &SkyFrame::getNegLon, &SkyFrame::setNegLon);
61  cls.def_property("projection", &SkyFrame::getProjection, &SkyFrame::setProjection);
62  cls.def_property("skyRefIs", &SkyFrame::getSkyRefIs, &SkyFrame::setSkyRefIs);
63  cls.def_property("skyTol", &SkyFrame::getSkyTol, &SkyFrame::setSkyTol);
64 
65  cls.def("getAsTime", &SkyFrame::getAsTime, "axis"_a);
66  cls.def("getIsLatAxis", &SkyFrame::getIsLatAxis, "axis"_a);
67  cls.def("getIsLonAxis", &SkyFrame::getIsLonAxis, "axis"_a);
68  cls.def("getSkyRef", &SkyFrame::getSkyRef);
69  cls.def("getSkyRefP", &SkyFrame::getSkyRefP);
70  cls.def("setAsTime", &SkyFrame::setAsTime, "axis"_a, "asTime"_a);
71  cls.def("setEquinox", &SkyFrame::setEquinox);
72  cls.def("setNegLon", &SkyFrame::setNegLon);
73  cls.def("setProjection", &SkyFrame::setProjection);
74  cls.def("setSkyRef", &SkyFrame::setSkyRef);
75  cls.def("setSkyRefP", &SkyFrame::setSkyRefP);
76  cls.def("skyOffsetMap", &SkyFrame::skyOffsetMap);
77 }
78 
79 } // namespace
80 } // namespace ast
AST wrapper classes and functions.
PYBIND11_MODULE(camera, mod)
Definition: camera.cc:34
T make_pair(T... args)