Loading [MathJax]/extensions/tex2jax.js
LSST Applications g04a91732dc+a777afbe81,g07dc498a13+7e3c5f68a2,g12483e3c20+0145ec33cd,g1409bbee79+7e3c5f68a2,g1a7e361dbc+7e3c5f68a2,g1fd858c14a+9f35e23ec3,g35bb328faa+fcb1d3bbc8,g3ad4f90e5c+0145ec33cd,g3bd4b5ce2c+cbf1bea503,g4e0f332c67+5d362be553,g53246c7159+fcb1d3bbc8,g5477a8d5ce+db04660fe6,g60b5630c4e+0145ec33cd,g623d845a50+0145ec33cd,g6f0c2978f1+3526b51a37,g75b6c65c88+d54b601591,g78460c75b0+2f9a1b4bcd,g786e29fd12+cf7ec2a62a,g7b71ed6315+fcb1d3bbc8,g8852436030+4639f750a5,g89139ef638+7e3c5f68a2,g9125e01d80+fcb1d3bbc8,g919ac25b3e+6220c5324a,g95236ca021+f7a31438ed,g989de1cb63+7e3c5f68a2,g9f33ca652e+2d6fa11d35,gaaedd4e678+7e3c5f68a2,gabe3b4be73+1e0a283bba,gb1101e3267+4a428ef779,gb4a253aaf5+0122250889,gb58c049af0+f03b321e39,gc99c83e5f0+76d20ab76d,gcf25f946ba+4639f750a5,gd6cbbdb0b4+c8606af20c,gde0f65d7ad+3d8a3b7e46,ge278dab8ac+932305ba37,gf795337580+03b96afe58,gfba249425e+fcb1d3bbc8,w.2025.08
LSST Data Management Base Package
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
lsst::afw::coord Namespace Reference

Namespaces

namespace  _refraction
 

Classes

class  Observatory
 Hold the location of an observatory. More...
 
class  Weather
 Basic weather information sufficient for a simple model for air mass or refraction. More...
 
