Harvesting environmental forcing data for running the Dynamic Agro-Ecosystem Simulator (DAESIM)
Project description
DAESIM_preprocess
Harvesting environmental forcing data for running the Dynamic Agro-Ecosystem Simulator (DAESIM).
Jupyter Notebook Examples
I've made some demo notebooks and these can be run directly in Google Colab like this:
Right click Google Colab > Open Link in New Tab > Open Colab > Sign In (just requires a google account) > GitHub > search for 'ChristopherBradley' > 'ChristopherBradley/DAESIM_preprocess' > select a notebook. Then uncomment the line '!pip install daesim-preprocess' and run each cell in sequence (or click 'Run all').
Note the terrain_tiles and topography notebooks don't work on Google Colab because of the gdalwarp dependency, so you need to run these locally (see Running Locally below).
Available Variables
ozwald_8day.py can download these variables modelled at 500m spatial and 8 day temporal resolution, from the Australian Water and Landscape Dynamics (OzWALD).
- Alb: Albedo
- BS: Bare Surface
- EVI: Enhanced Vegetation Index
- FMC: Fuel Moisture Content
- GPP: Gross Primary Productivity
- LAI: Leaf Area Index
- NDVI: Normalised Difference Vegetation Index
- NPV: Non Photosynthetic Vegetation
- OW: Open Water
- PV: Photosynthetic Vegetation
- Qtot: Streamflow
- SN: Snow
- Ssoil: Soil profile moisture change
ozwald_daily.py can download these climate variables modelled at varying spatial resolutions (500m-5km depending on the variable) and daily temporal resolution, also from OzWald.
- Pg : Gross precipitation
- Tmax : Maximum temperature
- Tmin : Minimum temperature
- Uavg : Average 24h windspeed
- Ueff : Effective daytime windspeed
- VPeff : Volume of effective rainfall
- kTavg : Coefficient to calculate mean screen level temperature
- kTeff : Coefficient to calculate effective screen level temperature
silo_daily.py can download these climate variables modelled at 5km resolution daily, from Scientific Information for LandOwners (SILO).
- daily_rain: Daily rainfall, mm
- monthly_rain: Monthly rainfall, mm
- max_temp: Maximum temperature, degrees Celsius
- min_temp: Minimum temperature, degrees Celsius
- vp: Vapour pressure, hPa
- vp_deficit: Vapour pressure deficit, hPa
- evap_pan: Class A pan evaporation, mm
- evap_syn: Synthetic estimate, mm
- evap_morton_lake: Morton's shallow lake evaporation, mm
- radiation: Solar radiation: Solar exposure, consisting of both direct and diffuse components, MJ/m2
- rh_tmax: Relative humidity at the time of maximum temperature, %
- rh_tmin: Relative humidity at the time of minimum temperature, %
- et_short_crop: Evapotranspiration FAO564 short crop, mm
- et_tall_crop: ASCE5 tall crop6, mm
- et_morton_actual: Morton's areal actual evapotranspiration, mm
- et_morton_potential: Morton's point potential evapotranspiration, mm
- et_morton_wet: Morton's wet-environment areal potential evapotranspiration over land, mm
- mslp: Mean sea level pressure Mean sea level pressure, hPa
slga_soils.py can download these soil variables modelled at 90m resolution from the Soils and Landscape Grid of Australia (SLGA).
- Clay
- Silt
- Sand
- pH_CaCl2
- Bulk_Density
- Available_Water_Capacity
- Effective_Cation_Exchange_Capacity
- Total_Nitrogen
- Total_Phosphorus
terrain_tiles.py can download global elevation data from various sources at minimum 30m resolution, rescaled to 10m resolution by using tile level 14 (Terrain Tiles).
- elevation
topography.py can download these derived topographic information mainly using (pysheds).
- slope
- aspect
- accumulation
- topographic wetness index (TWI)
Available Parameters
The functions in this repo use mostly the same inputs for consistency. All parameters have default values to make the functions easier to use and help with debugging.
| Function | Parameters |
|---|---|
| ozwald_8day | variables, lat, lon, buffer, start_year, end_year, outdir, stub, tmpdir, thredds, save_netcdf, plot |
| ozwald_daily | variables, lat, lon, buffer, start_year, end_year, outdir, stub, tmpdir, thredds, save_netcdf, plot |
| silo_daily | variables, lat, lon, buffer, start_year, end_year, outdir, stub, tmpdir, thredds, save_netcdf, plot |
| slga_soils | variables, lat, lon, buffer, outdir, stub, tmpdir, depths |
| terrain_tiles | lat, lon, buffer, outdir, stub, tmpdir, tile_level, interpolate |
| topography | outdir, stub, ds, smooth, sigma, savetifs, plot |
| daesim_forcing | outdir, stub |
Parameter Descriptions
This is the meaning of each parameter.
| Parameter | Default | Description |
|---|---|---|
| variables | depends on the function | List of variables to download |
| lat | -34.389 | Latitude from google maps (EPSG:4326) |
| lon | 148.469 | Longitude from google maps (EPSG:4326) |
| buffer | 0.01 or 0.1 | Buffer in degrees in each direction (so 0.01 ~= 2km x 2km) |
| start_year | 2020 | Temporal data starts from Jan 1 of this year |
| end_year | 2021 | Temporal data ends on Dec 31 of this year |
| outdir | "." (current directory) | The directory for the final outputs |
| stub | "TEST" | The name that gets prepended to each file |
| tmpdir | "." (current directory) | The directory for temporary intermediate files |
| thredds | True | Boolean to use the public facing Thredds API |
| save_netcdf | True | Boolean to save the final result to file |
| plot | True | Boolean to generate output png images |
The extra parameters for slga_soils, terrain_tiles and topography are documented in the relevant python files.
Return Types
Data is returned as an xarray DataSet and downloaded as NetCDF (.nc), tif, and/or png files.
Usage
This is the basic pattern for using each function. More comprehensive examples are in the notebooks and tests.
pip install DAESIM_preprocess
from DAESIM_preprocess.ozwald_daily import ozwald_daily # (or another function)
variables = [Tmax, Tmin] # (or other variables)
lat, lon, buffer = -34.38, 148.46, 0.01 # (or another location)
ds = ozwald_daily(variables, lat, lon, buffer)
Running Locally
- Download and install Miniconda from https://www.anaconda.com/download/success
- Add the miniconda filepath to your ~/.zhrc, e.g. export PATH="/opt/miniconda3/bin:$PATH"
brew install gdalgit clone https://github.com/ChristopherBradley/DAESIM_preprocess.gitcd DAESIM_preprocessconda env create -f environment.ymlconda activate DAESIM_preprocessexport PATH=$PATH:$(pwd)/src/DAESIM_preprocessjupyter lab(to run the example notebooks like on google colab)
Running via Command Line
After completing steps 1-8 of running locally, you can run each of the scripts directly via the command line. For example:
ozwald_8day.py --variable Ssoil --lat -34.389 --lon 148.469 --buffer 0.01 --start_year 2020 --end_year 2021
ozwald_daily.py --variable Tmin --lat -34.389 --lon 148.469 --buffer 0.01 --start_year 2020 --end_year 2021
silo_daily.py --variable min_temp --lat -34.389 --lon 148.469 --buffer 0.01 --start_year 2020 --end_year 2021
slga_soils.py --variable Clay --lat -34.389 --lon 148.469 --buffer 0.01
terrain_tiles.py --lat -34.389 --lon 148.469 --buffer 0.01
topography.py --outdir '.' --stub TEST
The main differences when running from the command line are that you can only specify a single variable at a time, and the boolean default is False. This is documented in each python file, and you can also use ozwald_8day.py --help to see info about the available parameters for each function from the command line.
Testing
After completing steps 1-8 of running locally, you can check the setup is working correctly by running the tests.
python tests/tests_local.py- In Visual Studio Code, you can use the debugger to set breakpoints and step through the code while analysing variables.
- You can test the command line arguments with the bash script
./tests/tests_command_line.sh - The local tests should all run on NCI, along with some additional tests
python tests/tests_nci.py
Sometimes the API's can be a bit temperamental, especially the SLGA, so you may need to wait a while and try the test again.
Uploading to PyPI
Just a note for myself when I need to republish the library.
- python3 -m build
- twine upload dist/*
- Enter the API token
- Check it out at https://pypi.org/project/DAESIM-preprocess
References
- Australia terrain data © Commonwealth of Australia (Geoscience Australia) 2017;
- Haan S, Harianto J, Butterworth N, Bishop T (2023) Geodata-Harvester: A Python package to jumpstart geospatial data extraction and analysis, Journal of Open Source Software, 8(89):5205, https://doi.org/10.21105/joss.05205
- Jeffrey SJ, Carter JO, Moodie KB, Beswick AR (2001) Using spatial interpolation to construct a comprehensive archive of Australian climate data, Environmental Modelling & Software, 16(4):309-30, https://doi.org/10.1016/S1364-8152(01)00008-1
- Rossel RV, Chen C, Grundy MJ, Searle R, Clifford D, Campbell PH (2015) The Australian three-dimensional soil grid: Australia’s contribution to the GlobalSoilMap project, Soil Research, 53(8):845-64, https://doi.org/10.1071/SR14366
- Mapzen (2017) Terrain Tiles on AWS, Amazon, accessed 28 October 2024, https://registry.opendata.aws/terrain-tiles
- United States 3DEP (formerly NED) and global GMTED2010 and SRTM terrain data courtesy of the U.S. Geological Survey.
- Van Dijk, AIJM (2010) The Australian Water Resources Assessment System. Technical Report 3. Landscape Model (version 0.5) Technical Description, CSIRO: Water for a Healthy Country National Research Flagship, https://awo.bom.gov.au/assets/notes/publications/Van_Dijk_AWRA05_TechReport3.pdf
- Van Dijk AIJM, Rahman J (2019) Synthesising multiple observations into annual environmental condition reports: the OzWALD system and Australia’s Environment Explorer. In Elsawah, S. (ed.) MODSIM2019, 23rd International Congress on Modelling and Simulation. Modelling and Simulation Society of Australia and New Zealand, pp. 884–890. ISBN: 978-0-9758400-9-2, https://doi.org/10.36334/modsim.2019.J5.vandijk
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file daesim_preprocess-0.0.7.tar.gz.
File metadata
- Download URL: daesim_preprocess-0.0.7.tar.gz
- Upload date:
- Size: 28.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a1b71344032aa3c167ddb3dfd7c4aa80a1f5da0a605bf91ea0bbabe527926569
|
|
| MD5 |
5b05c90006b0cec10d2c33e488418371
|
|
| BLAKE2b-256 |
f07ed9f2d35712b2cf35d6bb9ac27ca953679b0dfa25daeaef53e442cca9c749
|
File details
Details for the file daesim_preprocess-0.0.7-py3-none-any.whl.
File metadata
- Download URL: daesim_preprocess-0.0.7-py3-none-any.whl
- Upload date:
- Size: 29.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ff90c65eb75546afd0e56a9e3e29e4b057c1c4325527791a13ebd64e081b05f2
|
|
| MD5 |
b67fe3d08a59af64ee0b800c76bd32d3
|
|
| BLAKE2b-256 |
8269fcb6c06ae2263341e9e3bfcfc2ea49affdf58905b1e3b9240b2d1d80544b
|