Skip to content

Optimal interpolation

Thomas Nipen edited this page Jun 18, 2020 · 57 revisions

Optimal interpolation (OI) can be used to create gridded analysis by combining a gridded background field (e.g. from an NWP model) with observations at points. OI weights the background and the observations based on the uncertainty of each data source.

Gridpp's OI method does not perform any quality control (QC) on the observations. Check out Titanlib, which contains suitable QC functions for this purpose. For a complete step-by-step guide on creating gridded analysis, checkout https://tnipen.github.io/2020/06/15/titanlib-gridpp.html.

The OI function signature looks like this:

gridpp.optimal_interpolation(bgrid, background, points, pobs, pratios,
   pbackground, structure, max_points) 

Structure function

The structure function specifies how analysis increments are spread spatially. Gridpp supports several structure functions, but typically

structure = gridpp.BarnesStructure(100000, 200)

The image below illustrates how stations are selected (green) and discarded (red) for a particular gridpoint. In the left panel, all stations within some radius are selected, which is based on the set values for h and minRho.

Observation operator

Maximum locations

Stations can be further limited by setting maxLocations. For example, if maxLocations=4, then only the 4 locations with highest rho value are used (as in the right figure). This reduces computation time significantly in some cases. It also allows for the correction to be localized in dense areas, while still allowing for a large h value such that corrections can be applied in sparse areas.

Observations decorrelate in he vertical too, and is set by the v option.

Error variances

OI requires information about the uncertainty of observations and uncertainty of the background. sigma sets the standard error of the observation. For example, sigma=1 sets the standard error to 1 degree (for temperature). The uncertainty can be modified on a station-by-station basis (see Parameter Files below).

The uncertainty of the background comes from the ensemble spread. This spread is often too low and can therefore be inflated by setting the delta option. For example, delta=2 doubles the ensemble spread.

Transformation

A Gaussian assumption is used, however the background and observations can be transformed using a box-cox transformation.

OI is designed for both temperature and precipitation and can be specified using type. When type=precipitation, the background and observations are transformed using a box-cox transformation.

The observations and background can be transformed before the OI is applied by using the transform option. Currently, only transform=boxcox is supported. This transformation can be used for precipitation. The sigma option is set in the transformed space.

Anti-extrapolation

When OI interpolates the increment between observations, it can in some cases create increments that extrapolate outside the range of values of the increments at the observation points. Gridpp can prevent the extrapolation.

Python examples

The following example uses 3 observations:

Ensemble mode

Gridpp also supports an Ensemble-based Statistical Interpolation (EnSI; Lussana et al. 2019) scheme that uses spatial structure information from an ensemble of NWP model runs.

Clone this wiki locally