LSST Applications 27.0.0,g0265f82a02+469cd937ee,g02d81e74bb+21ad69e7e1,g1470d8bcf6+cbe83ee85a,g2079a07aa2+e67c6346a6,g212a7c68fe+04a9158687,g2305ad1205+94392ce272,g295015adf3+81dd352a9d,g2bbee38e9b+469cd937ee,g337abbeb29+469cd937ee,g3939d97d7f+72a9f7b576,g487adcacf7+71499e7cba,g50ff169b8f+5929b3527e,g52b1c1532d+a6fc98d2e7,g591dd9f2cf+df404f777f,g5a732f18d5+be83d3ecdb,g64a986408d+21ad69e7e1,g858d7b2824+21ad69e7e1,g8a8a8dda67+a6fc98d2e7,g99cad8db69+f62e5b0af5,g9ddcbc5298+d4bad12328,ga1e77700b3+9c366c4306,ga8c6da7877+71e4819109,gb0e22166c9+25ba2f69a1,gb6a65358fc+469cd937ee,gbb8dafda3b+69d3c0e320,gc07e1c2157+a98bf949bb,gc120e1dc64+615ec43309,gc28159a63d+469cd937ee,gcf0d15dbbd+72a9f7b576,gdaeeff99f8+a38ce5ea23,ge6526c86ff+3a7c1ac5f1,ge79ae78c31+469cd937ee,gee10cc3b42+a6fc98d2e7,gf1cff7945b+21ad69e7e1,gfbcc870c63+9a11dc8c8f
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.