Skip to main content

A spherical geometry library.

Project description

sphgeom: spherical geometry primitives

Overview

This low-level C++ library provides primitives for representing points and regions on the unit sphere, as well as support for partitioning the sphere. It can be used to answer the following sorts of questions:

  • Is point X inside region Y?
  • Do two regions A and B intersect?
  • Which pieces of the sphere does region C overlap?

Regions can be serialized to binary strings, so that they may be stored efficiently in files or VARBINARY database columns. They can also be approximated with simpler regions - for example, one can ask for the bounding circle of a convex polygon.

Python bindings that expose most of the C++ API are also provided via pybind11.

Points

There are 3 different classes for points

  • LonLat for spherical coordinates,
  • Vector3d for Cartesian vectors in ℝ³ (not constrained to lie on the unit sphere)
  • UnitVector3d for vectors in ℝ³ with unit ℓ² norm.

Regions

Four basic spherical Region types are provided:

  • Box, a longitude/latitude angle box
  • Circle, a small circle defined by a center and opening angle/chord length
  • Ellipse, the intersection of an elliptical cone with the unit sphere
  • ConvexPolygon, a convex spherical polygon with unit vector vertices and great circle edges

In addition to the spherical regions, there is a type for 3-D axis aligned boxes, Box3d. All spherical regions know how to compute their 3-D bounding boxes, which makes it possible to insert them into a 3-D R-tree. This is used by the exposure indexing task in the daf_ingest package to spatially index exposure bounding polygons using the SQLite 3 R*tree module.

A region can also determine its spatial relationship to another region, and test whether or not it contains a given unit vector.

Pixelizations

This library also provides support for assigning points to pixels (a.k.a. cells or partitions) in a Pixelization (a.k.a. partitioning) of the sphere, and for determining which pixels intersect a region.

Currently, the Chunker class implements the partitioning scheme employed by Qserv. The HtmPixelization class implements the HTM (Hierarchical Triangular Mesh) pixelization. The Q3cPixelization and Mq3cPixelization classes implement the original Quad Tree Cube indexing scheme and a modified version with reduced pixel area variation.

Installing with pip

A simple pip-compatible installer is available. This only installs the Python bindings and the resulting installation is not usable for linking from C++. Some metadata (in particular the version number) are not set properly for the distribution. The main purpose for now is to allow other packages to pip install from the GitHub URL in their CI systems where sphgeom is a dependency.

See Also

Contributing

For instructions on how to contribute, see http://dm.lsst.org/#contributing (or just send us a pull request).

Support

For help, see http://dm.lsst.org/#support.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

