Skip to main content

Geoprocessing routines for GIS

Project description

#####################
About PyGeoprocessing
#####################

PyGeoprocessing is a Python/Cython based library that provides a set of commonly
used raster, vector, and hydrological operations for GIS processing. Similar
functionality can be found in ArcGIS/QGIS raster algebra, ArcGIS zonal
statistics, and ArcGIS/GRASS/TauDEM hydrological routing routines.

PyGeoprocessing was developed at the Natural Capital Project to create a
programmable, open source, and free GIS processing library to support the
ecosystem service software InVEST. PyGeoprocessing's design prioritizes
computation and memory efficient runtimes, easy installation and cross
compatibility with other open source and proprietary software licenses, and a
simplified set of orthogonal GIS processing routines that interact with GIS data
via filename. Specifically the functionally provided by PyGeoprocessing includes

* programmable raster algebra routine (vectorize_datasets)
* routines for simplified raster creation and statistics
* integration with vector based geometry in many of the routines
* a simplified hydrological routing library including,
* d-infinity flow direction
* support for plateau drainage
* weighted and unweighted flow accumulation
* and weighted and unweighted flow distance

Dependencies include
* cython>=0.20.2
* numpy>=1.8.2
* scipy>=0.13.3
* shapely>=1.3.3
* gdal>=1.10.1


#######
History
#######

0.3.0 (XXX)
--------------

* Added watershed delination routine to pygeoprocessing.routing.delineate_watershed. Operates on a DEM and point shapefile, optionally snaps outlet points to nearest stream as defined by a thresholded flow accumulation raster and copies the oulet point fields into the constructed watershed shapefile.
* Fixing a memory leak in block caches that held on to dataset, band, and block references even after the object was destroyed.

0.2.2 (2015-05-07)
------------------

* Adding MinGW-specific compiler flags for statically linking pygeoprocessing binaries against libstdc++ and libgcc. Fixes an issue on many user's computers when installing from a wheel on the Python Package Index without having two needed DLLs on the PATH, resuling in an ImportError on pygeoprocessing.geoprocessing_core.pyd.
* Fixing an issue with versioning where 'dev' was displayed instead of the version recorded in pygeoprocessing/__init__.py.
* Adding all pygeoprocessing.geoprocessing functions to pygeoprocessing.__all__, which allows those functions to appear when calling help(pygeoprocessing).
* Adding routing_core.pxd to the manifest. This fixes an issue where some users were unable to compiler pygeoprocessing from source.

0.2.1 (2015-04-23)
------------------

* Fixed a bug on the test that determines if a raster should be memory blocked. Rasters were not getting square blocked if the memory block was row aligned. Now creates 256x256 blocks on rasters larger than 256x256.
* Updates to reclassify_dataset_uri to use numpy.digitize rather than Python loops across the number of keys.
* More informative error messages raised on incorrect bounding box mode.
* Updated docstring on get_lookup_from_table to indicate the headers are case insensitive.
* Added updates to align dataset list that report which dataset is being aligned. This is helpful for logging feedback when many datasets are passed in that don't take long enough to get a report from the underlying reproject dataset function.
* pygeoprocessing.routing.routing_core includes pxd to be `cimport`able from a Cython module.

0.2.0 (2015-04-14)
------------------

* Fixed a library wide issue relating to the underlying numpy types of GDT_Byte Datasets. Now correctly identify the signed and unsigned versions and removed all instances where code used to mod byte data to unsigned data and correctly creates signed/unsigned byte datasets during resampling.
* Removed extract_band_and_nodata function since it exposes the underlying GDAL types.
* Removed reclassify_by_dictionary since reclassify_dataset_uri provided almost the same functionality and was widely used.
* Removed the class OrderedDict that was not used.
* Removed the function calculate_value_not_in_dataset since it loaded the entire dataset into memory and was not useful.

0.1.8 (2015-04-13)
------------------

* Fixed an issue on reclassifying signed byte rasters that had negative nodata values but the internal type stored for vectorize datasets was unsigned.

0.1.7 (2015-04-02)
------------------

* Package logger objects are now identified by python heirarchical package paths (e.g. pygeoprocessing.routing)
* Fixed an issue where rasters that had undefined nodata values caused striping in the reclassify_dataset_uri function.

0.1.6 (2015-03-24)
---------------------

* Fixing LICENSE.TXT to .txt issue that keeps reoccuring.

0.1.5 (2015-03-16)
---------------------

* Fixed an issue where int32 dems with INT_MIN as the nodata value were being treated as real DEM values because of an internal cast to a float for the nodata type, but a cast to double for the DEM values.
* Fixed an issue where flat regions, such as reservoirs, that could only drain off the edge of the DEM now correctly drain as opposed to having undefined flow directions.

0.1.4 (2015-03-13)
---------------------

* Fixed a memory issue for DEMs on the order of 25k X 25k, still may have issues with larger DEMs.

0.1.3 (2015-03-08)
---------------------

* Fixed an issue so tox correctly executes on the repository.
* Created a history file to document current and previous releases.
* Created an informative README.rst.

0.1.2 (2015-03-04)
---------------------

* Fixing issue that caused "LICENSE.TXT not found" during pip install.

0.1.1 (2015-03-04)
---------------------

* Fixing issue with automatic versioning scheme.

0.1.0 (2015-02-26)
---------------------

* First release on PyPI.

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

pygeoprocessing-0.3.0a2.zip (497.6 kB view details)

Uploaded Source

Built Distribution

pygeoprocessing-0.3.0a2-cp27-none-win32.whl (858.9 kB view details)

Uploaded CPython 2.7 Windows x86

File details

Details for the file pygeoprocessing-0.3.0a2.zip.

File metadata

File hashes

Hashes for pygeoprocessing-0.3.0a2.zip
Algorithm Hash digest
SHA256 24a8a8fcff8ea5609b0afe895ec857c16cf63836e274f87d9a058f5c2ff1d095
MD5 22371daf6c7a2e271d750ffd2e802142
BLAKE2b-256 f2bc1bdb217300e36b46b2e0b6b6af226c993ce934aea4445ac7ff83ac9f2791

See more details on using hashes here.

File details

Details for the file pygeoprocessing-0.3.0a2-cp27-none-win32.whl.

File metadata

File hashes

Hashes for pygeoprocessing-0.3.0a2-cp27-none-win32.whl
Algorithm Hash digest
SHA256 6122b98d211d822c0e45ac9a53204ab44f6f0939308466f8387361b825a07dd9
MD5 080f7f4bdda126648dd23373e0e73a56
BLAKE2b-256 3fe03141d14ee9d5c8222a2da8a93975eebe557c8409f128bbdf940c7d34ec8f

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