LSST Applications g0603fd7c41+501e3db9f9,g0aad566f14+23d8574c86,g0dd44d6229+a1a4c8b791,g2079a07aa2+86d27d4dc4,g2305ad1205+a62672bbc1,g2bbee38e9b+047b288a59,g337abbeb29+047b288a59,g33d1c0ed96+047b288a59,g3a166c0a6a+047b288a59,g3d1719c13e+23d8574c86,g487adcacf7+cb7fd919b2,g4be5004598+23d8574c86,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+4a9e435310,g63cd9335cc+585e252eca,g858d7b2824+23d8574c86,g88963caddf+0cb8e002cc,g99cad8db69+43388bcaec,g9ddcbc5298+9a081db1e4,ga1e77700b3+a912195c07,gae0086650b+585e252eca,gb0e22166c9+60f28cb32d,gb2522980b2+793639e996,gb3a676b8dc+b4feba26a1,gb4b16eec92+63f8520565,gba4ed39666+c2a2e4ac27,gbb8dafda3b+a5d255a82e,gc120e1dc64+d820f8acdb,gc28159a63d+047b288a59,gc3e9b769f7+f4f1cc6b50,gcf0d15dbbd+a1a4c8b791,gdaeeff99f8+f9a426f77a,gdb0af172c8+b6d5496702,ge79ae78c31+047b288a59,w.2024.19
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(detect_pybind11, mod)
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.