lsst-sphgeom-24.0.0a20222600.tar.gz (128.7 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

lsst_sphgeom-24.0.0a20222600-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (606.2 kB view details)

Uploaded CPython 3.10manylinux: glibc 2.17+ x86-64

lsst_sphgeom-24.0.0a20222600-cp310-cp310-macosx_11_0_arm64.whl (457.6 kB view details)

Uploaded CPython 3.10macOS 11.0+ ARM64

lsst_sphgeom-24.0.0a20222600-cp310-cp310-macosx_10_9_x86_64.whl (478.5 kB view details)

Uploaded CPython 3.10macOS 10.9+ x86-64

lsst_sphgeom-24.0.0a20222600-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (610.1 kB view details)

Uploaded CPython 3.9manylinux: glibc 2.17+ x86-64

lsst_sphgeom-24.0.0a20222600-cp39-cp39-macosx_11_0_arm64.whl (457.7 kB view details)

Uploaded CPython 3.9macOS 11.0+ ARM64

lsst_sphgeom-24.0.0a20222600-cp39-cp39-macosx_10_9_x86_64.whl (478.6 kB view details)

Uploaded CPython 3.9macOS 10.9+ x86-64

lsst_sphgeom-24.0.0a20222600-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (607.5 kB view details)

Uploaded CPython 3.8manylinux: glibc 2.17+ x86-64

lsst_sphgeom-24.0.0a20222600-cp38-cp38-macosx_11_0_arm64.whl (457.6 kB view details)

Uploaded CPython 3.8macOS 11.0+ ARM64

lsst_sphgeom-24.0.0a20222600-cp38-cp38-macosx_10_9_x86_64.whl (478.5 kB view details)

Uploaded CPython 3.8macOS 10.9+ x86-64

File details

Details for the file lsst-sphgeom-24.0.0a20222600.tar.gz.

File metadata

  • Download URL: lsst-sphgeom-24.0.0a20222600.tar.gz
  • Upload date:
  • Size: 128.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for lsst-sphgeom-24.0.0a20222600.tar.gz
Algorithm Hash digest
SHA256 b6b87c48de71ba4b054460882bb9c5aa8328ba83566877cfe8b826f888ebce52
MD5 22c9e7c171ea80abbd5f19d3b7683f20
BLAKE2b-256 c838a14d267a3d56d1817e0c2e0010ab16aa740938457493cbbb5e3431c42292

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0cd713ebcabf5a111cffec72e162c781da740cb74c6374d66d9d2ccef0917b35
MD5 c0fbb2f54c56b9218506918eb86c3cf6
BLAKE2b-256 d37c3e529ff057665c42a31c92a8fdc09123c69774c85e4b0dbb9ed324f3febc

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp310-cp310-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp310-cp310-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 2257e1f461a62a7288f89af94523d6d88370d7bd73df9f7ad55a890418fa1081
MD5 23870d13317eb3899add50764af2020f
BLAKE2b-256 df542cbbdf1f8481d126ce38264c5a78e028330e5c4d771a6d03aceada1c5545

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp310-cp310-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp310-cp310-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 edb3e7fe84e5cff4ebf4c75b68719e1ea7545eb6cac826e8f9941228f84d4636
MD5 06d7a92e971ed2ceb2d1bdcf2fd1ddf4
BLAKE2b-256 a39c874d2132458f94aa3472cf6947b10650b66fbbac068dbaccf88e5a058bd7

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 5dfce6d64d4d4282f83df21b3e08eee7f115bceb6e98081730a9b178a7eede34
MD5 7e82cb2ea3d413c010dc035f812698cb
BLAKE2b-256 bdb0e8a8d397f326e238c8e3104cbff8de35138dcd7cb4a934fe49816ca72249

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp39-cp39-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp39-cp39-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6f623900c6ceb94a05a6654e9f885f5a08410ea7274fc89e58438dd7744e752c
MD5 18571df89c934b7826615c9d17cfa5fc
BLAKE2b-256 eedeee9b363935417c38f0b8d8bc259438baafd8b8462ef73a22e05fdbf71e29

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp39-cp39-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp39-cp39-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 bd970056a857c8905dbb6fdf16ad881920db7a0de732ecb33f928e10b9497a0b
MD5 3013b4bfb906978c8d424923e157cf1e
BLAKE2b-256 243c58c932bc542b9f8dd37172915e3d4e234bbae453f1e811bb2dca1917fe88

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 750b4c47c0b0052f4bc95edef5fde85dc4b89b2a227c19879d5eb5bb1f9f6638
MD5 b2c8da05647a34b8073e1e0c0a57ae43
BLAKE2b-256 e1e0a47365accbf6d6f33008fa5c655c2812418f721a0a9c6f0ca57b7a93909e

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp38-cp38-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp38-cp38-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 653c5d63221ce8c91761a44fc1d76eeb7ce531f807a32c486cff841936693ff1
MD5 0d1a3b428c71f10b3327d679d104c055
BLAKE2b-256 36198a7fa00486f92f69bde9403f05f36cf1a4a3eb58f312747c5c7a2bc440d5

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-24.0.0a20222600-cp38-cp38-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-24.0.0a20222600-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 5c864ebf4253e3a6f56137f6f84c108feeb4a54d3cbf959a12bd0cf623578e70
MD5 25e405c0971781839b11699787560066
BLAKE2b-256 5eefb17ce81ce9fe89d154185b3e4ba7e7505e9dd46577ad730fe473c50bc972

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page