Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tommylees112/vegetation_health
predicting vegetation health from precipitation and temperature
https://github.com/tommylees112/vegetation_health
Last synced: about 2 months ago
JSON representation
predicting vegetation health from precipitation and temperature
- Host: GitHub
- URL: https://github.com/tommylees112/vegetation_health
- Owner: tommylees112
- Created: 2019-03-11T12:18:12.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2019-05-02T17:48:07.000Z (over 5 years ago)
- Last Synced: 2024-06-11T17:40:49.774Z (7 months ago)
- Language: Jupyter Notebook
- Size: 6.77 MB
- Stars: 12
- Watchers: 2
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-earthobservation-code - vegetation health - Predicting vegetation health from precipitation and temperature (`Python` processing of optical imagery (non deep learning) / Processing imagery - post processing)
README
# Vegetation Health
Predicting vegetation health from precipitation and temperature
## Introduction
This repository experiments with different machine learning models to predict drought indices in East Africa
(specifically the Normalized Difference Vegetation Index) using temperature and precipitation data.## Results
Models are trained on data before 2016, and evaluated on 2016 data. Vegetation health in June is being predicted.
In addition, vegetation health can be hidden from the model to better understand the effects of the other features.
| Model | RMSE | RMSE (no veg) |
|:------------------------:|:----:|:-------------:|
|Linear Regression |0.040 |0.084 |
|Feedforward neural network|0.038 |0.070 |
|Recurrent neural network |0.035 |0.060 |The results of the models can also be compared visually with the ground truths (the example below is from the baseline
logistic regression):In addition, the effects of the inputs on the models' predictions are investigated using [shap values](https://github.com/slundberg/shap)
in Jupyter Notebooks, for both the [feedforward neural network](notebooks/04_gt_feedforward_model.ipynb) and the
[recurrent neural network](notebooks/08_gt_recurrent_model.ipynb).## Pipeline
[Python Fire](https://github.com/google/python-fire) is used to generate a CLI.
### Data cleaning
Normalize values from the original csv file, remove null values, add a year series.
```bash
python run.py clean
```
A target can be selected by adding the flag `--target`, e.g. `--target=ndvi_anomaly`.
By default, the target is `ndvi`. The selected target must be in
[`predictor.preprocessing.VALUE_COLS`](predictor/preprocessing.py).The original data is currently generated using datasets on the Oxford University cluster, using the scripts
in [`data`](data).### Data Processing
Turn the CSV into `numpy` arrays which can be input into the model.
```bash
python run.py engineer
```### Models
3 models have been implemented: a baseline linear regression, a feedforward neural network and a
recurrent neural network. They can be selected using the `--model_type` flag.```bash
python run.py train_model
```## Setup
[Anaconda](https://www.anaconda.com/download/#macos) running python 3.7 is used as the package manager. To get set up
with an environment, install Anaconda from the link above, and (from this directory) run```bash
conda env create -f environment.yml
```
This will create an environment named `vegetation_health` with all the necessary packages to run the code. To
activate this environment, run```bash
conda activate vegetation_health
```## Additional Notes
- The following variables are used by the model: `['lst_night', 'lst_day', 'precip', 'sm', 'ndvi', 'evi', 'ndvi_anomaly']`.
They are all from different sources- East Africa is defined here as the area of the original `.nc` file (`spi_spei.nc`)
lat min, lat max : `-4.9750023`, `15.174995`
lon min, lon max : `32.524994`, `48.274994`This makes the following bounding box: (left, bottom, right, top): `(32.524994, -4.9750023, 15.174995, 48.274994)`