workflows for regional land cover mapping, built in Google Earth Engine
Project description
Running Regional Land Cover Monitoring System Toolset
Installation
Install with pip:
pip install rlcms
GEE Python API Setup
Earth Engine requires you to authenticate your account credentials to access the Earth Engine python API and your chosen Cloud Project. We do this with the gcloud
python utility
- Download the installer for the
glcoud
command-line python utility from Google - Run the installer
- Select Single User and use the default Destination Folder
- Leave the Selected Components to Install as-is and click Install
- Leave all four boxes checked, and click Finish. This will open a new command-prompt window and auto run gcloud initialization
- It asks whether you'd like to log in, type y - this will open a new browser window to a Google Authentication page
- Choose your Google account that is linked to your Earth Engine account, then click Allow on the next page.
- You will be redirected to a page that says "You are now authenticated with the gcloud CLI!"
- Go back to your shell that had been opened for you by gcloud. It asks you to choose a cloud project and lists all available cloud projects that your google account has access to. Decide which project to authenticate with by typing its number in the list.
- Back in your separate shell window, first ensure you are in your custom conda env (running
conda activate env-name
), then run:
earthengine authenticate
- In the browser window that opens, select the Google account that is tied to your EE account, select the wwf-sig cloud project, then click Generate Token at the bottom of the page.
- On the next page, select your Google account again, then click Allow on the next page.
- Copy the authorization token it generates to your clipboard and back in your shell, paste it and hit Enter.
Testing Your Setup
Test that earthengine is setup and authenticated by checking the folder contents within the wwf-sig
cloud project.
- In your shell, run:
earthengine set_project <project-name>
earthengine ls projects/project-name/assets
If you do not get an error and it returns a list of folders and assets similar to this then you are good to go! :tada:
Tool Documentation
Each Command Line Interface (CLI) script tool can be run in your command-line terminal of choice. The user must provide values for each required command-line argument to control the analysis.
You can first run any script, only declaring the -h
flag. This will bring up the help dialog with a usage example and a description of required command-line arguments.
sample_pts
Generate Random Sample Points From an ee.Image, Formatted for Collect Earth Online
The points are pre-formatted for use in Collect Earth Online. You can choose to export the points to Google Drive, to GEE Asset or both.
example:
sample_pts -im input/path/to/image -band LANDCOVER -o output/path --n_points 100 --to_drive
composite
Creates a Sentinel-2 Composite for an AOI or reference polygons.
The resulting band stack is needed for both extracting training data information and as input to a trained model's inference. Set the -p
flag if your AOI is a set of reference polygons and not one contiguous AOI polygon - this will export band information only within each polygon's footprint.
example:
composite -a aoi/fc/path -d Landsat8 -s 2020-01-01 -e 2020-12-31 -o output/path --settings path/to/settings/file.txt
NOTE: The user can control which spectral indices and time series features to generate in this tool by providing a settings txt file, a template of which is located in the repository : /template_settings.txt
. See ProjectWorkflow.md for details.
train_test
Extract Train and Test Point Data from an Input Image within Reference Polygon Areas.
Generates stratified random samples from reference polygons, splitting the sample points into train and test points if desired. The image bands from the provided image are extracted to every point.
example:
train_test -rp path/to/reference_polygon_fc -im path/to/input/stack -o unique/output/path --class_values 1 2 3 4 5 6 7 8 --class_points 10 10 10 10 10 10 10
primitives
Create Land Cover Primitives For All Classes in Provided Training Data.
This script trains probability Random Forest models for each land cover class in your typology as provided by the numeric 'LANDCOVER' property in the provided reference data. It then exports these binary probability images one land cover at a time into a land cover 'Primitives' image collection. While doing so, it also reports out some model performance metrics saved to a new folder created in your local rlcms/metrics
folder on your computer.
example:
primitives -i input/stack/path -t training/data/path -o output/primitives/imagecollection/path
generate_LC
Generate Single Land Cover Image From Land Cover Primitives Image Collection
This script takes the RF primitives collection generated from the previous script and creates a single-band land cover image from them, taking the highest-probability Primitive at each pixel to assign the Land Cover class.
example:
generate_LC -i input/primitives/imagecollection/path -o output/path
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.