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-25.0.0a20225000.tar.gz (129.2 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-25.0.0a20225000-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (659.2 kB view details)

Uploaded CPython 3.10manylinux: glibc 2.17+ x86-64

lsst_sphgeom-25.0.0a20225000-cp310-cp310-macosx_11_0_arm64.whl (491.7 kB view details)

Uploaded CPython 3.10macOS 11.0+ ARM64

lsst_sphgeom-25.0.0a20225000-cp310-cp310-macosx_10_9_x86_64.whl (513.2 kB view details)

Uploaded CPython 3.10macOS 10.9+ x86-64

lsst_sphgeom-25.0.0a20225000-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (666.6 kB view details)

Uploaded CPython 3.9manylinux: glibc 2.17+ x86-64

lsst_sphgeom-25.0.0a20225000-cp39-cp39-macosx_11_0_arm64.whl (491.7 kB view details)

Uploaded CPython 3.9macOS 11.0+ ARM64

lsst_sphgeom-25.0.0a20225000-cp39-cp39-macosx_10_9_x86_64.whl (513.4 kB view details)

Uploaded CPython 3.9macOS 10.9+ x86-64

lsst_sphgeom-25.0.0a20225000-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (659.8 kB view details)

Uploaded CPython 3.8manylinux: glibc 2.17+ x86-64

lsst_sphgeom-25.0.0a20225000-cp38-cp38-macosx_11_0_arm64.whl (491.7 kB view details)

Uploaded CPython 3.8macOS 11.0+ ARM64

lsst_sphgeom-25.0.0a20225000-cp38-cp38-macosx_10_9_x86_64.whl (513.2 kB view details)

Uploaded CPython 3.8macOS 10.9+ x86-64

File details

Details for the file lsst-sphgeom-25.0.0a20225000.tar.gz.

File metadata

  • Download URL: lsst-sphgeom-25.0.0a20225000.tar.gz
  • Upload date:
  • Size: 129.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.1

File hashes

Hashes for lsst-sphgeom-25.0.0a20225000.tar.gz
Algorithm Hash digest
SHA256 edb02cbc9b8582ea8f1d2094ccca257eec1be11a73362f27f69c739cc70af13e
MD5 7c5400d2831d43a2ecfc3dc91ccba272
BLAKE2b-256 d51e452aa4d79d64bf25c0d17a19b821f8611d6fc0091704299487c572a98090

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 f21d77f7fc0c5b6775a58810e69882472cbe51fb8641414742e64e1c9e1f9668
MD5 7c21099812c89ed697fb65872d1fa911
BLAKE2b-256 9e2f39035a111717f18097ba8b0c5b059d67ca2abac2f081cfa9db3d084c0630

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp310-cp310-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp310-cp310-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 3179979fd6cf48b08135e6c3662071c002de256c4d51793da95b55a6a4004a23
MD5 31985db461bea8e5c742bd0e6c7cb808
BLAKE2b-256 36516efb2d9320393a96b794edbf2b40e5f84f0e12ec2a424ff1d725341e47aa

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp310-cp310-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp310-cp310-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 1148e3f0c350d0b2c47afb7e8634baf9242f5241b17981d83942f3b04d72406f
MD5 0dc1868be3ad175610990a9a9d6f0dfc
BLAKE2b-256 5d35724aeb588232a89b1a4741bf28f851645ea7637c45e4d2d44bed684c93cd

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 3fbea11921f016720469c4fabb590a3f9b3b3446cf3becc5225979af2a340021
MD5 565db7ae609a7abb6262b35cbe68a439
BLAKE2b-256 33e4035e64f8d6f235165d3796663683dc4834c4807483bcd53b1cddf0a44617

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp39-cp39-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp39-cp39-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 1478c162b88fdbe5ac49130f6a2dfa98de482f49a285f0a0aa832c87353c2950
MD5 21c8f453fad3dce848f6a2e74b132fa0
BLAKE2b-256 76edfaa06feb60bf08fb24c252d930d56beb3a2f7bb5ac18be8ef08a93fa345d

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp39-cp39-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp39-cp39-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 a4f56565915950981e0d310aaf6588ada2b3fba4b87e69ba81259df4cca22f40
MD5 d447ccec6eb0fa2670c04c745d5db0f8
BLAKE2b-256 095754811577f5493aba9a7602e42a2e08ffd27d4de79d5e43c4e9c5de97014b

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 86e4ea40e9c5eb23ffb40fabf5fd56678b1b7ed0672e4a43843d6019ae0e3350
MD5 03eb53889580b17bd1602569f6c1f41e
BLAKE2b-256 edde89976ac1d284b0abb78566e775e37fcbbc57dd7cc9f14f3945835a9c943f

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp38-cp38-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp38-cp38-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 b7907c22245000f8dffdea921dce4f00e3d37e9fc297506dc3423290ac10a657
MD5 8c169cc47bbb81df5917a3959984a8b1
BLAKE2b-256 2f28d312f0b8c1fadbf3766485ca99d5f8502b32734f85210f9ccce5780dbe52

See more details on using hashes here.

File details

Details for the file lsst_sphgeom-25.0.0a20225000-cp38-cp38-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for lsst_sphgeom-25.0.0a20225000-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 11d62460c7c754bb314f1e63ca070f608169ef046b880d5039acc159ff787cf4
MD5 f2c51cb61d3a96dda3c22b00a6750b98
BLAKE2b-256 b165704d0a557a69b4876f37d1078f0446b0f31b7fa063803f4d01c7891e264a

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