Skip to content

ECCCBen/SeaIceCNN

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

56 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SeaIceCNN

This repository contains the techniques and code referenced in the following publication:

Benoit Montpetit, Benjamin Deschamps, Joshua King & Jason Duffe (2023) Assessing the Parameterization of RADARSAT-2 Dual-polarized ScanSAR Scenes on the Accuracy of a Convolutional Neural Network for Sea Ice Classification: Case Study over Coronation Gulf, Canada, Canadian Journal of Remote Sensing, 49:1, DOI: 10.1080/07038992.2023.2247091

Open-Access Publication: Static Badge

Open-Access Dataset: DOI

Abstract

Arctic amplification has many impacts on sea-ice extent, thickness, and flux. It becomes critical to monitor sea-ice conditions at finer spatio-temporal resolution. We used a simple convolutional neural network (CNN) on the RADARSAT-2 dual-polarized ScanSAR wide archive available over Coronation Gulf, Canada, to assess which SAR parameter improves model performances to classify sea ice from water on a large volume of data covering 11 years of ice and surface water conditions. An overall accuracy of 90.1% was achieved on 989 scenes of 100% ice cover or ice-free conditions. An accuracy of 86.3% was achieved on the last year of data (134 scenes) which was kept out of the training process to test the model on an independent dataset. A better accuracy is obtained at lower incidence angles and the HH polarization provides the most information to classify ice from water. To achieve the best accuracy, the incidence angle and the noise equivalent sigma-nought had to be included as input to the model. A comparison done with the ASI passive microwave product shows similar errors in total sea ice concentration when using the Canadian Ice Service regional charts as reference. Nonetheless, errors from both datasets differ and the CNN outputs show greater potential to reduce masked areas, given the better spatial resolution, enabling data classification closer to land and identify features not captured by the ASI dataset.

Figure 7. (a) CIS regional chart valid July 13, 2020; (b) ASI SIC product of July 13, 2020; (c) MODIS Terra image of July 14; (d) RSAT-2 RGB: HH-HV-HV composite image of July 13,2020; and (e) CNN model output for July 13, 2020.)

Warning Access to RADARSAT-2 data products is not included with this repository. RADARSAT-2 Data and Products © MacDonald, Dettwiler and Associates Ltd. (2023) – All Rights Reserved. RADARSAT is an official mark of the Canadian Space Agency.

Ackowledgments

A special thanks to M. Brady for all his help in organizing this repo and making it shareable.

Environment Configuration

Use miniconda, mamba or anaconda to recreate the runtime environment:

conda env create -n seaicecnn -f environment.yml
conda activate seaicecnn

Warning The provided environment.yml file was generated on Windows 10 and may behave differently on Linux or Mac systems.

Warning Some notebooks in this repository require up to 100GB of available RAM to function properly due to the size of in-memory datasets.

Warning if you want to train the model yourself, it is suggested to use an Nvidia GPU as the environment is setup to make use of CUDA acceleration for Tensorflow. You may still train the model without a GPU but it will take considerably longer.

Data Preparation

To download the datasets used by the notebooks, use the following zenodo link and store the data as shown:

Data
├── AllIceDF.pkl
├── AllWaterDF.pkl
├── SeaIceCNN.h5
├── SeaIceCNN.pkl
├── TestDataS0_ice_rev.npy
├── TestDataS0_water_rev.npy
├── TrainingDataS0_ice_rev.npy
├── TrainingDataS0_water_rev.npy
├── WeeklySIC_ASI.pkl
├── WeeklySIC_CIS.pkl
├── WeeklySIC_RSAT-2.pkl
└── means_stds_S0_cnn.pkl

Exploring the Notebooks

After setting up the environment and data, you may wish to look first at the Table of Contents in the index notebook to discover which parts of the code interest you. In order to launch the Table of Contents notebook on your local system, use the following command while inside the activated seaicecnn environment:

jupyter notebook index.ipynb

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published