Loading [MathJax]/extensions/tex2jax.js
LSST Applications g04a91732dc+cc8870d3f5,g07dc498a13+5aa0b8792f,g0fba68d861+80045be308,g1409bbee79+5aa0b8792f,g1a7e361dbc+5aa0b8792f,g1fd858c14a+f64bc332a9,g208c678f98+1ae86710ed,g35bb328faa+fcb1d3bbc8,g4d2262a081+47ad8a29a8,g4d39ba7253+9633a327c1,g4e0f332c67+5d362be553,g53246c7159+fcb1d3bbc8,g60b5630c4e+9633a327c1,g668ecb457e+25d63fd678,g78460c75b0+2f9a1b4bcd,g786e29fd12+cf7ec2a62a,g7b71ed6315+fcb1d3bbc8,g8852436030+8b64ca622a,g89139ef638+5aa0b8792f,g89e1512fd8+04325574d3,g8d6b6b353c+9633a327c1,g9125e01d80+fcb1d3bbc8,g989de1cb63+5aa0b8792f,g9f33ca652e+b196626af7,ga9baa6287d+9633a327c1,gaaedd4e678+5aa0b8792f,gabe3b4be73+1e0a283bba,gb1101e3267+71e32094df,gb58c049af0+f03b321e39,gb90eeb9370+2807b1ad02,gcf25f946ba+8b64ca622a,gd315a588df+a39986a76f,gd6cbbdb0b4+c8606af20c,gd9a9a58781+fcb1d3bbc8,gde0f65d7ad+4e42d81ab7,ge278dab8ac+932305ba37,ge82c20c137+76d20ab76d,gfe73954cf8+a1301e4c20,w.2025.11
LSST Data Management Base Package
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
_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,
85 std::shared_ptr<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
116 defineClass(angle);
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...
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 ℝ³.
CompoundRegion is an intermediate base class for spherical regions that are comprised of a point-set ...
NormalizedAngleInterval represents closed intervals of normalized angles, i.e.
Region is a minimal interface for 2-dimensional regions on the unit sphere.
Definition Region.h:89
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.