LSST Applications g0f08755f38+82efc23009,g12f32b3c4e+e7bdf1200e,g1653933729+a8ce1bb630,g1a0ca8cf93+50eff2b06f,g28da252d5a+52db39f6a5,g2bbee38e9b+37c5a29d61,g2bc492864f+37c5a29d61,g2cdde0e794+c05ff076ad,g3156d2b45e+41e33cbcdc,g347aa1857d+37c5a29d61,g35bb328faa+a8ce1bb630,g3a166c0a6a+37c5a29d61,g3e281a1b8c+fb992f5633,g414038480c+7f03dfc1b0,g41af890bb2+11b950c980,g5fbc88fb19+17cd334064,g6b1c1869cb+12dd639c9a,g781aacb6e4+a8ce1bb630,g80478fca09+72e9651da0,g82479be7b0+04c31367b4,g858d7b2824+82efc23009,g9125e01d80+a8ce1bb630,g9726552aa6+8047e3811d,ga5288a1d22+e532dc0a0b,gae0086650b+a8ce1bb630,gb58c049af0+d64f4d3760,gc28159a63d+37c5a29d61,gcf0d15dbbd+2acd6d4d48,gd7358e8bfb+778a810b6e,gda3e153d99+82efc23009,gda6a2b7d83+2acd6d4d48,gdaeeff99f8+1711a396fd,ge2409df99d+6b12de1076,ge79ae78c31+37c5a29d61,gf0baf85859+d0a5978c5a,gf3967379c6+4954f8c433,gfb92a5be7c+82efc23009,gfec2e1e490+2aaed99252,w.2024.46
LSST Data Management Base Package
Loading...
Searching...
No Matches
_sphgeom.cc
Go to the documentation of this file.
1/*
2 * This file is part of sphgeom.
3 *
4 * Developed for the LSST Data Management System.
5 * This product includes software developed by the LSST Project
6 * (http://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 software is dual licensed under the GNU General Public License and also
11 * under a 3-clause BSD license. Recipients may choose which of these licenses
12 * to use; please see the files gpl-3.0.txt and/or bsd_license.txt,
13 * respectively. If you choose the GPL option then the following text applies
14 * (but note that there is still no warranty even if you opt for BSD instead):
15 *
16 * This program is free software: you can redistribute it and/or modify
17 * it under the terms of the GNU General Public License as published by
18 * the Free Software Foundation, either version 3 of the License, or
19 * (at your option) any later version.
20 *
21 * This program is distributed in the hope that it will be useful,
22 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
24 * GNU General Public License for more details.
25 *
26 * You should have received a copy of the GNU General Public License
27 * along with this program. If not, see <http://www.gnu.org/licenses/>.
28 */
29#include "pybind11/pybind11.h"
30
31#include "lsst/sphgeom/python.h"
32
33#include "lsst/sphgeom/Angle.h"
35#include "lsst/sphgeom/Box.h"
36#include "lsst/sphgeom/Box3d.h"
38#include "lsst/sphgeom/Circle.h"
44#include "lsst/sphgeom/LonLat.h"
52#include "lsst/sphgeom/Region.h"
55
56namespace py = pybind11;
57
58namespace lsst {
59namespace sphgeom {
60
61void defineCurve(py::module&);
62void defineOrientation(py::module&);
63void defineRelationship(py::module&);
64void defineUtils(py::module&);
65
66namespace {
67
68PYBIND11_MODULE(_sphgeom, mod) {
69 // Create all Python class instances up front, then define them.
70 //
71 // This results in docstrings containing only Python type names, even
72 // when there are circular dependencies in C++.
73
74 py::class_<Angle> angle(mod, "Angle");
75 py::class_<NormalizedAngle> normalizedAngle(mod, "NormalizedAngle");
76 py::class_<LonLat, std::shared_ptr<LonLat>> lonLat(mod, "LonLat");
77 py::class_<Vector3d, std::shared_ptr<Vector3d>> vector3d(mod, "Vector3d");
78 py::class_<UnitVector3d, std::shared_ptr<UnitVector3d>> unitVector3d(
79 mod, "UnitVector3d");
80 py::class_<Matrix3d, std::shared_ptr<Matrix3d>> matrix3d(mod, "Matrix3d");
81
82 py::class_<AngleInterval, std::shared_ptr<AngleInterval>> angleInterval(
83 mod, "AngleInterval");
84 py::class_<NormalizedAngleInterval,
86 normalizedAngleInterval(mod, "NormalizedAngleInterval");
87 py::class_<Interval1d, std::shared_ptr<Interval1d>> interval1d(
88 mod, "Interval1d");
89
90 py::class_<Box3d, std::shared_ptr<Box3d>> box3d(mod, "Box3d");
91
92 py::class_<Region, std::unique_ptr<Region>> region(mod, "Region");
93 py::class_<Box, std::unique_ptr<Box>, Region> box(mod, "Box");
94 py::class_<Circle, std::unique_ptr<Circle>, Region> circle(mod, "Circle");
95 py::class_<ConvexPolygon, std::unique_ptr<ConvexPolygon>, Region>
96 convexPolygon(mod, "ConvexPolygon");
97 py::class_<Ellipse, std::unique_ptr<Ellipse>, Region> ellipse(mod,
98 "Ellipse");
99 py::class_<CompoundRegion, std::unique_ptr<CompoundRegion>, Region> compoundRegion(mod, "CompoundRegion");
100 py::class_<UnionRegion, std::unique_ptr<UnionRegion>, CompoundRegion> unionRegion(mod, "UnionRegion");
101 py::class_<IntersectionRegion, std::unique_ptr<IntersectionRegion>, CompoundRegion>
102 intersectionRegion(mod, "IntersectionRegion");
103
104 py::class_<RangeSet, std::shared_ptr<RangeSet>> rangeSet(mod, "RangeSet");
105
106 py::class_<Pixelization> pixelization(mod, "Pixelization");
107 py::class_<HtmPixelization, Pixelization> htmPixelization(
108 mod, "HtmPixelization");
109 py::class_<Mq3cPixelization, Pixelization> mq3cPixelization(
110 mod, "Mq3cPixelization");
111 py::class_<Q3cPixelization, Pixelization> q3cPixelization(
112 mod, "Q3cPixelization");
113
114 py::class_<Chunker, std::shared_ptr<Chunker>> chunker(mod, "Chunker");
115
117 defineClass(normalizedAngle);
118 defineClass(lonLat);
119 defineClass(vector3d);
120 defineClass(unitVector3d);
121 defineClass(matrix3d);
122
123 defineClass(angleInterval);
124 defineClass(normalizedAngleInterval);
125 defineClass(interval1d);
126
127 defineClass(box3d);
128
129 defineClass(region);
130 defineClass(box);
131 defineClass(circle);
132 defineClass(convexPolygon);
133 defineClass(ellipse);
134 defineClass(compoundRegion);
135 defineClass(unionRegion);
136 defineClass(intersectionRegion);
137
138 defineClass(rangeSet);
139
140 defineClass(pixelization);
141 defineClass(htmPixelization);
142 defineClass(mq3cPixelization);
143 defineClass(q3cPixelization);
144
145 defineClass(chunker);
146
147 // Define C++ functions.
148
149 defineCurve(mod);
152 defineUtils(mod);
153}
154
155} // <anonymous>
156} // sphgeom
157} // lsst
This file defines a class for representing angle intervals.
This file declares a class for representing axis-aligned bounding boxes in ℝ³.
This file declares a class for partitioning the sky into chunks and sub-chunks.
This file declares a class for representing circular regions on the unit sphere.
This file declares classes for representing compound regions on the unit sphere.
This file declares a class for representing convex polygons with great circle edges on the unit spher...
table::Key< double > angle
This file declares a Pixelization subclass for the HTM indexing scheme.
This file defines a class for representing intervals of ℝ.
This file contains a class representing spherical coordinates.
This file contains a class representing 3x3 real matrices.
This file declares a Pixelization subclass for the modified Q3C indexing scheme.
This file declares a class for representing normalized angles.
This file declares a class representing closed intervals of normalized angles, i.e.
This file defines an interface for pixelizations of the sphere.
This file declares a Pixelization subclass for the Q3C indexing scheme.
This file provides a type for representing integer sets.
This file defines an interface for spherical regions.
This file declares a class for representing unit vectors in ℝ³.
This file declares a class for representing vectors in ℝ³.
PYBIND11_MODULE(_gauss2d, m)
Definition pybind11.cc:31
void defineOrientation(py::module &mod)
void defineClass(Pybind11Class &cls)
void defineCurve(py::module &mod)
Definition _curve.cc:39
void defineRelationship(py::module &mod)
void defineUtils(py::module &)
Definition _utils.cc:44
This file declares a class for representing angles.
This file declares a class for representing longitude/latitude angle boxes on the unit sphere.
This file declares a class for representing elliptical regions on the unit sphere.