- Python 3.8+
- Java 11.0+
- PostGIS (to find coincident footprints)
This repository contains the code required to reproduce the results and figures for the paper "Measuring small-scale tropical forest disturbance with GEDI."
-
GEDI Level 2A, Level 2B, and Level 4A.
These data products are available from the ORNL and LP DAACs. The codebase assumes that this data is already downloaded and the individual shots are loaded into a PostGIS database. Alternatively, if given an existing dataset of coincident shots, the later pipelines can be run without PostGIS by supplying the argument
--shots_dir=/path/to/coincident/shots/dataset
-
JRC Annual Forest Change maps and intensity data ("v1_2022")
These rasters are available from https://forobs.jrc.ec.europa.eu/ and on Google Earth Engine. The codebase assumes that this data is already downloaded and saved as aligned raster files. File naming conventions are enforced in data/jrc_intensity_parser.py and data/jrc_parser.py; these conventions match the file naming if the Annual Forest Change maps are downloaded from the JRC website and the intensity metrics are downloaded from Google Earth Engine. However, you may need to adjust these regular expressions to match your files.
-
RADD disturbance maps ("radd_alert_latest_v2023-04-16")
These rasters are available from Google Earth Engine. Once again, you may need to adjust file name conventions enforced in radd_parser.py to match your files.
In addition to setting up the data as described above, set up the environment as follows:
- Modify constants.py to contain local directory information
- Create a file called '.env' in the main repo directory with the following structure:
# User path constants
USER_PATH="/home/<user>"
DATA_PATH="/path/to/data"
RESULTS_PATH="/path/for/results"
# Database constants
DB_HOST="<hostname>"
DB_NAME="<db name>"
DB_USER="<db user>"
DB_PASSWORD="<db password>"
- Install required python packages (requirements/requirements.txt). Install the local module with
pip install -e /path/to/repo
This codebase contains four processing pipelines used to generate the data for the paper.
- find_coincident_shots.py: Find coincident shot pairs (< 40 m apart) for a given region.
- jrc_degradation_pipeline.py: Identify coincident shot pairs that overlap with disturbance events in the AFC dataset.
- radd_degradation_pipeline.py: Identify coincident shot pairs that overlap with disturbance events in the RADD dataset.
- jrc_disturb_intensity_pipeline.py: For a set of AFC-detected disturbance events, get the corresponding disturbance intensity.
Additionally, it includes a pipeline for identifying coincident shot pairs that fall in "intact" forest. This is only used in the supplementary analysis (not the main paper).
├── LICENSE
├── README.md <- The top-level README for developers using this project.
|
|── figures <- Jupyter notebooks used to produce the figures that
| appear in the paper and supplementary material.
│
├── requirements <- Directory containing the requirement files.
│
├── setup.py <- makes project pip installable
├── src <- Source code for use in this project.
│ ├── __init__.py <- Makes src a Python module
│ │
│ ├── data <- Functions to load data and perform basic parsing
│ │
│ ├── processing <- Functions to perform complex data processing/overlays
| |
│ ├── pipelines <- Scripts to run end-to-end processing pipelines
│ │
│ ├── utils <- General-purpose utility functions
│ │
│ ├── tests <- Unit tests of (some) functions
│ │
│ └── constants.py <- Environment variables, path constants, etc.
│
└── setup.cfg <- setup configuration file for linting rules
Project template created by the Cambridge AI4ER Cookiecutter.