Skip to main content

To process raster data for hydrological/hydrodynamic modelling

Project description

hydro_raster

Python code to process raster data for hydrological or hydrodynamic modelling, e.g., SynxFlow or HiPIMS-CUDA. The style of this package follows the Google Python Style Guide.

Full documentation about how to install and use is here.

Python version: >=3.6. To use the full function of this package for processing raster and feature files, rasterio and pyshp are required.

The CRS of both DEM and Shapfiles must be projected crs whose map unit is meter.

Functions included in this package:

  1. merge raster files
  2. edit raster cell values based on shapefile
  3. convert cross-section lines to river bathymetry raster
  4. remove overhead buildings/bridges on raster
  5. read, write, and visualise raster file

To install hydro_raster from command window/terminal:

pip install hydro_raster

To install using github repo:

git clone https://github.com/mingxiaodong/hydro-raster
cd hydro-raster
pip install .

Tutorial

A jupyter-notebook file is available to show a more detailed tutorial with outputs/plots of its codes.

  1. Read a raster file
from hydro_raster.Raster import Raster
from hydro_raster import get_sample_data
tif_file_name = get_sample_data('tif')
ras_obj = Raster(tif_file_name)
  1. Visualize a raster file
ras_obj.mapshow()
ras_obj.rankshow(breaks=[0, 10, 20, 30, 40, 50])
  1. Clip raster file
clip_extent = (340761, 341528, 554668, 555682) # left, right, bottom, top
ras_obj_cut = ras_obj.rect_clip(clip_extent) # raster can aslo be cut by a shapfile using 'clip' function
ras_obj_cut.mapshow()
  1. Rasterize polygons on a raster and return an index array with the same dimension of the raster array
shp_file_name = get_sample_data('shp')
index_array = ras_obj_cut.rasterize(shp_file_name)
index_array = index_array>=0
  1. Change raster cell values within the polygons by adding a fixed value
ras_obj_new = ras_obj_cut.duplicate()
ras_obj_new.array[index_array] = ras_obj_cut.array[index_array]+20
  1. Show the edited raster with the shapefile polygons
import matplotlib.pyplot as plt
from hydro_raster.grid_show import plot_shape_file
fig, ax = plt.subplots(1, 2)
ras_obj_cut.mapshow(ax=ax[0])
plot_shape_file(shp_file_name, ax=ax[0], linewidth=1)
ras_obj_new.mapshow(ax=ax[1])
plot_shape_file(shp_file_name, ax=ax[1], linewidth=1)
# values can also be changed based on the attributes of each shapefile features

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

hydro_raster-0.0.11.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

hydro_raster-0.0.11-py3-none-any.whl (1.4 MB view details)

Uploaded Python 3

File details

Details for the file hydro_raster-0.0.11.tar.gz.

File metadata

  • Download URL: hydro_raster-0.0.11.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.8.3

File hashes

Hashes for hydro_raster-0.0.11.tar.gz
Algorithm Hash digest
SHA256 be56be00bc44ae4e30eef2a82de93c0cea08bccb85eef52fc70ee03f41e2da38
MD5 511d270551441c57f770234d2e79ed0d
BLAKE2b-256 06262a246b946a34bcf9a50c63343a186dd6b8f80bc2417fef53db119cf63a32

See more details on using hashes here.

File details

Details for the file hydro_raster-0.0.11-py3-none-any.whl.

File metadata

File hashes

Hashes for hydro_raster-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 5ef0cbb89c513cb0099deefdd41556807240eef34a73ad47d9d7f7c3866f3061
MD5 a939400772dae5440a99f1ec6ee78c11
BLAKE2b-256 c8029c4f9ca6936464fb26606eb5ae501d73ad3e37663490f48b0859ee49b7bb

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