class  WrapperCollection
 A helper class for subdividing pybind11 module across multiple translation units (i.e. More...
 

Functions

std::ostreamoperator<< (std::ostream &os, Observatory const &obs)
 Print an Observatory to the stream.
 
std::ostreamoperator<< (std::ostream &os, Weather const &weath)
 print a Weather to an output stream
 
void wrapObservatory (WrapperCollection &)
 
void wrapWeather (WrapperCollection &)
 
 PYBIND11_MODULE (_coord, mod)
 

Function Documentation

◆ operator<<() [1/2]

std::ostream & lsst::afw::coord::operator<< ( std::ostream & os,
Observatory const & obs )

Print an Observatory to the stream.

Parameters
[in,out]osStream to print to
[in]obsthe Observatory to print

Definition at line 67 of file Observatory.cc.

67 {
68 os << obs.toString();
69 return os;
70}

◆ operator<<() [2/2]

std::ostream & lsst::afw::coord::operator<< ( std::ostream & os,
Weather const & weath )

print a Weather to an output stream

Definition at line 65 of file Weather.cc.

65 {
66 return os << "Weather(" << weath.getAirTemperature() << ", " << weath.getAirPressure() << ", "
67 << weath.getHumidity() << ")";
68}

◆ PYBIND11_MODULE()

lsst::afw::coord::PYBIND11_MODULE ( _coord ,
mod  )

Definition at line 39 of file _coord.cc.

39 {
40 WrapperCollection wrappers(mod, "lsst.afw.coord");
41 wrapObservatory(wrappers);
42 wrapWeather(wrappers);
43 wrappers.finish();
44}
A helper class for subdividing pybind11 module across multiple translation units (i....
Definition python.h:242
void wrapObservatory(WrapperCollection &)
void wrapWeather(WrapperCollection &)
Definition _weather.cc:39

◆ wrapObservatory()

void lsst::afw::coord::wrapObservatory ( WrapperCollection & wrappers)

Definition at line 36 of file _observatory.cc.

36 {
37 wrappers.wrapType(
38 py::class_<Observatory, std::shared_ptr<Observatory>>(wrappers.module, "Observatory"),
39 [](auto& mod, auto& cls) {
40 /* Constructors */
41 cls.def(py::init<lsst::geom::Angle const, lsst::geom::Angle const, double const>());
42
43 /* Operators */
44 cls.def(
45 "__eq__",
46 [](Observatory const& self, Observatory const& other) { return self == other; },
47 py::is_operator());
48 cls.def(
49 "__ne__",
50 [](Observatory const& self, Observatory const& other) { return self != other; },
51 py::is_operator());
52 cls.def("__str__", &Observatory::toString);
53 cls.def("__repr__", &Observatory::toString);
54
55 /* Members */
56 cls.def("getLongitude", &Observatory::getLongitude);
57 cls.def("getLatitude", &Observatory::getLatitude);
58 cls.def("getElevation", &Observatory::getElevation);
59 cls.def("setLongitude", &Observatory::setLongitude, "longitude"_a);
60 cls.def("setLatitude", &Observatory::setLatitude, "latitude"_a);
61 cls.def("setElevation", &Observatory::setElevation, "elevation"_a);
62 });
63}
Hold the location of an observatory.
Definition Observatory.h:43
void setLatitude(lsst::geom::Angle const latitude)
set telescope latitude (positive values are E of Greenwich)
std::string toString() const
get string representation
double getElevation() const noexcept
get telescope elevation (meters above reference spheroid)
Definition Observatory.h:82
void setElevation(double const elevation)
set telescope elevation (meters above reference spheroid)
void setLongitude(lsst::geom::Angle const longitude)
set telescope longitude
lsst::geom::Angle getLatitude() const noexcept
get telescope latitude
lsst::geom::Angle getLongitude() const noexcept
get telescope longitude (positive values are E of Greenwich)
PyType wrapType(PyType cls, ClassWrapperCallback function, bool setModuleName=true)
Add a type (class or enum) wrapper, deferring method and other attribute definitions until finish() i...
Definition python.h:391
pybind11::module module
The module object passed to the PYBIND11_MODULE block that contains this WrapperCollection.
Definition python.h:448

◆ wrapWeather()

void lsst::afw::coord::wrapWeather ( WrapperCollection & wrappers)

Definition at line 39 of file _weather.cc.

39 {
40 wrappers.wrapType(py::class_<lsst::afw::coord::Weather>(wrappers.module, "Weather"), [](auto &mod,
41 auto &cls) {
42 /* Constructors */
43 cls.def(py::init<double, double, double>(), "airTemperature"_a, "airPressure"_a, "humidity"_a);
44 cls.def(py::init<Weather const &>(), "weather"_a);
45
46 /* Operators */
47 cls.def(
48 "__eq__", [](Weather const &self, Weather const &other) { return self == other; },
49 py::is_operator());
50 cls.def(
51 "__ne__", [](Weather const &self, Weather const &other) { return self != other; },
52 py::is_operator());
53
54 /* Members */
55 cls.def("getAirPressure", &lsst::afw::coord::Weather::getAirPressure);
56 cls.def("getAirTemperature", &lsst::afw::coord::Weather::getAirTemperature);
57 cls.def("getHumidity", &lsst::afw::coord::Weather::getHumidity);
58 cpputils::python::addOutputOp(cls, "__str__");
59 cpputils::python::addOutputOp(cls, "__repr__");
60 });
61}
Basic weather information sufficient for a simple model for air mass or refraction.
Definition Weather.h:38
double getHumidity() const noexcept
get outside relative humidity (%)
Definition Weather.h:70
double getAirPressure() const noexcept
get outside air pressure (Pascal)
Definition Weather.h:67
double getAirTemperature() const noexcept
get outside air temperature (C)
Definition Weather.h:64
void addOutputOp(PyClass &cls, std::string const &method)
Add __str__ or __repr__ method implemented by operator<<.
Definition python.h:87