Skip to main content

Objects for DGGS Cells and collections of Cells.

Project description

DGGS Classes for Cells and Cell Collections for parametrisations of rHEALPix grids

This library contains classes for representing DGGS Cells and collections of these ("CellCollection") according to parametrisations of the rHEALPix Discrete Global Grid System. This provides a convenient low level API to work with Cells and CellCollections. An example of a library that utilises these objects for higher level geospatial operations is the rhealpix-sf library which provides a set of Simple Feature relation operations for DGGS Cells.

Validation is provided for Cell and CellCollections. CellCollections have the following operations performed on instantiation:

  • compression (where all children of a parent are present, replace with their parent)
  • deduplication (removal of repeated cells)
  • absorb (where a child and its parent are present, remove the child/children)
  • ordering (alphabetical and numerical based on suids)

These operations provide a consistent representation of collections of Cells, allowing higher level operations to work with a simplified, valid, and consistent set of cells.

Cells and CellCollections have the following attributes or methods:

  • add: Add two sets of Cell or CellCollections, returning a CellCollection
  • subtract: Subtract a Cell or CellCollection from an other, returning a CellCollection
  • equal: Test two Cells or CellCollections for equivalence
  • len: the number of Cells in a Cell (1) or CellCollection (N)
  • area: to be implemented
  • resolution / min and max resolution for CellCollections: the resolution or minimum / maximum resolution for Cells or CellCollections respectively.
  • neighbours: the Cells immediately neighbouring a Cell or CellCollection, optionally including diagonals. For CellCollections, excludes neighbouring cells interior to the CellCollection. Resolution specifiable.
  • border: the set of interior Cells along the edges of a Cell or CellCollection. Resolution specifiable.
  • children: the set of child Cells for a Cell or CellCollection. Resolution specifiable.

Installation

Coming to PyPI.

This package has no dependencies.

Use

These functions are implemented in the file rheal/dggs_classes.py

This means they can be used like this (full working script):

from rheal import Cell, CellCollection

a = Cell("R1")
b = Cell("R11")
c = CellCollection("R1 R2")
print(a + b)
# b is within a, so a CellCollection equivalent to a is returned
print(a - b)
# b is within a, so a subset of a is returned
print(a + c)
# c contains a, so a CellCollection equivalent to c is returned 
print(a == b)
# a's border at a resolution two levels higher than a's resolution
print(a.border(a.resolution+2))
# a's children at a resolution one level higher (default) than a's resolution
print(a.children())
# a's neighbours at a's resolution (default) including diagonals (default). Note only 7 neighbours due to the shape of the north hemisphere cell.
print(a.neighbours())

Testing

All tests are in tests/ and implemented using unittest.

There are individual tests for each of the Cell and CellCollection operations.

Contributing

Via GitHub, Issues & Pull Requests:

License

This code is licensed with the BSD 3-clause license as per LICENSE.

Citation

@software{https://github.com/surroundaustralia/rhealpix-geo,
  author = {{David Habgood}},
  title = {Objects for DGGS Cells and collections of Cells},
  version = {0.0.1},
  date = {2021},
  url = {https://github.com/surroundaustralia/rhealpix-geo}
}

Contact

Creator & maintainer:
David Habgood
Application Architect
SURROUND Australia Pty Ltd
david.habgood@surroundaustrlaia.com

https://orcid.org/0000-0002-3322-1868

Project details


Download files

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

Source Distribution

rhealpix-geo-0.1.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

rhealpix_geo-0.1-py3-none-any.whl (10.8 kB view details)

Uploaded Python 3

File details

Details for the file rhealpix-geo-0.1.tar.gz.

File metadata

  • Download URL: rhealpix-geo-0.1.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.0 CPython/3.8.10

File hashes

Hashes for rhealpix-geo-0.1.tar.gz
Algorithm Hash digest
SHA256 e5281642d3c8d282ba3f648e961a4ee3e682b013696271e784bf665587c9335d
MD5 027048d27a845ae1afd97a4c847ddeab
BLAKE2b-256 1e3bb89bd25c95f5f6b8c18c9f4c1ac116471d66cc221b73f6a4e2fc58175f3a

See more details on using hashes here.

Provenance

File details

Details for the file rhealpix_geo-0.1-py3-none-any.whl.

File metadata

  • Download URL: rhealpix_geo-0.1-py3-none-any.whl
  • Upload date:
  • Size: 10.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.0 CPython/3.8.10

File hashes

Hashes for rhealpix_geo-0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a5a7cab9a00bffde96c334a643bd0a865afffe9be88f4c68e8e454ca94e1eace
MD5 9f75afe55683691792109dc14b238a57
BLAKE2b-256 011832378e00474d408e5a8690b53fcd8dfa742d0214b4a4f5e6ba50b2b2bd8b

See more details on using hashes here.

Provenance

Supported by

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