Using satellite imagery to identify shelterbelts and measure their impacts on agricultural productivity
Project description
shelterbelts
This repo is for using satellite imagery to map and categorise shelterbelts across Australia, in preparation for measuring impacts on agricultural productivity at scale.
Google Earth Engine App
You can visualise some results from the repo in this Earth Engine App:
https://christopher-bradley-phd.projects.earthengine.app/view/shelterbelts
My slides from the latest Australian National University Research School of Biology (ANU RSB) conference (22 Nov 2025) are here: https://docs.google.com/presentation/d/1_ItZhrtzTDuZXp-qzwP6mT8-nzrLUdA0sI959rIH5zs/edit?usp=sharing
My poster for the Ecology Society of Australia ESA 2025 is here: https://docs.google.com/presentation/d/1oC9jB2WT0nFkxfwlVgvFz6CeqZGZr4pwQr8kT_aS2-k/edit?usp=sharing
Current Methods & Upcoming Plans
The tree predictions come from annual Sentinel-2 imagery largely following a method by Stewart et al. (2025), using a tree/no-tree training dataset provided by Nicolas Pucino.
After the predictions, pixels were categorised using the following method:
- Assign trees from model confidence (50% threshold)
- Assign scattered trees to small groups (< 20 pixels)
- Assign core & buffers to big groups (> 3 pixels thick)
- Assign sheltered vs unsheltered pixels based on percent cover within 100m (10% threshold) , or wind direction (10 pixels leeward, 5 pixels upwind)
- Assign grassland, cropland, urban and water categories from WorldCover 2021
- Assign riparian and roads trees (3 pixel buffer)
- Assign linear vs non-linear patches by fitting an ellipse and skeleton to each group and applying length and width thresholds (the EE App currently has an outdated version of this)
Upcoming Plans
- Expand shelter categories to the rest of Australia, for each year 2017-2025
- Calculate summary statistics for different regions (states, local govdernment areas, IBRA regions)
- Cleanup demoes and tests and publish in the Journal of Open Source Software
- Include 1m canopy height for all of ACT & NSW
- Analyse effects on productivity & potential future benefits
- Add layers with opportunities for more trees
Parameter Reference
The main parameters for categorising shelterbelts are below:
| Parameter | Default | Low Threshold | High Threshold | Description |
|---|---|---|---|---|
min_patch_size |
20 | 10 | 30 | Minimum area (pixels) to classify as a patch rather than scattered trees |
min_core_size |
1000 | 100 | 10000 | Minimum patch size (pixels) to classify as a core area |
edge_size |
3 | 1 | 5 | Distance (pixels) defining the edge region around patch cores |
max_gap_size |
1 | 0 | 2 | Maximum gap (pixels) to bridge when connecting tree clusters |
buffer_width |
3 | 1 | 5 | Number of pixels away from the feature that still counts as within the buffer |
distance_threshold |
20 | 10 | 30 | Distance from trees that counts as sheltered |
density_threshold |
5 | 3 | 10 | Percentage tree cover within distance_threshold that counts as sheltered |
wind_threshold |
20 | 10 | 30 | Wind speed threshold in km/h |
wind_method |
WINDWARD | MOST_COMMON | ALL | Method to determine primary wind direction |
strict_core_area |
strict | non-strict | strict | Whether to enforce strict connectivity for core areas |
min_shelterbelt_length |
15 | 10 | 30 | Minimum skeleton length (in pixels) to classify a cluster as linear |
max_shelterbelt_width |
6 | 4 | 8 | Maximum skeleton width (in pixels) to classify a cluster as linear |
Parameters can be modified when calling functions directly in Python or via command-line arguments. For example:
python -m shelterbelts.indices.tree_categories input.tif --min_patch_size 30 --edge_size 5
Setup
Local Setup
- 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"
git clone https://github.com/ChristopherBradley/shelterbelts.gitcd shelterbeltsconda env create -f environment.ymlconda activate shelterbelts
Setup on gadi at the National Computing Infrastructure (NCI)
- Create an account and request access to the projects xe2 (Borevitz Lab), v10 (Digital Earth Australia modules), ka08 (Sentinel-2 Imagery), ob53 (BARRA Wind).
ssh {username}@nci.org.auand enter the password used to create your account.git clone https://github.com/ChristopherBradley/shelterbelts.git- There are examples usage of the environments in pbs_scripts
Usage on NCI ARE (National Computing Infrastructure's Australian Research Environment)
- Login here: https://are.nci.org.au/
- Go to JupyterLab and create a session with 1 hour, queue normalbw, compute size small, project xe2, storage gdata/+gdata/xe2+gdata/v10+gdata/ka08+gdata/ob53, python environment base /g/data/xe2/cb8590/miniconda, conda environment /g/data/xe2/cb8590/miniconda/envs/shelterbelts. Alternatively, can use Module Dircetories /g/data/v10/public/modules/modulefiles and Modules: dea/20231204.
- Right click any .py file and open as a jupyter notebook. Currently some debugging arguments are usually commented out at the bottom of each file. I'm planning to move these to tests/demos.
Examples
There are jupyter notebooks to demo the functionality of this repo in notebooks. Also, there are .pbs scripts for submitting jobs to gadi in pbs_scripts, along with .sh scripts to submit many jobs in parallel. The main python files are in src/shelterbelts and these can all be run from the command line as well. The tests have the same examples as notebooks but are more convenient to run all at once (but less convenient for demo-ing/understanding the functionality).
Testing
If on gadi:
qsub -I -P xe2 -q copyq -l ncpus=1 -l mem=8GB -l walltime=02:00:00 -l storage=gdata/xe2+scratch/xe2 -l wd
Then:
conda activate /g/data/xe2/cb8590/miniconda/envs/shelterbelts
pytest tests
Documentation
Generate the html:
make clean && make html
You can view the documenation locally in a browser by opening docs/build/index.html
Run the doctests:
make doctest
Upload the html to github pages:
ghp-import -n -p -f docs/build/html
You can view the published documentation at: https://christopherbradley.github.io/shelterbelts/index.html
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
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 shelterbelts-0.0.1.tar.gz.
File metadata
- Download URL: shelterbelts-0.0.1.tar.gz
- Upload date:
- Size: 109.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
29d1f2d94f4b3f60058f320366baac053f29474e165e89cd586cd552759df822
|
|
| MD5 |
9d183adbadce3715061972dd0599c319
|
|
| BLAKE2b-256 |
16da2a887061312f84fd045a314ee64f9f3796a0e31e9559f6b2ea09622b49c9
|
File details
Details for the file shelterbelts-0.0.1-py3-none-any.whl.
File metadata
- Download URL: shelterbelts-0.0.1-py3-none-any.whl
- Upload date:
- Size: 131.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9a16a7bb51a28ca17c94a329f32c5e00902732550836aef658f63da805ccf67f
|
|
| MD5 |
3e05f71d65bd2a6e0f7077e9d525b483
|
|
| BLAKE2b-256 |
e7661c4cb7b531d5bcfa1734b4602d37029e8a5cca8d32e1264b80d8c052894e
|