Skip to content

CIRN Digital Earth Australia Coastal Earth Observation Workshop

Robbi Bishop-Taylor edited this page Oct 21, 2024 · 29 revisions

CIRN Coastal Earth Observation Workshop

Stephen Sagar, Assistant Director, Coastal & Aquatic Earth Observation Science  
Robbi Bishop-Taylor, Coastal Earth Observation Scientist

Prior to the workshop: register for the DEA Sandbox

We will be using the Digital Earth Australia Sandbox analysis environment for this workshop. The DEA Sandbox is an interactive Python-based coding environment with access to petabytes of satellite data across Australia and pre-installed scientific Python packages for EO analysis.

  1. Please follow the guide here to register for the DEA Sandbox before the Tuesday morning workshop: https://knowledge.dea.ga.gov.au/guides/setup/Sandbox/sandbox/#register

Important

Once you have registered, email Robbi.BishopTaylor@ga.gov.au if you would like to be granted access to larger 120 gb RAM, 16 CPUs resources during the workshop!

  • Additional Sandbox resources are provided for the purposes of this workshop for a period of six weeks
  • After six weeks (30th November 2024), access will revert to the default provisions
  • When you have finished using the DEA Sandbox, please shut down your server by clicking the File menu, then Hub control panel then Stop my server.

Getting started with eo-tides

eo-tides logo

eo-tides is a new coastal remote sensing Python package that provides parallelized tools for integrating satellite Earth observation data with tide modelling. eo-tides combines advanced tide modelling functionality from the pyTMD package with pandas, xarray and odc-geo, providing a suite of flexible tools for efficient analysis of coastal and ocean Earth observation data – from regional, continental, to global scale.

These tools can be applied to petabytes of freely available satellite data (e.g. from Digital Earth Australia or Microsoft Planetary Computer) loaded via Open Data Cube's odc-stac or datacube packages, supporting coastal and ocean earth observation analysis for any time period or location globally.

Follow the instructions below to get started with eo-tides on the DEA Sandbox:

Setting up eo-tides on the DEA Sandbox

  1. Log into the DEA Sandbox (https://app.sandbox.dea.ga.gov.au/):

    image

  2. Start up a server - select "4XL environment for coastal modelling workshop" if you emailed about extra access; otherwise "Default Environment":



  3. Press "Start" and wait for your server to launch. This may take several minutes.



  4. After a few minutes, your Sandbox will launch and you should see the screen below. On the left is a file browser that you can use to navigate the Sandbox. On the right is a window where we will run interactive "Jupyter Notebook" code examples (for more information, see here).

    image

  5. On the top-left, you will see a blue "New launcher" button. Click this, and then click "Start a new terminal session"

    image image

  6. The eo-tides code and examples live on Github here (https://github.com/GeoscienceAustralia/eo-tides). Our first step is to get a copy of eo-tides inside the DEA Sandbox so we can run it interactively. The commands below will create a "clone" of the eo-tides repository, and then install eo-tides as a Python package so we can use it:

    Clone eo-tides into a new CIRN/eo-tides/ directory:

    git clone https://github.com/GeoscienceAustralia/eo-tides.git CIRN/eo-tides
    

    And now install eo-tides:

    pip install eo-tides
    

    We are now ready to get started!

Launching our first Jupyter Notebook

  1. Using the file browser menu on the left, navigate to CIRN > eo-tides > docs > notebooks. You will see a list of "Jupyter Notebook" files:

    image

  2. Double click on Model_tides.ipynb to launch our first Jupyter Notebook:

  3. Jupyter Notebooks are interactive code examples that contain a mixture of static documentation text, and interactive code. To interact with the notebook, click on any cell, then either click the "play" button above to run the code, or shift-enter on your keyboard.



    The [ ]: symbol to the left of each Code cell describes the state of the cell:

    • [ ]: means that the cell has not been run yet.
    • [*]: means that the cell is currently running.
    • [1]: means that the cell has finished running and was the first cell run.
  4. By default, our Jupyter Notebook comes with outputs from the previous run included in the file. As a first step, we're going to restart and clear our notebook so we can start from fresh. Click Kernel in the file menu up the top-left, then click Restart Kernel and clear all outputs of all cells. This will restart the notebook and clear all our outputs.

    image

Tip

If you ever get stuck, you can restart your Jupyter Notebook by running Kernel > Restart Kernel and clear all outputs of all cells at any time.

Modelling tides with eo-tides

This workshop session will demonstrate how to use the model_tides function from the eo_tides.model module to model tide heights at multiple coordinates or time steps, using one or multiple ocean tide models. The model_tides function supports tide modelling based on a wide range of ocean tide models using a single line of code, parallelising this modelling where possible and returning data in a standardised pandas.Dataframe format. The model_tides function can be used independently of Earth observation (EO) data, e.g. for any application where you need to generate a time series of tide heights. However, it also underpins the more complex EO-related functions demonstrated in Combining tides with satellite data.

Getting started:

  1. Important: the first step in an eo-tides analysis is to download and set up tide models. We have set up the DEA Sandbox with some models for you, but we still need to tell eo-tides where these files are located. In the code cell below, update the code from directory = "../../tests/data/tide_models/" to:

    directory = "/var/share/tide_models/"
    

    image

  2. We've now set up the notebook ready to run. Follow along with the workshop presenter, running each cell one-by-one (using the "play" button or shift-enter) as instructed.

Combining tide modelling with free and open satellite imagery

Combining satellite imagery with tide modelling can be a powerful approach for correcting coastal imagery and for better understanding coastal processes captured by EO data. This workshop session will demonstrate how to integrate tide modelling with satellite Earth observation (EO) data using the tag_tides and pixel_tides functions from eo_tides.eo. These functions allow you to model the height of the tide at the exact moment of satellite image acquisition, and analyse satellite EO data by tidal conditions - for example, filter your data to satellite imagery collected during specific tidal stages (e.g. low or high tide).

Getting started:

  1. In the file browser menu, double-click on Satellite_data.ipynb to launch our second Jupyter Notebook:

    image

  2. Perform a Kernel > Restart Kernel and clear all outputs of all cells to to clear the notebook for a fresh start

  3. As in the previous example, to access our tide models we first need to update the code below from directory = "../../tests/data/tide_models/" to:

    directory = "/var/share/tide_models/"
    
  4. We've now set up the notebook ready to run. Follow along with the workshop presenter, running each cell one-by-one (using the "play" button or shift-enter) as instructed.

Tide statistics and biases in coastal EO imagery