Skip to main content

a Python library to run highlevel functions of DGGRIDv7 and v8

Project description

dggrid4py - a Python library to run highlevel functions of DGGRIDv7

PyPI version DOI

Documentation Status

Population Gridded

GNU AFFERO GENERAL PUBLIC LICENSE

DGGRID is a free software program for creating and manipulating Discrete Global Grids created and maintained by Kevin Sahr. DGGRID version 7.0 was released in September, 2019.

You need the ddgrid tool compiled available on the system.

Besides some lowlevel access influence the dggrid operations' metafile creation, a few highlevel functions are integrated to work with the more comfortable geopython libraries, like shapely and geopandas

  • grid_cell_polygons_for_extent(): fill extent/subset with cells at resolution (clip or world)
  • grid_cell_polygons_from_cellids(): geometry_from_cellid for dggs at resolution (from id list)
  • grid_cellids_for_extent(): get_all_indexes/cell_ids for dggs at resolution (clip or world)
  • cells_for_geo_points(): poly_outline for point/centre at resolution
import geopandas
import shapely

from dggrid4py import DGGRIDv7

# create an inital instance that knows where the dggrid tool lives, configure temp workspace and log/stdout output
dggrid_instance = DGGRIDv7(executable='<path_to>/dggrid', working_dir='.', capture_logs=False, silent=False)

# global ISEA4T grid at resolution 5 into GeoDataFrame to Shapefile
gdf1 = dggrid_instance.grid_cell_polygons_for_extent('ISEA4T', 5)
print(gdf1.head())
gdf1.to_file('isea4t_5.shp')

# clip extent
clip_bound = shapely.geometry.box(20.2,57.00, 28.4,60.0 )

# ISEA7H grid at resolution 9, for extent of provided WGS84 rectangle into GeoDataFrame to Shapefile
gdf3 = dggrid_instance.grid_cell_polygons_for_extent('ISEA7H', 9, clip_geom=est_bound)
print(gdf3.head())
gdf3.to_file('grids/est_shape_isea7h_9.shp')

# generate cell and areal statistics for a ISEA7H grids from resolution 0 to 8 (return a pandas DataFrame)
df1 = dggrid_instance.grid_stats_table('ISEA7H', 8)
print(df1.head(8))
df1.to_csv('isea7h_8_stats.csv', index=False)

# generate the DGGS grid cells that would cover a GeoDataFrame of points, return Polygons with cell IDs as GeoDataFrame
gdf4 = dggrid_instance.cells_for_geo_points(geodf_points_wgs84, False, 'ISEA7H', 5)
print(gdf4.head())
gdf4.to_file('polycells_from_points_isea7h_5.shp')

# generate the DGGS grid cells that would cover a GeoDataFrame of points, return cell IDs added as column to the points GDF
gdf5 = dggrid_instance.cells_for_geo_points(geodf_points_wgs84=geodf_points_wgs84, cell_ids_only=True, dggs_type='ISEA4H', resolution=8)
print(gdf5.head())
gdf5.to_file('geopoint_cellids_from_points_isea4h_8.shp')

# generate DGGS grid cell polygons based on 'cell_id_list' (a list or np.array of provided cell_ids)
gdf6 = dggrid_instance.grid_cell_polygons_from_cellids(cell_id_list=[1, 4, 8], 'ISEA7H', 5)
print(gdf6.head())
gdf6.to_file('from_seqnums_isea7h_5.shp')

# v0.2.6 API update split at dateline for cartesian GIS tools
gdf7 = dggrid_instance.grid_cell_polygons_for_extent('ISEA7H', 3, split_dateline=True)
gdf7.to_file('global_isea7h_3_interrupted.shp')

TODO:

  • sample vector values into dggs cells (aka binning)

  • sample raster values into dggs cells

  • get parent_for_cell_id at coarser resolution

  • get children_for_cell_id at finer resolution

Related work:

Originally insprired by dggridR, Richard Barnes’ R interface to DGGRID. However, dggridR is directly linked via Rcpp to DGGRID and calls native C/C++ functions.

After some unsuccessful trials with ctypes, cython, CFFI, pybind11 or cppyy (rather due to lack of experience) I found am2222/pydggrid (on PyPI) which made apparently some initial scaffolding for the transform operation with pybind11 including some sophisticated conda packaging for Windows. This might be worth following up. Interestingly, its todos include "Adding GDAL export Geometry Support" and "Support GridGeneration using DGGRID" which this dggrid4py module supports with integration of GeoPandas.

Bundling for different operating systems

Having to compile DGGRID for Windows can be a bit challenging. We are working on a conda package.

greater context DGGS in Earth Sciences and GIS

Some reading to be excited about: discourse.pangeo.io

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

dggrid4py-0.2.7.tar.gz (27.3 kB view details)

Uploaded Source

Built Distribution

dggrid4py-0.2.7-py3-none-any.whl (26.3 kB view details)

Uploaded Python 3

File details

Details for the file dggrid4py-0.2.7.tar.gz.

File metadata

  • Download URL: dggrid4py-0.2.7.tar.gz
  • Upload date:
  • Size: 27.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.16

File hashes

Hashes for dggrid4py-0.2.7.tar.gz
Algorithm Hash digest
SHA256 4bff2dc02a7fb8c393cdb19d3c07e0f6c2156136aa32105aa2fafa9a4d09b919
MD5 9e240c83f0c0f9f6d5c25f7cd40a7f9d
BLAKE2b-256 35c2b76eeaac7f23f5ea0675b6b19dbddf4e6c2f1cc24a875a212e2b85e67e27

See more details on using hashes here.

File details

Details for the file dggrid4py-0.2.7-py3-none-any.whl.

File metadata

  • Download URL: dggrid4py-0.2.7-py3-none-any.whl
  • Upload date:
  • Size: 26.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.16

File hashes

Hashes for dggrid4py-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 f9c4c9dd584e090fc414e3203374ad69e32c5d77afd0aa93e55f172081dd94d7
MD5 81d175012aed7ad146b0e1424de5427b
BLAKE2b-256 6b11f452ab8d787492070c84e4b6f8e5d54e3b85a722ed5ce4f1d90821acd5a1

See more details on using hashes here.

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