Coastseg stands for Coastal Segmentation, it is an interactive jupyter notebook for downloading satellite imagery with CoastSat and applying image segmentation models to satellite imagery. CoastSeg provides an interactive interface for drawing Regions of Interest (ROIs) on a map, downloading satellite imagery, loading geojson files, extracting shorelines from satellite imagery, and more.
- A mapping extension for CoastSat using Segmentation Zoo models.
- An interactive interface to download satellite imagery using CoastSat from Google Earth Engine
- An interactive interface for extracting shorelines from satellite imagery
- An interactive interface to apply segmentation models to satellite imagery
- Create ROIs(regions of interest) along the coast and automatically load shorelines on the map.
- Use Google Earth Engine to automatically download satellite imagery for each ROI clicked on the map.
- Coastseg can automatically extract shorelines from downloaded satellite imagery.
To get started with CoastSeg open this google colab which will open a jupyter notebook online. The notebook will walk you through connecting to Google Earth Engine, connecting to your google drive so you can save your downloaded images, and using the map dashboard to download satellite imagery.
Alternatively, if you want to get started on your local computer follow the installation instructions, activate the coastseg
environment, then change to the CoastSeg
directory cd coastseg
. Run one of the following notebooks with jupyter lab
to get started using coastseg.
Notebook to Download Satellite Imagery
jupyter lab SDS_coastsat_classifier.ipynb
Notebook to Run Image Segmentation Models
jupyter lab SDS_unet_classifier.ipynb
In order to use Coastseg you need to install Python packages in an environment. We recommend you use Anaconda to install the python packages in an environment for Coastseg. After you install Anaconda on your PC, open the Anaconda prompt or Terminal in Mac and Linux and use the cd
command (change directory) to go the folder where you have downloaded the Coastseg repository.
- Create an Anaconda environment
- This command creates an anaconda environment named
coastseg
and installspython 3.9
in it - You can also use
python 3.10
- We will install the CoastSeg package and its dependencies in this environment.
conda create --name coastseg python=3.9 -y
-
Activate your conda environment
conda activate coastseg
- If you have successfully activated coastseg you should see that your terminal's command line prompt should now start with
(coastseg)
.
- Install Conda Dependencies
- CoastSeg requires
jupyterlab
andgeopandas
to function properly so they will be installed in thecoastseg
environment. - Geopandas has GDAL as a dependency so its best to install it with conda.
- Make sure to install geopandas from the
conda-forge
channel to ensure you get the latest version. - Make sure to install both jupyterlab and geopandas from the conda forge channel to avoid dependency conflicts
conda install -c conda-forge geopandas jupyterlab -y
- CoastSeg requires
- Install the CoastSeg from PyPi
pip install coastseg
All the Installation Commands:
conda create --name coastseg python=3.9 -y
conda activate coastseg
conda install -c conda-forge geopandas jupyterlab -y
pip install coastseg
Use the command conda clean --all
to clean old packages from your anaconda base environment. Ensure you are not in your coastseg environment or any other environment by running conda deactivate
, to deactivate any environment you're in before running conda clean --all
. It is recommended that you have Anaconda prompt (terminal for Mac and Linux) open as an administrator before you attempt to install coastseg
again.
conda deactivate
conda clean --all
- Sign up to use Google Earth Engine Python API
First, you need to request access to Google Earth Engine at https://signup.earthengine.google.com/. It takes about 1 day for Google to approve requests.
- Authenticate with earthengine
Once your request has been approved, with the coastseg
environment activated, run the following command on the Anaconda Prompt(or terminal) to link your environment to the GEE server:
earthengine authenticate
A web browser will open, login with a gmail account and accept the terms and conditions. Then copy the authorization code into the Anaconda terminal. In the latest version of the earthengine-api, the authentication is done with gcloud. If an error is raised about gcloud missing, go to https://cloud.google.com/sdk/docs/install and install gcloud. After you have installed it, close the Anaconda Prompt and restart it, then activate the environment before running earthengine authenticate again.
-
Activate your conda environment
conda activate coastseg
- If you have successfully activated coastseg you should see that your terminal's command line prompt should now start with
(coastseg)
.
- Install the CoastSeg from PyPi
cd <location you downloaded coastseg> ex: cd C:\1_repos\CoastSeg
- Launch Jupyter Lab
- make you run this command in the coastseg directory so you can choose a notebook to use.
jupyter lab
Check out our wiki for comprehensive guides for how to use coastseg to download imagery and apply image segmentation models to the imagery you download.
Package maintainers:
- @dbuscombe-usgs Marda Science / USGS Pacific Coastal and Marine Science Center.
- @2320sharon : Lead Software Developer
Contributions: