Skip to content

FESOM/implicit_filter

Repository files navigation

Logo

Implicit Filter Python Package

DOI arXiv

The Implicit Filter Python Package provides a collection of classes for filtering data using implicit filtering techniques. Currently FESOM, NEMO and longitude-latitude meshes are supported.

For ICON please use this fork made by Aaron Wienkers. In the future it will be integrated into the main repository.

For optimal performance usage of Nvidia GPU is highly recommended.

For details of the implementation please read out paper on arXiv

For full mathematical formulation of the implicit filter please refer to this paper

Installation

Currently Python version 3.10 and 3.9 are supported. Using newer version can enabled

source ./path/to/enviroment/of/your/choice
git clone https://github.com/FESOM/implicit_filter

cd implicit_filter
# CPU only installation
pip install -e .
# GPU installation
pip install -e .[gpu]

Known issues

Installing CuPy can cause an error, in case this happens try installing it manually:

pip install cupy

In case it also doesn't work, check your Nvidia driver version using nvidia-smi and install CuPy version matching your drivers.

Tutorial

Lets start with loading FESOM mesh file and data that we want to filter

This is basic example with only scalar data.

import xarray as xr

path = "your path"
mesh = xr.open_dataset(path + "fesom.mesh.diag.nc")
data = xr.open_dataset(path + "ssh.nc")

unfiltered = data['ssh'].values[0, :]

Now we can create filter.

The easiest way to do it is by using mesh file path

from implicit_filter import CuPyFilter 
# if you don't have GPU use JaxFilter instead

flter = CuPyFilter()
flter.prepare_from_file(path + "fesom.mesh.diag.nc")

JAX warning might appear about GPU not being available, but it should be ignored.

If you don't have GPU support enabled importing CuPyFilter will cause an import error.

Alternatively you can set arrays by yourself, but this is shown in notebooks in examples.

It is highly recommended to save filter's auxiliary arrays as it can take significant amount of time to compute them. Auxiliary arrays are specific to each mesh, so they only need to be computed once.

flter.save_to_file("filter_cash")

Later filter can be created based on this file

flter = CuPyFilter.load_from_file("filter_cash.npz")

Now you can define wavenumber of the filter in two ways.

Using function from the package:

from implicit_filter import convert_to_wavenumbers

distance = 100 # filter size 
dxm = 5 # mesh resolution 
# Units has to be consistent among mesh file and distance and dxm

k = convert_to_wavenumbers(distance, dxm)

or manually:

wavelength = 70
Kc = wavelength * dxm
k = 2 * math.pi / Kc

Finally you can filter your data

filtered = flter.compute(1, k, unfiltered)

Dependencies

CPU only: NumPy, ScipPy, JAX

GPU accelerated: NumPy, CuPy, JAX

Visualization: Matplotlib

IO: Xarray