NEMO Ocean Engine: Gurvan Madec, and The NEMO Team
NEMO Ocean Engine: Gurvan Madec, and The NEMO Team
January 2011
version 3.3
Note du Pole de modelisation de lInstitut Pierre-Simon Laplace No 27
ISSN No 1288-1619.
Introduction
Model basics
2.1 Primitive Equations . . . . . . . . . . . . . . . . . . . . . .
2.1.1 Vector Invariant Formulation . . . . . . . . . . . . .
2.1.2 Boundary Conditions . . . . . . . . . . . . . . . . .
2.2 The Horizontal Pressure Gradient . . . . . . . . . . . . . .
2.2.1 Pressure Formulation . . . . . . . . . . . . . . . . .
2.2.2 Free Surface Formulation . . . . . . . . . . . . . .
2.3 Curvilinear z-coordinate System . . . . . . . . . . . . . . .
2.3.1 Tensorial Formalism . . . . . . . . . . . . . . . . .
2.3.2 Continuous Model Equations . . . . . . . . . . . . .
2.4 Curvilinear generalised vertical coordinate System . . . . .
2.4.1 The s-coordinate Formulation . . . . . . . . . . . .
2.4.2 Curvilinear z*coordinate System . . . . . . . . . .
2.4.3 Curvilinear Terrain-following scoordinate . . . . .
2.4.4 Curvilinear zcoordinate . . . . . . . . . . . . . . .
2.5 Subgrid Scale Physics . . . . . . . . . . . . . . . . . . . . .
2.5.1 Vertical Subgrid Scale Physics . . . . . . . . . . . .
2.5.2 Lateral Diffusive and Viscous Operators Formulation
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
11
12
12
13
15
15
15
18
18
20
23
24
25
28
30
31
31
32
37
38
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
ii
3.2
3.3
3.4
3.5
3.6
4
.
.
.
.
.
38
39
40
42
43
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
45
46
46
47
49
51
51
53
55
55
57
58
60
62
62
62
65
67
69
69
70
71
71
72
73
73
73
74
75
75
75
76
76
78
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
iii
.
.
.
.
.
.
.
.
.
.
.
.
80
81
82
82
84
86
87
87
88
88
89
89
93
95
95
95
96
96
99
100
100
100
101
102
103
103
103
104
105
106
106
106
107
108
108
109
109
111
111
5.5
5.6
5.7
5.8
5.9
6
iv
7
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
113
115
116
117
119
121
122
122
122
123
124
125
125
127
127
128
130
130
131
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
133
134
137
137
138
139
143
143
145
146
149
149
150
150
151
151
152
152
153
153
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
v
9
.
.
.
.
.
.
155
156
159
159
159
162
163
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
165
166
166
167
167
172
174
176
177
177
179
179
180
181
183
183
184
185
186
186
187
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
189
190
190
191
193
195
196
197
200
201
201
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
vi
11.7 Diagnosing the Steric effect in sea surface height . . . . . . . . . 202
12 Observation and model comparison (OBS)
12.1 Running the observation operator code example . . . . . . . . . .
12.2 Technical details . . . . . . . . . . . . . . . . . . . . . . . . . .
12.2.1 Profile feedback type observation file header . . . . . . .
12.2.2 Sea level anomaly feedback type observation file header .
12.2.3 Sea surface temperature feedback type observation file
header . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12.3 Theoretical details . . . . . . . . . . . . . . . . . . . . . . . . . .
12.3.1 Horizontal interpolation methods . . . . . . . . . . . . .
12.3.2 Grid search . . . . . . . . . . . . . . . . . . . . . . . . .
12.3.3 Parallel aspects of horizontal interpolation . . . . . . . . .
12.3.4 Vertical interpolation operator . . . . . . . . . . . . . . .
207
208
210
211
213
214
216
216
217
218
221
. . . . . .
. . . . . .
orca rX)
. . . . . .
.
.
.
.
.
.
.
.
239
240
240
241
242
vii
15.3.2 ORCA pre-defined resolution
15.4 GYRE family : double gyre basin (key
15.5 EEL family : periodic channel . . . .
15.6 POMME : mid-latitude sub-domain .
A Curvilinear sCoordinate Equations
A.1 Chain rule of scoordinate . . . . . .
A.2 Continuity Equation in scoordinate .
A.3 Momentum Equation in scoordinate
A.4 Tracer Equation . . . . . . . . . . . .
. . . .
gyre)
. . . .
. . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
242
244
245
246
.
.
.
.
247
248
248
250
254
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
261
262
263
266
266
266
270
272
272
273
274
276
276
277
277
278
279
279
280
280
283
284
284
viii
D Coding Rules
D.1 The program structure .
D.2 Coding conventions . .
D.3 Naming Conventions .
D.4 The program structure .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
285
286
286
288
289
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
291
291
291
292
293
295
296
297
298
299
301
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
Index
302
Index
302
Bibliographie
309
Abstract / Resume
The ocean engine of NEMO (Nucleus for European Modelling of the Ocean) is a primitive equation model adapted to regional and global ocean circulation problems. It is
intended to be a flexible tool for studying the ocean and its interactions with the others
components of the earth climate system over a wide range of space and time scales. Prognostic variables are the three-dimensional velocity field, a linear or non-linear sea surface
height, the temperature and the salinity. In the horizontal direction, the model uses a curvilinear orthogonal grid and in the vertical direction, a full or partial step z-coordinate, or
s-coordinate, or a mixture of the two. The distribution of variables is a three-dimensional
Arakawa C-type grid. Various physical choices are available to describe ocean physics,
including TKE, GLS and KPP vertical physics. Within NEMO, the ocean is interfaced
with a sea-ice model (LIM v2 and v3), passive tracer and biogeochemical models (TOP)
and, via the OASIS coupler, with several atmospheric general circulation models. It also
support two-way grid embedding via the AGRIF software.
Le moteur oceanique de NEMO (Nucleus for European Modelling of the Ocean) est
un mod`ele aux e quations primitives de la circulation oceanique regionale et globale. Il
se veut un outil flexible pour e tudier sur un vaste spectre spatiotemporel locean et ses
interactions avec les autres composantes du syst`eme climatique terrestre. Les variables
pronostiques sont le champ tridimensionnel de vitesse, une hauteur de la mer lineaire
ou non, la temperature et la salinite. La distribution des variables se fait sur une grille
C dArakawa tridimensionnelle utilisant une coordonnee verticale z a` niveaux entiers ou
partiels, ou une coordonnee s, ou encore une combinaison des deux. Differents choix sont
proposes pour decrire la physique oceanique, incluant notamment des physiques verticales TKE, GLS et KPP. A travers linfrastructure NEMO, locean est interface avec des
mod`eles de glace de mer, de biogeochimie et de traceurs passifs, et, via le coupleur OASIS, a` plusieurs mod`eles de circulation generale atmospherique. Il supporte e galement
lembotement interactif de maillages via le logiciel AGRIF.
Disclaimer
Like all components of NEMO, the ocean component is developed under the CECILL
license, which is a French adaptation of the GNU GPL (General Public License). Anyone
may use it freely for research purposes, and is encouraged to communicate back to the
NEMO team its own developments and improvements. The model and the present document have been made available as a service to the community. We cannot certify that
the code and its manual are free of errors. Bugs are inevitable and some have undoubtedly survived the testing phase. Users are encouraged to bring them to our attention. The
author assumes no responsibility for problems, errors, or incorrect usage of NEMO.
1 Introduction
The Nucleus for European Modelling of the Ocean (NEMO ) is a framework of ocean
related engines, namely OPA1 for the ocean dynamics and thermodynamics, LIM2 for
the sea-ice dynamics and thermodynamics, TOP3 for the biogeochemistry (both transport (TRP) and sources minus sinks (LOBSTER, PISCES)4 . It is intended to be a flexible
tool for studying the ocean and its interactions with the other components of the earth
climate system (atmosphere, sea-ice, biogeochemical tracers, ...) over a wide range of
space and time scales. This documentation provides information about the physics represented by the ocean component of NEMO and the rationale for the choice of numerical
schemes and the model design. More specific information about running the model on
different computers, or how to set up a configuration, are found on the NEMO web site
(www.locean-ipsl.upmc.fr/NEMO).
The ocean component of NEMO has been developed from the OPA model, release
8.2, described in Madec et al. [1998]. This model has been used for a wide range of
applications, both regional or global, as a forced ocean model and as a model coupled
with the atmosphere. A complete list of references is found on the NEMO web site.
This manual is organised in as follows. Chapter 2 presents the model basics, i.e.
the equations and their assumptions, the vertical coordinates used, and the subgrid scale
physics. This part deals with the continuous equations of the model (primitive equations,
with potential temperature, salinity and an equation of state). The equations are written
in a curvilinear coordinate system, with a choice of vertical coordinates (z or s, with the
rescaled height coordinate formulation z*, or s*). Momentum equations are formulated in
the vector invariant form or in the flux form. Dimensional units in the meter, kilogram,
1
Introduction
TAB . 1.1 Organization of Chapters mimicking the one of the model directories.
Chapter 3
Chapter 4
Chapter 5
Chapter 6
Chapter 7
Chapter 8
Chapter 9
Chapter 10
Chapter 11
Chapter 12
Chapter 13
Chapter 14
Chapter 15
DOM
TRA
DYN
SBC
LBC
LDF
ZDF
DIA
OBS
ASM
SOL
-
Introduction
Partial support of s-coordinate : there is presently no support for neutral physics in s- coordinate and for the new options for horizontal pressure gradient computation with a non-linear
equation of state.
9
16. introduction of LIM-3, the new Louvain-la-Neuve sea-ice model (C-grid rheology and new thermodynamics including bulk ice salinity) [Vancoppenolle et al.
2009b;a]
In addition, several minor modifications in the coding have been introduced with the
constant concern of improving the model performance.
2 Model basics
Contents
2.1
2.2
2.3
2.4
2.5
Primitive Equations . . . . . . . . . . . . . . . . . . . . .
2.1.1 Vector Invariant Formulation . . . . . . . . . . . . .
2.1.2 Boundary Conditions . . . . . . . . . . . . . . . . .
The Horizontal Pressure Gradient . . . . . . . . . . . . .
2.2.1 Pressure Formulation . . . . . . . . . . . . . . . . .
2.2.2 Free Surface Formulation . . . . . . . . . . . . . .
Curvilinear z-coordinate System . . . . . . . . . . . . . .
2.3.1 Tensorial Formalism . . . . . . . . . . . . . . . . .
2.3.2 Continuous Model Equations . . . . . . . . . . . . .
Curvilinear generalised vertical coordinate System . . . .
2.4.1 The s-coordinate Formulation . . . . . . . . . . . .
2.4.2 Curvilinear z*coordinate System . . . . . . . . . .
2.4.3 Curvilinear Terrain-following scoordinate . . . . .
2.4.4 Curvilinear zcoordinate . . . . . . . . . . . . . . .
Subgrid Scale Physics . . . . . . . . . . . . . . . . . . . .
2.5.1 Vertical Subgrid Scale Physics . . . . . . . . . . . .
2.5.2 Lateral Diffusive and Viscous Operators Formulation
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
12
12
13
15
15
15
18
18
20
23
24
25
28
30
31
31
32
12
2.1
2.1.1
Model basics
Primitive Equations
Vector Invariant Formulation
The ocean is a fluid that can be described to a good approximation by the primitive
equations, i.e. the Navier-Stokes equations along with a nonlinear equation of state which
couples the two active tracers (temperature and salinity) to the fluid velocity, plus the
following additional assumptions made from scale considerations :
(1) spherical earth approximation : the geopotential surfaces are assumed to be spheres
so that gravity (local vertical) is parallel to the earths radius
(2) thin-shell approximation : the ocean depth is neglected compared to the earths
radius
(3) turbulent closure hypothesis : the turbulent fluxes (which represent the effect of
small scale processes on the large-scale) are expressed in terms of large-scale features
(4) Boussinesq hypothesis : density variations are neglected except in their contribution to the buoyancy force
(5) Hydrostatic hypothesis : the vertical momentum equation is reduced to a balance
between the vertical pressure gradient and the buoyancy force (this removes convective
processes from the initial Navier-Stokes equations and so convective processes must be
parameterized instead)
(6) Incompressibility hypothesis : the three dimensional divergence of the velocity
vector is assumed to be zero.
Because the gravitational force is so dominant in the equations of large-scale motions, it is useful to choose an orthogonal set of unit vectors (i,j,k) linked to the earth such
that k is the local upward vector and (i,j) are two vectors orthogonal to k, i.e. tangent
to the geopotential surfaces. Let us define the following variables : U the vector velocity,
U = Uh +w k (the subscript h denotes the local horizontal vector, i.e. over the (i,j) plane),
T the potential temperature, S the salinity, the in situ density. The vector invariant form
of the primitive equations in the (i,j,k) vector system provides the following six equations (namely the momentum balance, the hydrostatic equilibrium, the incompressibility
equation, the heat and salt conservation equations and an equation of state) :
Uh
1
1
2
= ( U) U + U
f k Uh h p + DU + FU (2.1a)
t
2
o
h
p
= g
z
(2.1b)
U=0
(2.1c)
13
T
= (T U) + DT + F T
t
(2.1d)
S
= (S U) + DS + F S
t
(2.1e)
= (T, S, p)
(2.1f)
where is the generalised derivative vector operator in (i, j, k) directions, t is the time, z
is the vertical coordinate, is the in situ density given by the equation of state (2.1f), o is
a reference density, p the pressure, f = 2 k is the Coriolis acceleration (where is the
Earths angular velocity vector), and g is the gravitational acceleration. DU , DT and DS
are the parameterisations of small-scale physics for momentum, temperature and salinity,
and FU , F T and F S surface forcing terms. Their nature and formulation are discussed in
2.5 and page 2.1.2.
.
2.1.2
Boundary Conditions
An ocean is bounded by complex coastlines, bottom topography at its base and an
air-sea or ice-sea interface at its top. These boundaries can be defined by two surfaces,
z = H(i, j) and z = (i, j, k, t), where H is the depth of the ocean bottom and is
the height of the sea surface. Both H and are usually referenced to a given surface,
z = 0, chosen as a mean sea surface (Fig. 2.1). Through these two boundaries, the ocean
can exchange fluxes of heat, fresh water, salt, and momentum with the solid earth, the
continental margins, the sea ice and the atmosphere. However, some of these fluxes are so
weak that even on climatic time scales of thousands of years they can be neglected. In the
following, we briefly review the fluxes exchanged at the interfaces between the ocean and
the other components of the earth system.
Land - ocean interface : the major flux between continental margins and the ocean is
a mass exchange of fresh water through river runoff. Such an exchange modifies
the sea surface salinity especially in the vicinity of major river mouths. It can be
neglected for short range integrations but has to be taken into account for long term
integrations as it influences the characteristics of water masses formed (especially
at high latitudes). It is required in order to close the water cycle of the climate
system. It is usually specified as a fresh water flux at the air-sea interface in the
vicinity of river mouths.
Solid earth - ocean interface : heat and salt fluxes through the sea floor are small, except in special areas of little extent. They are usually neglected in the model 1 . The
1
In fact, it has been shown that the heat flux associated with the solid Earth cooling (i.e.the
geothermal heating) is not negligible for the thermohaline circulation of the world ocean (see
5.4.3).
14
Model basics
(i,j,t)
H(i,j)
i, j
F IG . 2.1 The ocean is bounded by two surfaces, z = H(i, j) and z = (i, j, t),
where H is the depth of the sea floor and the height of the sea surface. Both H
and are referenced to z = 0.
boundary condition is thus set to no flux of heat and salt across solid boundaries.
For momentum, the situation is different. There is no flow across solid boundaries,
i.e. the velocity normal to the ocean bottom and coastlines is zero (in other words,
the bottom velocity is parallel to solid boundaries). This kinematic boundary condition can be expressed as :
w = Uh h (H)
(2.2)
In addition, the ocean exchanges momentum with the earth through frictional processes. Such momentum transfer occurs at small scales in a boundary layer. It must
be parameterized in terms of turbulent fluxes using bottom and/or lateral boundary
conditions. Its specification depends on the nature of the physical parameterisation
used for DU in (2.1a). It is discussed in 2.5.1, page 31.
Atmosphere - ocean interface : the kinematic surface condition plus the mass flux of
fresh water PE (the precipitation minus evaporation budget) leads to :
w=
+ Uh |z= h () + P E
t
(2.3)
The dynamic boundary condition, neglecting the surface tension (which removes
capillary waves from the system) leads to the continuity of pressure across the
interface z = . The atmosphere and ocean also exchange horizontal momentum
(wind stress), and heat.
Sea ice - ocean interface : the ocean and sea ice exchange heat, salt, fresh water and
momentum. The sea surface temperature is constrained to be at the freezing point
15
at the interface. Sea ice salinity is very low ( 4 6 psu) compared to those of the
ocean ( 34 psu). The cycle of freezing/melting is associated with fresh water and
salt fluxes that cannot be neglected.
2.2
2.2.1
ph (i, j, z, t) =
g (T, S, ) d
(2.4)
=z
Two strategies can be considered for the surface pressure term : (a) introduce of a new
variable , the free-surface elevation, for which a prognostic equation can be established
and solved ; (b) assume that the ocean surface is a rigid lid, on which the pressure (or its
horizontal gradient) can be diagnosed. When the former strategy is used, one solution of
the free-surface elevation consists of the excitation of external gravity waves. The flow
is barotropic and the surface moves up and down with gravity as the restoring force.
The phase speed of such waves is high (some hundreds of metres per second) so that
the time step would have to be very short if they were present in the model. The latter
strategy filters out these waves since the rigid lid approximation implies = 0, i.e. the
sea surface is the surface z = 0. This well known approximation increases the surface
wave speed to infinity and modifies certain other longwave dynamics (e.g. barotropic
Rossby or planetary waves). The rigid-lid hypothesis is an obsolescent feature in modern
OGCMs. It has been available until the release 3.1 of NEMO , and it has been removed in
release 3.2 and followings. Only the free surface formulation is now described in the this
document (see the next sub-section).
2.2.2
= D + P E
t
where D = (H + ) Uh
(2.5)
16
Model basics
hydrostatic assumption, and their phase speed is quite high. Their time scale is short with
respect to the other processes described by the primitive equations.
Two choices can be made regarding the implementation of the free surface in the
model, depending on the physical processes of interest.
If one is interested in EGWs, in particular the tides and their interaction with the
baroclinic structure of the ocean (internal waves) possibly in shallow seas, then a non
linear free surface is the most appropriate. This means that no approximation is made in
(2.5) and that the variation of the ocean volume is fully taken into account. Note that in
order to study the fast time scales associated with EGWs it is necessary to minimize time
filtering effects (use an explicit time scheme with very small time step, or a split-explicit
scheme with reasonably small time step, see 6.5.1 or 6.5.2.
If one is not interested in EGW but rather sees them as high frequency noise, it
is possible to apply an explicit filter to slow down the fastest waves while not altering
the slow barotropic Rossby waves. If further, an approximative conservation of heat and
salt contents is sufficient for the problem solved, then it is sufficient to solve a linearized
version of (2.5), which still allows to take into account freshwater fluxes applied at the
ocean surface [Roullet and Madec 2000].
The filtering of EGWs in models with a free surface is usually a matter of discretisation of the temporal derivatives, using the time splitting method [Killworth et al. 1991,
Zhang and Endoh 1992] or the implicit scheme [Dukowicz and Smith 1994]. In NEMO ,
we use a slightly different approach developed by Roullet and Madec [2000] : the damping of EGWs is ensured by introducing an additional force in the momentum equation.
(2.1a) becomes :
Uh
= M g (
) g Tc (e
t )
(2.6)
t
where Tc , is a parameter with dimensions of time which characterizes the force, e = /o
is the dimensionless density, and M represents the collected contributions of the Coriolis,
hydrostatic pressure gradient, non-linear and viscous terms in (2.1a).
The new force can be interpreted as a diffusion of vertically integrated volume flux
divergence. The time evolution of D is thus governed by a balance of two terms, g
A and g Tc A D, associated with a propagative regime and a diffusive regime in the
temporal spectrum, respectively. In the diffusive regime, the EGWs no longer propagate,
i.e. they are stationary and damped. The diffusion regime applies to the modes shorter
than Tc . For longer ones, the diffusion term vanishes. Hence, the temporally unresolved
EGWs can be damped by choosing Tc > t. Roullet and Madec [2000] demonstrate
that (2.6) can be integrated with a leap frog scheme except the additional term which has
to be computed implicitly. This is not surprising since the use of a large time step has a
necessarily numerical cost. Two gains arise in comparison with the previous formulations.
Firstly, the damping of EGWs can be quantified through the magnitude of the additional
term. Secondly, the numerical scheme does not need any tuning. Numerical stability is
ensured as soon as Tc > t.
When the variations of free surface elevation are small compared to the thickness of
the first model layer, the free surface equation (2.5) can be linearized. As emphasized by
17
Roullet and Madec [2000] the linearization of (2.5) has consequences on the conservation
of salt in the model. With the nonlinear free surface equation, the time evolution of the
total salt content is
Z
Z
S dv = S (
D + P E) ds
(2.7)
t
t
D
where S is the salinity, and the total salt is integrated over the whole ocean volume D
bounded by the time-dependent free surface. The right hand side (which is an integral over
the free surface) vanishes when the nonlinear equation (2.5) is satisfied, so that the salt
is perfectly conserved. When the free surface equation is linearized, Roullet and Madec
[2000] show that the total salt content integrated in the fixed volume D (bounded by the
surface z = 0) is no longer conserved :
Z
Z
S dv = S
ds
(2.8)
t
t
D
The right hand side of (2.8) is small in equilibrium solutions [Roullet and Madec
2000]. It can be significant when the freshwater forcing is not balanced and the globally
averaged free surface is drifting. An increase in sea surface height results in a decrease
of the salinity in the fixed volume D. Even in that case though, the total salt integrated in
the variable volume D varies much less, since (2.8) can be rewritten as
Z
Z
Z
Z
S
S dv =
S dv + S ds =
ds
(2.9)
t
t
t
D
Although the total salt content is not exactly conserved with the linearized free surface, its variations are driven by correlations of the time variation of surface salinity with
the sea surface height, which is a negligible term. This situation contrasts with the case
of the rigid lid approximation in which case freshwater forcing is represented by a virtual
salt flux, leading to a spurious source of salt at the ocean surface [Huang 1993, Roullet
and Madec 2000].
18
2.3
2.3.1
Model basics
e1 = (a + z)
cos +
i
i
"
2 2 #1/2
(2.10)
e2 = (a + z)
cos +
j
j
z
e3 =
k
Since the ocean depth is far smaller than the earths radius, a + z, can be replaced
by a in (2.10) (thin-shell approximation). The resulting horizontal scale factors e1 , e2 are
independent of k while the vertical scale factor is a single function of k as k is parallel
19
z
i
k
j
F IG . 2.2 the geographical coordinate system (, , z) and the curvilinear coordinate system (i,j,k).
to z. The scalar and vector operators that appear in the primitive equations (Eqs. (2.1a) to
(2.1f)) can be written in the tensorial form, invariant in any orthogonal horizontal curvilinear coordinate system transformation :
q =
1 q
1 q
1 q
i+
j+
k
e1 i
e2 j
e3 k
1
1 a3
(e2 a1 ) (e1 a2 )
A=
+
+
e1 e2
i
j
e3 k
1 a3
1 a2
A=
e2 j
e3 k
1 a1
1 a3
i+
j
e3 k
e1 i
1
(e2 a2 ) (e1 a1 )
+
k
e1 e2
i
j
(2.11a)
(2.11b)
(2.11c)
q = (q)
(2.11d)
A = ( A) ( A)
(2.11e)
20
2.3.2
Model basics
e1 e2
i
j
1
(e2 u) (e1 v)
=
(2.13)
+
e1 e2
i
j
Using the fact that the horizontal scale factors e1 and e2 are independent of k and that
e3 is a function of the single variable k, the nonlinear term of (2.1a) can be transformed
as follows :
1
( U) U + U2
2
h
h
=
=
1 u
1 w
e3 k h e1 i w i
1 v
u e12 w
j e3 k
v
u
1
+
2
1
+
2
w
v
2
2
1 (u +v )
e1
i
2
2
1 (u +v )
e2
j
+ 1
e3
2
2
2
1 (u +v +w )
e1
i
2
2
2
1 (u +v +w )
e2
j
w
w
u
k
v
k
w
e1
w
e2
w
i
w
j
1
2e1
1
2e2
w2
i
w2
j
The last term of the right hand side is obviously zero, and thus the nonlinear term of
(2.1a) is written in the (i, j, k) coordinate system :
1
1
1 Uh
( U) U + U2
= k Uh + h U2h + w
(2.14)
2
2
e
k
3
h
This is the so-called vector invariant form of the momentum advection term. For some
purposes, it can be advantageous to write this term in the so-called flux form, i.e. to write
it as the divergence of fluxes. For example, the first component of (2.14) (the i-component)
is transformed as follows :
(u2 +v 2 )
( U) U + 12 U2 i = v + 2 1e1
+ e13 w u
i
k
=
1
e1 e2
v (ei2 v) + v (ej1 u) +
1
e1 e2
n
(e1 u v)
v
v
2
v 2 e
+
e
v
+
e
u
2
1
i
i
j o
j
(w u)
1
w
2 u u)
+ (ei
u (ei2 u) + e2 v v
+
u
i
e3
k
k
1
e1 e2
v
+e2 u u
i + e2 v i +
1
e3
u
k
1
e1 e2
(e2 u u)
(e1 u v)
i + j
+ e11e2 u (ej1 v)
= (U u) ( U) u +
1 (w u)
e3 k
(e2 u)
e1
u
j
i
21
+
v
1
e1 e2
2
v 2 e
i + uv
1 w
e3 k u
e1
j
1
e1 e2
2
v 2 e
i
as U = 0 (incompressibility) it comes :
e1
2
= (U u) + e11e2 v e
u
(v)
i
j
The flux form of the momentum advection term is therefore given by :
1
( U) U + U2
2
h
e2
e1
1
Uu
v
u
k Uh (2.15)
=
+
Uv
e1 e2
i
j
The flux form has two terms, the first one is expressed as the divergence of momentum
fluxes (hence the flux form name given to this formulation) and the second one is due to
the curvilinear nature of the coordinate system used. The latter is called the metric term
and can be viewed as a modification of the Coriolis parameter :
1
e1
e2
f f+
u
(2.16)
v
e1 e2
i
j
Note that in the case of geographical coordinate, i.e. when (i, j) (, ) and
(e1 , e2 ) (a cos , a), we recover the commonly used modification of the Coriolis parameter f f + (u/a) tan .
To sum up, the curvilinear z-coordinate equations solved by the ocean model can be
written in the following tensorial formalism :
Vector invariant form of the momentum equations :
u
1
1 u
= + ( + f ) v
u2 + v 2 w
t
2 e1 i
e k
3
1 ps + ph
+ DuU + FuU
e1 i
o
(2.17a)
v
1
1 v
= ( + f ) u
u2 + v 2 w
t
2 e2 j
e k
3
1 ps + ph
+ DvU + FvU
e2 j
o
22
Model basics
flux form of the momentum equations :
u
e2
1
e1
v
v
=+ f+
u
t
e1 e2
i
j
(e2 u u) (e1 v u)
1 (w u)
1
+
e1 e2
i
j
e3 k
1 ps + ph
+
e1 e2
i
j
e3 k
1 ps + ph
+ DT + F T
t
e1 e2
i
j
e3 k
S
1
(e2 S u) (e1 S v)
1 (S w)
=
+
+ DS + F S
t
e1 e2
i
j
e3 k
= (T, S, z(k))
(2.21)
(2.22)
(2.23)
(2.24)
2.4
23
(2.25)
with the restriction that the above equation gives a single-valued monotonic relationship
between s and k, when i, j and t are held fixed. (2.25) is a transformation from the
(i, j, k, t) coordinate system with independent variables into the (i, j, s, t) generalised
coordinate system with s depending on the other three variables through (2.25). This socalled generalised vertical coordinate [Kasahara 1974] is in fact an Arbitrary Lagrangian
Eulerian (ALE) coordinate. Indeed, choosing an expression for s is an arbitrary choice that
determines which part of the vertical velocity (defined from a fixed referential) will cross
the levels (Eulerian part) and which part will be used to move them (Lagrangian part). The
coordinate is also sometime referenced as an adaptive coordinate [Hofmeister et al. 2009],
since the coordinate system is adapted in the course of the simulation. Its most often used
implementation is via an ALE algorithm, in which a pure lagrangian step is followed by
regridding and remapping steps, the later step implicitly embedding the vertical advection
[Hirt et al. 1974, Chassignet et al. 2003, White et al. 2009]. Here we follow the [Kasahara
1974] strategy : a regridding step (an update of the vertical coordinate) followed by an
eulerian step with an explicit computation of vertical advection relative to the moving
s-surfaces.
the generalized vertical coordinates used in ocean modelling are not orthogonal, which
contrasts with many other applications in mathematical physics. Hence, it is useful to keep
in mind the following properties that may seem odd on initial encounter.
24
Model basics
The horizontal velocity in ocean models measures motions in the horizontal plane,
perpendicular to the local gravitational field. That is, horizontal velocity is mathematically the same regardless the vertical coordinate, be it geopotential, isopycnal, pressure, or
terrain following. The key motivation for maintaining the same horizontal velocity component is that the hydrostatic and geostrophic balances are dominant in the large-scale
ocean. Use of an alternative quasi-horizontal velocity, for example one oriented parallel
to the generalized surface, would lead to unacceptable numerical errors. Correspondingly,
the vertical direction is anti-parallel to the gravitational force in all of the coordinate systems. We do not choose the alternative of a quasi-vertical direction oriented normal to the
surface of a constant generalized vertical coordinate.
It is the method used to measure transport across the generalized vertical coordinate
surfaces which differs between the vertical coordinate choices. That is, computation of
the dia-surface velocity component represents the fundamental distinction between the
various coordinates. In some models, such as geopotential, pressure, and terrain following,
this transport is typically diagnosed from volume or mass conservation. In other models,
such as isopycnal layered models, this transport is prescribed based on assumptions about
the physical processes producing a flux across the layer interfaces.
In this section we first establish the PE in the generalised vertical s-coordinate, then
we discuss the particular cases available in NEMO , namely z, z*, s, and z.
2.4.1
, and
1 z
2 =
e2 j s
(2.26)
= w e3
s
1 u 2 v
t
(2.27)
The equations solved by the ocean model (2.1) in scoordinate can be written as
follows :
25
* momentum equation :
1 (e3 u)
1
1 u
= + ( + f ) v
u2 + v 2
e3 t
2 e1 i
e3 k
1 ps + ph
+ g 1 + DuU + FuU
e1 i
o
o
1 (e3 v)
1 v
1
u2 + v 2
= ( + f ) u
e3 t
2 e2 j
e k
3
1 ps + ph
+ g 2 + DvU + FvU
e2 j
o
o
(2.28)
(2.29)
where the relative vorticity, , the surface pressure gradient, and the hydrostatic pressure
have the same expressions as in z-coordinates although they do not represent exactly the
same quantities. is provided by the continuity equation (see Appendix A) :
e3
+ e3 +
=0
t
s
1
(e2 e3 u) (e1 e3 v)
with =
+
e1 e2 e3
i
j
(2.30)
* tracer equations :
1 (e3 T )
1
(e2 e3 u T ) (e1 e3 v T )
=
+
e3 t
e1 e2 e3
i
j
1 (T )
+ DT + F S
e3 k
1 (e3 S)
1
(e2 e3 u S) (e1 e3 v S)
=
+
e3 t
e1 e2 e3
i
j
1 (S )
+ DS + F S
e3 k
(2.31)
(2.32)
The equation of state has the same expression as in z-coordinate, and similar expressions are used for mixing and forcing terms.
2.4.2
26
Model basics
vertical resolution [Adcroft and Campin 2004]. In the z* formulation, the variation of the
column thickness due to sea-surface undulations is not concentrated in the surface level,
as in the z-coordinate formulation, but is equally distributed over the full water column.
Thus vertical levels naturally follow sea-surface variations, with a linear attenuation with
depth, as illustrated by figure fig.1c . Note that with a flat bottom, such as in fig.1c, the
bottom-following z coordinate and z* are equivalent. The definition and modified oceanic
equations for the rescaled vertical coordinate z*, including the treatment of fresh-water
flux at the surface, are detailed in Adcroft and Campin (2004). The major points are summarized here. The position ( z*) and vertical discretization (z*) are expressed as :
H + z* = (H + z)/r
and z* = z/r
with r =
H +
H
(2.33)
Since the vertical displacement of the free surface is incorporated in the vertical coordinate z*, the upper and lower boundaries are at fixed z* position, z* = 0 and z* = H
respectively. Also the divergence of the flow field is no longer zero as shown by the conti-
(a)
(b)
(c)
F IG . 2.3 (a) z-coordinate in linear free-surface case ; (b) zcoordinate in nonlinear free surface case ; (c) re-scaled height coordinate (become popular as the
z*-coordinate [Adcroft and Campin 2004] ).
27
nuity equation :
r
= z* (r Uh ) (r w*) = 0
t
To overcome problems with vanishing surface and/or bottom cells, we consider the
zstar coordinate
z
?
z =H
(2.34)
H +
This coordinate is closely related to the eta coordinate used in many atmospheric
models (see Black (1994) for a review of eta coordinate atmospheric models). It was originally used in ocean models by Stacey et al. (1995) for studies of tides next to shelves,
and it has been recently promoted by Adcroft and Campin (2004) for global climate modelling.
The surfaces of constant z ? are quasi-horizontal. Indeed, the z ? coordinate reduces to
z when is zero. In general, when noting the large differences between undulations of
the bottom topography versus undulations in the surface height, it is clear that surfaces
constant z ? are very similar to the depth surfaces. These properties greatly reduce difficulties of computing the horizontal pressure gradient relative to terrain following sigma
models discussed in 2.4.3. Additionally, since z ? when = 0, no flow is spontaneously
generated in an unforced ocean starting from rest, regardless the bottom topography. This
behaviour is in contrast to the case with s-models, where pressure gradient errors in the
presence of nontrivial topographic variations can generate nontrivial spontaneous flow
from a resting state, depending on the sophistication of the pressure gradient solver. The
quasi-horizontal nature of the coordinate surfaces also facilitates the implementation of
neutral physics parameterizations in z ? models using the same techniques as in z-models
(see Chapters 13-16 of Griffies [2004]) for a discussion of neutral physics in z-models, as
well as Section 9.2 in this document for treatment in NEMO ).
The range over which z ? varies is time independent H z ? 0. Hence, all cells
remain nonvanishing, so long as the surface height maintains >?H. This is a minor
constraint relative to that encountered on the surface height when using s = z or s = z.
Because z ? has a time independent range, all grid cells have static increments ds, and
the sum of the ver tical increments yields the time independent ocean depth The z ? coordinate is therefore invisible to undulations of the free surface, since it moves along with the
free surface. This proper ty means that no spurious ver tical transpor t is induced across
surfaces of constant z ? by the motion of external gravity waves. Such spurious transpor
t can be a problem in z-models, especially those with tidal forcing. Quite generally, the
time independent range for the z ? coordinate is a very convenient proper ty that allows for
a nearly arbitrary ver tical resolution even in the presence of large amplitude fluctuations
of the surface height, again so long as > H.
28
2.4.3
Model basics
p
z|s
s
(2.35)
The second term in (2.35) depends on the tilt of the coordinate surface and introduces
a truncation error that is not present in a z-model. In the special case of a coordinate
(i.e. a depth-normalised coordinate system = z/H), Haney [1991] and Beckmann and
Haidvogel [1993] have given estimates of the magnitude of this truncation error. It depends on topographic slope, stratification, horizontal and vertical resolution, the equation
of state, and the finite difference scheme. This error limits the possible topographic slopes
that a model can handle at a given horizontal and vertical resolution. This is a severe
restriction for large-scale applications using realistic bottom topography. The large-scale
slopes require high horizontal resolution, and the computational cost becomes prohibi-
29
tive. This problem can be at least partially overcome by mixing s-coordinate and step-like
representation of bottom topography [Gerdes 1993a;b, Madec et al. 1996]. However, the
definition of the model domain vertical coordinate becomes then a non-trivial thing for a
realistic bottom topography : a envelope topography is defined in s-coordinate on which
a full or partial step bottom topography is then applied in order to adjust the model depth
to the observed one (see 4.3.
For numerical reasons a minimum of diffusion is required along the coordinate surfaces of any finite difference model. It causes spurious diapycnal mixing when coordinate
surfaces do not coincide with isoneutral surfaces. This is the case for a z-model as well
as for a s-model. However, density varies more strongly on ssurfaces than on horizontal
surfaces in regions of large topographic slopes, implying larger diapycnal diffusion in a
s-model than in a z-model. Whereas such a diapycnal diffusion in a z-model tends to weaken horizontal density (pressure) gradients and thus the horizontal circulation, it usually
reinforces these gradients in a s-model, creating spurious circulation. For example, imagine an isolated bump of topography in an ocean at rest with a horizontally uniform stratification. Spurious diffusion along s-surfaces will induce a bump of isoneutral surfaces
over the topography, and thus will generate there a baroclinic eddy. In contrast, the ocean
will stay at rest in a z-model. As for the truncation error, the problem can be reduced
by introducing the terrain-following coordinate below the strongly stratified portion of
the water column (i.e. the main thermocline) [Madec et al. 1996]. An alternate solution
consists of rotating the lateral diffusive tensor to geopotential or to isoneutral surfaces (see
2.5.2. Unfortunately, the slope of isoneutral surfaces relative to the s-surfaces can very
large, strongly exceeding the stability limit of such a operator when it is discretized (see
Chapter 9).
The scoordinates introduced here [Lott et al. 1990, Madec et al. 1996] differ mainly
in two aspects from similar models : it allows a representation of bottom topography with
mixed full or partial step-like/terrain following topography ; It also offers a completely
general transformation, s = s(i, j, z) for the vertical coordinate.
30
2.4.4
Model basics
Curvilinear zcoordinate
The z-coordinate has been developed by Leclair and Madec [2010]. It is not available
in the current version of NEMO .
2.5
31
2.5.1
vU
vm Uh
D =
A
,
z
z
(2.36)
vT
vT T
vS
vT S
D =
A
, D =
A
z
z
z
z
where Avm and AvT are the vertical eddy viscosity and diffusivity coefficients, respectively. At the sea surface and at the bottom, turbulent fluxes of momentum, heat and salt
must be specified (see Chap. 7 and 10 and 5.5). All the vertical physics is embedded in
the specification of the eddy coefficients. They can be assumed to be either constant, or
function of the local fluid properties (e.g. Richardson number, Brunt-Vaisala frequency...),
32
Model basics
or computed from a turbulent closure model. The choices available in NEMO are discussed in 10).
2.5.2
33
All these parameterisations of subgrid scale physics present advantages and drawbacks. There are not all available in NEMO . In the z-coordinate formulation, five options
are offered for active tracers (temperature and salinity) : second order geopotential operator, second order isoneutral operator, Gent and Mcwilliams [1990] parameterisation,
fourth order geopotential operator, and various slightly diffusive advection schemes. The
same options are available for momentum, except Gent and Mcwilliams [1990] parameterisation which only involves tracers. In the s-coordinate formulation, additional options
are offered for tracers : second order operator acting along ssurfaces, and for momentum : fourth order operator acting along ssurfaces (see 9).
1
0
r1
1
r2
<= 0
2
2
r1 r2 r1 + r2
with
(2.37)
where r1 and r2 are the slopes between the surface along which the diffusive operator
acts and the model level (e.g. z- or s-surfaces). Note that the formulation (2.37) is exact
for the rotation between geopotential and s-surfaces, while it is only an approximation
for the rotation between isoneutral and z- or s-surfaces. Indeed, in the latter case, two
assumptions are made to simplify (2.37) [Cox 1987]. First, the horizontal contribution of
the dianeutral mixing is neglected since the ratio between iso and dia-neutral diffusive
coefficients is known to be several orders of magnitude smaller than unity. Second, the
two isoneutral directions of diffusion are assumed to be independent since the slopes are
generally less than 102 in the ocean (see Appendix B).
For geopotential diffusion, r1 and r2 are the slopes between the geopotential and computational surfaces : in z-coordinates they are zero (r1 = r2 = 0) while in s-coordinate
(including z* case) they are equal to 1 and 2 , respectively (see (2.26) ).
For isoneutral diffusion r1 and r2 are the slopes between the isoneutral and computational surfaces. Therefore, they have a same expression in z- and s-coordinates :
e3
r1 =
e1
1
,
e3
r1 =
e1
1
(2.38)
When the Eddy Induced Velocity parametrisation (eiv) [Gent and Mcwilliams 1990]
is used, an additional tracer advection is introduced in combination with the isoneutral
diffusion of tracers :
DlT = AlT < T + (U T )
(2.39)
where U = (u , v , w ) is a non-divergent, eddy-induced transport velocity. This velo-
34
Model basics
eiv
eiv
w =
A e2 r1 +
A e1 r2
e1 e2 i
j
u = +
(2.40)
where Aeiv is the eddy induced velocity coefficient (or equivalently the isoneutral thickness diffusivity coefficient), and r1 and r2 are the slopes between isoneutral and geopotential surfaces and thus depends on the coordinate considered :
(
rn
in z-coordinate
rn =
where n = 1, 2
(2.41)
rn + n in z* and s-coordinates
The normal component of the eddy induced velocity is zero at all the boundaries. This
can be achieved in a model by tapering either the eddy coefficient or the slopes to zero in
the vicinity of the boundaries. The latter strategy is used in NEMO (cf. Chap. 9).
(2.42)
It is the second order operator given by (2.37) applied twice with the eddy diffusion
coefficient correctly placed.
1 Alm
1 Alm e3
(2.43)
i
e2 e3
j
e1
=
1 Alm
1 Alm e3
+
e2
j
e1 e3
i
Such a formulation ensures a complete separation between the vorticity and horizontal
divergence fields (see Appendix E). Unfortunately, it is not available for geopotential
diffusion in scoordinates and for isoneutral diffusion in both z- and s-coordinates (i.e.
35
when a rotation is required). In these two cases, the u and vfields are considered as
independent scalar fields, so that the diffusive operator is given by :
DulU = . (< u)
DvlU = . (< v)
(2.44)
where < is given by (2.37). It is the same expression as those used for diffusive operator
on tracers. It must be emphasised that such a formulation is only exact in a Cartesian
coordinate system, i.e. on a f or plane, not on the sphere. It is also a very good
approximation in vicinity of the Equator in a geographical coordinate system [Lengaigne
et al. 2003].
DulU = Alm u
where () = (<())
DlU = Alm v
v
(2.46)
Contents
3.1
3.2
3.3
3.4
3.5
3.6
.
.
.
.
.
.
.
.
.
.
.
.
38
38
39
40
42
43
38
Having defined the continuous equations in Chap. 2, we need now to choose a time
discretization. In the present chapter, we provide a general description of the NEMO time
stepping strategy and the consequences for the order in which the equations are solved.
3.1
3.2
39
scheme allows the coexistence of a numerical and a physical mode due to its leading third
order dispersive error. In other words a divergence of odd and even time steps may occur.
To prevent it, the leapfrog scheme is often used in association with a Robert-Asselin time
filter (hereafter the LF-RA scheme). This filter, first designed by Robert [1966] and more
comprehensively studied by Asselin [1972], is a kind of laplacian diffusion in time that
mixes odd and even time steps :
h
i
t
t+t
xtF = xt + xtt
2x
+
x
(3.2)
F
where the subscript F denotes filtered values and is the Asselin coefficient. is initialized as rn atfp (namelist parameter). Its default value is rn atfp=103 (see 3.5), causing
only a weak dissipation of high frequency motions ([Farge 1987]). The addition of a time
filter degrades the accuracy of the calculation from second to first order. However, the second order truncation error is proportional to , which is small compared to 1. Therefore,
the LF-RA is a quasi second order accurate scheme. The LF-RA scheme is preferred to
other time differencing schemes such as predictor corrector or trapezoidal schemes, because the user has an explicit and simple control of the magnitude of the time diffusion of
the scheme. When used with the 2nd order space centred discretisation of the advection
terms in the momentum and tracer equations, LF-RA avoids implicit numerical diffusion :
diffusion is set explicitly by the user through the Robert-Asselin filter parameter and the
viscosity and diffusion coefficients.
3.3
laplacian diffusion
8
t
h
A <
(3.4)
4
bilaplacian diffusion
64 t
where e is the smallest grid size in the two horizontal directions and Ah is the mixing
coefficient. The linear constraint (3.4) is a necessary condition, but not sufficient. If it is
not satisfied, even mildly, then the model soon becomes wildly unstable. The instability
can be removed by either reducing the length of the time steps or reducing the mixing
coefficient.
For the vertical diffusion terms, a forward time differencing scheme can be used, but
usually the numerical stability condition imposes a strong constraint on the time step. Two
40
solutions are available in NEMO to overcome the stability constraint : (a) a forward time
differencing scheme using a time splitting technique (ln zdfexp = true) or (b) a backward
(or implicit) time differencing scheme (ln zdfexp = false). In (a), the master time step t
is cut into N fractional time steps so that the stability criterion is reduced by a factor of
N . The computation is performed as follows :
xtt = xtt
tt+L 2t
N
tt+(L1) 2t
N
= x
2t
2t
DFtt+(L1) N
N
for L = 1 to N
(3.5)
xt+t = xt+t
with DF a vertical diffusion term. The number of fractional time steps, N , is given by
setting nn zdfexp, (namelist parameter). The scheme (b) is unconditionally stable but diffusive. It can be written as follows :
xt+t = xtt + 2 t RHSt+t
x
(3.6)
This scheme is rather time consuming since it requires a matrix inversion, but it becomes attractive since a value of 3 or more is needed for N in the forward time differencing
scheme. For example, the finite difference approximation of the temperature equation is :
vT
t+1
T (k)t+1 T (k)t1
1
Aw
(3.7)
RHS +
k
T
2 t
e3t
e3w k+1/2
where RHS is the right hand side of the equation except for the vertical diffusion term.
We rewrite (3.6) as :
c(k + 1) T t+1 (k + 1) + d(k) T t+1 (k) c(k) T t+1 (k 1) b(k)
(3.8)
where
c(k) = AvT
w (k) / e3w (k)
d(k) = e3t (k) / (2t) + ck + ck+1
b(k) = e3t (k) T t1 (k) / (2t) + RHS
(3.8) is a linear system of equations with an associated matrix which is tridiagonal.
Moreover, c(k) and d(k) are positive and the diagonal term is greater than the sum of the
two extra-diagonal terms, therefore a special adaptation of the Gauss elimination procedure is used to find the solution (see for example Richtmyer and Morton [1967]).
3.4
41
continuity equation
tracer equation
T
time filter
model operations
F IG . 3.1 Sketch of the leapfrog time stepping sequence in NEMO from Leclair and Madec [2009]. The use of a semi-implicit computation of the hydrostatic
pressure gradient requires the tracer equation to be stepped forward prior to the
momentum equation. The need for knowledge of the vertical scale factor (here
denoted as h) requires the sea surface height and the continuity equation to be
stepped forward prior to the computation of the tracer equation. Note that the method for the evaluation of the surface pressure gradient ps is not presented here
(see 6.5).
42
at tt, t and t+t is used (see 6.4.4). This technique, controlled by the nn dynhpg rst
namelist parameter, does not introduce a significant additional computational cost when
tracers and thus density is time stepped before the dynamics. This time step ordering is
used in NEMO (Fig.3.1).
This technique, used in several GCMs (NEMO , POP or MOM for instance), makes
the Leap-Frog scheme as efficient 1 as the Forward-Backward scheme used in MOM
[Griffies et al. 2005] and more efficient than the LF-AM3 scheme (leapfrog time stepping
combined with a third order Adams-Moulthon interpolation for the predictor phase) used
in ROMS [Shchepetkin and McWilliams 2005].
In fact, this technique is efficient when the physical phenomenon that limits the timestep is internal gravity waves (IGWs). Indeed, it is equivalent to applying a time filter to
the pressure gradient to eliminate high frequency IGWs. Obviously, the doubling of the
time-step is achievable only if no other factors control the time-step, such as the stability
limits associated with advection, diffusion or Coriolis terms. For example, it is inefficient
in low resolution global ocean configurations, since inertial oscillations in the vicinity
of the North Pole are the limiting factor for the time step. It is also often inefficient in
very high resolution configurations where strong currents and small grid cells exert the
strongest constraint on the time step.
3.5
The efficiency is defined as the maximum allowed Courant number of the time stepping
scheme divided by the number of computations of the right-hand side per time step.
43
2 Q5
2 Q3
Q3/2
1
Q1/2
time step
time step
2 Q4
2 Q2
Q1/2
2
Q3/2
Q7/2
Q5/2
3
Q5/2
Q9/2
Q7/2
F IG . 3.2 Illustration of forcing integration methods. (top) Traditional formulation : the forcing is defined at the same time as the variable to which it is applied
(integer value of the time step index) and it is applied over a 2t period. (bottom)
modified formulation : the forcing is defined in the middle of the time (integer and
a half value of the time step index) and the mean of two successive forcing values
(n 1/2, n + 1/2). is applied over a 2t period.
Since the filtering of the forcing was the source of non-conservation in the classical LFRA scheme, the modified formulation becomes conservative [Leclair and Madec 2009].
Second, the LF-RA becomes a truly quasi-second order scheme. Indeed, (3.9) used in
combination with a careful treatment of static instability (10.2.2) and of the TKE physics
(10.1.4), the two other main sources of time step divergence, allows a reduction by two
orders of magnitude of the Asselin filter parameter.
Note that the forcing is now provided at the middle of a time step : Qt+t/2 is the
forcing applied over the [t, t + t] time interval. This and the change in the time filter,
(3.10), allows an exact evaluation of the contribution due to the forcing term between any
two time steps, even if separated by only t since the time filter is no longer applied to
the forcing term.
3.6
Start/Restart strategy
!----------------------------------------------------------------------&namrun
!
parameters of the run
!----------------------------------------------------------------------nn_no
=
0
! job number
cn_exp
= "ORCA2" ! experience name
nn_it000
=
1
! first time step
nn_itend
=
5475
! last time step (std 5475)
nn_date0
= 010101
! initial calendar date yymmdd (used if nn_rstctl=1)
nn_leapy
=
0
! Leap year calendar (1) or not (0)
ln_rstart
= .false.
! start from rest (F) or from a restart file (T)
nn_rstctl
=
0
! restart control = 0 nn_it000 is not compared to the restart file value
!
= 1 use nn_date0 in namelist (not the value in the restart file)
!
= 2 calendar parameters read in the restart file
cn_ocerst_in = "restart"
! suffix of ocean restart name (input)
cn_ocerst_out = "restart"
! suffix of ocean restart name (output)
nn_istate
=
0
! output the initial state (1) or not (0)
44
nn_stock
nn_write
ln_dimgnnn
ln_mskland
ln_clobber
nn_chunksz
!
!
!
!
!
!
The first time step of this three level scheme when starting from initial conditions is a
forward step (Euler time integration) :
x1 = x0 + t RHS0
(3.11)
This is done simply by keeping the leapfrog environment (i.e. the (3.1) three level time
stepping) but setting all x0 (before) and x1 (now) fields equal at the first time step and
using half the value of t.
It is also possible to restart from a previous computation, by using a restart file. The
restart strategy is designed to ensure perfect restartability of the code : the user should
obtain the same results to machine precision either by running the model for 2N time
steps in one go, or by performing two consecutive experiments of N steps with a restart.
This requires saving two time levels and many auxiliary data in the restart files in machine
precision.
Note that when a semi-implicit scheme is used to evaluate the hydrostatic pressure
gradient (see 6.4.4), an extra three-dimensional field has to be added to the restart file
to ensure an exact restartability. This is done optionally via the nn dynhpg rst namelist
parameter, so that the size of the restart file can be reduced when restartability is not a key
issue (operational oceanography or in ensemble simulations for seasonal forecasting).
Note the size of the time step used, t, is also saved in the restart file. When restarting,
if the the time step has been changed, a restart using an Euler time stepping scheme is
imposed.
Contents
4.1
4.2
4.3
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
46
46
47
49
51
51
53
55
55
57
58
60
62
62
62
46
Having defined the continuous equations in Chap. 2 and chosen a time discretization
Chap. 3, we need to choose a discretization on a grid, and numerical algorithms. In the
present chapter, we provide a general description of the staggered grid used in NEMO , and
other information relevant to the main directory routines as well as the DOM (DOMain)
directory.
4.1
4.1.1
f
f
47
4.1.2
Discrete Operators
Given the values of a variable q at adjacent points, the differencing and averaging
operators at the midpoint between them are :
i [q] = q(i + 1/2) q(i 1/2)
i
(4.1a)
(4.1b)
Similar operators are defined with respect to i + 1/2, j, j + 1/2, k, and k + 1/2.
Following (2.11a) and (2.11d), the gradient of a variable q defined at a t-point has its
three components defined at u-, v- and w-points while its Laplacien is defined at t-point.
48
T
u
v
w
f
uw
vw
fw
j
j
j + 1/2
j
j + 1/2
j
j + 1/2
j + 1/2
k
k
k
k + 1/2
k
k + 1/2
k + 1/2
k + 1/2
These operators have the following discrete forms in the curvilinear s-coordinate system :
q
1
q
e1t e2t e3t
1
1
1
i+1/2 [q] i +
j+1/2 [q] j +
[q] k
e1u
e2v
e3w k+1/2
(4.2)
e2u e3u
e1v e3v
i+1/2 [q] + j
j+1/2 [q]
i
e1u
e2v
1
1
+
k
[q] (4.3)
e3t
e3w k+1/2
A=
1
e2v e3vw
1
e2u e3uw
1
e1f e2f
j+1/2 [e3w a3 ] k+1/2 [e2v a2 ]
k+1/2 [e1u a1 ] i+1/2 [e3w a3 ]
i+1/2 [e2v a2 ] j+1/2 [e1u a1 ]
(4.4)
(4.5)
(4.6)
1
1
(i [e2u e3u a1 ] + j [e1v e3v a2 ]) +
k [a3 ]
e1t e2t e3t
e3t
(4.7)
In the special case of a pure z-coordinate system, (4.3) and (4.7) can be simplified.
In this case, the vertical scale factor becomes a function of the single variable k and thus
does not depend on the horizontal location of a grid point. For example (4.7) reduces to :
A=
1
1
(i [e2u a1 ] + j [e1v a2 ]) +
k [a3 ]
e1t e2t
e3t
49
The vertical average over the whole water column denoted by an overbar becomes for
a quantity q which is a masked field (i.e. equal to zero inside solid area) :
1
q =
H
ko
q e3q dk
kb
1 X
q e3q
Hq
(4.8)
where Hq is the ocean depth, which is the masked sum of the vertical scale factors at
q points, k b and k o are the bottom and surface k-indices, and the symbol k o refers to a
summation over all grid points of the same type in the direction indicated by the subscript
(here k).
In continuous form, the following properties are satisfied :
q = 0
(4.9)
( A) = 0
(4.10)
ai i [b]
(4.11)
a i+1/2 bi+1/2
(4.12)
X
i
ai b
X
i
In other words, the adjoint of the differencing and averaging operators are i = i+1/2
and ( i ) = i+1/2 , respectively. These two properties will be used extensively in the
Appendix E to demonstrate integral conservative properties of the discrete formulation
chosen.
4.1.3
Numerical Indexing
The array representation used in the F ORTRAN code requires an integer indexing
while the analytical definition of the mesh (see 4.1.1) is associated with the use of integer
values for t-points and both integer and integer and a half values for all the other points.
Therefore a specific integer indexing must be defined for points other than t-points (i.e.
velocity and vorticity grid-points). Furthermore, the direction of the vertical indexing has
been changed so that the surface level is at k = 1.
50
j+1
j+1
j
j
j-1
j-1
i-1
i-1
u
v
i+1
T
i+1
F IG . 4.2 Horizontal integer indexing used in the F ORTRAN code. The dashed
area indicates the cell in which variables contained in arrays have the same i- and
j-indices
Horizontal Indexing
The indexing in the horizontal plane has been chosen as shown in Fig.4.2. For an
increasing i index (j index), the t-point and the eastward u-point (northward v-point)
have the same index (see the dashed area in Fig.4.2). A t-point and its nearest northeast
f -point have the same i-and j-indices.
51
Vertical Indexing
In the vertical, the chosen indexing requires special attention since the k-axis is reorientated downward in the F ORTRAN code compared to the indexing used in the semidiscrete equations and given in 4.1.1. The sea surface corresponds to the w-level k =
1 which is the same index as t-level just below (Fig.4.3). The last w-level (k = jpk)
either corresponds to the ocean floor or is inside the bathymetry while the last t-level is
always inside the bathymetry (Fig.4.3). Note that for an increasing k index, a w-point
and the t-point just below have the same k index, in opposition to what is done in the
horizontal plane where it is the t-point and the nearest velocity points in the direction of
the horizontal axis that have the same i or j index (compare the dashed area in Fig.4.2 and
4.3). Since the scale factors are chosen to be strictly positive, a minus sign appears in the
F ORTRAN code before all the vertical derivatives of the discrete equations given in this
documentation.
Domain Size
The total size of the computational domain is set by the parameters jpiglo, jpjglo
and jpk in the i, j and k directions respectively. They are given as parameters in the
par oce.F90 module1 . The use of parameters rather than variables (together with dynamic allocation of arrays) was chosen because it ensured that the compiler would optimize
the executable code efficiently, especially on vector machines (optimization may be less
efficient when the problem size is unknown at the time of compilation). Nevertheless,
it is possible to set up the code with full dynamical allocation by using the AGRIF packaged [Debreu et al. 2008]. Note that are other parameters in par oce.F90 that refer
to the domain size. The two parameters jpidta and jpjdta may be larger than jpiglo,
jpjglo when the user wants to use only a sub-region of a given configuration. This is the
zoom capability described in 14.3. In most applications of the model, jpidta = jpiglo,
jpjdta = jpjglo, and jpizoom = jpjzoom = 1. Parameters jpi and jpj refer to the size
of each processor subdomain when the code is run in parallel using domain decomposition
(key mpp mpi defined, see 8.3).
4.2
4.2.1
When a specific configuration is used (ORCA2 global ocean, etc...) the parameter are actually defined in additional files introduced by par oce.F90 module via CPP include command.
For example, ORCA2 parameters are set in par ORCA R2.h90 file
52
LEVELS
1
1
2
k
k+1
jpk-2
jpk-2
jpk-1
jpk-1
jpk
jpk
w
T
w
w
T
w
w
T
w
w
T
w
T
w
T
w
T
T
w
T
w
T
F IG . 4.3 Vertical integer indexing used in the F ORTRAN code. Note that the kaxis is orientated downward. The dashed area indicates the cell in which variables
contained in arrays have the same k-index.
53
factors are defined using the analytical first derivative of the transformation (2.10). These
definitions are done in two modules, domhgr.F90 and domzgr.F90, which provide the
horizontal and vertical meshes, respectively. This section deals with the horizontal mesh
parameters.
In a horizontal plane, the location of all the model grid points is defined from the analytical expressions of the longitude and latitude as a function of (i, j). The horizontal
scale factors are calculated using (2.10). For example, when the longitude and latitude are
function of a single value (i and j, respectively) (geographical configuration of the mesh),
the horizontal mesh definition reduces to define the wanted (i), (j), and their derivatives 0 (i) 0 (j) in the domhgr.F90 module. The model computes the grid-point positions
and scale factors in the horizontal plane as follows :
t glamt = (i)
t gphit = (j)
u glamu = (i + 1/2)
u gphiu = (j)
v glamv = (i)
v gphiv = (j + 1/2)
f glamf = (i + 1/2)
f gphif = (j + 1/2)
where the last letter of each computational name indicates the grid point considered and ra
is the earth radius (defined in phycst.F90 along with all universal constants). Note that the
horizontal position of and scale factors at w-points are exactly equal to those of t-points,
thus no specific arrays are defined at w-points.
Note that the definition of the scale factors (i.e. as the analytical first derivative of the
transformation that gives (, , z) as a function of (i, j, k)) is specific to the NEMO model [Marti et al. 1992]. As an example, e1t is defined locally at a t-point, whereas many
other models on a C grid choose to define such a scale factor as the distance between
the U -points on each side of the t-point. Relying on an analytical transformation has two
advantages : firstly, there is no ambiguity in the scale factors appearing in the discrete
equations, since they are first introduced in the continuous equations ; secondly, analytical transformations encourage good practice by the definition of smoothly varying grids
(rather than allowing the user to set arbitrary jumps in thickness between adjacent layers)
[Treguier et al. 1996]. An example of the effect of such a choice is shown in Fig. 4.4.
4.2.2
54
z
k-1 = 10 m
Tk+1
k-1 = 40 m
Tk
z
Wk+3/2
Wk+1/2
Wk+3/2 T
k+1
Wk+1/2
zk-1/2= -50 m
Tk-1
(a)
zk-3/2= -150 m
ek+3/2 = 5 m
ek+1/2 = 20 m
ek-1/2= 65 m
Wk-1/2
Tk-1
Wk-3/2
ek-1 = 8.75 m
ek-1 = 38.75 m
Tk
Wk-1/2
k-1 = 100 m
zk+3/2 = 0 m
zk+1/2 = -10 m
ek-1 = 98.75 m
ek-3/2= 140 m
Wk-3/2
(b)
jphgr mesh=0 The most general curvilinear orthogonal grids. The coordinates and their
first derivatives with respect to i and j are provided in a input file (coordinates.nc),
read in hgr read subroutine of the domhgr module.
jphgr mesh=1 to 5 A few simple analytical grids are provided (see below). For other
analytical grids, the domhgr.F90 module must be modified by the user.
There are two simple cases of geographical grids on the sphere. With jphgr mesh=1,
the grid (expressed in degrees) is regular in space, with grid sizes specified by parameters
ppe1 deg and ppe2 deg, respectively. Such a geographical grid can be very anisotropic at
high latitudes because of the convergence of meridians (the zonal scale factors e1 become
much smaller than the meridional scale factors e2 ). The Mercator grid (jphgr mesh=4)
avoids this anisotropy by refining the meridional scale factors in the same way as the
zonal ones. In this case, meridional scale factors and latitudes are calculated analytically
using the formulae appropriate for a Mercator projection, based on ppe1 deg which is a
55
reference grid spacing at the equator (this applies even when the geographical equator
is situated outside the model domain). In these two cases (jphgr mesh=1 or 4), the grid
position is defined by the longitude and latitude of the south-westernmost point (ppglamt0
and ppgphi0). Note that for the Mercator grid the user need only provide an approximate
starting latitude : the real latitude will be recalculated analytically, in order to ensure that
the equator corresponds to line passing through t- and u-points.
Rectangular grids ignoring the spherical geometry are defined with jphgr mesh = 2,
3, 5. The domain is either an f -plane (jphgr mesh = 2, Coriolis factor is constant) or a
beta-plane (jphgr mesh = 3, the Coriolis factor is linear in the j-direction). The grid size
is uniform in meter in each direction, and given by the parameters ppe1 m and ppe2 m
respectively. The zonal grid coordinate (glam arrays) is in kilometers, starting at zero with
the first t-point. The meridional coordinate (gphi. arrays) is in kilometers, and the second
t-point corresponds to coordinate gphit = 0. The input parameter ppglam0 is ignored.
ppgphi0 is used to set the reference latitude for computation of the Coriolis parameter.
In the case of the beta plane, ppgphi0 corresponds to the center of the domain. Finally,
the special case jphgr mesh=5 corresponds to a beta plane in a rotated domain for the
GYRE configuration, representing a classical mid-latitude double gyre system. The rotation allows us to maximize the jet length relative to the gyre areas (and the number of grid
points).
The choice of the grid must be consistent with the boundary conditions specified by
the parameter jperio (see 8).
4.2.3
4.3
!----------------------------------------------------------------------&namdom
!
space and time domain (bathymetry, mesh, timestep)
!-----------------------------------------------------------------------
56
(a)
(d)
(b)
(e)
(c)
(f)
F IG . 4.5 The ocean bottom as seen by the model : (a) z-coordinate with full
step, (b) z-coordinate with partial step, (c) s-coordinate : terrain following representation, (d) hybrid s z coordinate, (e) hybrid s z coordinate with partial step,
and (f) same as (e) but with variable volume associated with the non-linear free
surface. Note that the variable volume option (key vvl) can be used with any of
the 5 coordinates (a) to (e).
nn_bathy
=
nn_closea
=
nn_msh
=
rn_hmin
=
rn_e3zps_min=
rn_e3zps_rat=
1
0
0
-3.
20.
0.1
rn_rdt
nn_baro
rn_atfp
nn_acc
= 5760.
=
64
=
0.1
=
0
rn_rdtmin
rn_rdtmax
rn_rdth
= 28800.
= 28800.
= 800.
!
!
!
!
!
!
!
!
!
!
!
In the vertical, the model mesh is determined by four things : (1) the bathymetry given
in meters ; (2) the number of levels of the model (jpk) ; (3) the analytical transformation
z(i, j, k) and the vertical scale factors (derivatives of the transformation) ; and (4) the
masking system, i.e. the number of wet model levels at each (i, j) column of points.
The choice of a vertical coordinate, even if it is made through a namelist parameter, must be done once of all at the beginning of an experiment. It is not intended as
57
an option which can be enabled or disabled in the middle of an experiment. Three main
choices are offered (Fig. 4.5a to c) : z-coordinate with full step bathymetry (ln zco = true),
z-coordinate with partial step bathymetry (ln zps = true), or generalized, s-coordinate
(ln sco = true). Hybridation of the three main coordinates are available : s z or s zps
coordinate (Fig. 4.5d and 4.5e). When using the variable volume option key vvl) (i.e.
non-linear free surface), the coordinate follow the time-variation of the free surface so
that the transformation is time dependent : z(i, j, k, t) (Fig. 4.5f). This option can be used
with full step bathymetry or s-coordinate (hybride and partial step coordinates have not
yet been tested in NEMO v2.3).
Contrary to the horizontal grid, the vertical grid is computed in the code and no provision is made for reading it from a file. The only input file is the bathymetry (in meters)
(bathy meter.nc) 2 . After reading the bathymetry, the algorithm for vertical grid definition
differs between the different options :
zco set a reference coordinate transformation z0 (k), and set z(i, j, k, t) = z0 (k).
zps set a reference coordinate transformation z0 (k), and calculate the thickness of the
deepest level at each (i, j) point using the bathymetry, to obtain the final threedimensional depth and scale factor arrays.
sco smooth the bathymetry to fulfil the hydrostatic consistency criteria and set the threedimensional transformation.
s-z and s-zps smooth the bathymetry to fulfil the hydrostatic consistency criteria and set
the three-dimensional transformation z(i, j, k), and possibly introduce masking of
extra land points to better fit the original bathymetry file
The arrays describing the grid point depths and vertical scale factors are three dimensional arrays (i, j, k) even in the case of z-coordinate with full step bottom topography.
In non-linear free surface (key vvl), their knowledge is required at before, now and after
time step, while they do not vary in time in linear free surface case. To improve the code
readability while providing this flexibility, the vertical coordinate and scale factors are
defined as functions of (i, j, k) with fs as prefix (examples : fse3t b, fse3t n, fse3t a,
for the before, now and after scale factors at t-point) that can be either three different
arrays when key vvl is defined, or a single fixed arrays. These functions are defined in the
file domzgr substitute.h90 of the DOM directory. They are used throughout the code, and
replaced by the corresponding arrays at the time of pre-processing (CPP capability).
4.3.1
Meter Bathymetry
Three options are possible for defining the bathymetry, according to the namelist variable nn bathy :
nn bathy = 0 a flat-bottom domain is defined. The total depth zw (jpk) is given by the
coordinate transformation. The domain can either be a closed basin or a periodic
channel depending on the parameter jperio.
2
N.B. in full step z-coordinate, a bathy level.nc file can replace the bathy meter.nc file, so that
the computation of the number of wet ocean point in each water column is by-passed
58
nn bathy = -1 a domain with a bump of topography one third of the domain width at the
central latitude. This is meant for the EEL-R5 configuration, a periodic or open
boundary channel with a seamount.
nn bathy = 1 read a bathymetry. The bathy meter.nc file (Netcdf format) provides the
ocean depth (positive, in meters) at each grid point of the model grid. The bathymetry is usually built by interpolating a standard bathymetry product (e.g. ETOPO2)
onto the horizontal ocean mesh. Defining the bathymetry also defines the coastline :
where the bathymetry is zero, no model levels are defined (all levels are masked).
When a global ocean is coupled to an atmospheric model it is better to represent all
large water bodies (e.g, great lakes, Caspian sea...) even if the model resolution does not
allow their communication with the rest of the ocean. This is unnecessary when the ocean
is forced by fixed atmospheric conditions, so these seas can be removed from the ocean
domain. The user has the option to set the bathymetry in closed seas to zero (see 14.2),
but the code has to be adapted to the users configuration.
4.3.2
(4.13)
59
depth
(meters)
0
scale factor
(meters)
600
1000
500
400
2000
300
3000
200
4000
100
5000
1
10
20
vertical index
30
F IG . 4.6 Default vertical mesh for ORCA2 : 30 ocean levels (L30). Vertical level
functions for (a) T-point depth and (b) the associated scale factor as computed
from (4.13) using (4.14) in z-coordinate.
(4.14)
z(jpk) = 5000.
With the choice of the stretching hcr = 3 and the number of levels jpk=31, the four
coefficients hsur , h0 , h1 , and hth in (4.13) have been determined such that (4.14) is satisfied, through an optimisation procedure using a bisection method. For the first standard
60
ORCA2 vertical grid this led to the following values : hsur = 4762.96, h0 = 255.58, h1 =
245.5813, and hth = 21.43336. The resulting depths and scale factors as a function of the
model levels are shown in Fig. 4.6 and given in Table 4.2. Those values correspond to the
parameters ppsur, ppa0, ppa1, ppkth in the parameter file par oce.F90.
Rather than entering parameters hsur , h0 , and h1 directly, it is possible to recalculate
them. In that case the user sets ppsur=ppa0=ppa1=pp to be computed, in par oce.F90,
and specifies instead the four following parameters :
ppacr=hcr : stretching factor (nondimensional). The larger ppacr, the smaller the
stretching. Values from 3 to 10 are usual.
ppkth=hth : is approximately the model level at which maximum stretching occurs
(nondimensional, usually of order 1/2 or 2/3 of jpk)
ppdzmin : minimum thickness for the top layer (in meters)
pphmax : total depth of the ocean (meters).
As an example, for the 45 layers used in the DRAKKAR configuration those parameters
are : jpk=46, ppacr=9, ppkth=23.563, ppdzmin=6m, pphmax=5750m.
4.3.3
In z-coordinate partial step, the depths of the model levels are defined by the reference
analytical function z0 (k) as described in the previous section, except in the bottom layer.
The thickness of the bottom layer is allowed to vary as a function of geographical location
(, ) to allow a better representation of the bathymetry, especially in the case of small
slopes (where the bathymetry varies by less than one level thickness from one grid point
to the next). The reference layer thicknesses e03t have been defined in the absence of bathymetry. With partial steps, layers from 1 to jpk-2 can have a thickness smaller than e3t (jk).
The model deepest layer (jpk-1) is allowed to have either a smaller or larger thickness
than e3t (jpk) : the maximum thickness allowed is 2 e3t (jpk 1). This has to be kept
in mind when specifying the maximum depth pphmax in partial steps : for example, with
pphmax= 5750 m for the DRAKKAR 45 layer grid, the maximum ocean depth allowed
is actually 6000 m (the default thickness e3t (jpk 1) being 250 m). Two variables in the
namdom namelist are used to define the partial step vertical grid. The mimimum water
thickness (in meters) allowed for a cell partially filled with bathymetry at level jk is the
minimum of rn e3zps min (thickness in meters, usually 20 m) or e3t (jk) rn e3zps rat
(a fraction, usually 10%, of the default thickness e3t (jk)).
LEVEL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
gdept
5.00
15.00
25.00
35.01
45.01
55.03
65.06
75.13
85.25
95.49
105.97
116.90
128.70
142.20
158.96
181.96
216.65
272.48
364.30
511.53
732.20
1033.22
1405.70
1830.89
2289.77
2768.24
3257.48
3752.44
4250.40
4749.91
5250.23
gdepw
0.00
10.00
20.00
30.00
40.01
50.02
60.04
70.09
80.18
90.35
100.69
111.36
122.65
135.16
150.03
169.42
197.37
241.13
312.74
429.72
611.89
872.87
1211.59
1612.98
2057.13
2527.22
3011.90
3504.46
4001.16
4500.02
5000.00
61
e3t
10.00
10.00
10.00
10.01
10.01
10.02
10.04
10.09
10.17
10.33
10.65
11.27
12.47
14.78
19.23
27.66
43.26
70.88
116.11
181.55
261.03
339.39
402.26
444.87
470.55
484.95
492.70
496.78
498.90
500.00
500.56
e3w
10.00
10.00
10.00
10.00
10.01
10.02
10.03
10.06
10.12
10.24
10.47
10.91
11.77
13.43
16.65
22.78
34.30
55.21
90.99
146.43
220.35
301.42
373.31
426.00
459.47
478.83
489.44
495.07
498.02
499.54
500.33
TAB . 4.2 Default vertical mesh in z-coordinate for 30 layers ORCA2 configuration as computed from (4.13) using the coefficients given in (4.14)
62
4.3.4
In s-coordinate (ln sco = true), the depth and thickness of the model levels are defined
from the product of a depth field and either a stretching function or its derivative, respectively :
z(k) = h(i, j) z0 (k)
e3 (k) = h(i, j) z00 (k)
(4.15)
where h is the depth of the last w-level (z0 (k)) defined at the t-point location in the
horizontal and z0 (k) is a function which varies from 0 at the sea surface to 1 at the
ocean bottom. The depth field h is not necessary the ocean depth, since a mixed step-like
and bottom-following representation of the topography can be used (Fig. 4.5d-e). In the
example provided (zgr sco routine, see domzgr.F90) h is a smooth envelope bathymetry
and steps are used to represent sharp bathymetric gradients.
A new flexible stretching function, modified from Song and Haidvogel [1994] is provided as an example :
z = hc + (h hc ) cs)
[tanh ( (s + b)) tanh ( b)]
c(s) =
2 sinh ()
(4.16)
where hc is the thermocline depth and and b are the surface and bottom control parameters such that 0 6 6 20, and 0 6 b 6 1. b has been designed to allow surface and/or
bottom increase of the vertical resolution (Fig. 4.7).
4.3.5
4.3.6
63
F IG . 4.7 Examples of the stretching function applied to a sea mont ; from left
to right : surface, surface and bottom, and bottom intensified resolutions
a 2D integer array, mbathy, which gives the number of ocean levels (i.e. those that are
not masked) at each t-point. mbathy is computed from the meter bathymetry using the
definiton of gdept as the number of t-points which gdept bathy.
Modifications of the model bathymetry are performed in the bat ctl routine (see domzgr.F90
module) after mbathy is computed. Isolated grid points that do not communicate with another ocean point at the same level are eliminated.
From the mbathy array, the mask fields are defined as follows :
(
1 if k mbathy(i, j)
tmask(i, j, k) =
0 if k mbathy(i, j)
umask(i, j, k) = tmask(i, j, k) tmask(i + 1, j, k)
vmask(i, j, k) = tmask(i, j, k) tmask(i, j + 1, k)
f mask(i, j, k) = tmask(i, j, k) tmask(i + 1, j, k)
tmask(i, j, k) tmask(i + 1, j, k)
Note that wmask is not defined as it is exactly equal to tmask with the numerical
indexing used ( 4.1.3). Moreover, the specification of closed lateral boundaries requires
that at least the first and last rows and columns of the mbathy array are set to zero. In the
particular case of an east-west cyclical boundary condition, mbathy has its last column
equal to the second one and its first column equal to the last but one (and so too the mask
arrays) (see 8.2).
Contents
5.1
5.2
5.3
5.4
5.5
5.6
67
69
69
70
71
71
72
73
73
73
74
75
75
75
76
76
78
80
81
82
82
84
66
5.9
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
86
87
87
88
88
89
89
5.1
67
The advection tendency of a tracer in flux form is the divergence of the advective
fluxes. Its discrete expression is given by :
ADV =
1
1
( i [e2u e3u u u ] + j [e1v e3v v v ] )
k [w w ]
bt
e3t
(5.1)
where is either T or S, and bt = e1t e2t e3t is the volume of T -cells. The flux form
in (5.1) implicitly requires the use of the continuity equation. Indeed, it is obtained by
using the following equality : (U T) = U T which results from the use of the
continuity equation, U = 0 or t e3 + e3 U = 0 in constant volume or variable
volume case, respectively. Therefore it is of paramount importance to design the discrete
analogue of the advection tendency so that it is consistent with the continuity equation in
order to enforce the conservation properties of the continuous equations. In other words,
by replacing by the number 1 in (5.1) we recover the discrete form of the continuity
equation which is used to calculate the vertical velocity.
The key difference between the advection schemes available in NEMO is the choice
made in space and time interpolation to define the value of the tracer at the velocity points
(Fig. 5.1).
Along solid lateral and bottom boundaries a zero tracer flux is automatically specified,
since the normal velocity is zero there. At the sea surface the boundary condition depends
on the type of sea surface chosen :
linear free surface : the first level thickness is constant in time : the vertical boundary
condition is applied at the fixed surface z = 0 rather than on the moving surface
z = . There is a non-zero advective flux which is set for all advection schemes as
w |k=1/2 = Tk=1 , i.e. the product of surface velocity (at z = 0) by the first level
tracer value.
non-linear free surface : (key vvl is defined) convergence/divergence in the first ocean
level moves the free surface up/down. There is no tracer advection through it so
that the advective fluxes through the surface are also zero
In all cases, this boundary condition retains local conservation of tracer. Global conservation is obtained in both rigid-lid and non-linear free surface cases, but not in the linear
free surface case. Nevertheless, in the latter case, it is achieved to a good approximation
68
T
Ti+1+Ti
2
muscl
cen2
ppm
Ti
Ti-1
Ti+1
Ui+1/2
ups
i-1
i-1/2
i+1/2
Ui t
i+1
since the non-conservative term is the product of the time derivative of the tracer and the
free surface height, two quantities that are not correlated (see 2.2.2, and also Roullet and
Madec [2000], Griffies et al. [2001], Campin et al. [2004]).
The velocity field that appears in (5.1) and (??) is the centred (now) eulerian ocean
velocity (see Chap. 6). When eddy induced velocity (eiv) parameterisation is used it is the
now effective velocity (i.e. the sum of the eulerian and eiv velocities) which is used.
The choice of an advection scheme is made in the nam traadv namelist, by setting to
true one and only one of the logicals ln traadv xxx. The corresponding code can be found
in the traadv xxx.F90 module, where xxx is a 3 or 4 letter acronym corresponding to each
scheme. Details of the advection schemes are given below. The choice of an advection
scheme is a complex matter which depends on the model physics, model resolution, type
69
5.1.1
i+1/2
(5.2)
The scheme is non diffusive (i.e. it conserves the tracer variance, 2 ) but dispersive
(i.e. it may create false extrema). It is therefore notoriously noisy and must be used in
conjunction with an explicit diffusion operator to produce a sensible solution. The associated time-stepping is performed using a leapfrog scheme in conjunction with an Asselin
time-filter, so T in (5.2) is the now tracer value. The centered second order advection is
computed in the traadv cen2.F90 module. In this module, it is advantageous to combine
the cen2 scheme with an upstream scheme in specific areas which require a strong diffusion in order to avoid the generation of false extrema. These areas are the vicinity of
large river mouths, some straits with coarse resolution, and the vicinity of ice cover area
(i.e. when the ocean temperature is close to the freezing point). This combined scheme
has been included for specific grid points in the ORCA2 and ORCA4 configurations only.
This is an obsolescent feature as the recommended advection scheme for the ORCA configuration is TVD (see 5.1.3).
Note that using the cen2 scheme, the overall tracer advection is of second order accuracy since both (5.1) and (5.2) have this order of accuracy.
5.1.2
1
i i+1/2 [T ]
6
i+1/2
negative values can appear in an initially strictly positive tracer field which is advected
(5.3)
70
Strictly speaking, the cen4 scheme is not a 4th order advection scheme but a 4th
order evaluation of advective fluxes, since the divergence of advective fluxes (5.1) is kept
at 2nd order. The phrase 4th order scheme used in oceanographic literature is usually
associated with the scheme presented here. Introducing a true 4th order advection scheme
is feasible but, for consistency reasons, it requires changes in the discretisation of the
tracer advection together with changes in both the continuity equation and the momentum
advection terms.
A direct consequence of the pseudo-fourth order nature of the scheme is that it is not
non-diffusive, i.e. the global variance of a tracer is not preserved using cen4. Furthermore,
it must be used in conjunction with an explicit diffusion operator to produce a sensible
solution. The time-stepping is also performed using a leapfrog scheme in conjunction with
an Asselin time-filter, so T in (5.3) is the now tracer.
At a T -grid cell adjacent to a boundary (coastline, bottom and surface), an additional
hypothesis must be made to evaluate ucen4 . This hypothesis usually reduces the order
of the scheme. Here we choose to set the gradient of T across the boundary to zero.
Alternative conditions can be specified, such as a reduction to a second order scheme for
these near boundary grid points.
5.1.3
(
Ti+1
=
Ti
if ui+1/2 < 0
if ui+1/2 0
(5.4)
where cu is a flux limiter function taking values between 0 and 1. There exist many ways
to define cu , each corresponding to a different total variance decreasing scheme. The
one chosen in NEMO is described in Zalesak [1979]. cu only departs from 1 when the
advective term produces a local extremum in the tracer field. The resulting scheme is quite
expensive but positive. It can be used on both active and passive tracers. This scheme is
tested and compared with MUSCL and the MPDATA scheme in Levy et al. [2001] ; note
that in this paper it is referred to as FCT (Flux corrected transport) rather than TVD.
The TVD scheme is implemented in the traadv tvd.F90 module.
For stability reasons (see ??), ucen2 is evaluated in (5.4) using the now tracer while
ups
u is evaluated using the before tracer. In other words, the advective part of the scheme
is time stepped with a leap-frog scheme while a forward scheme is used for the diffusive
part.
5.1.4
71
ui+1/2 t
1
+
1
f
if ui+1/2 > 0
i
i
2
e
1u
mus
u =
(5.5)
ui+1/2 t
^
i+1/2 +
1+
i+1/2
if ui+1/2 < 0
2
e1u
where f
i is the slope of the tracer on which a limitation is imposed to ensure the positive
character of the scheme.
The time stepping is performed using a forward scheme, that is the before tracer field
is used to evaluate umus .
For an ocean grid point adjacent to land and where the ocean velocity is directed
toward land, two choices are available : an upstream flux (ln traadv muscl=true) or a
second order flux (ln traadv muscl2=true). Note that the latter choice does not ensure
the positive character of the scheme. Only the former can be used on both active and
passive tracers. The two MUSCL schemes are implemented in the traadv tvd.F90 and
traadv tvd2.F90 modules.
5.1.5
(5.6)
6 i+1
if ui+1/2 < 0
where i = i i+1/2 [ ] .
This results in a dissipatively dominant (i.e. hyper-diffusive) truncation error [Shchepetkin and McWilliams 2005]. The overall performance of the advection scheme is similar
to that reported in Farrow and Stevens [1995]. It is a relatively good compromise between
accuracy and smoothness. It is not a positive scheme, meaning that false extrema are permitted, but the amplitude of such are significantly reduced over the centred second order
method. Nevertheless it is not recommended that it should be applied to a passive tracer
that requires positivity.
The intrinsic diffusion of UBS makes its use risky in the vertical direction where the
control of artificial diapycnal fluxes is of paramount importance. Therefore the vertical
flux is evaluated using the TVD scheme when ln traadv ubs=true.
72
For stability reasons (see ??), the first term in (5.6) (which corresponds to a second
order centred scheme) is evaluated using the now tracer (centred in time) while the second
term (which is the diffusive part of the scheme), is evaluated using the before tracer (forward in time). This choice is discussed by Webb et al. [1998] in the context of the QUICK
advection scheme. UBS and QUICK schemes only differ by one coefficient. Replacing
1/6 with 1/8 in (5.6) leads to the QUICK advection scheme [Webb et al. 1998]. This option is not available through a namelist parameter, since the 1/6 coefficient is hard coded.
Nevertheless it is quite easy to make the substitution in the traadv ubs.F90 module and
obtain a QUICK scheme.
Four different options are possible for the vertical component used in the UBS scheme.
ubs
w can be evaluated using either (a) a centred 2nd order scheme, or (b) a TVD scheme,
or (c) an interpolation based on conservative parabolic splines following the Shchepetkin
and McWilliams [2005] implementation of UBS in ROMS, or (d) a UBS. The 3rd case
has dispersion properties similar to an eighth-order accurate conventional scheme. The
current reference version uses method b)
Note that :
(1) When a high vertical resolution O(1m) is used, the model stability can be controlled by vertical advection (not vertical diffusion which is usually solved using an implicit
scheme). Computer time can be saved by using a time-splitting technique on vertical advection. Such a technique has been implemented and validated in ORCA05 with 301
levels. It is not available in the current reference version.
(2) It is straightforward to rewrite (5.6) as follows :
(
+ i
if ui+1/2 > 0
1
ubs
cen4
u = u +
(5.7)
12 i+1
if ui+1/2 < 0
or equivalently
ui+1/2 uubs = ui+1/2 T
1
i i+1/2 [T ]
6
i+1/2
1
1
|u|i+1/2 i+1/2 [ i ]
2
6
(5.8)
(5.7) has several advantages. Firstly, it clearly reveals that the UBS scheme is based on
the fourth order scheme to which an upstream-biased diffusion term is added. Secondly,
this emphasises that the 4th order part (as well as the 2nd order part as stated above)
has to be evaluated at the now time step using (5.6). Thirdly, the diffusion term is in fact a
biharmonic operator with an eddy coefficient which is simply proportional to the velocity :
1
3
Alm
u = 12 e1u |u|. Note that NEMO v3.3 still uses (5.6), not (5.7).
5.1.6
73
in the traadv qck.F90 module. The resulting scheme is quite expensive but positive. It can
be used on both active and passive tracers. However, the intrinsic diffusion of QCK makes
its use risky in the vertical direction where the control of artificial diapycnal fluxes is of
paramount importance. Therefore the vertical flux is evaluated using the CEN2 scheme.
This no longer guarantees the positivity of the scheme. The use of TVD in the vertical
direction (as for the UBS case) should be implemented to restore this property.
5.1.7
5.2
The options available for lateral diffusion are a laplacian (rotated or not) or a biharmonic operator, the latter being more scale-selective (more diffusive at small scales). The
specification of eddy diffusivity coefficients (either constant or variable in space and time)
as well as the computation of the slope along which the operators act, are performed in
the ldftra.F90 and ldfslp.F90 modules, respectively. This is described in Chap. 9. The lateral diffusion of tracers is evaluated using a forward scheme, i.e. the tracers appearing in
its expression are the before tracers in time, except for the pure vertical component that
appears when a rotation tensor is used. This latter term is solved implicitly together with
the vertical diffusion term (see ??).
5.2.1
74
where bt =e1t e2t e3t is the volume of T -cells. It is implemented in the traadv lap.F90
module.
This lateral operator is computed in traldf lap.F90. It is a horizontal operator (i.e. acting along geopotential surfaces) in the z-coordinate with or without partial steps, but
is simply an iso-level operator in the s-coordinate. It is thus used when, in addition
to ln traldf lap=true, we have ln traldf level=true or ln traldf hor=ln zco=true. In both
cases, it significantly contributes to diapycnal mixing. It is therefore not recommended.
Note that in the partial step z-coordinate (ln zps=true), tracers in horizontally adjacent
cells are located at different depths in the vicinity of the bottom. In this case, horizontal
derivatives in (5.9) at the bottom level require a specific treatment. They are calculated in
the zpshde.F90 module, described in 5.9.
5.2.2
1
=
bt
i+1/2,k
e2u e3u
i
i+1/2 [T ] e2u r1u k+1/2 [T ]
e1u
j+1/2,k
e1v e3v
lT
+ j Av
j+1/2 [T ] e1v r2v k+1/2 [T ]
e2v
i,k+1/2
+ k AlT
e2w r1w i+1/2 [T ]
w
AlT
u
(5.10)
j,k+1/2
e1w e2w 2
2
r1w + r2w k+1/2 [T ]
+
e3w
where bt =e1t e2t e3t is the volume of T -cells, r1 and r2 are the slopes between the surface
of computation (z- or s-surfaces) and the surface along which the diffusion operator acts
(i.e. horizontal or iso-neutral surfaces). It is thus used when, in addition to ln traldf lap=
true, we have ln traldf iso=true, or both ln traldf hor=true and ln zco=true. The way these
slopes are evaluated is given in 9.2. At the surface, bottom and lateral boundaries, the
turbulent fluxes of heat and salt are set to zero using the mask technique (see 8.1).
The operator in (5.10) involves both lateral and vertical derivatives. For numerical stability, the vertical second derivative must be solved using the same implicit time scheme as
that used in the vertical physics (see 5.3). For computer efficiency reasons, this term is not
computed in the traldf iso.F90 module, but in the trazdf.F90 module where, if iso-neutral
2 + r2 .
mixing is used, the vertical mixing coefficient is simply increased by e1we3we2w r1w
2w
This formulation conserves the tracer but does not ensure the decrease of the tracer
variance. Nevertheless the treatment performed on the slopes (see 9) allows the model to
run safely without any additional background horizontal diffusion [Guilyardi et al. 2001].
An alternative scheme developed by Griffies et al. [1998] which preserves both tracer and
75
its variance is also available in NEMO (ln traldf grif =true). A complete description of the
algorithm is given in App.??.
Note that in the partial step z-coordinate (ln zps=true), the horizontal derivatives at the
bottom level in (5.10) require a specific treatment. They are calculated in module zpshde,
described in 5.9.
5.2.3
5.2.4
5.3
76
The formulation of the vertical subgrid scale tracer physics is the same for all the
vertical coordinates, and is based on a laplacian operator. The vertical diffusion operator
given by (2.36) takes the following semi-discrete space form :
DTvT
DTvS
vT
1
Aw
=
k
[T ]
e3t
e3w k+1/2
vS
Aw
1
k
k+1/2 [S]
=
e3t
e3w
(5.11)
vS
where AvT
w and Aw are the vertical eddy diffusivity coefficients on temperature and savS
linity, respectively. Generally, AvT
w = Aw except when double diffusive mixing is parameterised (i.e. key zdfddm is defined). The way these coefficients are evaluated is given
in 10 (ZDF). Furthermore, when iso-neutral mixing is used, both mixing coefficients are
2 + r2
increased by e1we3we2w r1w
2w to account for the vertical second derivative of (5.10).
At the surface and bottom boundaries, the turbulent fluxes of heat and salt must be
specified. At the surface they are prescribed from the surface forcing and added in a dedicated routine (see 5.4.1), whilst at the bottom they are set to zero for heat and salt unless
a geothermal flux forcing is prescribed as a bottom boundary condition (see 5.4.3).
The large eddy coefficient found in the mixed layer together with high vertical resolution implies that in the case of explicit time stepping (ln zdfexp=true) there would be too
restrictive a constraint on the time step. Therefore, the default implicit time stepping is preferred for the vertical diffusion since it overcomes the stability constraint. A forward time
differencing scheme (ln zdfexp=true) using a time splitting technique (nn zdfexp > 1)
is provided as an alternative. Namelist variables ln zdfexp and nn zdfexp apply to both
tracers and dynamics.
5.4
5.4.1
External Forcing
Surface boundary condition (trasbc.F90)
The surface boundary condition for tracers is implemented in a separate module
(trasbc.F90) instead of entering as a boundary condition on the vertical diffusion operator (as in the case of momentum). This has been found to enhance readability of the
code. The two formulations are completely equivalent ; the forcing terms in trasbc are the
surface fluxes divided by the thickness of the top model layer.
Due to interactions and mass exchange of water (Fmass ) with other Earth system
components (i.e. atmosphere, sea-ice, land), the change in the heat and salt content of the
surface layer of the ocean is due both to the heat and salt fluxes crossing the sea surface
(not linked with Fmass ) and to the heat and salt content of the mass exchange.
The surface module (sbcmod.F90, see 7) provides the following forcing fields (used
on tracers) :
77
Qns , the non-solar part of the net surface heat flux that crosses the sea surface (i.e.
the difference between the total surface heat flux and the fraction of the short wave flux
that penetrates into the water column, see 5.4.2)
emp, the mass flux exchanged with the atmosphere (evaporation minus precipitation)
empS , an equivalent mass flux taking into account the effect of ice-ocean mass
exchange
rnf, the mass flux associated with runoff (see 7.8 for further detail of how it acts on
temperature and salinity tendencies)
The empS field is not simply the budget of evaporation-precipitation+freezing-melting
because the sea-ice is not currently embedded in the ocean but levitates above it. There is
no mass exchanged between the sea-ice and the ocean. Instead we only take into account
the salt flux associated with the non-zero salinity of sea-ice, and the concentration/dilution
effect due to the freezing/melting (F/M) process. These two parts of the forcing are then
converted into an equivalent mass flux given by empS emp. As a result of this mess, the
surface boundary condition on temperature and salinity is applied as follows :
In the nonlinear free surface case (key vvl is defined) :
1
o Cp e3t |k=1
1
FS =
o e3t |k=1
FT =
(5.12)
Qns
(5.13)
(empS S|k=1 )
where xt means that x is averaged over two consecutive time steps (tt/2 and t+t/2).
Such time averaging prevents the divergence of odd and even time step (see 3).
The two set of equations, (5.12) and (5.13), are obtained by assuming that the temperature of precipitation and evaporation are equal to the ocean surface temperature and that
their salinity is zero. Therefore, the heat content of the emp budget must be added to the
temperature equation in the variable volume case, while it does not appear in the constant
volume case. Similarly, the emp budget affects the ocean surface salinity in the constant
volume case (through the concentration dilution effect) while it does not appears explicitly in the variable volume case since salinity change will be induced by volume change.
In both constant and variable volume cases, surface salinity will change with ice-ocean
salt flux and F/M flux (both contained in empS emp) without mass exchanges.
Note that the concentration/dilution effect due to F/M is computed using a constant ice
salinity as well as a constant ocean salinity. This approximation suppresses the correlation
between SSS and F/M flux, allowing the ice-ocean salt exchanges to be conservative.
Indeed, if this approximation is not made, even if the F/M budget is zero on average over
the whole ocean domain and over the seasonal cycle, the associated salt flux is not zero,
78
since sea-surface salinity and F/M flux are intrinsically correlated (high SSS are found
where freezing is strong whilst low SSS is usually associated with high melting areas).
Even using this approximation, an exact conservation of heat and salt content is only
achieved in the variable volume case. In the constant volume case, there is a small imbalance associated with the product (t emp) SSS. Nevertheless, the salt content
variation is quite small and will not induce a long term drift as there is no physical reason
for (t emp) and SSS to be correlated [Roullet and Madec 2000]. Note that, while quite
small, the imbalance in the constant volume case is larger than the imbalance associated
with the Asselin time filter [Leclair and Madec 2009]. This is the reason why the modified
filter is not applied in the constant volume case.
5.4.2
=
=
=
=
=
=
=
=
=
./
.true.
.true.
.false.
.false.
1
0.58
0.35
23.0
!
!
!
!
!
!
!
!
!
When the penetrative solar radiation option is used (ln flxqsr=true), the solar radiation
penetrates the top few tens of meters of the ocean. If it is not used (ln flxqsr=false) all the
heat flux is absorbed in the first ocean level. Thus, in the former case a term is added to
the time evolution equation of temperature (2.1d) and the surface boundary condition is
modified to take into account only the non-penetrative part of the surface heat flux :
T
1
I
= ... +
t
o Cp e3 k
(5.14)
k [Iw ]
(5.15)
o Cp e3 k
o Cp e3t
The shortwave radiation, Qsr , consists of energy distributed across a wide spectral
range. The ocean is strongly absorbing for wavelengths longer than 700 nm and these
wavelengths contribute to heating the upper few tens of centimetres. The fraction of Qsr
that resides in these almost non-penetrative wavebands, R, is 58% (specified through
namelist parameter rn abs). It is assumed to penetrate the ocean with a decreasing exponential profile, with an e-folding depth scale, 0 , of a few tens of centimetres (typically
79
0 = 0.35 m set as rn si0 in the namtra qsr namelist). For shorter wavelengths (400700 nm), the ocean is more transparent, and solar energy propagates to larger depths where
it contributes to local heating. The way this second part of the solar energy penetrates into
the ocean depends on which formulation is chosen. In the simple 2-waveband light penetration scheme (ln qsr 2bd=true) a chlorophyll-independent monochromatic formulation
is chosen for the shorter wavelengths, leading to the following expression [Paulson and
Simpson 1977] :
h
i
I(z) = Qsr Rez/0 + (1 R) ez/1
(5.16)
where 1 is the second extinction length scale associated with the shorter wavelengths. It
is usually chosen to be 23 m by setting the rn si0 namelist parameter. The set of default
values (0 , 1 , R) corresponds to a Type I water in Jerlovs (1968) classification (oligotrophic waters).
Such assumptions have been shown to provide a very crude and simplistic representation of observed light penetration profiles (Morel [1988], see also Fig.5.2). Light absorption in the ocean depends on particle concentration and is spectrally selective. Morel
[1988] has shown that an accurate representation of light penetration can be provided by a
61 waveband formulation. Unfortunately, such a model is very computationally expensive.
Thus, Lengaigne et al. [2007] have constructed a simplified version of this formulation in
which visible light is split into three wavebands : blue (400-500 nm), green (500-600 nm)
and red (600-700nm). For each wave-band, the chlorophyll-dependent attenuation coefficient is fitted to the coefficients computed from the full spectral model of Morel [1988]
(as modified by Morel and Maritorena [2001]), assuming the same power-law relationship. As shown in Fig.5.2, this formulation, called RGB (Red-Green-Blue), reproduces
quite closely the light penetration profiles predicted by the full spectal model, but with
much greater computational efficiency. The 2-bands formulation does not reproduce the
full model very well.
The RGB formulation is used when ln qsr rgb=true. The RGB attenuation coefficients (i.e. the inverses of the extinction length scales) are tabulated over 61 nonuniform chlorophyll classes ranging from 0.01 to 10 g.Chl/L (see the routine trc oce rgb in
trc oce.F90 module). Three types of chlorophyll can be chosen in the RGB formulation :
(1) a constant 0.05 g.Chl/L value everywhere (nn chdta=0) ; (2) an observed time varying
chlorophyll (nn chdta=1) ; (3) simulated time varying chlorophyll by TOP biogeochemical model (ln qsr bio=true). In the latter case, the RGB formulation is used to calculate
both the phytoplankton light limitation in PISCES or LOBSTER and the oceanic heating
rate.
The trend in (5.15) associated with the penetration of the solar radiation is added to
the temperature trend, and the surface heat flux is modified in routine traqsr.F90.
When the z-coordinate is preferred to the s-coordinate, the depth of wlevels does
not significantly vary with location. The level at which the light has been totally absorbed
(i.e. it is less than the computer precision) is computed once, and the trend associated with
the penetration of the solar radiation is only added down to that level. Finally, note that
when the ocean is shallow (< 200 m), part of the solar radiation can reach the ocean floor.
80
Depth (m)
0
40
80
120
Chl=0.05 mg.m-3
20
100
180
I(z) (W/m2)
(a)
260
Chl=0.5 mg.m-3
20
100
180
I(z)(W/m 2)
(b)
260
In this case, we have chosen that all remaining radiation is absorbed in the last ocean level
(i.e. I is masked).
5.4.3
Usually it is assumed that there is no exchange of heat or salt through the ocean bottom, i.e. a no flux boundary condition is applied on active tracers at the bottom. This is the
default option in NEMO , and it is implemented using the masking technique. However,
there is a non-zero heat flux across the seafloor that is associated with solid earth cooling.
This flux is weak compared to surface fluxes (a mean global value of 0.1 W/m2 [Stein
and Stein 1992]), but it warms systematically the ocean and acts on the densest water
masses. Taking this flux into account in a global ocean model increases the deepest overturning cell (i.e. the one associated with the Antarctic Bottom Water) by a few Sverdrups
[Emile-Geay and Madec 2009].
The presence of geothermal heating is controlled by setting the namelist parameter
ln trabbc to true. Then, when nn geoflx is set to 1, a constant geothermal heating is in-
81
L atitude
50N
50S
100E
40.00
80.00
120.00
160W
L ongitude
160.00
200.00
240.00
60W
280.00
320.00
360.00
400.00
F IG . 5.3 Geothermal Heat flux (in mW.m2 ) used by Emile-Geay and Madec
[2009]. It is inferred from the age of the sea floor and the formulae of Stein and
Stein [1992].
troduced whose value is given by the nn geoflx cst, which is also a namelist parameter.
When nn geoflx is set to 2, a spatially varying geothermal heat flux is introduced which
is provided in the geothermal heating.nc NetCDF file (Fig.5.3) [Emile-Geay and Madec
2009].
5.5
82
downstairs following the step topography, sometimes over a thickness much larger than
the thickness of the observed gravity plume. A similar problem occurs in the s-coordinate
when the thickness of the bottom level varies rapidly downstream of a sill [Willebrand
et al. 2001], and the thickness of the plume is not resolved.
The idea of the bottom boundary layer (BBL) parameterisation, first introduced by
Beckmann and Doscher [1997], is to allow a direct communication between two adjacent
bottom cells at different levels, whenever the densest water is located above the less dense
water. The communication can be by a diffusive flux (diffusive BBL), an advective flux
(advective BBL), or both. In the current implementation of the BBL, only the tracers
are modified, not the velocities. Furthermore, it only connects ocean bottom cells, and
therefore does not include all the improvements introduced by Campin and Goosse [1999].
5.5.1
(5.17)
with the lateral gradient operator taken between bottom cells, and Al the lateral diffusivity in the BBL. Following Beckmann and Doscher [1997], the latter is prescribed with
a spatial dependence, i.e. in the conditional form
if H < 0
Abbl
Al (i, j, t) =
(5.18)
0
otherwise
where Abbl is the BBL diffusivity coefficient, given by the namelist parameter rn ahtbbl
and usually set to a value much larger than the one used for lateral mixing in the open
ocean. The constraint in (5.18) implies that sigma-like diffusion only occurs when the
density above the sea floor, at the top of the slope, is larger than in the deeper ocean
(see green arrow in Fig.5.4). In practice, this constraint is applied separately in the two
horizontal directions, and the density gradient in (5.18) is evaluated with the log gradient
formulation :
/ = T + S
(5.19)
where , and are functions of T , S and H , the along bottom mean temperature,
salinity and depth, respectively.
5.5.2
hT
i+1/2
83
i+1
e3u ikup
ikup
hT
i+1
kdwn
i+1
e3u i+1
kdwn
partial cell
F IG . 5.4 Advective/diffusive Bottom Boundary Layer. The BBL parameterisation is activated when ikup is larger than i+1
kdnw . Red arrows indicate the additional
overturning circulation due to the advective BBL. The transport of the downslope
flow is defined either as the transport of the bottom ocean cell (black arrow), or as
a function of the along slope density gradient. The green arrow indicates the diffusive BBL flux directly connecting kup and kdwn ocean bottom cells. connection
nn bbl adv = 1 : the downslope velocity is chosen to be the Eulerian ocean velocity just above the topographic step (see black arrow in Fig.5.4) [Beckmann and Doscher
1997]. It is a conditional advection, that is, advection is allowed only if dense water overlies less dense water on the slope (i.e. H < 0) and if the velocity is directed
towards greater depth (i.e. U H > 0).
nn bbl adv = 2 : the downslope velocity is chosen to be proportional to , the density
difference between the higher cell and lower cell densities [Campin and Goosse 1999].
The advection is allowed only if dense water overlies less dense water on the slope (i.e.
84
H < 0). For example, the resulting transport of the downslope flow, here in the
i-direction (Fig.5.4), is simply given by the following expression :
utr
bbl = g
(5.20)
T
kup
kdw
bt do
kdw
utr
sh
do
sh
bbl
t Tkup
+ sh
Tkup
Tkup
bt kup
do
do
t Tkdw
t Tkdw
+
(5.21)
sh
t Tkup
(5.22)
utr
sh
do
bbl
T
T
k+1
k
bt do
k
(5.23)
5.6
85
!----------------------------------------------------------------------&namdta_tem
!
data : temperature
("key_dtatem")
!----------------------------------------------------------------------!
! file name ! frequency (hours)
! variable ! time interp. ! clim !yearly or ! weights ! rotation !
!
!
! (if <0 months)
!
name
! (logical)
! (T/F) ! monthly ! filename ! pairing !
sn_tem = data_1m_potential_temperature_nomask, -1,votemper, .true. , .true., yearly
,
,
!
cn_dir
= ./
! root directory for the location of the runoff files
/
!----------------------------------------------------------------------&namdta_sal
!
data : salinity
("key_dtasal")
!----------------------------------------------------------------------!
! file name ! frequency (hours)
! variable ! time interp. ! clim !yearly or ! weights ! rotation !
!
!
! (if <0 months)
!
name
!
(logical) ! (T/F) ! monthly ! filename ! pairing !
sn_sal
= data_1m_salinity_nomask, -1 ,vosaline,
.true.
, .true., yearly
,
,
!
cn_dir
= ./
! root directory for the location of the runoff files
/
In some applications it can be useful to add a Newtonian damping term into the temperature and salinity equations :
T
= (T To )
t
S
= (S So )
t
(5.24)
where is the inverse of a time scale, and To and So are given temperature and salinity
fields (usually a climatology). The restoring term is added when key tradmp is defined.
It also requires that both key dtatem and key dtasal are defined and fill in namdta tem
and namdta sal namelists (i.e. that To and So are read using fldread.F90, see 7.2.1). The
restoring coefficient is a three-dimensional array initialized by the user in routine dtacof
also located in module tradmp.F90.
The two main cases in which (5.24) is used are (a) the specification of the boundary
conditions along artificial walls of a limited domain basin and (b) the computation of the
velocity field associated with a given T -S field (for example to build the initial state of a
prognostic simulation, or to use the resulting velocity field for a passive tracer study). The
first case applies to regional models that have artificial walls instead of open boundaries.
In the vicinity of these walls, takes large values (equivalent to a time scale of a few
days) whereas it is zero in the interior of the model domain. The second case corresponds
to the use of the robust diagnostic method [Sarmiento and Bryan 1982]. It allows us to
find the velocity field consistent with the model dynamics whilst having a T , S field close
to a given climatological field (To , So ). The time scale associated with So is generally
not a constant but spatially varying in order to respect other properties. For example, it is
usually set to zero in the mixed layer (defined either on a density or So criterion) [Madec
et al. 1996] and in the equatorial region [Reverdin et al. 1991, Fujio and Imasato 1991,
Marti 1992] since these two regions have a short time scale of adjustment ; while smaller
are used in the deep ocean where the typical time scale is long [Sarmiento and Bryan
1982]. In addition the time scale is reduced (even to zero) along the western boundary to
allow the model to reconstruct its own western boundary structure in equilibrium with its
physics. The choice of the shape of the Newtonian damping is controlled by two namelist
parameters nn hdmp and nn zdmp. The former allows us to specify : the width of the
equatorial band in which no damping is applied ; a decrease in the vicinity of the coast ;
86
and a damping everywhere in the Red and Med Seas. The latter sets whether damping
should act in the mixed layer or not. The time scale associated with the damping depends
on the depth as a hyperbolic tangent, with rn surf as surface value, rn bot as bottom value
and a transition depth of rn dep.
The robust diagnostic method is very efficient in preventing temperature drift in intermediate waters but it produces artificial sources of heat and salt within the ocean. It also
has undesirable effects on the ocean convection. It tends to prevent deep convection and
subsequent deep-water formation, by stabilising the water column too much.
An example of the computation of for a robust diagnostic experiment with the
ORCA2 model is provided in the tradmp.F90 module (subroutines dtacof and cofdis
which compute the coefficient and the distance to the bathymetry, respectively). These
routines are provided as examples and can be customised by the user.
5.7
The general framework for tracer time stepping is a modified leap-frog scheme [Leclair and Madec 2009], i.e. a three level centred time scheme associated with a Asselin
time filter (cf. 3.5) :
(e3t T )t+t = (e3t T )tt
f
(e3t T )tf
= (e3t T )t
+2 t et3t RHSt
h
i
t
t+t
+ (e3t T )tt
2(e
T
)
+
(e
T
)
3t
3t
f
h
i
t Qt+t/2 Qtt/2
(5.25)
where RHS is the right hand side of the temperature equation, the subscript f denotes
filtered values, is the Asselin coefficient, and S is the total forcing applied on T (i.e.
fluxes plus content in mass exchanges). is initialized as rn atfp (namelist parameter).
Its default value is rn atfp=103 . Note that the forcing correction term in the filter is not
applied in linear free surface (lk vvl=false) (see 5.4.1. Not also that in constant volume
case, the time stepping is performed on T , not on its content, e3t T .
87
When the vertical mixing is solved implicitly, the update of the next tracer fields
is done in module trazdf.F90. In this case only the swapping of arrays and the Asselin
filtering is done in the tranxt.F90 module.
In order to prepare for the computation of the next time step, a swap of tracer arrays
is performed : T tt = T t and T t = Tf .
5.8
5.8.1
88
The default option (namelist parameter nn eos=0) is the Jackett and McDougall [1995]
equation of state. Its use is highly recommended. However, for process studies, it is often
convenient to use a linear approximation of the density. With such an equation of state
there is no longer a distinction between in situ and potential density and both cabbeling
and thermobaric effects are removed. Two linear formulations are available : a function of
T only (nn eos=1) and a function of both T and S (nn eos=2) :
da (T ) = (T )/o 1 = 0.0285 T
da (T, S) = (T, S)/o 1 = S T
(5.26)
where and are the thermal and haline expansion coefficients, and o , the reference
volumic mass, rau0. ( and can be modified through the rn alpha and rn beta namelist
parameters). Note that when da is a function of T only (nn eos=1), the salinity is a passive
tracer and can be used as such.
5.8.2
g
e3w
k+1/2 [S] k+1/2 [T ]
(5.28)
where and are the constant coefficients used to defined the linear equation of state
(5.26).
5.8.3
89
surface temperature increase and so the pressure dependence is neglected. The dependence on T and S is weak. For example, with S = 35 psu, Cp increases from 3989 to
4002 when T varies from -2 C to 31 C. Therefore, Cp has been chosen as a constant :
Cp = 4.103 J Kg 1 K 1 . Its value is set in phycst.F90 module.
5.8.4
(5.29)
(5.29) is only used to compute the potential freezing point of sea water (i.e. referenced
to the surface p = 0), thus the pressure dependent terms in (5.29) (last term) have been
dropped. The freezing point is computed through tfreez, a F ORTRAN function that can be
found in eosbn2.F90.
5.9
Te =
i
ei+1
3w e3w
i+1
k T i+1
i+1
3w
i
if ei+1
3w e3w
T i
i
if ei+1
3w < e3w
i
ei+1
3w e3w
+
k T i+1
ei3w
90
i+1/2
i+1
ZT k
i+1
ZT k
e3w k
ik-1
i+1
k-1
i+1
ik
partial cell
i+1
k
e3w k
i+1
k
91
and the resulting forms for the horizontal difference and the horizontal average value of
T at a U -point are :
i
e Ti
if ei+1
3w e3w
T
i+1/2 T =
T i+1 Te
if ei+1 < ei
3w
3w
(5.30)
T
i+1/2
(T
T i )/2
i
if ei+1
3w e3w
i+1 e
(T
T )/2
i
if ei+1
3w < e3w
Contents
6.1
6.2
6.3
6.4
6.5
6.6
94
6.7
6.8
6.9
dynldf bilap)
. . . . . . . .
. . . . . . . .
. . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
109
109
111
111
6.1
6.1.1
95
1
e1f e2f
(6.1)
1
(i [e2u e3u u] + j [e1v e3v v])
e1t e2t e3t
(6.2)
Note that although the vorticity has the same discrete expression in z- and s-coordinates,
its physical meaning is not identical. is a pseudo vorticity along s-surfaces (only pseudo
because (u, v) are still defined along geopotential surfaces, but are not necessarily defined
at the same depth).
The vorticity and divergence at the before step are used in the computation of the horizontal diffusion of momentum. Note that because they have been calculated prior to the
Asselin filtering of the before velocities, the before vorticity and divergence arrays must
be included in the restart file to ensure perfect restartability. The vorticity and divergence
at the now time step are used for the computation of the nonlinear advection and of the
vertical velocity respectively.
6.1.2
1 X
emp
e3t
w
(6.3)
where emp is the surface freshwater budget (evaporation minus precipitation), expressed
in Kg/m2 /s (which is equal to mm/s), and w =1,035 Kg/m3 is the reference density of sea
water (Boussinesq approximation). If river runoff is expressed as a surface freshwater flux
(see 7) then emp can be written as the evaporation minus precipitation, minus the river
runoff. The sea-surface height is evaluated using exactly the same time stepping scheme
as the tracer equation (5.25) : a leapfrog scheme in combination with an Asselin time filter,
i.e. the velocity appearing in (6.3) is centred in time (now velocity). This is of paramount
importance. Replacing T by the number 1 in the tracer equation and summing over the
water column must lead to the sea surface height equation otherwise tracer content will
not be conserved ??.
96
The vertical velocity is computed by an upward integration of the horizontal divergence starting at the bottom, taking into account the change of the thickness of the levels :
6.2
The vector invariant form of the momentum equations is the one most often used
in applications of the NEMO ocean model. The flux form option (see next section) has
been present since version 2. Coriolis and momentum advection terms are evaluated using
a leapfrog scheme, i.e. the velocity appearing in these expressions is centred in time
(now velocity). At the lateral boundaries either free slip, no slip or partial slip boundary
conditions are applied following Chap.8.
6.2.1
Four discretisations of the vorticity term (ln dynvor xxx=true) are available : conserving potential enstrophy of horizontally non-divergent flow (ENS scheme) ; conserving
horizontal kinetic energy (ENE scheme) ; conserving potential enstrophy for the relative vorticity term and horizontal kinetic energy for the planetary vorticity term (MIX
scheme) ; or conserving both the potential enstrophy of horizontally non-divergent flow
and horizontal kinetic energy (ENE scheme) (see Appendix ??). The vorticity terms are
all computed in dedicated routines that can be found in the dynvor.F90 module.
97
i
i,j+1/2
1 +f
(e1v e3v v)
+e
e3f
1u
(6.5)
j
i+1/2,j
+
f
(e2u e3u u)
e2v
e3f
j
1
+f
i+1/2
(e1v e3v v)
+e
e3f
1u
(6.6)
i
1 + f
j+1/2
(e2u e3u u)
e2v
e3f
i
j
i,j+1/2
1
f
1
i+1/2
+
(e
e
v)
(e
e
v)
1v 3v
1v 3v
e
e3f
e1u e3f
1u
(6.7)
j
i
i+1/2,j
1
f
j+1/2
(e2u e3u u)
+
(e2u e3u u)
e2v e3f
e2v e3f
98
points, a price worth paying to avoid a double averaging in the pressure gradient term as
in the B-grid.
A very nice solution to the problem of double averaging was proposed by Arakawa
and Hsu [1990]. The idea is to get rid of the double averaging by considering triad combinations of vorticity. It is noteworthy that this solution is conceptually quite similar to
the one proposed by [Griffies et al. 1998] for the discretization of the iso-neutral diffusion
operator (see App.E).
The Arakawa and Hsu [1990] vorticity advection scheme for a single layer is modified
for spherical coordinates as described by Arakawa and Lamb [1981] to obtain the EEN
scheme. First consider the discrete expression of the potential vorticity, q, defined at an
f -point :
+f
q=
(6.8)
e3f
where the relative vorticity is defined by (6.1), the Coriolis parameter is given by f =
2 sin f and the layer thickness at f -points is :
e3f = e3t
i+1/2,j+1/2
(6.9)
Note that a key point in (6.9) is that the averaging in the i- and j- directions uses the
masked vertical scale factor but is always divided by 4, not by the sum of the masks at the
four T -points. This preserves the continuity of e3f when one or more of the neighbouring
e3t tends to zero and extends by continuity the value of e3f into the land areas. This feature
is essential for the z-coordinate with partial steps.
i
Next, the vorticity triads, ij Qjpp can be defined at a T -point as the following triad
combinations of the neighbouring potential vorticities defined at f-points (Fig. 6.1) :
1 iip
i+jp
i+ip
j ip
Q
=
(6.10)
q
+
q
+
q
i jp
j+jp
j+ip
jjp
12
where the indices ip and kp take the values : ip = 1/2 or 1/2 and jp = 1/2 or 1/2.
Finally, the vorticity terms are represented as :
1 X i+1/2ip ip
i+1/2i
+q e3 v +
Qjp (e1v e3v v)j+jp p
e1u
ip , k p
(6.11)
X
1
ip
i+ip
i
q
e
u
Q
(e
e
u)
3
2u
3u
j+1/2jp jp
j+1/2jp
e2v
ip , k p
This EEN scheme in fact combines the conservation properties of the ENS and ENE
schemes. It conserves both total energy and potential enstrophy in the limit of horizontally
nondivergent flow (i.e. =0) (see Appendix ??). Applied to a realistic ocean configuration, it has been shown that it leads to a significant reduction of the noise in the vertical
velocity field [Le Sommer et al. 2009]. Furthermore, used in combination with a partial
steps representation of bottom topography, it improves the interaction between current
and topography, leading to a larger topostrophy of the flow [Barnier et al. 2006, Penduff
et al. 2007].
99
i+1
T
F
V
j+1
j-1
i-1
i+1
j+1
F IG . 6.1 Triads used in the energy and enstrophy conserving scheme (een) for
u-component (upper panel) and v-component (lower panel).
6.2.2
h i
i
1
j
i+1/2 u2 + v 2
2 e1u
(6.12)
h i
i
1
j
2
2
u +v
2 e2v j+1/2
100
6.2.3
k
1
e1t e2t w i+1/2 k+1/2 [u]
e1u e2u e3u
k
1
6.3
(6.13)
In the flux form (as in the vector invariant form), the Coriolis and momentum advection terms are evaluated using a leapfrog scheme, i.e. the velocity appearing in their
expressions is centred in time (now velocity). At the lateral boundaries either free slip, no
slip or partial slip boundary conditions are applied following Chap.8.
6.3.1
e2
e1
v
u
i
j
f+
1 i+1/2
v
i+1/2 [e2u ] uj+1/2 j+1/2 [e1u ]
(6.14)
e1f e2f
Any of the (C.13), (6.6) and (C.15) schemes can be used to compute the product of
the Coriolis parameter and the vorticity. However, the energy-conserving scheme (C.15)
has exclusively been used to date. This term is evaluated using a leapfrog scheme, i.e. the
velocity is centred in time (now velocity).
6.3.2
101
h
i
1
i
i+1/2
e
e
u
u
+
e
e
v
u
2u
3u
t
j
1u
3u
f
i+1/2
i
h
i+1/2
+
e
e
w
u
1w
2w
uw
k
(6.15)
h
i
j+1/2
e
e
u
v
+ j+1/2 e1u e3u v i vt
i
2u
3u
f
h
i
+ e e wj+1/2 v
k
1w 2w
vw
Two advection schemes are available : a 2nd order centered finite difference scheme,
CEN2, or a 3rd order upstream biased scheme, UBS. The latter is described in Shchepetkin and McWilliams [2005]. The schemes are selected using the namelist logicals
ln dynadv cen2 and ln dynadv ubs. In flux form, the schemes differ by the choice of a
space and time interpolation to define the value of u and v at the centre of each face of uand v-cells, i.e. at the T -, f -, and uw-points for u and at the f -, T - and vw-points for v.
102
of the advection scheme is similar to that reported in Farrow and Stevens [1995]. It is a relatively good compromise between accuracy and smoothness. It is not a positive scheme,
meaning that false extrema are permitted. But the amplitudes of the false extrema are
significantly reduced over those in the centred second order method. As the scheme already includes a diffusion component, it can be used without explicit lateral diffusion on
momentum (i.e. ln dynldf lap=ln dynldf bilap=false), and it is recommended to do so.
The UBS scheme is not used in all directions. In the vertical, the centred 2nd order
ubs
evaluation of the advection is preferred, i.e. uubs
uw and uvw in (6.16) are used. UBS is
diffusive and is associated with vertical mixing of momentum.
For stability reasons, the first term in (6.17), which corresponds to a second order
centred scheme, is evaluated using the now velocity (centred in time), while the second
term, which is the diffusion part of the scheme, is evaluated using the before velocity
(forward in time). This is discussed by Webb et al. [1998] in the context of the Quick
advection scheme.
Note that the UBS and QUICK (Quadratic Upstream Interpolation for Convective
Kinematics) schemes only differ by one coefficient. Replacing 1/6 by 1/8 in (6.17) leads
to the QUICK advection scheme [Webb et al. 1998]. This option is not available through
a namelist parameter, since the 1/6 coefficient is hard coded. Nevertheless it is quite easy
to make the substitution in the dynadv ubs.F90 module and obtain a QUICK scheme.
Note also that in the current version of dynadv ubs.F90, there is also the possibility
of using a 4th order evaluation of the advective velocity as in ROMS. This is an error and
should be suppressed soon.
6.4
The key distinction between the different algorithms used for the hydrostatic pressure
gradient is the vertical coordinate used, since HPG is a horizontal pressure gradient, i.e.
computed along geopotential surfaces. As a result, any tilt of the surface of the computational levels will require a specific treatment to compute the hydrostatic pressure gradient.
The hydrostatic pressure gradient term is evaluated either using a leapfrog scheme,
i.e. the density appearing in its expression is centred in time (now ), or a semi-implcit
scheme. At the lateral boundaries either free slip, no slip or partial slip boundary conditions are applied.
6.4.1
103
h i
1
i+1/2 ph
= g i+1/2 [e3w ]k=km
2
k=km
(6.18)
h i
1
=
p
g
[e
]
j+1/2
j+1/2 3w
k=km
2
k=km
for 1 < k < km (interior layer)
h
i
h i
h i
1
h
h
(6.19)
Note that the 1/2 factor in (6.18) is adequate because of the definition of e3w as the
vertical derivative of the scale factor at the surface level (z = 0). Note also that in case
of variable volume level (key vvl defined), the surface pressure gradient is included in
(6.18) and (6.19) through the space and time variations of the vertical scale factor e3w .
6.4.2
6.4.3
s- and z-s-coordinates
Pressure gradient formulations in an s-coordinate have been the subject of a vast number of papers (e.g., Song [1998], Shchepetkin and McWilliams [2005]). A number of
different pressure gradient options are coded, but they are not yet fully documented or
tested.
104
Traditional coding (see for example Madec et al. [1996] : (ln dynhpg sco=true,
ln dynhpg hel=true)
h i g i+1/2
i+1/2 ph +
[zt ]
o e1u
o e1u i+1/2
(6.20)
h i g j+1/2
[zt ]
p +
o e2v j+1/2
o e2v j+1/2
Where the first term is the pressure gradient along coordinates, computed as in (6.18)
- (6.19), and zT is the depth of the T -point evaluated from the sum of the vertical scale
factors at the w-point (e3w ). The version ln dynhpg hel=true has been added by Aike
Beckmann and involves a redefinition of the relative position of T -points relative to wpoints.
Weighted density Jacobian (WDJ) [Song 1998] (ln dynhpg wdj=true)
Density Jacobian with cubic polynomial scheme (DJC) [Shchepetkin and McWilliams
2005] (ln dynhpg djc=true)
Rotated axes scheme (rot) [Thiem and Berntsen 2006] (ln dynhpg rot=true)
Note that expression (6.20) is used when the variable volume formulation is activated
(key vvl) because in that case, even with a flat bottom, the coordinate surfaces are not
horizontal but follow the free surface [Levier et al. 2007]. The other pressure gradient
options are not yet available.
6.4.4
(6.21)
(6.22)
The semi-implicit time scheme (6.22) is made possible without significant additional
computation since the density can be updated to time level t + t before computing the
105
horizontal hydrostatic pressure gradient. It can be easily shown that the stability limit
associated with the hydrostatic pressure gradient doubles using (6.22) compared to that
using the standard leapfrog scheme (6.21). Note that (6.22) is equivalent to applying a
time filter to the pressure gradient to eliminate high frequency IGWs. Obviously, when
using (6.22), the doubling of the time-step is achievable only if no other factors control
the time-step, such as the stability limits associated with advection or diffusion.
In practice, the semi-implicit scheme is used when ln dynhpg imp=true. In this case,
we choose to apply the time filter to temperature and salinity used in the equation of state,
instead of applying it to the hydrostatic pressure or to the density, so that no additional
storage array has to be defined. The density used to compute the hydrostatic pressure
gradient (whatever the formulation) is evaluated as follows :
e zt ) with X
e = 1/4 X t+t + 2 X t + X tt
t = (Te, S,
(6.23)
Note that in the semi-implicit case, it is necessary to save the filtered density, an extra
three-dimensional field, in the restart file to restart the model with exact reproducibility.
This option is controlled by nn dynhpg rst, a namelist parameter.
6.5
The surface pressure gradient term is related to the representation of the free surface
(2.2). The main distinction is between the fixed volume case (linear free surface) and the
variable volume case (nonlinear free surface, key vvl is defined). In the linear free surface
case (2.2.2) the vertical scale factors e3 are fixed in time, while they are time-dependent
in the nonlinear case (2.2.2). With both linear and nonlinear free surface, external gravity
waves are allowed in the equations, which imposes a very small time step when an explicit
time stepping is used. Two methods are proposed to allow a longer time step for the threedimensional equations : the filtered free surface, which is a modification of the continuous
equations (see (2.6)), and the split-explicit free surface described below. The extra term
introduced in the filtered method is calculated implicitly, so that the update of the next
velocities is done in module dynspg flt.F90 and not in dynnxt.F90.
The form of the surface pressure gradient term depends on how the user wants to
handle the fast external gravity waves that are a solution of the analytical equation (2.2).
Three formulations are available, all controlled by a CPP key (ln dynspg xxx) : an explicit
formulation which requires a small time step ; a filtered free surface formulation which
allows a larger time step by adding a filtering term into the momentum equation ; and a
split-explicit free surface formulation, described below, which also allows a larger time
step.
106
The extra term introduced in the filtered method is calculated implicitly, so that a
solver is used to compute it. As a consequence the update of the next velocities is done
in module dynspg flt.F90 and not in dynnxt.F90.
6.5.1
[]
e1u o i+1/2
1
[]
e2v o j+1/2
(6.24)
Note that in the non-linear free surface case (i.e. key vvl defined), the surface pressure gradient is already included in the momentum tendency through the level thickness
variation allowed in the computation of the hydrostatic pressure gradient. Thus, nothing
is done in the dynspg exp.F90 module.
6.5.2
6.5.3
t-t
107
t+1/2t
t+t
t+3/2t
t+2t
~~
U
F IG . 6.2 Schematic of the split-explicit time stepping scheme for the external
and internal modes. Time increases to the right. Internal mode time steps (which
are also the model time steps) are denoted by tt, t, t+t, and t+2t. The curved line represents a leap-frog time step, and the smaller time steps N te = 32 t
are denoted by the zig-zag line. The vertically integrated forcing M(t) computed at
the model time step t represents the interaction between the external and internal
motions. While keeping M and freshwater forcing field fixed, a leap-frog integration carries the external mode variables (surface height and vertically integrated
velocity) from t to t + 32 t using N external time steps of length te . Time averaging the external fields over the 23 N + 1 time steps (endpoints included) centers
the vertically integrated velocity and the sea surface height at the model timestep
t + t. These averaged values are used to update M(t) with both the surface pressure gradient and the Coriolis force, therefore providing the t + t velocity. The
model time stepping scheme can then be achieved by a baroclinic leap-frog time
step that carries the surface height from t t to t + t.
6.6
The options available for lateral diffusion are to use either laplacian (rotated or not)
or biharmonic operators. The coefficients may be constant or spatially variable ; the description of the coefficients is found in the chapter on lateral physics (Chap.9). The lateral
diffusion of momentum is evaluated using a forward scheme, i.e. the velocity appearing
in its expression is the before velocity in time, except for the pure vertical component that
appears when a tensor of rotation is used. This latter term is solved implicitly together
with the vertical diffusion term (see ??)
108
At the lateral boundaries either free slip, no slip or partial slip boundary conditions
are applied according to the users choice (see Chap.8).
6.6.1
i
h
i
h
1
1
lm
lm
lU
A
D
=
j
3f
u
f
e1u i+1/2 T
e2u e3u
(6.25)
i
h
i
h
lm
DvlU = 1 j+1/2 Alm
e
A
i
3f
T
f
e2v
e1v e3v
As explained in 2.5.2, this formulation (as the gradient of a divergence and curl of
the vorticity) preserves symmetry and ensures a complete separation between the vorticity
and divergence parts of the momentum diffusion.
6.6.2
109
j, k+1/2
e1u e2u 2
2
+
r1uw + r2uw k+1/2 [u]
e3uw
(6.26)
1
DvlV =
e e e
1v 2v 3v
i+1/2, k
lm e2f e3f
i+1/2 [v] e2f r1f k+1/2 [v]
i+1/2 Af
e1f
j, k
lm e1t e3t
+ j AT
j [v] e1t r2t k+1/2 [v]
e2t
i+1/2, k+1/2
lm
+ k Avw e2v r1vw i+1/2 [v]
e1v r2vw j+1/2 [v]
j+1/2, k+1/2
e1v e2v 2
2
+
r1vw + r2vw k+1/2 [v]
e3vw
where r1 and r2 are the slopes between the surface along which the diffusion operator acts
and the surface of computation (z- or s-surfaces). The way these slopes are evaluated is
given in the lateral physics chapter (Chap.9).
6.6.3
6.7
110
!----------------------------------------------------------------------rn_avm0
=
1.2e-4 ! vertical eddy viscosity
[m2/s]
(background Kz if not "key_zdfcst")
rn_avt0
=
1.2e-5 ! vertical eddy diffusivity [m2/s]
(background Kz if not "key_zdfcst")
nn_avb
=
0
! profile for background avt & avm (=1) or not (=0)
nn_havtb
=
0
! horizontal shape for avtb (=1) or not (=0)
ln_zdfevd
= .true.
! enhanced vertical diffusion (evd) (T) or not (F)
nn_evdm
=
0
! evd apply on tracer (=0) or on tracer and momentum (=1)
rn_avevd
= 100.
! evd mixing coefficient [m2/s]
ln_zdfnpc
= .false.
! Non-Penetrative Convective algorithm (T) or not (F)
nn_npc
=
1
! frequency of application of npc
nn_npcp
= 365
! npc control print frequency
ln_zdfexp
= .false.
! time-stepping: split-explicit (T) or implicit (F) time stepping
nn_zdfexp
=
3
! number of sub-timestep for ln_zdfexp=T
/
The large vertical diffusion coefficient found in the surface mixed layer together with
high vertical resolution implies that in the case of explicit time stepping there would be
too restrictive a constraint on the time step. Two time stepping schemes can be used for the
vertical diffusion term : (a) a forward time differencing scheme (ln zdfexp=true) using a
time splitting technique (nn zdfexp > 1) or (b) a backward (or implicit) time differencing
scheme (ln zdfexp=false) (see ??). Note that namelist variables ln zdfexp and nn zdfexp
apply to both tracers and dynamics.
The formulation of the vertical subgrid scale physics is the same whatever the vertical
coordinate is. The vertical diffusion operators given by (2.36) take the following semidiscrete space form :
vm
Auw
1
vm
[u]
Du
e3u
e3uw k+1/2
(6.27)
vm
Avw
1
Dvvm
k
[v]
e3v
e3vw k+1/2
vm
where Avm
uw and Avw are the vertical eddy viscosity and diffusivity coefficients. The way
these coefficients are evaluated depends on the vertical physics used (see 10).
The surface boundary condition on momentum is the stress exerted by the wind. At
the surface, the momentum fluxes are prescribed as the boundary condition on the vertical
turbulent momentum fluxes,
Avm Uh
1 u
=
e3 k z=1 o v
(6.28)
where (u , v ) are the two components of the wind stress vector in the (i,j) coordinate
system. The high mixing coefficients in the surface mixed layer ensure that the surface
wind stress is distributed in the vertical over the mixed layer depth. If the vertical mixing
coefficient is small (when no mixed layer scheme is used) the surface stress enters only
the top model level, as a body force. The surface wind stress is calculated in the surface
module routines (SBC, see Chap.7)
The turbulent flux of momentum at the bottom of the ocean is specified through a
bottom friction parameterisation (see 10.4)
6.8
111
External Forcings
Besides the surface and bottom stresses (see the above section) which are introduced
as boundary conditions on the vertical mixing, two other forcings enter the dynamical
equations.
One is the effect of atmospheric pressure on the ocean dynamics. Another forcing
term is the tidal potential. Both of which will be introduced into the reference version
soon.
6.9
The general framework for dynamics time stepping is a leap-frog scheme, i.e. a three
level centred time scheme associated with an Asselin time filter (cf. Chap.3). The scheme
is applied to the velocity, except when using the flux form of momentum advection (cf.
6.3) in the variable volume case (key vvl defined), where it has to be applied to the
thickness weighted velocity (see A.3)
vector invariant form or linear free surface (ln dynhpg vec=true ; key vvl not defined) :
2u
+
u
f
flux form and nonlinear free surface (ln dynhpg vec=false ; key vvl defined) :
(e
u)
2
(e
u)
+
(e
u)
3u
3u
3u
3u
f
f
where RHS is the right hand side of the momentum equation, the subscript f denotes filtered values and is the Asselin coefficient. is initialized as nn atfp (namelist parameter).
Its default value is nn atfp = 103 . In both cases, the modified Asselin filter is not applied
since perfect conservation is not an issue for the momentum equations.
Note that with the filtered free surface, the update of the after velocities is done
in the dynsp flt.F90 module, and only array swapping and Asselin filtering is done in
dynnxt.F90.
Contents
7.1
7.2
7.3
7.4
7.5
7.6
7.7
7.8
7.9
115
116
117
119
121
122
122
122
123
124
125
125
127
127
128
130
130
131
114
!----------------------------------------------------------------------&namsbc
!
Surface Boundary Condition (surface module)
!----------------------------------------------------------------------nn_fsbc
= 5
! frequency of surface boundary condition computation
!
(also = the frequency of sea-ice model call)
ln_ana
= .false.
! analytical formulation
(T => fill namsbc_ana )
ln_flx
= .false.
! flux formulation
(T => fill namsbc_flx )
ln_blk_clio = .false.
! CLIO bulk formulation
(T => fill namsbc_clio)
ln_blk_core = .true.
! CORE bulk formulation
(T => fill namsbc_core)
ln_cpl
= .false.
! Coupled formulation
(T => fill namsbc_cpl )
ln_apr_dyn = .false.
! Patm gradient added in ocean & ice Eqs.
(T => fill namsbc_apr )
nn_ice
= 2
! =0 no ice boundary condition
,
! =1 use observed ice-cover
,
! =2 ice-model used
("key_lim3" or "key_lim2)
ln_dm2dc
= .false.
! daily mean to diurnal cycle on short wave
ln_rnf
= .true.
! runoffs
(T => fill namsbc_rnf)
ln_ssr
= .true.
! Sea Surface Restoring on T and/or S
(T => fill namsbc_ssr)
nn_fwb
= 3
! FreshWater Budget: =0 unchecked
!
=1 global mean of e-p-r set to zero at each time step
!
=2 annual global mean of e-p-r set to zero
!
=3 global emp set to zero and spread out over erp area
/
The surface pressure field could be use in bulk formulae, nevertheless none of the current bulk
formulea (CLIO and CORE) uses the it.
115
In this chapter, we first discuss where the surface boundary condition appears in the
model equations. Then we present the four ways of providing the surface boundary condition, followed by the description of the atmospheric pressure and the river runoff. Next the
scheme for interpolation on the fly is described. Finally, the different options that further
modify the fluxes applied to the ocean are discussed.
7.1
(7.3)
where Iw is a non-dimensional function that describes the way the light penetrates inside
the water column. It is generally a sum of decreasing exponentials (see 5.4.2).
The surface freshwater budget is provided by fields : emp and empS which may or may
not be identical. Indeed, a surface freshwater flux has two effects : it changes the volume
of the ocean and it changes the surface concentration of salt (and other tracers). Therefore
it appears in the sea surface height as a volume flux, emp (dynspg xxx modules), and in
the salinity time evolution equations as a concentration/dilution effect, empS (trasbc.F90
module).
+ emp
t
(7.4)
empS S
S
+
t
e3t
k=1
116
Model variable
ssu m
ssv m
sst m
sss m
Units
m.s1
m.s1
K
psu
point
U
V
T
T
TAB . 7.1 Ocean variables provided by the ocean to the surface module (SBC).
The variable are averaged over nf sbc time step, i.e. the frequency of computation
of surface fluxes.
In the real ocean, emp = empS and the ocean salt content is conserved, but it exist several numerical reasons why this equality should be broken. For example, when the ocean
is coupled to a sea-ice model, the water exchanged between ice and ocean is slightly
salty (mean sea-ice salinity is 4 psu). In this case, empS take into account both concentration/dilution effect associated with freezing/melting and the salt flux between ice and
ocean, while emp is only the volume flux. In addition, in the current version of NEMO
, the sea-ice is assumed to be above the ocean (the so-called levitating sea-ice). Freezing/melting does not change the ocean volume (no impact on emp) but it modifies the
SSS.
Note that SST can also be modified by a freshwater flux. Precipitation (in particular
solid precipitation) may have a temperature significantly different from the SST. Due to
the lack of information about the temperature of precipitation, we assume it is equal to the
SST. Therefore, no concentration/dilution term appears in the temperature equation. It has
to be emphasised that this absence does not mean that there is no heat flux associated with
precipitation ! Precipitation can change the ocean volume and thus the ocean heat content.
It is therefore associated with a heat flux (not yet diagnosed in the model) [Roullet and
Madec 2000]).
The ocean model provides the surface currents, temperature and salinity averaged
over nf sbc time-step (7.1).The computation of the mean is done in sbcmod.F90 module.
7.2
117
3. make the run duration independent from the period cover by the input files.
4. provide a simple user interface and a rather simple developer interface by limiting
the number of prerequisite information.
As a results the user have only to fill in for each variable a structure in the namelist
file to defined the input data file and variable names, the frequency of the data (in hours
or months), whether its is climatological data or not, the period covered by the input file
(one year, month, week or day), and two additional parameters for on-the-fly interpolation.
When adding a new input variable, the developer has to add the associated structure in the
namelist, read this information by mirroring the namelist read in sbc blk init for example,
and simply call fld read to obtain the desired input field at the model time-step and grid
points.
The only constraints are that the input file is a NetCDF file, the file name follows a
nomenclature (see 7.2.1), the period it cover is one year, month, week or day, and, if
on-the-fly interpolation is used, a file of weights must be supplied (see 7.2.2).
Note that when an input data is archived on a disc which is accessible directly from
the workspace where the code is executed, then the use can set the cn dir to the pathway leading to the data. By default, the data are assumed to have been copied so that
cn dir=./.
7.2.1
!
!
file name
! time interp. !
!
(logical) !
where
File name : the stem name of the NetCDF file to be open. This stem will be completed
automatically by the model, with the addition of a .nc at its end and by date information and possibly a prefix (when using AGRIF). Tab.7.2 provides the resulting
file name in all possible cases according to whether it is a climatological file or not,
and to the open/close frequency (see below for definition).
Record frequency : the frequency of the records contained in the input file. Its unit is in
hours if it is positive (for example 24 for daily forcing) or in months if negative (for
example -1 for monthly forcing or -12 for annual forcing). Note that this frequency
must really be an integer and not a real. On some computers, seting it to 24. can
be interpreted as 240 !
Variable name : the name of the variable to be read in the input NetCDF file.
Time interpolation : a logical to activate, or not, the time interpolation. If set to false, the forcing will have a steplike shape remaining constant during each forcing
period. For example, when using a daily forcing without time interpolation, the forcing remaining constant from 00h0000 to 23h5959. If set to true, the forcing
118
119
7.2.2
Interpolation on-the-Fly
Interpolation on the Fly allows the user to supply input files required for the surface
forcing on grids other than the model grid. To do this he or she must supply, in addition
to the source data file, a file of weights to be used to interpolate from the data grid to
the model grid. The original development of this code used the SCRIP package (freely
available here under a copyright agreement). In principle, any package can be used to
generate the weights, but the variables in the input weights file must have the same names
and meanings as assumed by the model. Two methods are currently available : bilinear
and bicubic interpolation.
Bilinear Interpolation
The input weights file in this case has two sets of variables : src01, src02, src03,
src04 and wgt01, wgt02, wgt03, wgt04. The src variables correspond to the point in
the input grid to which the weight wgt is to be applied. Each src value is an integer
corresponding to the index of a point in the input grid when written as a one dimensional
array. For example, for an input grid of size 5x10, point (3,2) is referenced as point 8, since
(2-1)*5+3=8. There are four of each variable because bilinear interpolation uses the four
120
points defining the grid box containing the point to be interpolated. All of these arrays are
on the model grid, so that values src01(i,j) and wgt01(i,j) are used to generate a value for
point (i,j) in the model.
Symbolically, the algorithm used is :
fm (i, j) = fm (i, j) +
4
X
wgt(k)f (idx(src(k)))
(7.5)
k=1
where function idx() transforms a one dimensional index src(k) into a two dimensional
index, and wgt(1) corresponds to variable wgt01 for example.
Bicubic Interpolation
Again there are two sets of variables : src and wgt. But in this case there are 16
of each. The symbolic algorithm used to calculate values on the model grid is now :
4
X
8
X
k=9
k=13
f
fm (i, j) = fm (i, j)+
wgt(k)f (idx(src(k))) +
wgt(k)
i idx(src(k))
k=1
k=5
12
16
X
X
f
2 f
+
wgt(k)
+
wgt(k)
j idx(src(k))
ij idx(src(k))
The gradients here are taken with respect to the horizontal indices and not distances since
the spatial dependency has been absorbed into the weights.
Implementation
To activate this option, a non-empty string should be supplied in the weights filename
column of the relevant namelist ; if this is left as an empty string no action is taken. In
the model, weights files are read in and stored in a structured type (WGT) in the fldread
module, as and when they are first required. This initialisation procedure determines whether the input data grid should be treated as cyclical or not by inspecting a global attribute
stored in the weights input file. This attribute must be called ew wrap and be of integer
type. If it is negative, the input non-model grid is assumed not to be cyclic. If zero or greater, then the value represents the number of columns that overlap. E.g. if the input grid
has columns at longitudes 0, 1, 2, .... , 359, then ew wrap should be set to 0 ; if longitudes
are 0.5, 2.5, .... , 358.5, 360.5, 362.5, ew wrap should be 2. If the model does not find attribute ew wrap, then a value of -999 is assumed. In this case the fld read routine defaults
ew wrap to value 0 and therefore the grid is assumed to be cyclic with no overlapping
columns. (In fact this only matters when bicubic interpolation is required.) Note that no
testing is done to check the validity in the model, since there is no way of knowing the
name used for the longitude variable, so it is up to the user to make sure his or her data is
correctly represented.
121
Next the routine reads in the weights. Bicubic interpolation is assumed if it finds a
variable with name src05, otherwise bilinear interpolation is used. The WGT structure
includes dynamic arrays both for the storage of the weights (on the model grid), and
when required, for reading in the variable to be interpolated (on the input data grid). The
size of the input data array is determined by examining the values in the src arrays
to find the minimum and maximum i and j values required. Since bicubic interpolation
requires the calculation of gradients at each point on the grid, the corresponding arrays
are dimensioned with a halo of width one grid point all the way around. When the array
of points from the data file is adjacent to an edge of the data grid, the halo is either a copy
of the row/column next to it (non-cyclical case), or is a copy of one from the first few
columns on the opposite side of the grid (cyclical case).
Limitations
1. The case where input data grids are not logically rectangular has not been tested.
2. This code is not guaranteed to produce positive definite answers from positive definite inputs when a bicubic interpolation method is used.
3. The cyclic condition is only applied on left and right columns, and not to top and
bottom rows.
4. The gradients across the ends of a cyclical grid assume that the grid spacing between the two columns involved are consistent with the weights used.
5. Neither interpolation scheme is conservative. (There is a conservative scheme available in SCRIP, but this has not been implemented.)
Utilities
A set of utilities to create a weights file for a rectilinear input grid is available (see the
directory NEMOGCM/TOOLS/WEIGHTS).
7.3
The analytical formulation of the surface boundary condition is the default scheme.
In this case, all the six fluxes needed by the ocean are assumed to be uniform in space.
They take constant values given in the namelist namsbc ana by the variables rn utau0,
rn vtau0, rn qns0, rn qsr0, and rn emp0 (emp = empS ). The runoff is set to zero. In
addition, the wind is allowed to reach its nominal value within a given number of time
steps (nn tau000).
122
If a user wants to apply a different analytical forcing, the sbcana.F90 module can be
modified to use another scheme. As an example, the sbc ana gyre.F90 routine provides
the analytical forcing for the GYRE configuration (see GYRE configuration manual, in
preparation).
7.4
= ./
!
!
,
,
,
,
,
clim !
(T/F) !
.false.,
.false.,
.false.,
.false.,
.false.,
yearly/
monthly
yearly
yearly
yearly
yearly
yearly
!
!
,
,
,
,
,
weights
filename
!
!
,
,
,
,
,
rotation !
pairing !
In the flux formulation (ln flx=true), the surface boundary condition fields are directly
read from input files. The user has to define in the namelist namsbc flx the name of the
file, the name of the variable read in the file, the time frequency at which it is given (in
hours), and a logical setting whether a time interpolation to the model time step is required
for this field. See 7.2.1 for a more detailed description of the parameters.
Note that in general, a flux formulation is used in associated with a restoring term to
observed SST and/or SSS. See 7.9.3 for its specification.
7.5
7.5.1
!
!
,
,
,
,
,
,
,
,
,
clim
(T/F)
.true.
.true.
.true.
.true.
.true.
.true.
.true.
.true.
.true.
!
!
,
,
,
,
,
,
,
,
,
yearly/
monthly
yearly
yearly
yearly
yearly
yearly
yearly
yearly
yearly
yearly
!
!
,
,
,
,
,
,
,
,
,
weights
filename
!
!
,
,
,
,
,
,
,
,
,
rotation !
pairing !
Uwnd
Vwnd
=
=
=
=
./
.false.
.false.
1.
!
!
!
!
123
The CORE bulk formulae have been developed by Large and Yeager [2004]. They
have been designed to handle the CORE forcing, a mixture of NCEP reanalysis and
satellite data. They use an inertial dissipative method to compute the turbulent transfer
coefficients (momentum, sensible heat and evaporation) from the 10 metre wind speed,
air temperature and specific humidity. This Large and Yeager [2004] dataset is available
through the GFDL web site.
Note that substituting ERA40 to NCEP reanalysis fields does not require changes in
the bulk formulea themself. This is the so-called DRAKKAR Forcing Set (DFS) [Brodeau
et al. 2009].
The required 8 input fields are :
Variable desciption
Model variable
Units
i-component of the 10m air velocity
utau
m.s1
j-component of the 10m air velocity
vtau
m.s1
10m air temperature
tair
K
Specific humidity
humi
%
Incoming long wave radiation
qlw
W.m2
Incoming short wave radiation
qsr
W.m2
Total precipitation (liquid + solid)
precip
Kg.m2 .s1
Solid precipitation
snow
Kg.m2 .s1
point
T
T
T
T
T
T
T
T
Note that the air velocity is provided at a tracer ocean point, not at a velocity ocean
point (u- and v-points). It is simpler and faster (less fields to be read), but it is not the
recommended method when the ocean grid size is the same or larger than the one of the
input atmospheric fields.
7.5.2
= ./
!
!
,
,
,
,
,
,
,
clim
(T/F)
.true.
.true.
.true.
.true.
.true.
.true.
.true.
!
!
,
,
,
,
,
,
,
yearly/
monthly
yearly
yearly
yearly
yearly
yearly
yearly
yearly
!
!
,
,
,
,
,
,
,
weights
filename
!
!
,
,
,
,
,
,
,
The CLIO bulk formulae were developed several years ago for the Louvain-la-neuve
coupled ice-ocean model (CLIO, Goosse et al. [1999]). They are simpler bulk formulae.
rotation !
pairing !
124
They assume the stress to be known and compute the radiative fluxes from a climatological
cloud cover.
The required 7 input fields are :
Variable desciption
i-component of the ocean stress
j-component of the ocean stress
Wind speed module
10m air temperature
Specific humidity
Cloud cover
Total precipitation (liquid + solid)
Solid precipitation
Model variable
utau
vtau
vatm
tair
humi
precip
snow
Units
N.m2
N.m2
m.s1
K
%
%
Kg.m2 .s1
Kg.m2 .s1
point
U
V
T
T
T
T
T
T
As for the flux formulation, information about the input data required by the model is
provided in the namsbc blk core or namsbc blk clio namelist (see 7.2.1).
7.6
In the coupled formulation of the surface boundary condition, the fluxes are provided
by the OASIS coupler at a frequency which is defined in the OASIS coupler, while sea
and ice surface temperature, ocean and ice albedo, and ocean currents are sent to the
atmospheric component.
A generalised coupled interface has been developed. It is currently interfaced with
OASIS 3 (key oasis3) and does not support OASIS 4 2 . It has been successfully used to interface NEMO to most of the European atmospheric GCM (ARPEGE, ECHAM, ECMWF,
HadAM, LMDz), as well as to WRF (Weather Research and Forecasting Model).
2
The key oasis4 exist. It activates portion of the code that are still under development.
125
Note that in addition to the setting of ln cpl to true, the key coupled have to be defined. The CPP key is mainly used in sea-ice to ensure that the atmospheric fluxes are
actually recieved by the ice-ocean system (no calculation of ice sublimation in coupled
mode). When PISCES biogeochemical model (key top and key pisces) is also used in the
coupled system, the whole carbon cycle is computed by defining key cpl carbon cycle.
In this case, CO2 fluxes are exchanged between the atmosphere and the ice-ocean system.
7.7
= ./
= .false.
!
!
The optional atmospheric pressure can be used to force ocean and ice dynamics
(ln apr dyn = true, namsbc namelist ). The input atmospheric forcing defined via sn apr
structure (namsbc apr namelist) can be interpolated in time to the model time step, and
even in space when the interpolation on-the-fly is used. When used to force the dynamics,
the atmospheric pressure is further transformed into an equivalent inverse barometer sea
surface height, ib , using :
ib =
1
(Patm Po )
g o
(7.6)
where Patm is the atmospheric pressure and Po a reference atmospheric pressure. A value
of 101, 000 N/m2 is used unless ln ref apr is set to true. In this case Po is set to the value
of Patm averaged over the ocean domain, i.e. the mean value of ib is kept to zero at all
time step.
The gradient of ib is added to the RHS of the ocean momentum equation (see dynspg.F90
for the ocean). For sea-ice, the sea surface height, m , which is provided to the sea ice model is set to ib (see sbcssr.F90 module). ib can be set in the output. This can simplify
altimetry data and model comparison as inverse barometer sea surface height is usually
removed from these date prior to their distribution.
7.8
= ./
= .false.
!
!
!
!
,
,
,
,
,
clim
(T/F)
.true.
.true.
.true.
.true.
.true.
!
!
,
,
,
,
,
yearly/
monthly
yearly
yearly
yearly
yearly
yearly
!
!
,
,
,
,
,
weights
filename
!
!
,
,
,
,
,
rotation !
pairing !
126
ln_rnf_mouth
rn_hrnf
rn_avt_rnf
rn_rfact
ln_rnf_depth
ln_rnf_tem
ln_rnf_sal
.true.
15.e0
1.e-3
1.e0
.false.
.false.
.false.
!
!
!
!
!
!
!
River runoff generally enters the ocean at a nonzero depth rather than through the
surface. Many models, however, have traditionally inserted river runoff to the top model
cell. This was the case in NEMO prior to the version 3.3, and was combined with an option
to increase vertical mixing near the river mouth.
However, with this method numerical and physical problems arise when the top grid
cells are of the order of one meter. This situation is common in coastal modelling and is
becoming more common in open ocean and climate modelling 3 .
As such from V 3.3 onwards it is possible to add river runoff through a non-zero
depth, and for the temperature and salinity of the river to effect the surrounding ocean.
The user is able to specify, in a NetCDF input file, the temperature and salinity of the
river, along with the depth (in metres) which the river should be added to.
Namelist options, ln rnf depth, ln rnf sal and ln rnf temp control whether the river
attributes (depth, salinity and temperature) are read in and used. If these are set as false
the river is added to the surface box only, assumed to be fresh (0 psu), and/or taken as
surface temperature respectively.
The runoff value and attributes are read in in sbcrnf. For temperature -999 is taken
as missing data and the river temperature is taken to be the surface temperatue at the
river point. For the depth parameter a value of -1 means the river is added to the surface
box only, and a value of -999 means the river is added through the entire water column.
After being read in the temperature and salinity variables are multiplied by the amount of
runoff (converted into m/s) to give the heat and salt content of the river runoff. After the
user specified depth is read ini, the number of grid boxes this corresponds to is calculated
and stored in the variable nz rnf . The variable h dep is then calculated to be the depth (in
metres) of the bottom of the lowest box the river water is being added to (i.e. the total
depth that river water is being added to in the model).
The mass/volume addition due to the river runoff is, at each relevant depth level, added
to the horizontal divergence (hdivn) in the subroutine sbc rnf div (called from divcur.F90).
This increases the diffusion term in the vicinity of the river, thereby simulating a momentum flux. The sea surface height is calculated using the sum of the horizontal divergence
terms, and so the river runoff indirectly forces an increase in sea surface height.
The hdivn terms are used in the tracer advection modules to force vertical velocities.
This causes a mass of water, equal to the amount of runoff, to be moved into the box above.
The heat and salt content of the river runoff is not included in this step, and so the tracer
concentrations are diluted as water of ocean temperature and salinity is moved upward
out of the box and replaced by the same volume of river water with no corresponding heat
and salt addition.
3
At least a top cells thickness of 1 meter and a 3 hours forcing frequency are required to
properly represent the diurnal cycle [Bernie et al. 2005]. see also 7.9.1.
127
For the linear free surface case, at the surface box the tracer advection causes a flux
of water (of equal volume to the runoff) through the sea surface out of the domain, which
causes a salt and heat flux out of the model. As such the volume of water does not change,
but the water is diluted.
For the non-linear free surface case (key vvl), no flux is allowed through the surface.
Instead in the surface box (as well as water moving up from the boxes below) a volume
of runoff water is added with no corresponding heat and salt addition and so as happens
in the lower boxes there is a dilution effect. (The runoff addition to the top box along with
the water being moved up through boxes below means the surface box has a large increase
in volume, whilst all other boxes remain the same size)
In trasbc the addition of heat and salt due to the river runoff is added. This is done in
the same way for both vvl and non-vvl. The temperature and salinity are increased through
the specified depth according to the heat and salt content of the river.
In the non-linear free surface case (vvl), near the end of the time step the change in
sea surface height is redistrubuted through the grid boxes, so that the original ratios of
grid box heights are restored. In doing this water is moved into boxes below, throughout
the water column, so the large volume addition to the surface box is spread between all
the grid boxes.
It is also possible for runnoff to be specified as a negative value for modelling flow
through straits, i.e. modelling the Baltic flow in and out of the North Sea. When the flow is
out of the domain there is no change in temperature and salinity, regardless of the namelist
options used, as the ocean water leaving the domain removes heat and salt (at the same
concentration) with it.
7.9
Miscellaneous options
7.9.1
128
analytical solution
reconstructed (mean of
analytical solution at ti
over t)
Qsr
t1
t2
t5
t3
t4
time of day (t)
t6
7.9.2
time = 1h
50
time = 7h
50
time = 13h
50
time = 19h
129
100
150
120
120
100
100
80
80
60
60
40
40
20
20
0
140
120
100
150
150
50
time = 9h
100
150
0
140
100
80
80
60
60
40
40
20
20
0
140
50
time = 15h
100
150
0
140
100
80
80
60
60
40
40
20
20
120
50
time = 21h
120
100
140
time = 5h
120
100
120
100
140
time = 3h
100
150
0
140
120
100
100
80
80
60
60
40
40
20
20
50
100
150
50
100
150
50
100
150
time = 11h
time = 17h
time = 23h
component must start with U and the northward component with V. The remaining
characters in the strings are used to identify which pair of components go together. So
for example, strings U1 and V1 next to utau and vtau would pair the wind stress
components together and rotate them on to the model grid directions ; U2 and V2
could be used against a second pair of components, and so on. The extra characters used
in the strings are arbitrary. The rot rep routine from the geo2ocean.F90 module is used to
perform the rotation.
130
7.9.3
= ./
=
0
=
2
rn_dqdt
rn_deds
ln_sssr_bnd
rn_sssr_bnd
=
=
=
=
-40.
-27.7
.true.
4.e0
!
!
!
!
!
!
!
!
! clim ! yearly/
! (T/F) ! monthly
, .false., yearly
, .true. , yearly
!
!
,
,
weights
filename
!
!
,
,
In forced mode using a flux formulation (ln flx = true), a feedback term must be added
to the surface heat flux Qons :
Qns = Qons +
dQ
( T |k=1 SSTObs )
dT
(7.7)
where SST is a sea surface temperature field (observed or climatological), T is the model
surface layer temperature and dQ
dT is a negative feedback coefficient usually taken equal
to 40 W/m2 /K. For a 50 m mixed-layer depth, this value corresponds to a relaxation
time scale of two months. This term ensures that if T perfectly matches the supplied SST,
then Q is equal to Qo .
In the fresh water budget, a feedback term can also be added. Converted into an equivalent freshwater flux, it takes the following expression :
emp = empo + s1 e3t
( S|k=1 SSSObs )
S|k=1
(7.8)
where empo is a net surface fresh water flux (observed, climatological or an atmospheric model product), SSSObs is a sea surface salinity (usually a time interpolation of the
monthly mean Polar Hydrographic Climatology [Steele et al. 2001]), S|k=1 is the model
surface layer salinity and s is a negative feedback coefficient which is provided as a namelist parameter. Unlike heat flux, there is no physical justification for the feedback term
in 7.8 as the atmosphere does not care about ocean surface salinity [Madec and Delecluse
1997]. The SSS restoring term should be viewed as a flux correction on freshwater fluxes
to reduce the uncertainties we have on the observed freshwater budget.
7.9.4
rotation !
pairing !
131
nn ice = 1 sea-ice can exist in the computational domain, but no sea-ice model is used.
An observed ice covered area is read in a file. Below this area, the SST is restored to the freezing point and the heat fluxes are set to 4 W/m2 (2 W/m2 ) in
the northern (southern) hemisphere. The associated modification of the freshwater
fluxes are done in such a way that the change in buoyancy fluxes remains zero. This
prevents deep convection to occur when trying to reach the freezing point (and so
ice covered area condition) while the SSS is too large. This manner of managing
sea-ice area, just by using si IF case, is usually referred as the ice-if model. It can
be found in the sbcice if.F90 module.
nn ice = 2 or more A full sea ice model is used. This model computes the ice-ocean
fluxes, that are combined with the air-sea fluxes using the ice fraction of each model cell to provide the surface ocean fluxes. Note that the activation of a sea-ice
model is is done by defining a CPP key (key lim2 or key lim3). The activation
automatically ovewrite the read value of nn ice to its appropriate value (i.e. 2 for
LIM-2 and 3 for LIM-3).
7.9.5
Contents
8.1
8.2
8.3
8.4
8.5
134
137
137
138
139
143
143
145
146
149
149
150
150
151
151
152
152
153
153
134
8.1
The discrete representation of a domain with complex boundaries (coastlines and bottom topography) leads to arrays that include large portions where a computation is not
required as the model variables remain at zero. Nevertheless, vectorial supercomputers
are far more efficient when computing over a whole array, and the readability of a code is
greatly improved when boundary conditions are applied in an automatic way rather than
by a specific computation before or after each computational loop. An efficient way to
work over the whole domain while specifying the boundary conditions, is to use multiplication by mask arrays in the computation. A mask array is a matrix whose elements
are 1 in the ocean domain and 0 elsewhere. A simple multiplication of a variable by its
own mask ensures that it will remain zero over land areas. Since most of the boundary
conditions consist of a zero flux across the solid boundaries, they can be simply applied
by multiplying variables by the correct mask arrays, i.e. the mask array of the grid point
where the flux is evaluated. For example, the heat flux in the i-direction is evaluated at
u-points. Evaluating this quantity as,
AlT T
AlT
u i+1/2 [T ] masku
e1 i
e1u
(8.1)
(where masku is the mask array at a u-point) ensures that the heat flux is zero inside
land and at the boundaries, since masku is zero at solid boundaries which in this case are
defined at u-points (normal velocity u remains zero at the coast) (Fig. 8.1).
For momentum the situation is a bit more complex as two boundary conditions must
be provided along the coast (one each for the normal and tangential velocities). The boundary of the ocean in the C-grid is defined by the velocity-faces. For example, at a given
T -level, the lateral boundary (a coastline or an intersection with the bottom topography)
is made of segments joining f -points, and normal velocity points are located between two
f points (Fig. 8.1). The boundary condition on the normal velocity (no flux through solid
boundaries) can thus be easily implemented using the mask system. The boundary condition on the tangential velocity requires a more specific treatment. This boundary condition
influences the relative vorticity and momentum diffusive trends, and is required in order
to compute the vorticity at the coast. Four different types of lateral boundary condition
are available, controlled by the value of the rn shlat namelist parameter. (The value of the
maskf array along the coastline is set equal to this parameter.) These are :
free-slip boundary condition (rn shlat=0) : the tangential velocity at the coastline is
equal to the offshore velocity, i.e. the normal derivative of the tangential velocity
135
ocean
V=0
V=0
U=0
V=0
U=0
T-point
f-point
u-, v-points
land
F IG . 8.1 Lateral boundary (thick line) at T-level. The velocity normal to the
boundary is set to zero.
is zero at the coast, so the vorticity : maskf array is set to zero inside the land and
just at the coast (Fig. 8.2-a).
no-slip boundary condition (rn shlat=2) : the tangential velocity vanishes at the coastline. Assuming that the tangential velocity decreases linearly from the closest ocean
velocity grid point to the coastline, the normal derivative is evaluated as if the velocities at the closest land velocity gridpoint and the closest ocean velocity gridpoint
were of the same magnitude but in the opposite direction (Fig. 8.2-b). Therefore,
the vorticity along the coastlines is given by :
2 i+1/2 [e2v v] j+1/2 [e1u u] / (e1f e2f ) ,
where u and v are masked fields. Setting the maskf array to 2 along the coastline
provides a vorticity field computed with the no-slip boundary condition, simply by
multiplying it by the maskf :
1
i+1/2 [e2v v] j+1/2 [e1u u] maskf
e1f e2f
(8.2)
136
(a) land
ocean
(b) land
ocean
fmask=0
fmask=1
fmask=2
fmask>2
0<fmask<2
(c) land
ocean
(d) land
ocean
F IG . 8.2 lateral boundary condition (a) free-slip (rn shlat = 0) ; (b) no-slip
(rn shlat = 2) ; (c) partial free-slip (0 < rn shlat < 2) and (d) strong noslip (2 < rn shlat). Implied ghost velocity inside land area is display in grey.
137
partial free-slip boundary condition (0<rn shlat<2) : the tangential velocity at the
coastline is smaller than the offshore velocity, i.e. there is a lateral friction but not
strong enough to make the tangential velocity at the coast vanish (Fig. 8.2-c). This
can be selected by providing a value of maskf strictly inbetween 0 and 2.
strong no-slip boundary condition (2<rn shlat) : the viscous boundary layer is assumed to be smaller than half the grid size (Fig. 8.2-d). The friction is thus larger
than in the no-slip case.
Note that when the bottom topography is entirely represented by the s-coor-dinates
(pure s-coordinate), the lateral boundary condition on tangential velocity is of much less
importance as it is only applied next to the coast where the minimum water depth can be
quite shallow.
The alternative numerical implementation of the no-slip boundary conditions for an
arbitrary coast line of Shchepetkin and OBrien [1996] is also available through the key noslip accurate
CPP key. It is based on a fourth order evaluation of the shear at the coast which, in turn,
allows a true second order scheme in the interior of the domain (i.e. the numerical boundary scheme simulates the truncation error of the numerical scheme used in the interior of
the domain). Shchepetkin and OBrien [1996] found that such a technique considerably
improves the quality of the numerical solution. In NEMO , such spectacular improvements
have not been found in the half-degree global ocean (ORCA05), but significant reductions
of numerically induced coastal upwellings were found in an eddy resolving simulation of
the Alboran Sea [Olivier 2001]. Nevertheless, since a no-slip boundary condition is not
recommended in an eddy permitting or resolving simulation [Penduff et al. 2007], the use
of this option is also not recommended.
In practice, the no-slip accurate option changes the way the curl is evaluated at the
coast (see divcur.F90 module), and requires the nature of each coastline grid point (convex
or concave corners, straight north-south or east-west coast) to be specified. This is performed in routine dom msk nsa in the domask.F90 module.
8.2
8.2.1
138
T- or u-point
variables
line(1) = line(2)
row(jpj) = row(2)
v- or f-point
variables
row(1) = row(jpj-1)
(a)
line(1) = -line(2)
(b)
F IG . 8.3 setting of (a) east-west cyclic (b) symmetric across the equator boundary conditions.
model interior. To choose a lateral model boundary condition is to specify the first and
last rows and columns of the model variables.
For closed boundary (jperio=0) , solid walls are imposed at all model boundaries : first
and last rows and columns are set to zero.
For cyclic east-west boundary (jperio=1) , first and last rows are set to zero (closed)
whilst the first column is set to the value of the last-but-one column and the last
column to the value of the second one (Fig. 8.3-a). Whatever flows out of the eastern (western) end of the basin enters the western (eastern) end. Note that there is
no option for north-south cyclic or for doubly cyclic cases.
For symmetric boundary condition across the equator (jperio=2) , last rows, and first
and last columns are set to zero (closed). The row of symmetry is chosen to be the
u- and T points equator line (j = 2, i.e. at the southern end of the domain). For
arrays defined at u or T points, the first row is set to the value of the third row
while for most of v- and f -point arrays (v, , j, but scalar arrays such as eddy
coefficients) the first row is set to minus the value of the second row (Fig. 8.3-b).
Note that this boundary condition is not yet available for the case of a massively
parallel computer (key mpp defined).
8.2.2
North-fold (jperio = 3 to 6)
The north fold boundary condition has been introduced in order to handle the north
boundary of a three-polar ORCA grid. Such a grid has two poles in the northern hemisphere. to be completed...
139
F IG . 8.4 North fold boundary with a T -point pivot and cyclic east-west boundary condition (jperio = 4), as used in ORCA 2, 1/4, and 1/12. Pink shaded area
corresponds to the inner domain mask (see text).
8.3
140
at the very most on one neighbouring point. The only non-local computations concern
the vertical physics (implicit diffusion, 1.5 turbulent closure scheme, ...) (delocalization
over the whole water column), and the solving of the elliptic equation associated with the
surface pressure gradient computation (delocalization over the whole horizontal domain).
Therefore, a pencil strategy is used for the data sub-structuration : the 3D initial domain is
laid out on local processor memories following a 2D horizontal topological splitting. Each
sub-domain computes its own surface and bottom boundary conditions and has a side wall
overlapping interface which defines the lateral boundary conditions for computations in
the inner sub-domain. The overlapping area consists of the two rows at each edge of the
sub-domain. After a computation, a communication phase starts : each processor sends to
its neighbouring processors the update values of the points corresponding to the interior
overlapping area to its neighbouring sub-domain (i.e. the innermost of the two overlapping
rows). The communication is done through message passing. Usually the parallel virtual
language, PVM, is used as it is a standard language available on nearly all MPP computers.
More specific languages (i.e. computer dependant languages) can be easily used to speed
up the communication, such as SHEM on a T3E computer. The data exchanges between
processors are required at the very place where lateral domain boundary conditions are
set in the mono-domain computation (III.10-c) : the lbc lnk routine which manages such
conditions is substituted by mpplnk.F or mpplnk2.F routine when running on an MPP
computer (key mpp mpi defined). It has to be pointed out that when using the MPP
version of the model, the east-west cyclic boundary condition is done implicitly, whilst
the south-symmetric boundary condition option is not available.
In the standard version of the OPA model, the splitting is regular and arithmetic. the
i-axis is divided by jpni and the j-axis by jpnj for a number of processors jpnij most
often equal to jpni jpnj (model parameters set in par oce.F90). Each processor is
independent and without message passing or synchronous process , programs run alone
and access just its own local memory. For this reason, the main model dimensions are
now the local dimensions of the subdomain (pencil) that are named jpi, jpj, jpk. These
dimensions include the internal domain and the overlapping rows. The number of rows to
exchange (known as the halo) is usually set to one (jpreci=1, in par oce.F90). The whole
domain dimensions are named jpiglo, jpjglo and jpk. The relationship between the whole
domain and a sub-domain is :
jpi = (jpiglo 2 jpreci + (jpni 1))/jpni + 2 jpreci
jpj = (jpjglo 2 jprecj + (jpnj 1))/jpnj + 2 jprecj
(8.3)
where jpni, jpnj are the number of processors following the i- and j-axis.
Figure IV.3 : example of a domain splitting with 9 processors and no east-west cyclic boundary conditio
One also defines variables nldi and nlei which correspond to the internal domain
bounds, and the variables nimpp and njmpp which are the position of the (1,1) grid-point
in the global domain. An element of Tl , a local array (subdomain) corresponds to an element of Tg , a global array (whole domain) by the relationship :
Tg (i + nimpp 1, j + njmpp 1, k) = Tl (i, j, k),
(8.4)
141
142
points processors, which can then be eliminated. (For example, the mpp optimiz tools,
available from the DRAKKAR web site.) This optimisation is dependent on the specific bathymetry employed. The user then chooses optimal parameters jpni, jpnj and jpnij
with jpnij < jpni jpnj, leading to the elimination of jpni jpnj jpnij land
processors. When those parameters are specified in module par oce.F90, the algorithm in
the inimpp2 routine sets each processors parameters (nbound, nono, noea,...) so that the
land-only processors are not taken into account.
Note that the inimpp2 routine is general so that the original inimpp routine should be suppressed from th
When land processors are eliminated, the value corresponding to these locations in
the model output files is zero. Note that this is a problem for a mesh output file written by
such a model configuration, because model users often divide by the scale factors (e1t,
e2t, etc) and do not expect the grid size to be zero, even on land. It may be best not to
eliminate land processors when running the model especially to write the mesh files as
outputs (when nn msh namelist parameter differs from 0).
(a)
(b)
F IG . 8.6 Example of Atlantic domain defined for the CLIPPER projet. Initial
grid is composed of 773 x 1236 horizontal points. (a) the domain is split onto 9
subdomains (jpni=9, jpnj=20). 52 subdomains are land areas. (b) 52 subdomains
are eliminated (white rectangles) and the resulting number of processors really
used during the computation is jpnij=128.
8.4
143
8.4.1
Boundary geometry
First one has to realize that open boundaries may not necessarily be located at the
extremities of the computational domain. They may exist in the middle of the domain, for
example at Gibraltar Straits if one wants to avoid including the Mediterranean in an Atlantic domain. This flexibility has been found necessary for the CLIPPER project [Treguier
et al. 2001]. Because of the complexity of the geometry of ocean basins, it may even be
necessary to have more than one west open boundary, more than one north, etc. This
is not possible with the OBC option : only one open boundary of each kind, west, east,
south and north is allowed ; these names refer to the grid geometry (not to the direction of
the geographical west, east, etc).
144
The open boundary geometry is set by a series of parameters in the module obc par.F90.
For an eastern open boundary, parameters are lp obc east (true if an east open boundary
exists), jpieob the i-index along which the eastern open boundary (eob) is located, jpjed
the j-index at which it starts, and jpjef the j-index where it ends (note d is for debut
and f for fin in French). Similar parameters exist for the west, south and north cases
(Table 8.1).
Boundary and
Constant index
Starting index (debut) Ending index (fin)
Logical flag
West
jpiwob >= 2
jpjwd>= 2
jpjwf = jpjglo-1
lp obc west
i-index of a u point
j of a T point
j of a T point
East
jpieob<=jpiglo-2
jpjed >= 2
jpjef <= jpjglo-1
lp obc east
i-index of a u point
j of a T point
j of a T point
South
jpjsob >= 2
jpisd >= 2
jpisf <=jpiglo-1
lp obc south
j-index of a v point
i of a T point
i of a T point
North
jpjnob <= jpjglo-2
jpind >= 2
jpinf <=jpiglo-1
lp obc north
j-index of a v point
i of a T point
i of a T point
TAB . 8.1 Names of different indices relating to the open boundaries. In the case
of a completely open ocean domain with four ocean boundaries, the parameters
take exactly the values indicated.
The open boundaries must be along coordinate lines. On the C-grid, the boundary
itself is along a line of normal velocity points : v points for a zonal open boundary (the
south or north one), and u points for a meridional open boundary (the west or east one).
Another constraint is that there still must be a row of masked points all around the domain,
as if the domain were a closed basin (unless periodic conditions are used together with
open boundary conditions). Therefore, an open boundary cannot be located at the first/last
index, namely, 1, jpiglo or jpjglo. Also, the open boundary algorithm involves calculating
the normal velocity points situated just on the boundary, as well as the tangential velocity
and temperature and salinity just outside the boundary. This means that for a west/south
boundary, normal velocities and temperature are calculated at the same index jpiwob and
jpjsob, respectively. For an east/north boundary, the normal velocity is calculated at index
jpieob and jpjnob, but the outside temperature is at index jpieob+1 and jpjnob+1. This
means that jpieob, jpjnob cannot be bigger than jpiglo-2, jpjglo-2.
The starting and ending indices are to be thought of as T point indices : in many cases
they indicate the first land T -point, at the extremity of an open boundary (the coast line
follows the f grid points, see Fig. 8.7 for an example of a northern open boundary). All
indices are relative to the global domain. In the free surface case it is possible to have
ocean corners, that is, an open boundary starting and ending in the ocean.
Although not compulsory, it is highly recommended that the bathymetry in the vicinity of an open boundary follows the following rule : in the direction perpendicular to the
145
open line, the water depth should be constant for 4 grid points. This is in order to ensure
that the radiation condition, which involves model variables next to the boundary, is calculated in a consistent way. On Fig.8.7 we indicate by an = symbol, the points which should
have the same depth. It means that at the 4 points near the boundary, the bathymetry is
cylindrical . The line behind the open T -line must be 0 in the bathymetry file (as shown
on Fig.8.7 for example).
8.4.2
Boundary data
It is necessary to provide information at the boundaries. The simplest case is when
this information does not change in time and is equal to the initial conditions (namelist
variable nn obcdta=0). This is the case for the standard configuration EEL5 with open
boundaries. When (nn obcdta=1), open boundary information is read from netcdf files.
For convenience the input files are supposed to be similar to the history NEMO output
files, for dimension names and variable names. Open boundary arrays must be dimensioned according to the parameters of table 8.1 : for example, at the western boundary,
arrays have a dimension of jpwf -jpwd+1 in the horizontal and jpk in the vertical.
When ocean observations are used to generate the boundary data (a hydrographic section for example, as in Treguier et al. [2001]) it happens often that only the velocity normal
to the boundary is known, which is the reason why the initial OBC code assumes that only
T , S, and the normal velocity (u or v) needs to be specified. As more and more global mo-
146
del solutions and ocean analysis products become available, it will be possible to provide
information about all the variables (including the tangential velocity) so that the specification of four variables at each boundaries will become standard. For the sea surface height,
one must distinguish between the filtered free surface case and the time-splitting or explicit treatment of the free surface. In the first case, it is assumed that the user does not wish
to represent high frequency motions such as tides. The boundary condition is thus one of
zero normal gradient of sea surface height at the open boundaries, following Marchesiello
et al. [2001]. No information other than the total velocity needs to be provided at the open
boundaries in that case. In the other two cases (time splitting or explicit free surface), the
user must provide barotropic information (sea surface height and barotropic velocities)
and the use of the Flather algorithm for barotropic variables is recommanded. However,
this algorithm has not yet been fully tested and bugs remain in NEMO v2.3. Users should
read the code carefully before using it. Finally, in the case of the rigid lid approximation
the barotropic streamfunction must be provided, as documented in Treguier et al. [2001]).
This option is no longer recommended but remains in NEMO V2.3.
One frequently encountered case is when an open boundary domain is constructed
from a global or larger scale NEMO configuration. Assuming the domain corresponds to
indices ib : ie, jb : je of the global domain, the bathymetry and forcing of the small
domain can be created by using the following netcdf utility on the global files : ncks -F
d x, ib, ie d y, jb, je (part of the nco series of utilities, see their website). The open
boundary files can be constructed using ncks commands, following table 8.2.
It is assumed that the open boundary files contain the variables for the period of the
model integration. If the boundary files contain one time frame, the boundary data is held
fixed in time. If the files contain 12 values, it is assumed that the input is a climatology
for a repeated annual cycle (corresponding to the case ln obc clim =true). The case of an
arbitrary number of time frames is not yet implemented correctly ; the user is required to
write his own code in the module obc dta.F90 to deal with this situation.
8.4.3
Radiation algorithm
The art of open boundary management consists in applying a constraint strong enough
that the inner domain feels the rest of the ocean, but weak enough that perturbations are
allowed to leave the domain with minimum false reflections of energy. The constraints are
specified separately at each boundary as time scales for inflow and outflow as defined
below. The time scales are set (in days) by namelist parameters such as rn dpein, rn dpeob
for the eastern open boundary for example. When both time scales are zero for a given
boundary (e.g. for the western boundary, lp obc west=true, rn dpwob=0 and rn dpwin=0)
this means that the boundary in question is a fixed boundary where the solution is
set exactly by the boundary data. This is not recommended, except in combination with
increased viscosity in a sponge layer next to the boundary in order to avoid spurious
reflections.
The radiationrelaxation algorithm is applied when either relaxation time (for inflow
or outflow) is non-zero. It has been developed and tested in the SPEM model and its
OBC
West
East
South
North
Variable
file name
T,S
obcwest TS.nc
U
obcwest U.nc
V
obcwest V.nc
T,S
obceast TS.nc
U
obceast U.nc
V
obceast V.nc
T,S
obcsouth TS.nc
U
obcsouth U.nc
V
obcsouth V.nc
T,S
obcnorth TS.nc
U
obcnorth U.nc
V
obcnorth V.nc
Index
ib+1
ib+1
ib+1
ie-1
ie-2
ie-1
jb+1
jb+1
jb+1
je-1
je-1
je-2
147
Start
jb+1
jb+1
jb+1
jb+1
jb+1
jb+1
ib+1
ib+1
ib+1
ib+1
ib+1
ib+1
end
je 1
je 1
je 1
je 1
je 1
je 1
ie 1
ie 1
ie 1
ie 1
ie 1
ie 1
TAB . 8.2 Requirements for creating open boundary files from a global configuration, appropriate for the subdomain of indices ib : ie, jb : je. Index designates the i or j index along which the u of v boundary point is situated in the
global configuration, starting and ending with the j or i indices indicated. For
example, to generate file obcnorth V.nc, use the command ncks F d y, je 2
d x, ib + 1, ie 1
148
successor ROMS [Barnier et al. 1996, Marchesiello et al. 2001], which is an s-coordinate
model on an Arakawa C-grid. Although the algorithm has been numerically successful
in the CLIPPER Atlantic models, the physics do not work as expected [Treguier et al.
2001]. Users are invited to consider open boundary conditions (OBC hereafter) with some
scepticism [Durran 2001, Blayo and Debreu 2005].
The first part of the algorithm calculates a phase velocity to determine whether perturbations tend to propagate toward, or away from, the boundary. Let us consider a model
variable . The phase velocities (Cx ,Cy ) for the variable , in the directions normal and
tangential to the boundary are
Cx =
t
x
+ 2y )
(2x
Cy =
t
y .
+ 2y )
(2x
(8.5)
Following Treguier et al. [2001] and Marchesiello et al. [2001] we retain only the normal component of the velocity, Cx , setting Cy = 0 (but unlike the original Orlanski
radiation algorithm we retain y in the expression for Cx ).
The discrete form of (8.5), described by Barnier et al. [1998], takes into account the
two rows of grid points situated inside the domain next to the boundary, and the three
previous time steps (n, n 1, and n 2). The same equation can then be discretized at the
boundary at time steps n 1, n and n + 1 in order to extrapolate for the new boundary
value n+1 .
In the open boundary algorithm as implemented in NEMO v2.3, the new boundary
values are updated differently depending on the sign of Cx . Let us take an eastern boundary as an example. The solution for variable at the boundary is given by a generalized
wave equation with phase velocity C , with the addition of a relaxation term, as :
t = Cx x +
t =
1
(c )
i
1
(c )
o
(8.6)
(8.7)
where c is the estimate of at the boundary, provided as boundary data. Note that
in (8.6), Cx is bounded by the ratio x/t for stability reasons. When Cx is eastward (outward propagation), the radiation condition (8.6) is used. When Cx is westward (inward propagation), (8.7) is used with a strong relaxation to climatology (usually
i = rn dpein =1 day). Equation (8.7) is solved with a Euler time-stepping scheme. As
a consequence, setting i smaller than, or equal to the time step is equivalent to a fixed
boundary condition. A time scale of one day is usually a good compromise which guarantees that the inflow conditions remain close to climatology while ensuring numerical
stability.
In the case of a western boundary located in the Eastern Atlantic, Penduff et al. [2000]
have been able to implement the radiation algorithm without any boundary data, using
persistence from the previous time step instead. This solution has not worked in other
cases [Treguier et al. 2001], so that the use of boundary data is recommended. Even in
the outflow condition (8.6), we have found it desirable to maintain a weak relaxation to
149
climatology. The time step is usually chosen so as to be larger than typical turbulent scales
(of order 1000 days ).
The radiation condition is applied to the model variables : temperature, salinity, tangential and normal velocities. For normal and tangential velocities, u and v, radiation is
applied with phase velocities calculated from u and v respectively. For the radiation of
tracers, we use the phase velocity calculated from the tangential velocity in order to avoid
calculating too many independent radiation velocities and because tangential velocities
and tracers have the same position along the boundary on a C-grid.
8.4.4
8.4.5
Volume conservation
It is necessary to control the volume inside a domain when using open boundaries.
With fixed boundaries, it is enough to ensure that the total inflow/outflow has reasonable
values (either zero or a value compatible with an observed volume balance). When using
radiative boundary conditions it is necessary to have a volume constraint because each
open boundary works independently from the others. The methodology used to control
this volume is identical to the one coded in the ROMS model [Marchesiello et al. 2001].
Explain obc vol. . .
OBC algorithm for update, OBC restart, list of routines where obc key appears. . .
OBC rigid lid ? . . .
150
8.5
=
=
=
=
=
=
=
=
=
nn_volctl
.false.
.false.
.false.
.false.
.false.
.false.
.false.
9
1
0
!
!
!
!
!
!
!
!
!
!
!
!
8.5.1
d = 1, N
(8.8)
where m is the model solution and e is the specified external field, d gives the discrete
distance from the model boundary and is a parameter that varies from 1 at d = 1 to a
small value at d = N . It can be shown that this scheme is equivalent to adding a relaxation
term to the prognostic equation for of the form :
1
( e )
(8.9)
where the relaxation time scale is given by a function of and the model time step t :
=
1
t
(8.10)
151
Thus the model solution is completely prescribed by the external conditions at the edge of
the model domain and is relaxed towards the external conditions over the rest of the FRS
zone. The application of a relaxation zone helps to prevent spurious reflection of outgoing
signals from the model boundary.
The function is specified as a tanh function :
d1
(d) = 1 tanh
, d = 1, N
(8.11)
2
The width of the FRS zone is specified in the namelist as nn rimwidth. This is typically
set to a value between 8 and 10.
8.5.2
c
( e ) ,
h
(8.12)
where U is the depth-mean velocity normal to the boundary and is the sea surface height,
both from the model. The subscript e indicates the same
fields from external sources. The
speed of external gravity waves is given by c = gh, and h is the depth of the water
column. The depth-mean normal velocity along the edge of the model domain is set equal
to the external depth-mean normal velocity, plus a correction term that allows gravity
waves generated internally to exit the model boundary. Note that the sea-surface height
gradient in (8.12) is a spatial gradient across the model boundary, so that e is defined on
the T points with nbrdta = 1 and is defined on the T points with nbrdta = 2. U and
Ue are defined on the U or V points with nbrdta = 1, i.e. between the two T grid points.
8.5.3
Choice of schemes
The Flow Relaxation Scheme may be applied separately to the temperature and salinity (ln tra frs = true) and the velocity fields (ln dyn frs = true). Flather radiation conditions may be applied using externally defined barotropic velocities and sea-surface height
(ln dyn fla = true) or using tidal harmonics fields (ln tides = true) or both. FRS and Flather conditions may be applied simultaneously. A typical configuration where all possible conditions might be used is a tidal, shelf-seas model, where the barotropic boundary
conditions are fixed with the Flather scheme using tidal harmonics and possibly output
from a large-scale model, and FRS conditions are applied to the tracers and baroclinic
velocity fields, using fields from a large-scale model.
Note that FRS conditions will work with the filtered (key dynspg flt) or time-split
(key dynspg ts) solutions for the surface pressure gradient. The Flather condition will
only work for the time-split solution (key dynspg ts). FRS conditions are applied at the
end of the main model time step. Flather conditions are applied during the barotropic
subcycle in the time-split solution.
152
8.5.4
Boundary geometry
The definition of the open boundary is completely flexible. An example is shown in
Fig. 8.8. The boundary zone is defined by a series of index arrays read in from the input
boundary data files : nbidta, nbjdta, and nbrdta. The first two of these define the global
(i, j) indices of each point in the boundary zone and the nbrdta array defines the discrete
distance from the boundary with nbrdta = 1 meaning that the point is next to the edge
of the model domain and nbrdta > 1 showing that the point is increasingly further away
from the edge of the model domain. These arrays are defined separately for each of the T ,
U and V grids, but the relationship between the points is assumed to be as in Fig. 8.8 with
the T points forming the outermost row of the boundary and the first row of velocities
normal to the boundary being inside the first row of T points. The order in which the
points are defined is unimportant.
8.5.5
153
shown in Fig. 8.9, i.e. seconds since yyyy-mm-dd hh :mm :ss The fields are then linearly
interpolated to the model time at each timestep. Note that for this option, the time axis of
the input files must completely span the time period of the model integration. If ln clim is
set to true (climatological boundary forcing), the model will expect either a single set of
annual mean fields (constant boundary forcing) or 12 sets of monthly mean fields in the
input files.
As in the OBC module there is an option to use initial conditions as boundary conditions. This is chosen by setting nn dtactl = 0. However, since the model defines the boundary geometry by reading the boundary index arrays from the input files, it is still necessary to provide a set of input files in this case. They need only contain the boundary index
arrays, nbidta, nbjdta, nbrdta.
8.5.6
Volume correction
There is an option to force the total volume in the regional model to be constant,
similar to the option in the OBC module. This is controlled by the nn volctl parameter in
the namelist. A value ofnn volctl = 0 indicates that this option is not used. If nn volctl = 1
then a correction is applied to the normal velocities around the boundary at each timestep
to ensure that the integrated volume flow through the boundary is zero. If nn volctl = 2
then the calculation of the volume change on the timestep includes the change due to the
freshwater flux across the surface and the correction velocity corrects for this as well.
8.5.7
154
Ref.: MERSEA-WP09-MERCA-TASK-9.1.1
page 15
Contents
9.1
9.2
9.3
156
The lateral physics terms in the momentum and tracer equations have been described in 2.5.1 and their discrete formulation in 5.2 and 6.6). In this section we further
discuss each lateral physics option. Choosing one lateral physics scheme means for the
user defining, (1) the space and time variations of the eddy coefficients ; (2) the direction
along which the lateral diffusive fluxes are evaluated (model level, geopotential or isopycnal surfaces) ; and (3) the type of operator used (harmonic, or biharmonic operators,
and for tracers only, eddy induced advection on tracers). These three aspects of the lateral diffusion are set through namelist parameters and CPP keys (see the nam traldf and
nam dynldf below).
!----------------------------------------------------------------------&namtra_ldf
!
lateral diffusion scheme for tracer
!----------------------------------------------------------------------!
! Type of the operator :
ln_traldf_lap
= .true.
! laplacian operator
ln_traldf_bilap = .false. ! bilaplacian operator
!
! Direction of action :
ln_traldf_level = .false. ! iso-level
ln_traldf_hor
= .false. ! horizontal (geopotential)
(require "key_ldfslp" when ln_sco=T)
ln_traldf_iso
= .true.
! iso-neutral
(require "key_ldfslp")
ln_traldf_grif
= .false. ! griffies skew flux formulation
(require "key_ldfslp") ! UNDER TEST, DO NOT USE
ln_traldf_gdia
= .false. ! griffies operator strfn diagnostics (require "key_ldfslp") ! UNDER TEST, DO NOT USE
!
! Coefficient
rn_aht_0
= 2000.
! horizontal eddy diffusivity for tracers [m2/s]
rn_ahtb_0
=
0.
! background eddy diffusivity for ldf_iso [m2/s]
rn_aeiv_0
= 2000.
! eddy induced velocity coefficient [m2/s]
(require "key_traldf_eiv")
/
!----------------------------------------------------------------------&namdyn_ldf
!
lateral diffusion on momentum
!----------------------------------------------------------------------!
! Type of the operator :
ln_dynldf_lap
= .true.
! laplacian operator
ln_dynldf_bilap = .false. ! bilaplacian operator
!
! Direction of action :
ln_dynldf_level = .false. ! iso-level
ln_dynldf_hor
= .true.
! horizontal (geopotential)
(require "key_ldfslp" in s-coord.)
ln_dynldf_iso
= .false. ! iso-neutral
(require "key_ldfslp")
!
! Coefficient
rn_ahm_0_lap
= 40000.
! horizontal laplacian eddy viscosity
[m2/s]
rn_ahmb_0
=
0.
! background eddy viscosity for ldf_iso [m2/s]
rn_ahm_0_blp
=
0.
! horizontal bilaplacian eddy viscosity [m4/s]
/
9.1
157
used. The resulting eddy viscosity and diffusivity coefficients can be a function of more
than one variable. Changes in the computer code when switching from one option to
another have been minimized by introducing the eddy coefficients as statement functions
(include file ldftra substitute.h90 and ldfdyn substitute.h90). The functions are replaced
by their actual meaning during the preprocessing step (CPP). The specification of the
space variation of the coefficient is made in ldftra.F90 and ldfdyn.F90, or more precisely
in include files traldf cNd.h90 and dynldf cNd.h90, with N=1, 2 or 3. The user can modify
these include files as he/she wishes. The way the mixing coefficient are set in the reference
version can be briefly described as follows :
Vertically varying Mixing Coefficients (key traldf c1d and key dynldf c1d)
The 1D option is only available when using the z-coordinate with full step. Indeed in
all the other types of vertical coordinate, the depth is a 3D function of (i,j,k) and therefore,
introducing depth-dependent mixing coefficients will require 3D arrays. In the 1D option,
a hyperbolic variation of the lateral mixing coefficient is introduced in which the surface
value is rn aht0 (rn ahm0), the bottom value is 1/4 of the surface value, and the transition
takes place around z=300 m with a width of 300 m (i.e. both the depth and the width of
the inflection point are set to 300 m). This profile is hard coded in file traldf c1d.h90, but
can be easily modified by users.
Horizontally Varying Mixing Coefficients (key traldf c2d and key dynldf c2d)
By default the horizontal variation of the eddy coefficient depends on the local mesh
size and the type of operator used :
max(e1 , e2 ) l
Ao
for laplacian operator
emax
Al =
max(e1 , e2 )3 l
(9.1)
where emax is the maximum of e1 and e2 taken over the whole masked ocean domain,
and Alo is the rn ahm0 (momentum) or rn aht0 (tracer) namelist parameter. This variation is intended to reflect the lesser need for subgrid scale eddy mixing where the grid
size is smaller in the domain. It was introduced in the context of the DYNAMO modelling project [Willebrand et al. 2001]. Note that such a grid scale dependance of mixing
coefficients significantly increase the range of stability of model configurations presenting large changes in grid pacing such as global ocean models. Indeed, in such a case, a
158
constant mixing coefficient can lead to a blow up of the model due to large coefficient
compare to the smallest grid size (see 3.3), especially when using a bilaplacian operator.
Other formulations can be introduced by the user for a given configuration. For example,
in the ORCA2 global ocean model (key orca r2), the laplacian viscosity operator uses
rn ahm0 = 4.104 m2 /s poleward of 20 north and south and decreases linearly to rn aht0 =
2.103 m2 /s at the equator [Madec et al. 1996, Delecluse and Madec 2000]. This modification can be found in routine ldf dyn c2d orca defined in ldfdyn c2d.F90. Similar modified horizontal variations can be found with the Antarctic or Arctic sub-domain options
of ORCA2 and ORCA05 (key antarctic or key arctic defined, see ldfdyn antarctic.h90
and ldfdyn arctic.h90).
Space Varying Mixing Coefficients (key traldf c3d and key dynldf c3d)
The 3D space variation of the mixing coefficient is simply the combination of the 1D
and 2D cases, i.e. a hyperbolic tangent variation with depth associated with a grid size
dependence of the magnitude of the coefficient.
159
(5) the eddy coefficient associated with a biharmonic operator must be set to a negative
value.
(6) it is possible to use both the laplacian and biharmonic operators concurrently.
(7) it is possible to run without explicit lateral diffusion on momentum (ln dynldf lap
= ln dynldf bilap = false). This is recommended when using the UBS advection scheme
on momentum (ln dynadv ubs = true, see 6.3.2) and can be useful for testing purposes.
9.2
9.2.1
e3u
e1u e3w
i+1/2, k
e3v
e2v e3w
j+1/2, k
i+1/2 [zt ]
[zt ]
e1u i+1/2
j+1/2 [zt ]
[zt ]
e2v j+1/2
i, k+1/2
[zt ]
e1w i+1/2
j, k+1/2
1
=
j+1/2 [zt ]
e2w
(9.2)
[zuw ]
e1w i+1/2
1
[zvw ]
e2w j+1/2
These slopes are computed once in ldfslp init when ln sco=True, and either ln traldf hor=True
or ln dynldf hor=True.
9.2.2
160
discrete formulation is found using the fact that the diffusive fluxes of locally referenced
potential density (i.e. insitu density) vanish. So, substituting T by in (5.10) and setting
the diffusive fluxes in the three directions to zero leads to the following definition for the
neutral slopes :
r1u =
r2v =
e3u
e1u
e3v
e2v
i+1/2 []
i+1/2, k
k+1/2 []
j+1/2 []
j+1/2, k
k+1/2 []
i, k+1/2
r1w =
e3w
e1w
(9.3)
i+1/2 []
k+1/2 []
j, k+1/2
r2w
e3w j+1/2 []
=
e2w
k+1/2 []
As the mixing is performed along neutral surfaces, the gradient of in (9.3) has to be
evaluated at the same local pressure (which, in decibars, is approximated by the depth in
meters in the model). Therefore (9.3) cannot be used as such, but further transformation
is needed depending on the vertical coordinate used :
z-coordinate with full step : in (9.3) the densities appearing in the i and j derivatives
are taken at the same depth, thus the insitu density can be used. This is not the
case for the vertical derivatives : k+1/2 [] is replaced by N 2 /g, where N 2
is the local Brunt-Vaisala frequency evaluated following McDougall [1987] (see
5.8.2).
z-coordinate with partial step : this case is identical to the full step case except that at
partial step level, the horizontal density gradient is evaluated as described in 5.9.
s- or hybrid s-z- coordinate : in the current release of NEMO , there is no specific
treatment for iso-neutral mixing in the s-coordinate. In other words, iso-neutral
mixing will only be accurately represented with a linear equation of state (nn eos=1
or 2). In the case of a true equation of state, the evaluation of i and j derivatives
in (9.3) will include a pressure dependent part, leading to the wrong evaluation of
the neutral slopes.
Note : The solution for s-coordinate passes trough the use of different (and better) expression for the constraint on iso-neutral fluxes. Following Griffies [2004],
instead of specifying directly that there is a zero neutral diffusive flux of locally
referenced potential density, we stay in the T -S plane and consider the balance
between the neutral direction diffusive fluxes of potential temperature and salinity :
F(T ) = F(S)
(9.4)
161
r1u =
r2v =
e3u
e1u
e3v
e2v
u k+1/2 [T ]
e3w
e1w
j+1/2, k
v k+1/2 [T ]
v k+1/2 [S]
j+1/2, k
i, k+1/2
(9.5)
w i+1/2 [T ]
w i+1/2 [S]
w k+1/2 [T ] w k+1/2 [S]
j, k+1/2
r2w
i+1/2, k
i, k+1/2
r1w =
u k+1/2 [S]
w j+1/2 [S]
e3w w j+1/2 [T ]
=
e2w
w k+1/2 [T ] w k+1/2 [S]
j, k+1/2
where and , the thermal expansion and saline contraction coefficients introduced in 5.8.2, have to be evaluated at the three velocity points. In order to save computation time, they should be approximated by the mean of their values at T -points
(for example in the case of : u = T i+1/2 , v = T j+1/2 and w = T k+1/2 ).
Note that such a formulation could be also used in the z-coordinate and z-coordinate
with partial steps cases.
This implementation is a rather old one. It is similar to the one proposed by Cox
[1987], except for the background horizontal diffusion. Indeed, the Cox implementation
of isopycnal diffusion in GFDL-type models requires a minimum background horizontal
diffusion for numerical stability reasons. To overcome this problem, several techniques
have been proposed in which the numerical schemes of the ocean model are modified
[Weaver and Eby 1997, Griffies et al. 1998]. Here, another strategy has been chosen [Lazar
1997] : a local filtering of the iso-neutral slopes (made on 9 grid-points) prevents the development of grid point noise generated by the iso-neutral diffusion operator (Fig. 9.1). This
allows an iso-neutral diffusion scheme without additional background horizontal mixing.
This technique can be viewed as a diffusion operator that acts along large-scale (2 x)
iso-neutral surfaces. The diapycnal diffusion required for numerical stability is thus minimized and its net effect on the flow is quite small when compared to the effect of an
horizontal background mixing.
Nevertheless, this iso-neutral operator does not ensure that variance cannot increase,
contrary to the Griffies et al. [1998] operator which has that property.
In addition and also for numerical stability reasons [Cox 1987, Griffies 2004], the
slopes are bounded by 1/100 everywhere. This limit is decreasing linearly to zero fom
70 meters depth and the surface (the fact that the eddies feel the surface motivates this
flattening of isopycnals near the surface).
For numerical stability reasons [Cox 1987, Griffies 2004], the slopes must also be
bounded by 1/100 everywhere. This constraint is applied in a piecewise linear fashion,
increasing from zero at the surface to 1/100 at 70 metres and thereafter decreasing to
162
zero at the bottom of the ocean. (the fact that the eddies feel the surface motivates this
flattening of isopycnals near the surface).
add here a discussion about the flattening of the slopes, vs tapering the coefficient.
9.2.3
r2t = r2v j
and
(9.6)
The major issue remaining is in the specification of the boundary conditions. The
same boundary conditions are chosen as those used for lateral diffusion along model level
163
surfaces, i.e. using the shear computed along the model levels and with no additional
friction at the ocean bottom (see 8.1).
9.3
(9.7)
where Aeiv is the eddy induced velocity coefficient whose value is set through rn aeiv,
a nam traldf namelist parameter. The three components of the eddy induced velocity are
computed and add to the eulerian velocity in traadv eiv.F90. This has been preferred to
a separate computation of the advective trends associated with the eiv velocity, since it
allows us to take advantage of all the advection schemes offered for the tracers (see 5.1)
and not just the 2nd order advection scheme as in previous releases of OPA [Madec et al.
1998]. This is particularly useful for passive tracers where positivity of the advection
scheme is of paramount importance.
At the surface, lateral and bottom boundaries, the eddy induced velocity, and thus the
advective eddy fluxes of heat and salt, are set to zero.
164
mixed
layer
?
?
interior
ocean
depth
(a)
slopes
iso-neutral
surface
iso-neutral
surface
interior
ocean
bounded by
the surface
slopes
mixed
layer
interior
ocean
depth
(c)
10-2
mixed
layer
depth
(b)
slopes
iso-neutral
surface
F IG . 9.2 Vertical profile of the slope used for lateral mixing in the mixed layer :
(a) in the real ocean the slope is the iso-neutral slope in the ocean interior, which
has to be adjusted at the surface boundary (i.e. it must tend to zero at the surface
since there is no mixing across the air-sea interface : wall boundary condition).
Nevertheless, the profile between the surface zero value and the interior iso-neutral
one is unknown, and especially the value at the base of the mixed layer ; (b) profile of slope using a linear tapering of the slope near the surface and imposing a
maximum slope of 1/100 ; (c) profile of slope actually used in NEMO : a linear
decrease of the slope from zero at the surface to its ocean interior value computed
just below the mixed layer. Note the huge change in the slope at the base of the
mixed layer between (b) and (c).
Contents
10.1 Vertical Mixing . . . . . . . . . . . . . . . . . . . . . . . . .
10.1.1 Constant (key zdfcst) . . . . . . . . . . . . . . . . .
10.1.2 Richardson Number Dependent (key zdfric) . . . . .
10.1.3 TKE Turbulent Closure Scheme (key zdftke) . . . . .
10.1.4 TKE discretization considerations (key zdftke) . . . .
10.1.5 GLS Generic Length Scale (key zdfgls) . . . . . . . .
10.1.6 K Profile Parametrisation (KPP) (key zdfkpp) . . . .
10.2 Convection . . . . . . . . . . . . . . . . . . . . . . . . . . .
10.2.1 Non-Penetrative Convective Adjustment (ln tranpc) .
10.2.2 Enhanced Vertical Diffusion (ln zdfevd) . . . . . . . .
10.2.3 Turbulent Closure Scheme (key zdftke or key zdfgls)
10.3 Double Diffusion Mixing (key zdfddm) . . . . . . . . . . .
10.4 Bottom Friction (zdfbfr) . . . . . . . . . . . . . . . . . . . .
10.4.1 Linear Bottom Friction (nn botfr = 0 or 1) . . . . . .
10.4.2 Non-Linear Bottom Friction (nn botfr = 2) . . . . . .
10.4.3 Bottom Friction stability considerations . . . . . . . .
10.4.4 Bottom Friction with split-explicit time splitting . . .
10.5 Tidal Mixing (key zdftmx) . . . . . . . . . . . . . . . . . .
10.5.1 Bottom intensified tidal mixing . . . . . . . . . . . .
10.5.2 Indonesian area specific treatment (ln zdftmx itf ) . . .
166
166
167
167
172
174
176
177
177
179
179
180
181
183
183
184
185
186
186
187
166
10.1
Vertical Mixing
The discrete form of the ocean subgrid scale physics has been presented in 5.3 and
6.7. At the surface and bottom boundaries, the turbulent fluxes of momentum, heat and
salt have to be defined. At the surface they are prescribed from the surface forcing (see
Chap. 7), while at the bottom they are set to zero for heat and salt, unless a geothermal flux
forcing is prescribed as a bottom boundary condition (i.e. key trabbl defined, see 5.4.3),
and specified through a bottom friction parameterisation for momentum (see 10.4).
In this section we briefly discuss the various choices offered to compute the vertivm and AvT (AvS ), defined at
cal eddy viscosity and diffusivity coefficients, Avm
u , Av
uw-, vw- and w- points, respectively (see 5.3 and 6.7). These coefficients can be assumed to be either constant, or a function of the local Richardson number, or computed
from a turbulent closure model (either TKE or KPP formulation). The computation of
these coefficients is initialized in the zdfini.F90 module and performed in the zdfric.F90,
zdftke.F90 or zdfkpp.F90 modules. The trends due to the vertical momentum and tracer
diffusion, including the surface forcing, are computed and added to the general trend in
the dynzdf.F90 and trazdf.F90 modules, respectively. These trends can be computed using
either a forward time stepping scheme (namelist parameter ln zdfexp=true) or a backward
time stepping scheme (ln zdfexp=false) depending on the magnitude of the mixing coefficients, and thus of the formulation used (see 3).
10.1.1
When key zdfcst is defined, the momentum and tracer vertical eddy coefficients are
set to constant values over the whole ocean. This is the crudest way to define the vertical
ocean physics. It is recommended that this option is only used in process studies, not in
basin scale simulations. Typical values used in this case are :
vm
4
Avm
m2 .s1
u = Av = 1.2 10
167
These values are set through the rn avm0 and rn avt0 namelist parameters. In all
cases, do not use values smaller that those associated with the molecular viscosity and
diffusivity, that is 106 m2 .s1 for momentum, 107 m2 .s1 for temperature and
109 m2 .s1 for salinity.
10.1.2
When key zdfric is defined, a local Richardson number dependent formulation for
the vertical momentum and tracer eddy coefficients is set. The vertical mixing coefficients are diagnosed from the large scale variables computed by the model. In situ measurements have been used to link vertical turbulent activity to large scale ocean structures.
The hypothesis of a mixing mainly maintained by the growth of Kelvin-Helmholtz like
instabilities leads to a dependency between the vertical eddy coefficients and the local Richardson number (i.e. the ratio of stratification to vertical shear). Following Pacanowski
and Philander [1981], the following formulation has been implemented :
AvT
vT
ric
A
=
+ AvT
b
(1 + a Ri)n
(10.1)
AvT
vm
vm
+ Ab
A =
(1 + a Ri)
where Ri = N 2 / (z Uh )2 is the local Richardson number, N is the local Brunt-Vaisala freare the constant background values set as in the
and Avm
quency (see 5.8.2), AvT
b
b
vT
constant case (see 10.1.1), and Aric = 104 m2 .s1 is the maximum value that can
be reached by the coefficient when Ri 0, a = 5 and n = 2. The last three values can
be modified by setting the rn avmri, rn alp and nn ric namelist parameters, respectively.
10.1.3
168
rn_efr
nn_htau
=
=
0.05
1
!
!
!
!
!
The vertical eddy viscosity and diffusivity coefficients are computed from a TKE
turbulent closure model based on a prognostic equation for e, the turbulent kinetic energy,
and a closure assumption for the turbulent length scales. This turbulent closure model has
been developed by Bougeault and Lacarrere [1989] in the atmospheric case, adapted by
Gaspar et al. [1990] for the oceanic case, and embedded in OPA, the ancestor of NEMO,
by Blanke and Delecluse [1993] for equatorial Atlantic simulations. Since then, significant
modifications have been introduced by Madec et al. [1998] in both the implementation
and the formulation of the mixing length scale. The time evolution of e is the result of
the production of e through vertical shear, its destruction through stratification, its vertical
diffusion, and its dissipation of Kolmogorov [1942] type :
"
2 #
e
Km
u 2
v
1 Avm
e
e3/2
2
= 2
+
K N +
(10.2)
c
t
e3
k
k
e3 k e3 k
l
Km = Ck lk
K = A
vm
/Prt
(10.3)
where N is the local Brunt-Vaisala frequency (see 5.8.2), l and l are the dissipation
and mixing length scales, Prt is the Prandtl number, Km and K are the vertical
eddy
viscosity and diffusivity coefficients. The constants Ck = 0.1 and C = 2/2 0.7
are designed to deal with vertical mixing at any depth [Gaspar et al. 1990]. They are set
through namelist parameters nn ediff and nn ediss. Prt can be set to unity or, following
Blanke and Delecluse [1993], be a function of the local Richardson number, Ri :
1 if Ri 0.2
Prt = 5 Ri if 0.2 Ri 2
10 if 2 Ri
The choice of Prt is controlled by the nn pdl namelist parameter.
At the sea surface, the value of e is prescribed from the wind stress field as eo =
ebb | |/o , with ebb the rn ebb namelist parameter. The default value of ebb is 3.75. [Gaspar et al. 1990]), however a much larger value can be used when taking into account the
surface wave breaking (see below Eq. (10.8)). The bottom value of TKE is assumed to be
equal to the value of the level just above. The time integration of the e equation may formally lead to negative values because the numerical scheme does not ensure its positivity.
To overcome this problem, a cut-off in the minimum value of e is used
(rn emin namelist
parameter). Following Gaspar et al. [1990], the cut-off value is set to 2/2 106 m2 .s2 .
This allows the subsequent formulations to match that of Gargett [1984] for the diffusion
in the thermocline and deep ocean : K = 103 /N . In addition, a cut-off is applied on Km
and K to avoid numerical instabilities associated with too weak vertical diffusion. They
must be specified at least larger than the molecular values, and are set through rn avm0
and rn avt0 (namzdf namelist, see 10.1.1).
169
lk = l = 2
e /N
(10.4)
which is valid in a stable stratified region with constant values of the Brunt- Vaisala frequency. The resulting length scale is bounded by the distance to the surface or to the
bottom (nn mxl = 0) or by the local vertical scale factor (nn mxl = 1). Blanke and Delecluse [1993] notice that this simplification has two major drawbacks : it makes no sense
for locally unstable stratification and the computation no longer uses all the information contained in the vertical density profile. To overcome these drawbacks, Madec et al.
[1998] introduces the nn mxl = 2 or 3 cases, which add an extra assumption concerning
the vertical gradient of the computed length scale. So, the length scales are first evaluated
as in (10.4) and then bounded such that :
1 l
1
with l = lk = l
(10.5)
e3 k
(10.5) means that the vertical variations of the length scale cannot be larger than the variations of depth. It provides a better approximation of the Gaspar et al. [1990] formulation
while being much less time consuming. In particular, it allows the length scale to be limited not only by the distance to the surface or to the ocean bottom but also by the distance
to a strongly stratified portion of the water column such as the thermocline (Fig. 10.1). In
order to impose the (10.5) constraint, we introduce two additional length scales : lup and
ldwn , the upward and downward length scales, and evaluate the dissipation and mixing
length scales as (and note that here we use numerical indexing) :
(k)
(k)
(k+1)
lup
= min l(k) , lup
+ e3t
from k = 1 to jpk
(10.6)
(k)
(k1)
(k1)
ldwn = min l(k) , ldwn + e3t
from k = jpk to 1
q
where l(k) is computed using (10.4), i.e. l(k) = 2
e(k) /N 2 (k) .
In the nn mxl = 2 case, the dissipation and mixing length scales take the same value :
lk = l = min ( lup , ldwn ), while in the nn mxl = 3 case, the dissipation and mixing
turbulent length scales are give as in Gaspar et al. [1990] :
p
lk =
lup ldwn
(10.7)
l = min ( lup , ldwn )
At the ocean surface, a non zero length scale is set through the rn lmin0 namelist
parameter. Usually the surface scale is given by lo = zo where = 0.4 is von Karmans
170
Depth (m)
20
l
lk
40
lup
ldwn
60
80
l=
2 eN
80
90
100
0
10
20
30
40
50
60
70
Mixing length scale(m)
100
constant and zo the roughness parameter of the surface. Assuming zo = 0.1 m [Craig
and Banner 1994] leads to a 0.04 m, the default value of rn lsurf . In the ocean interior a
minimum length scale is set to recover the molecular viscosity when e reach its minimum
171
Charnocks relation :
lo =
| |
g o
(10.9)
where = 0.40 is the von Karman constant, and is the Charnocks constant. Mellor and
Blumberg [2004] suggest = 2.105 the value chosen by Stacey [1999] citing observation
evidence, and CB = 100 the Craig and Banners value. As the surface boundary condition on TKE is prescribed through eo = ebb | |/o , with ebb the rn ebb namelist parameter,
setting rn ebb = 67.83 corresponds to CB = 100. further setting ln lsurf to true applies
(10.9) as surface boundary condition on length scale, with hard coded to the Stacets
value. Note that a minimal threshold of rn emin0= 104 m2 .s2 (namelist parameters)
is applied on surface e value.
Langmuir cells
Langmuir circulations (LC) can be described as ordered large-scale vertical motions in
the surface layer of the oceans. Although LC have nothing to do with convection, the circulation pattern is rather similar to so-called convective rolls in the atmospheric boundary
layer. The detailed physics behind LC is described in, for example, Craik and Leibovich
[1976]. The prevailing explanation is that LC arise from a nonlinear interaction between
the Stokes drift and wind drift currents.
Here we introduced in the TKE turbulent closure the simple parameterization of Langmuir circulations proposed by [Axell 2002] for a k turbulent closure. The parameterization, tuned against large-eddy simulation, includes the whole effect of LC in an extra
source terms of TKE, PLC . The presence of PLC in (10.2), the TKE equation, is controlled
by setting ln lc to true in the namtke namelist.
By making an analogy with the characteristic convective velocity scale (e.g., DAlessio et al. [1998]), PLC is assumed to be :
PLC (z) =
3 (z)
wLC
HLC
(10.10)
where wLC (z) is the vertical velocity profile of LC, and HLC is the LC depth. With no
information about the wave field, wLC is assumed to be proportional to the Stokes drift
us = 0.377 | |1/2 , where | | is the surface wind stress module 1 . For the vertical variation,
wLC is assumed to be zero at the surface as well as at a finite depth HLC (which is often
close to the mixed layer depth), and simply varies as a sine function in between (a firstorder profile for the Langmuir cell structures). The resulting expression for wLC is :
(
cLC us sin( z/HLC ) if z HLC
wLC =
(10.11)
0
otherwise
1
Following Li and Garrett [1993], the surface Stoke drift velocity may be expressed as us =
0.016 |U10m |. Assuming an air density of a = 1.22 Kg/m3 and a drag coefficient of 1.5 103
give the expression used of us as a function of the module of surface stress
172
where cLC = 0.15 has been chosen by [Axell 2002] as a good compromise to fit LES
data. The chosen value yields maximum vertical velocities wLC of the order of a few
centimeters per second. The value of cLC is set through the rn lc namelist parameter,
having in mind that it should stay between 0.15 and 0.54 [Axell 2002].
The HLC is estimated in a similar way as the turbulent length scale of TKE equations :
HLC is depth to which a water parcel with kinetic energy due to Stoke drift can reach on
its own by converting its kinetic energy to potential energy, according to
Z
1
N 2 z dz = u2s
2
HLC
(10.12)
10.1.4
Km z u z u
dz
H
Here, the vertical diffusion of momentum is discretized backward in time with a coefficient, Km , known at time t (Fig. 10.2), as it is required when using the TKE scheme (see
3.3). The first term of the right hand side of (10.13) represents the kinetic energy transfer
at the surface (atmospheric forcing) and at the bottom (friction effect). The second term is
always negative. It is the dissipation rate of kinetic energy, and thus minus the shear production rate of e. (10.13) implies that, to be energetically consistent, the production rate of
e used to compute (
e)t (and thus Km t ) should be expressed as Km tt (z u)tt (z u)t
(and not by the more straightforward Km (z u)2 expression taken at time t or t t).
A similar consideration applies on the destruction rate of e due to stratification (second term of the right hand side of (10.2)). This term must balance the input of potential
energy resulting from vertical mixing. The rate of change of potential energy (in 1D for the
momentum
t-t
173
t+t
TKE
tracer
F IG . 10.2 Illustration of the TKE time integration and its links to the momentum
and tracer time integration.
174
= g z K (z )
H
H
Z
h
i
t+t K t (N 2 )t+t dz
+
= z K t (N 2 )t+t
H
(10.14)
where we use N 2 = g k /(e3 ). The first term of the right hand side of (10.14) is
always zero because there is no diffusive flux through the ocean surface and bottom).
The second term is minus the destruction rate of e due to stratification. Therefore (10.13)
implies that, to be energetically consistent, the product K tt (N 2 )t should be used in
(10.2), the TKE equation.
Let us now address the space discretization issue. The vertical eddy coefficients are
defined at w-point whereas the horizontal velocity components are in the centre of the
side faces of a t-box in staggered C-grid (Fig.4.1). A space averaging is thus required to
obtain the shear TKE production term. By redoing the (10.13) in the 3D case, it can be
shown that the product of eddy coefficient by the shear at t and t t must be performed
prior to the averaging. Furthermore, the possible time variation of e3 (key vvl case) have
to be taken into account.
The above energetic considerations leads to the following final discrete form for the
TKE equation :
(
i
t+t ]
t
(
e)t (
e)tt
i+1/2 tt k+1/2 [u
k+1/2 [u ]
Km
t
e3 ut+t
e3 ut
j)
t
t+t ]
j+1/2 tt k+1/2 [v
k+1/2 [v ]
+ Km
e3 v t+t
e3 v t
(10.15)
K tt (N 2 )t
1
e)t+t ]
tt k [(
+
Km
e3 wt+t k+1/2
e3 wt+t
tt
e
c
(
e)t+t
l
where the last two terms in (10.15) (vertical diffusion and Kolmogorov dissipation) are
time stepped using a backward scheme (see3.3). Note that the Kolmogorov term has been
linearized in time in order to render the implicit computation possible. The restart of the
TKE scheme requires the storage of e, Km , K and
l as they all appear in the right hand
side of (10.15). For the latter, it is in fact the ratio e/l which is stored.
10.1.5
175
&namzdf_gls
!
GLS vertical diffusion
("key_zdfgls")
!----------------------------------------------------------------------rn_emin
= 1.e-6
! minimum value of e
[m2/s2]
rn_epsmin
= 1.e-12 ! minimum value of eps [m2/s3]
ln_length_lim = .true. ! limit on the dissipation rate under stable stratification (Galperin et al., 1988)
rn_clim_galp = 0.53
! galperin limit
ln_crban
= .true. ! Use Craig & Banner (1994) surface wave mixing parametrisation
ln_sigpsi
= .true. ! Activate or not Burchard 2001 mods on psi schmidt number in the wb case
rn_crban
= 100.
! Craig and Banner 1994 constant for wb tke flux
rn_charn
= 70000. ! Charnock constant for wb induced roughness length
nn_tkebc_surf =
1
! surface tke condition (0/1/2=Dir/Neum/Dir Mellor-Blumberg)
nn_tkebc_bot =
1
! bottom tke condition (0/1=Dir/Neum)
nn_psibc_surf =
1
! surface psi condition (0/1/2=Dir/Neum/Dir Mellor-Blumberg)
nn_psibc_bot =
1
! bottom psi condition (0/1=Dir/Neum)
nn_stab_func =
2
! stability function (0=Galp, 1= KC94, 2=CanutoA, 3=CanutoB)
nn_clos
=
1
! predefined closure type (0=MY82, 1=k-eps, 2=k-w, 3=Gen)
/
The Generic Length Scale (GLS) scheme is a turbulent closure scheme based on two
prognostic equations : one for the turbulent kinetic energy e, and another for the generic
length scale, [Umlauf and Burchard 2003; 2005]. This later variable is defined as :
= C0 p em ln , where the triplet (p, m, n) value given in Tab.10.1 allows to recover
a number of well-known turbulent closures (k-kl [Mellor and Yamada 1982], k- [Rodi
1987], k- [Wilcox 1988] among others [Umlauf and Burchard 2003, Kantha and Carniel
2005]). The GLS scheme is given by the following set of equations :
"
2 #
1 Km
Km
v
e
u 2
e
2
K N +
=
+
(10.16)
t
e e 3
k
k
e3 k e3 k
)
"
2 #
C1 K m
v
u 2
C3 K N 2 C2 F w
+
e3
k
k
1 Km
+
e3 k e3 k
=
t
e
Km = C
K = C0
(10.17)
e l
e l
(10.18)
e3/2
(10.19)
l
where N is the local Brunt-Vaisala frequency (see 5.8.2) and the dissipation rate. The
constants C1 , C2 , C3 , e , and the wall function (F w) depends of the choice of the
turbulence model. Four different turbulent models are pre-defined (Tab.10.1). They are
made available through the nn clo namelist parameter.
In the Mellor-Yamada model, the negativity of n allows to use a wall function to force
the convergence of the mixing length towards Kzb (K : Kappa and zb : rugosity length)
value near physical boundaries (logarithmic boundary layer law). C and C0 are calculated from stability function proposed by Galperin et al. [1988], or by Kantha and Clayson
[1994] or one of the two functions suggested by Canuto et al. [2001] (nn stab func = 0, 1,
2 or 3, resp.). The value of C0 depends of the choice of the stability function.
= C0
176
nn clo
(p, n, m)
k
C1
C2
C3
Fwall
k kl
0
(0,1,1)
2.44
2.44
0.9
0.5
1.
Yes
k
1
( 3 , 1.5 , -1 )
1.
1.3
1.44
1.92
1.
k
2
( -1 , 0.5 , -1 )
2.
2.
0.555
0.833
1.
generic
3
( 2 , 1 , -0.67 )
0.8
1.07
1.
1.22
1.
TAB . 10.1 Set of predefined GLS parameters, or equivalently predefined turbulence models available with key zdfgls and controlled by the nn clos namelist
parameter.
The surface and bottom boundary condition on both e and can be calculated thanks
to Dirichlet or Neumann condition through nn tkebc surf and nn tkebc bot, resp. As for
TKE closure , the wave effect on the mixing is considered when ln crban = true [Craig
and Banner 1994, Mellor and Blumberg 2004]. The rn crban namelist parameter is CB
in (10.8) and rn charn provides the value of in (10.9).
The equation is known to fail in stably stratified flows, and for this reason almost
all authors apply a clipping of the length scale as an ad hoc remedy.With this clipping,
the maximum permissible length scale is determined by lmax = clim 2
e/N . A value of
clim = 0.53 is often used [Galperin et al. 1988]. Umlauf and Burchard [2005] show that
the value of the clipping factor is of crucial importance for the entrainment depth predicted
in stably stratified situations, and that its value has to be chosen in accordance with the algebraic model for the turbulent uxes. The clipping is only activated if ln length lim=true,
and the clim is set to the rn clim galp value.
The time and space discretization of the GLS equations follows the same energetic
consideration as for the TKE case described in 10.1.4 [Burchard 2002]. Examples of
performance of the 4 turbulent closure scheme can be found in Warner et al. [2005].
10.1.6
10.2. Convection
10.2
177
Convection
!----------------------------------------------------------------------&namzdf
!
vertical physics
!----------------------------------------------------------------------rn_avm0
=
1.2e-4 ! vertical eddy viscosity
[m2/s]
(background Kz if not "key_zdfcst")
rn_avt0
=
1.2e-5 ! vertical eddy diffusivity [m2/s]
(background Kz if not "key_zdfcst")
nn_avb
=
0
! profile for background avt & avm (=1) or not (=0)
nn_havtb
=
0
! horizontal shape for avtb (=1) or not (=0)
ln_zdfevd
= .true.
! enhanced vertical diffusion (evd) (T) or not (F)
nn_evdm
=
0
! evd apply on tracer (=0) or on tracer and momentum (=1)
rn_avevd
= 100.
! evd mixing coefficient [m2/s]
ln_zdfnpc
= .false.
! Non-Penetrative Convective algorithm (T) or not (F)
nn_npc
=
1
! frequency of application of npc
nn_npcp
= 365
! npc control print frequency
ln_zdfexp
= .false.
! time-stepping: split-explicit (T) or implicit (F) time stepping
nn_zdfexp
=
3
! number of sub-timestep for ln_zdfexp=T
/
Static instabilities (i.e. light potential densities under heavy ones) may occur at particular ocean grid points. In nature, convective processes quickly re-establish the static
stability of the water column. These processes have been removed from the model via
the hydrostatic assumption so they must be parameterized. Three parameterisations are
available to deal with convective processes : a non-penetrative convective adjustment or
an enhanced vertical diffusion, or/and the use of a turbulent closure scheme.
10.2.1
178
LEVELS
initial profile
st
step
nd
step
3
4
5
vertical profiles while the algorithm used in NEMO converges for any profile in a number
of iterations which is less than the number of vertical levels. This property is of paramount
importance as pointed out by Killworth [1989] : it avoids the existence of permanent and
unrealistic static instabilities at the sea surface. This non-penetrative convective algorithm
has been proved successful in studies of the deep water formation in the north-western
Mediterranean Sea [Madec et al. 1991b;a, Madec and Crepon 1991].
Note that in the current implementation of this algorithm presents several limitations.
First, potential density referenced to the sea surface is used to check whether the density profile is stable or not. This is a strong simplification which leads to large errors for
realistic ocean simulations. Indeed, many water masses of the world ocean, especially
Antarctic Bottom Water, are unstable when represented in surface-referenced potential
density. The scheme will erroneously mix them up. Second, the mixing of potential den-
10.2. Convection
179
sity is assumed to be linear. This assures the convergence of the algorithm even when the
equation of state is non-linear. Small static instabilities can thus persist due to cabbeling :
they will be treated at the next time step. Third, temperature and salinity, and thus density, are mixed, but the corresponding velocity fields remain unchanged. When using a
Richardson Number dependent eddy viscosity, the mixing of momentum is done through
the vertical diffusion : after a static adjustment, the Richardson Number is zero and thus
the eddy viscosity coefficient is at a maximum. When this convective adjustment algorithm is used with constant vertical eddy viscosity, spurious solutions can occur since the
vertical momentum diffusion remains small even after a static adjustment. In that case,
we recommend the addition of momentum mixing in a manner that mimics the mixing in
temperature and salinity [Speich 1992, Speich et al. 1996].
10.2.2
10.2.3
180
case, the term corresponding to the destruction of turbulent kinetic energy through stratification in (10.2) or (10.16) becomes a source term, since N 2 is negative. It results in large
vT
vm
vm
2 1
values of AvT
T and AT , and also the four neighbouring Au and Av (up to 1 m s ).
These large values restore the static stability of the water column in a way similar to that
of the enhanced vertical diffusion parameterisation (10.2.2). However, in the vicinity of
the sea surface (first ocean layer), the eddy coefficients computed by the turbulent closure
scheme do not usually exceed 102 m.s1 , because the mixing length scale is bounded
by the distance to the sea surface. It can thus be useful to combine the enhanced vertical
diffusion with the turbulent closure scheme, i.e. setting the ln zdfnpc namelist parameter
to true and defining the turbulent closure CPP key all together.
The KPP turbulent closure scheme already includes enhanced vertical diffusion in the
case of convection, as governed by the variables bvsqcon and dif con found in zdfkpp.F90,
therefore ln zdfevd=false should be used with the KPP scheme.
10.3
Double diffusion occurs when relatively warm, salty water overlies cooler, fresher
water, or vice versa. The former condition leads to salt fingering and the latter to diffusive
convection. Double-diffusive phenomena contribute to diapycnal mixing in extensive regions of the ocean. Merryfield et al. [1999] include a parameterisation of such phenomena
in a global ocean model and show that it leads to relatively minor changes in circulation
but exerts significant regional influences on temperature and salinity. This parameterisation has been introduced in zdfddm.F90 module and is controlled by the key zdfddm CPP
key.
Diapycnal mixing of S and T are described by diapycnal diffusion coefficients
vT
vT
AvT = AvT
o + Af + Ad
vS
vS
AvS = AvS
o + Af + Ad
otherwise
(
AvS
f
vS
AvT
f = 0.7 Af /R
(10.20)
(10.21)
181
The factor 0.7 in (10.21) reflects the measured ratio FT /FS 0.7 of buoyancy
flux of heat to buoyancy flux of salt (e.g., McDougall and Taylor [1984]). Following
Merryfield et al. [1999], we adopt Rc = 1.6, n = 6, and Av = 104 m2 .s1 .
To represent mixing of S and T by diffusive layering, the diapycnal diffusivities suggested by Federov (1988) is used :
(
1.3635 exp 4.6 exp 0.54 (R1 1)
if 0 < R < 1 and N 2 > 0
vT
Ad =
0
otherwise
(10.22)
AvS
d
2
vT
0
otherwise
(10.23)
The dependencies of (10.20) to (10.23) on R are illustrated in Fig. 10.4. Implementing this requires computing R at each grid point on every time step. This is done in
eosbn2.F90 at the same time as N 2 is computed. This avoids duplication in the computation of and (which is usually quite expensive).
10.4
182
&nambfr
!
bottom friction
!----------------------------------------------------------------------nn_bfr
=
1
! type of bottom friction :
= 0 : free slip, = 1 : linear friction
!
= 2 : nonlinear friction
rn_bfri1
=
4.e-4 ! bottom drag coefficient (linear case)
rn_bfri2
=
1.e-3 ! bottom drag coefficient (non linear case)
rn_bfeb2
=
2.5e-3 ! bottom turbulent kinetic energy background (m2/s2)
ln_bfr2d
= .false.
! horizontal variation of the bottom friction coef (read a 2D mask file )
rn_bfrien
=
50.
! local multiplying factor of bfr (ln_bfr2d=T)
/
Both the surface momentum flux (wind stress) and the bottom momentum flux (bottom friction) enter the equations as a condition on the vertical diffusive flux. For the
bottom boundary layer, one has :
Avm (Uh /z) = FhU
(10.24)
where FhU is represents the downward flux of horizontal momentum outside the logarithmic turbulent boundary layer (thickness of the order of 1 m in the ocean). How FhU
influences the interior depends on the vertical resolution of the model near the bottom
relative
Ekman layer depth
to the Ekman layer depth. For example, in order to obtain an vm
vm
d = 2 A /f = 50 m, one needs a vertical diffusion coefficient A = 0.125 m2 s1
(for a Coriolis frequency f = 104 m2 s1 ). With a background diffusion coefficient
Avm = 104 m2 s1 , the Ekman layer depth is only 1.4 m. When the vertical mixing
coefficient is this small, using a flux condition is equivalent to entering the viscous forces
(either wind stress or bottom friction) as a body force over the depth of the top or bottom
model layer. To illustrate this, consider the equation for u at k, the last ocean level :
Fu
uk
1 Avm
uw
u
=
k+1/2 [u] Fh h
(10.25)
t
e3u e3uw
e3u
If the bottom layer thickness is 200 m, the Ekman transport will be distributed over that
depth. On the other hand, if the vertical resolution is high (1 m or less) and a turbulent
closure model is used, the turbulent Ekman layer will be represented explicitly by the
model. However, the logarithmic layer is never represented in current primitive equation
model applications : it is necessary to parameterize the flux Fhu . Two choices are available
in NEMO : a linear and a quadratic bottom friction. Note that in both cases, the rotation
between the interior velocity and the bottom friction is neglected in the present release of
NEMO .
In the code, the bottom friction is imposed by adding the trend due to the bottom
friction to the general momentum trend in dynbfr.F90. For the time-split surface pressure
gradient algorithm, the momentum trend due to the barotropic component needs to be
handled separately. For this purpose it is convenient to compute and store coefficients
which can be simply combined with bottom velocities and geometric values to provide
the momentum trend due to bottom friction. These coefficients are computed in zdfbfr.F90
and generally take the form cU
b where :
FU
cU
Uh
= h = b Ubh
t
e3u
e3u
where Ubh = (ub , vb ) is the near-bottom, horizontal, ocean velocity.
(10.26)
10.4.1
183
Avm Uh
= r Ubh
e3 k
(10.27)
where r is a friction coefficient expressed in ms1 . This coefficient is generally estimated by setting a typical decay time in the deep ocean, and setting r = H/ , where H
is the ocean depth. Commonly accepted values of are of the order of 100 to 200 days
[Weatherly 1984]. A value 1 = 107 s1 equivalent to 115 days, is usually used in
quasi-geostrophic models. One may consider the linear friction as an approximation of
quadratic friction, r 2 CD Uav (Gill [1982], Eq. 9.6.6). For example, with a drag coefficient CD = 0.002, a typical speed of tidal currents of Uav = 0.1 m s1 , and assuming
an ocean depth H = 4000 m, the resulting friction coefficient is r = 4 104 m s1 . This
is the default value used in NEMO . It corresponds to a decay time scale of 115 days. It
can be changed by specifying rn bfric1 (namelist parameter).
For the linear friction case the coefficients defined in the general expression (10.26)
are :
cub = r
cvb = r
(10.28)
When nn botfr=1, the value of r used is rn bfric1. Setting nn botfr=0 is equivalent to setting r = 0 and leads to a free-slip bottom boundary condition. These values are assigned
in zdfbfr.F90. From v3.2 onwards there is support for local enhancement of these values
via an externally defined 2D mask array (ln bfr2d=true) given in the bfr coef.nc input
NetCDF file. The mask values should vary from 0 to 1. Locations with a non-zero mask
value will have the friction coefficient increased by mask value*rn bfrien*rn bfric1.
10.4.2
184
As for the linear case, the bottom friction is imposed in the code by adding the trend
due to the bottom friction to the general momentum trend in dynbfr.F90. For the non-linear
friction case the terms computed in zdfbfr.F90 are :
h
i1/2
2
cub = CD u2 + vi+1,j + eb
h
i1/2
i,j+1 2 + v 2 + eb
cvb = CD u
(10.30)
The coefficients that control the strength of the non-linear bottom friction are initialised as namelist parameters : CD = rn bfri2, and eb =rn bfeb2. Note for applications which
treat tides explicitly a low or even zero value of rn bfeb2 is recommended. From v3.2
onwards a local enhancement of CD is possible via an externally defined 2D mask array
(ln bfr2d=true). See previous section for details.
10.4.3
u =
(10.31)
where linear bottom friction and a leapfrog timestep have been assumed. To ensure that
the bottom friction cannot reverse the direction of flow it is necessary to have :
|u| < |u|
(10.32)
2t
<1
e3u
r<
e3u
2t
(10.33)
This same inequality can also be derived in the non-linear bottom friction case if a velocity of 1 m.s1 is assumed. Alternatively, this criterion can be rearranged to suggest a
minimum bottom box thickness to ensure stability :
e3u > 2 r t
(10.34)
which it may be necessary to impose if partial steps are being used. For example, if |u| = 1
m.s1 , rdt = 1800 s, r = 103 then e3u should be greater than 3.6 m. For most applications, with physically sensible parameters these restrictions should not be of concern.
But caution may be necessary if attempts are made to locally enhance the bottom friction
parameters. To ensure stability limits are imposed on the bottom friction coefficients both
185
during initialisation and at each time step. Checks at initialisation are made in zdfbfr.F90
(assuming a 1 m.s1 velocity in the non-linear case). The number of breaches of the stability criterion are reported as well as the minimum and maximum values that have been set.
The criterion is also checked at each time step, using the actual velocity, in dynbfr.F90.
Values of the bottom friction coefficient are reduced as necessary to ensure stability ; these
changes are not reported.
10.4.4
U
+ 2t RHS / [1 2t cub /He ]
(10.35)
is the barotropic velocity, He is the full depth (including sea surface height),
where U
u
cb is the bottom friction coefficient as calculated in zdf bfr and RHS represents all the
186
components to the vertically integrated momentum trend except for that due to bottom
friction.
10.5
10.5.1
E(x, y) F (z)
N2
(10.36)
where is the mixing efficiency, N the Brunt-Vaisala frequency (see 5.8.2), the density,
q the tidal dissipation efficiency, and F (z) the vertical structure function.
The mixing efficiency of turbulence is set by (rn me namelist parameter) and is
usually taken to be the canonical value of = 0.2 (Osborn 1980). The tidal dissipation
efficiency is given by the parameter q (rn tfe namelist parameter) represents the part of
the internal wave energy flux E(x, y) that is dissipated locally, with the remaining 1 q
radiating away as low mode internal waves and contributing to the background internal
wave field. A value of q = 1/3 is typically used St. Laurent et al. [2002]. The vertical
structure function F (z) models the distribution of the turbulent mixing in the vertical.
It is implemented as a simple exponential decaying upward away from the bottom, with
a vertical scale of ho (rn htmx namelist parameter, with a typical value of 500 m) [St.
Laurent and Nash 2004],
H+z
e ho
F (i, j, k) =
H
ho 1 e ho
(10.37)
and is normalized so that vertical integral over the water column is unity.
The associated vertical viscosity is calculated from the vertical diffusivity assuming
vT
a Prandtl number of 1, i.e. Avm
tides = Atides . In the limit of N 0 (or becoming negative), the vertical diffusivity is capped at 300 cm2 /s and impose a lower limit on N 2 of
rn n2min usually set to 108 s2 . These bounds are usually rarely encountered.
187
The internal wave energy map, E(x, y) in (10.36), is derived from a barotropic model
of the tides utilizing a parameterization of the conversion of barotropic tidal energy into
internal waves. The essential goal of the parameterization is to represent the momentum
exchange between the barotropic tides and the unrepresented internal waves induced by
the tidal ow over rough topography in a stratified ocean. In the current version of NEMO
, the map is built from the output of the barotropic global ocean tide model MOG2DG [Carr`ere and Lyard 2003]. This model provides the dissipation associated with internal wave energy for the M2 and K1 tides component (Fig. 10.5). The S2 dissipation is
simply approximated as being 1/4 of the M2 one. The internal wave energy is thus :
E(x, y) = 1.25EM 2 + EK1 . Its global mean value is 1.1 TW, in agreement with independent estimates [Egbert and Ray 2000; 2001].
10.5.2
q E(i, j)
when z N < 0
N R N dz
F (i, j, k)
(10.38)
q E(i, j)
when z N > 0
N 2 dz
Averaged over the ITF area, the resulting tidal mixing coefficient is 1.5 cm2 /s, which
agrees with the independent estimates inferred from observations. Introduced in a regional OGCM, the parameterization improves the water mass characteristics in the different
Indonesian seas, suggesting that the horizontal and vertical distributions of the mixing are
adequately prescribed [Koch-Larrouy et al. 2007; 2008b;a]. Note also that such a parameterisation has a sugnificant impact on the behaviour of global coupled GCMs [KochLarrouy et al. 2010].
188
F IG . 10.5 (a) M2 and (b) K2 internal wave drag energy from Carr`ere and Lyard
[2003] (W/m2 ).
Contents
11.1 Old Model Output (default or key dimgout) . .
11.2 Standard model Output (IOM) . . . . . . . . . .
11.2.1 Basic knowledge . . . . . . . . . . . . . .
11.2.2 Detailed functionalities . . . . . . . . . .
11.2.3 IO SERVER . . . . . . . . . . . . . . . .
11.2.4 Practical issues . . . . . . . . . . . . . . .
11.3 NetCDF4 Support (key netcdf4) . . . . . . . . .
11.4 Tracer/Dynamics Trends (TRD) . . . . . . . . .
11.5 On-line Floats trajectories (FLO) (key floats) . .
11.6 Other Diagnostics (key diahth, key diaar5) . . .
11.7 Diagnosing the Steric effect in sea surface height
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
190
190
191
193
195
196
197
200
201
201
202
190
11.1
11.2
191
11.2.1
Basic knowledge
XML basic rules
XML tags begin with the less-than character (<) and end with the greater-than
character (>). You use tags to mark the start and end of elements, which are the logical
units of information in an XML document. In addition to marking the beginning of an
element, XML start tags also provide a place to specify attributes. An attribute specifies
a single property for an element, using a name/value pair, for example : <a b=x c=y
b=z> ... </a>. See here for more details.
192
<!-- averaged
sst -->
<!-- instantaneous sss -->
The field sst which is part (or a child) of the field definition will inherit the value
ave(X) of the attribute operation from its parent field definition. Note that a child
can overwrite the attribute definition inherited from its parents. In the example above, the
field sss will therefore output instantaneous values instead of average values.
example 2 : Use (or overwrite) attributes value of a field when listing the variables
included in a file
<field_definition>
<field id="sst" description="sea surface temperature" />
<field id="sss" description="sea surface salinity"
/>
</field_definition>
<file_definition>
<file id="file_1" />
<field ref="sst"
/>
<field ref="sss" description="my description" />
</file>
</file_definition>
With the help of the inheritance, the concept of group allow to define a set of attributes
for several fields or files.
example 3, group of fields : define a group T grid variables identified with the name
grid T. By default variables of this group have no vertical axis but, following inheritance
rules, axis ref can be redefined for the field toce that is a 3D variable.
<field_definition>
<group id="grid_T" axis_ref="none" grid_ref="T_grid_variables">
<field id="sst"/>
<field id="sss"/>
<field id="toce" axis_ref="deptht"/> <!-- overwrite axis def -->
</group>
</field_definition>
example 4, group of files : define a group of file with the attribute output freq equal
to 432000 (5 days)
<file_definition>
<group id="5d" output_freq="432000">
<file id="5d_grid_T" name="auto">
...
</file>
<file id="5d_grid_U" name="auto">
...
</file>
</group>
</file_definition>
193
11.2.2
name
attribute
freq op
freq op
name
jbegin, ni,
name suffix
ibegin, jbegin,
name suffix
attribute value
rn rdt
rn rdt nn fsbc
filename defined by
a call to roudia nam
following NEMO
nomenclature
according to the grid
according to the grid
Detailed functionalities
Tag list
context : define the model using the xml file. Id is the only attribute accepted. Its value
must be nemo or n nemo for the nth AGRIF zoom. Child of simulation tag.
field : define the field to be output. Accepted attributes are axis ref, description, enable,
freq op, grid ref, id (if child of field definition), level, operation, name, ref (if child
of file), unit, zoom ref. Child of field definition, file or group of fields tag.
field definition : definition of the part of the xml file corresponding to the field definition.
Accept the same attributes as field tag. Child of context tag.
group : define a group of file or field. Accept the same attributes as file or field.
characteristics. Accepted attributes are description, enable,
file : define the output fileOs
output freq, output level, id, name, name suffix. Child of file definition or group
of files tag.
file definition : definition of the part of the xml file corresponding to the file definition.
Accept the same attributes as file tag. Child of context tag.
axis : definition of the vertical axis. Accepted attributes are description, id, positive, size,
unit. Child of axis definition tag.
axis definition : definition of the part of the xml file corresponding to the vertical axis
definition. Accept the same attributes as axis tag. Child of context tag
grid : definition of the horizontal grid. Accepted attributes are description and id. Child
of axis definition tag.
194
grid definition : definition of the part of the xml file corresponding to the horizontal grid
definition. Accept the same attributes as grid tag. Child of context tag
zoom : definition of a subdomain of an horizontal grid. Accepted attributes are description, id, i/jbegin, ni/j. Child of grid tag.
Attributes list
Applied to a tag or a group of tags.
Another table, perhaps ?
Attribute Applied to ? Definition Comment axis ref field String defining the vertical
axis of the variable. It refers to the id of the vertical axis defined in the axis tag. Use non
if the variable has no vertical axis
axis ref : field attribute. String defining the vertical axis of the variable. It refers to the id
of the vertical axis defined in the axis tag. Use none if the variable has no vertical
axis
description : this attribute can be applied to all tags but it is used only with the field tag.
In this case, the value of description will be used to define, in the output netcdf file,
the attributes long name and standard name of the variable.
enabled : field and file attribute. Logical to switch on/off the output of a field or a file.
freq op : field attribute (automatically defined, see part 1.4 (control of the xml attributes)). An integer defining the frequency in seconds at which NEMO is calling
iom put for this variable. It corresponds to the model time step (rn rdt in the namelist) except for the variables computed at the frequency of the surface boundary
condition (rn rdt ? nn fsbc in the namelist).
grid ref : field attribute. String defining the horizontal grid of the variable. It refers to the
id of the grid tag.
ibegin : zoom attribute. Integer defining the zoom starting point along x direction. Automatically defined for TAO/RAMA/PIRATA moorings (see part 1.4).
id : exists for all tag. This is a string defining the name to a specific tag that will be used
later to refer to this tag. Tags of the same category must have different ids.
jbegin : zoom attribute. Integer defining the zoom starting point along y direction. Automatically defined for TAO/RAMA/PIRATA moorings and equatorial section (see
part 1.4).
level : field attribute. Integer from 0 to 10 defining the output priority of a field. See
output level attribute definition
operation : field attribute. String defining the type of temporal operation to perform on a
variable. Possible choices are ave(X) for temporal mean, inst(X) for instantaneous, t min(X) for temporal min and t max(X) for temporal max.
output freq : file attribute. Integer defining the operation frequency in seconds. For
example 86400 for daily mean.
195
output level : file attribute. Integer from 0 to 10 defining the output priority of variables
in a file : all variables listed in the file with a level smaller or equal to output level
be output even if they are listed in the file.
will be output. Other variables wonOt
positive : axis attribute (always .FALSE.). Logical defining the vertical axis convention
used in NEMO (positive downward). Define the attribute positive of the variable in
the netcdf output file.
prec : field attribute. Integer defining the output precision. Not implemented, we always
output real4 arrays.
name : field or file attribute. String defining the name of a variable or a file. If the name
of a file is undefined, its id is used as a name. 2 files must have different names.
Files with specific ids will have their name automatically defined (see part 1.4).
Note that is name will be automatically completed by the cpu number (if needed)
and .nc
name suffix : file attribute. String defining a suffix to be inserted after the name and
before the cpu number and the .nc termination. Files with specific ids have an
automatic definition of their suffix (see part 1.4).
ni : zoom attribute. Integer defining the zoom extent along x direction. Automatically
defined for equatorial sections (see part 1.4).
nj : zoom attribute. Integer defining the zoom extent along x direction.
ref : field attribute. String referring to the id of the field we want to add in a file.
size : axis attribute. use unknown...
unit : field attribute. String defining the unit of a variable and the associated attribute in
the netcdf output file.
zoom ref : field attribute. String defining the subdomain of data on which the file should
be written (to ouput data only in a limited area). It refers to the id of a zoom defined
in the zoom tag.
11.2.3
IO SERVER
Attached or detached mode ?
Iom put is based on the io server developed by Yann Meurdesoif from IPSL (see here
for the source code or see its copy in NEMOGCM/EXTERNAL directory). This server
can be used in attached mode (as a library) or in detached mode (as an external executable on n cpus). In attached mode, each cpu of NEMO will output its own subdomain.
In detached mode, the io server will gather data from NEMO and output them split over
n files with n the number of cpu dedicated to the io server.
196
using server : logical, switch to use the server in attached or detached mode (.TRUE.
corresponding to detached mode).
using oasis : logical, set to .TRUE. if NEMO is used in coupled mode.
client id = oceanx : character, used only in coupled mode. Specify the id used in
OASIS to refer to NEMO. The same id must be used to refer to NEMO in the $NBMODEL part of OASIS namcouple in the call of prim init comp proto in cpl oasis3f90
server id = ionemo : character, used only in coupled mode. Specify the id used in
OASIS to refer to the IO SERVER when used in detached mode. Use the same id to refer
to the io server in the $NBMODEL part of OASIS namcouple.
global mpi buffer size : integer ; define the size in Mb of the MPI buffer used by the
io server.
11.2.4
Practical issues
Add your own outputs
It is very easy to add you own outputs with iom put. 4 points must be followed.
1- in NEMO code, add a
CALL iom put( identifier, array )
where you want to output a 2D or 3D array.
2- dont forget to add
USE iom ! I/O manager library
in the list of used modules in the upper part of your module.
3- in the file definition part of the xml file, add the definition of your variable using the
same identifier you used in the f90 code.
<field_definition>
...
<field id="identifier" description="blabla" />
...
</field_definition>
attributes axis ref and grid ref must be consistent with the size of the array to
pass to iom put. if your array is computed within the surface module each nn fsbc
time step, add the field definition within the group defined with the id SBC :
<group id=SBC...>
4- add your field in one of the output files
197
You must increase the value of dom max nb in fliocom.f90 (multiply it by 10 for
example).
If you mix, in the same file, variables with different freq op (see definition above), like
for example variables from the surface module with other variables, IOIPSL will print in
the standard output file warning messages saying there may be a bug.
WARNING FROM ROUTINE histvar_seq
--> There were 10 errors in the learned sequence of variables
--> for file
4
--> This looks like a bug, please report it.
11.3
198
be relinked simply with the new libraries and will then read both NetCDF3 and NetCDF4
files. NEMO executables linked with NetCDF4 libraries can be made to produce NetCDF3
files by setting the ln nc4zip logical to false in the namnc4 namelist :
!----------------------------------------------------------------------&namnc4
!
netcdf4 chunking and compression settings
("key_netcdf4")
!----------------------------------------------------------------------nn_nchunks_i=
4
! number of chunks in i-dimension
nn_nchunks_j=
4
! number of chunks in j-dimension
nn_nchunks_k=
31
! number of chunks in k-dimension
! setting nn_nchunks_k = jpk will give a chunk size of 1 in the vertical which
! is optimal for postprocessing which works exclusively with horizontal slabs
ln_nc4zip
= .true.
! (T) use netcdf4 chunking and compression
! (F) ignore chunking information and produce netcdf3-compatible files
/
If key netcdf4 has not been defined, these namelist parameters are not read. In this
case, ln nc4zip is set false and dummy routines for a few NetCDF4-specific functions are
defined. These functions will not be used but need to be included so that compilation is
possible with NetCDF3 libraries.
When using NetCDF4 libraries, key netcdf4 should be defined even if the intention is
to create only NetCDF3-compatible files. This is necessary to avoid duplication between
the dummy routines and the actual routines present in the library. Most compilers will
fail at compile time when faced with such duplication. Thus when linking with NetCDF4
libraries the user must define key netcdf4 and control the type of NetCDF file produced
via the namelist parameter.
Chunking and compression is applied only to 4D fields and there is no advantage
in chunking across more than one time dimension since previously written chunks would
have to be read back and decompressed before being added to. Therefore, user control over
chunk sizes is provided only for the three space dimensions. The user sets an approximate
number of chunks along each spatial axis. The actual size of the chunks will depend on
global domain size for mono-processors or, more likely, the local processor domain size
for distributed processing. The derived values are subject to practical minimum values (to
avoid wastefully small chunk sizes) and cannot be greater than the domain size in any
dimension. The algorithm used is :
ichunksz(1)
ichunksz(2)
ichunksz(3)
ichunksz(4)
=
=
=
=
As an example, setting :
nn_nchunks_i=4, nn_nchunks_j=4 and nn_nchunks_k=31
Filename
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
...
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
ORCA2
restart 0000.nc
restart 0001.nc
restart 0002.nc
restart 0003.nc
restart 0004.nc
restart 0005.nc
restart 0006.nc
restart 0007.nc
2d grid T 0000.nc
2d grid T 0001.nc
2d grid T 0002.nc
2d grid T 0003.nc
2d grid T 0004.nc
2d grid T 0005.nc
2d grid T 0006.nc
2d grid T 0007.nc
2d
2d
2d
2d
2d
2d
2d
2d
grid
grid
grid
grid
grid
grid
grid
grid
W
W
W
W
W
W
W
W
0000.nc
0001.nc
0002.nc
0003.nc
0004.nc
0005.nc
0006.nc
0007.nc
199
TAB . 11.1 Filesize comparison between NetCDF3 and NetCDF4 with chunking
and compression
200
When key iomput is activated with key netcdf4 chunking and compression parameters for fields produced via iom put calls are set via an equivalent and identically named namelist to namnc4 in xmlio server.def . Typically this namelist serves the mean files
whilst the namnc4 in the main namelist file continues to serve the restart files. This duplication is unfortunate but appropriate since, if using io servers, the domain sizes of the
individual files produced by the io server processes may be different to those produced by
the invidual processing regions and different chunking choices may be desired.
11.4
When key trddyn and/or key trddyn CPP variables are defined, each trend of the
dynamics and/or temperature and salinity time evolution equations is stored in threedimensional arrays just after their computation (i.e. at the end of each dyn .F 90 and/or
tra .F 90 routines). These trends are then used in trdmod.F90 (see TRD directory)
every nn trd time-steps.
What is done depends on the CPP keys defined :
key trddyn, key trdtra : a check of the basin averaged properties of the momentum
and/or tracer equations is performed ;
key trdvor : a vertical summation of the moment tendencies is performed, then the curl
is computed to obtain the barotropic vorticity tendencies which are output ;
key trdmld : output of the tracer tendencies averaged vertically either over the mixed
layer (nn ctls=0), or over a fixed number of model levels (nn ctls>1 provides the
number of level), or over a spatially varying but temporally fixed number of levels
(typically the base of the winter mixed layer) read in ctlsurf idx.nc (nn ctls=1) ;
The units in the output file can be changed using the nn ucf namelist parameter.
For example, in case of salinity tendency the units are given by PSU/s/nn ucf . Setting
nn ucf =86400 (i.e. the number of second in a day) provides the tendencies in PSU/d.
When key trdmld is defined, two time averaging procedure are proposed. Setting
ln trdmld instant to true, a simple time averaging is performed, so that the resulting tendency is the contribution to the change of a quantity between the two instantaneous values
taken at the extremities of the time averaging period. Setting ln trdmld instant to false, a
double time averaging is performed, so that the resulting tendency is the contribution to
the change of a quantity between two time mean values. The later option requires the use
of an extra file, restart mld.nc (ln trdmld restart=true), to restart a run.
201
Note that the mixed layer tendency diagnostic can also be used on biogeochemical
models via the key trdtrc and key trdmld trc CPP keys.
11.5
The on-line computation of floats advected either by the three dimensional velocity
field or constraint to remain at a given depth (w = 0 in the computation) have been
introduced in the system during the CLIPPER project. The algorithm used is based either
on the work of Blanke and Raynaud [1997] (default option), or on a 4t h Runge-Hutta
algorithm (ln flork4=true). Note that the Blanke and Raynaud [1997] algorithm have the
advantage of providing trajectories which are consistent with the numeric of the code, so
that the trajectories never intercept the bathymetry.
See also here the web site describing the off-line use of this marvellous diagnostic
tool.
11.6
202
ln_ptrcomp = .true.
nn_fptr
= 1
nn_fwri
= 15
!
!
!
!
(orca configuration only, need input basins mask file named "subbasins.nc"
Add decomposition : overturning
Frequency of ptr computation [time step]
Frequency of ptr outputs [time step]
In addition, a series of diagnostics has been added in the diaar5.F90. They corresponds to outputs that are required for AR5 simulations (see Section ?? below for one of
them). Activating those outputs requires to define the key diaar5 CPP key.
11.7
203
pect to the flow field calculated by the model [Greatbatch 1994], but extra attention is
required when investigating sea level, as steric changes are an important contribution to
local changes in sea level on seasonal and climatic time scales. This is especially true for
investigation into sea level rise due to global warming.
Fortunately, the steric contribution to the sea level consists of a spatially uniform
component that can be diagnosed by considering the mass budget of the world ocean
[Greatbatch 1994]. In order to better understand how global mean sea level evolves and
thus how the steric sea level can be diagnosed, we compare, in the following, the nonBoussinesq and Boussinesq cases.
R
Let denote M the
R total mass of liquid seawater (M = D dv),RV the total volume
of seawater (V = D dv), A the total surface
of the ocean (A = S ds), the global
R
meanRseawater (in situ) density (
= 1/V D dv), and the global mean sea level (
=
1/A S ds).
A non-Boussinesq fluid conserves mass. It satisfies the following relations :
M = V
(11.1)
V = A
Temporal changes in total mass is obtained from the density conservation equation :
1
emp
t (e3 ) + ( U) =
(11.2)
e3
e3 surface
where is the in situ density, and emp the surface mass exchanges with the other media
of the Earth system (atmosphere, sea-ice, land). Its global averaged leads to the total mass
change
t M = A emp
(11.3)
R
where emp = S emp ds is the net mass flux through the ocean surface. Bringing (11.3)
and the time derivative of (11.1) together leads to the evolution equation of the mean sea
level
emp V t
t =
(11.4)
A
The first term in equation (11.4) alters sea level by adding or subtracting mass from the
ocean. The second term arises from temporal changes in the global mean density ; i.e.
from steric effects.
In a Boussinesq fluid, is replaced by o in all the equation except when appears
multiplied by the gravity (i.e. in the hydrostatic balance of the primitive Equations). In
particular, the mass conservation equation, (11.2), degenerates into the incompressibility
equation :
emp
1
t (e3 ) + (U) =
(11.5)
e3
o e3
surface
and the global average of this equation now gives the temporal change of the total volume,
t V = A
emp
o
(11.6)
204
Only the volume is conserved, not mass, or, more precisely, the mass which is conserved
is the Boussinesq mass, Mo = o V. The total volume (or equivalently the global mean
sea level) is altered only by net volume fluxes across the ocean surface, not by changes in
mean mass of the ocean : the steric effect is missing in a Boussinesq fluid.
Nevertheless, following [Greatbatch 1994], the steric effect on the volume can be
diagnosed by considering the mass budget of the ocean. The apparent changes in M,
mass of the ocean, which are not induced by surface mass flux must be compensated by a
spatially uniform change in the mean sea level due to expansion/contraction of the ocean
[Greatbatch 1994]. In others words, the Boussinesq mass, Mo , can be related to M, the
total mass of the ocean seen by the Boussinesq model, via the steric contribution to the
sea level, s , a spatially uniform variable, as follows :
Mo = M + o s A
(11.7)
Any change in M which cannot be explained by the net mass flux through the ocean
surface
R is converted into a mean change in sea level. Introducing the total density anomaly,
D = D da dv, where da = ( o )/o is the density anomaly used in NEMO (cf. 5.8.1)
in (11.7) leads to a very simple form for the steric height :
s =
1
D
A
(11.8)
The above formulation of the steric height of a Boussinesq ocean requires four remarks. First, one can be tempted to define o as the initial value of M/V, i.e. set Dt=0 =
0, so that the initial steric height is zero. We do not recommend that. Indeed, in this case
o depends on the initial state of the ocean. Since o has a direct effect on the dynamics
of the ocean (it appears in the pressure gradient term of the momentum equation) it is
definitively not a good idea when inter-comparing experiments. We better recommend to
fixe once for all o to 1035 Kg m3 . This value is a sensible choice for the reference density used in a Boussinesq ocean climate model since, with the exception of only a small
percentage of the ocean, density in the World Ocean varies by no more than 2% from this
value (Gill [1982], page 47).
Second, we have assumed here that the total ocean surface, A, does not change when
the sea level is changing as it is the case in all global ocean GCMs (wetting and drying of
grid point is not allowed).
Third, the discretisation of (11.8) depends on the type of free surface which is considered. In the non linear free surface case, i.e. key vvl defined, it is given by
P
i, j, k da e1t e2t e3t
s = P
(11.9)
i, j, k e1t e2t e3t
whereas in the linear free surface, the volume above the z=0 surface must be explicitly
taken into account to better approximate the total ocean mass and thus the steric sea level :
P
P
da e1t e2t
i, j, k da e1t e2t e3t +
Pi, j
s = P
(11.10)
i, j, k e1t e2t e3t +
i, j e1t e2t
205
The fourth and last remark concerns the effective sea level and the presence of seaice. In the real ocean, sea ice (and snow above it) depresses the liquid seawater through its
mass loading. This depression is a result of the mass of sea ice/snow system acting on the
liquid ocean. There is, however, no dynamical effect associated with these depressions
in the liquid ocean sea level, so that there are no associated ocean currents. Hence, the
dynamically relevant sea level is the effective sea level, i.e. the sea level as if sea ice (and
snow) were converted to liquid seawater [Campin et al. 2008]. However, in the current
version of NEMO the sea-ice is levitating above the ocean without mass exchanges between ice and ocean. Therefore the model effective sea level is always given by + s ,
whether or not there is sea ice present.
In AR5 outputs, the thermosteric sea level is demanded. It is steric sea level due to
changes in ocean density arising just from changes in temperature. It is given by :
Z
1
s =
da (T, So , po ) dv
(11.11)
A D
where So and po are the initial salinity and pressure, respectively.
Both steric and thermosteric sea level are computed in diaar5.F90 which needs the
key diaar5 defined to be called.
Contents
12.1 Running the observation operator code example . . . . . . 208
12.2 Technical details . . . . . . . . . . . . . . . . . . . . . . . . 210
12.2.1 Profile feedback type observation file header . . . . . 211
12.2.2 Sea level anomaly feedback type observation file header 213
12.2.3 Sea surface temperature feedback type observation file
header . . . . . . . . . . . . . . . . . . . . . . . . . . 214
12.3 Theoretical details . . . . . . . . . . . . . . . . . . . . . . . 216
12.3.1 Horizontal interpolation methods . . . . . . . . . . . 216
12.3.2 Grid search . . . . . . . . . . . . . . . . . . . . . . . 217
12.3.3 Parallel aspects of horizontal interpolation . . . . . . . 218
12.3.4 Vertical interpolation operator . . . . . . . . . . . . . 221
208
The observation and model comparison code (OBS) reads in observation files (profile
temperature and salinity, sea surface temperature, sea level anomaly, sea ice concentration,
and velocity) and calculates an interpolated model equivalent value at the observation
location and nearest model timestep. The OBS code is called from opa.F90 in order to
initialise the model and to calculate the model equivalent values for observations on the
0th timestep. The code is then called again after each timestep from step.F90. The code
was originally developed for use with NEMOVAR.
For all data types a 2D horizontal interpolator is needed to interpolate the model
fields to the observation location. For in situ profiles, a 1D vertical interpolator is needed
in addition to provide model fields at the observation depths. Currently this only works in
z-level model configurations, but is being developed to work with a generalised vertical
coordinate system. Temperature data from moored buoys (TAO, TRITON, PIRATA) in
the ENACT/ENSEMBLES data-base are available as daily averaged quantities. For this
type of observation the observation operator will compare such observations to the model
temperature fields averaged over one day. The relevant observation type may be specified
in the namelist using endailyavtypes. Otherwise the model value from the nearest timestep
to the observation time is used.
The resulting data are saved in a feedback file (or files) which can be used for model
validation and verification and also to provide information for data assimilation. This code
is controlled by the namelist nam obs. To build with the OBS code active key diaobs must
be set.
Section 12.1 introduces a test example of the observation operator code including
where to obtain data and how to setup the namelist. Section 12.2 introduces some more
technical details of the different observation types used and also shows a more complete
namelist. Finally section 12.3 introduces some of the theoretical aspects of the observation
operator including interpolation methods and running on multiple processors.
12.1
209
!----------------------------------------------------------------------!
namobs
observation usage switch
!----------------------------------------------------------------------!
! ln_t3d
Logical switch for T profile observations
! ln_s3d
Logical switch for S profile observations
! ln_ena
Logical switch for ENACT insitu data set
! ln_cor
Logical switch for Coriolis insitu data set
! ln_profb
Logical switch for feedback insitu data set
! ln_sla
Logical switch for SLA observations
! ln_sladt
Logical switch for AVISO SLA data
! ln_slafb
Logical switch for feedback SLA data
! ln_ssh
Logical switch for SSH observations
! ln_sst
Logical switch for SST observations
! ln_reysst
Logical switch for Reynolds observations
! ln_ghrsst
Logical switch for GHRSST observations
! ln_sstfb
Logical switch for feedback SST data
! ln_sss
Logical switch for SSS observations
! ln_seaice
Logical switch for Sea Ice observations
! ln_vel3d
Logical switch for velocity observations
! ln_velavcur
Logical switch for velocity daily av. cur.
! ln_velhrcur
Logical switch for velocity high freq. cur.
! ln_velavadcp
Logical switch for velocity daily av. ADCP
! ln_velhradcp
Logical switch for velocity high freq. ADCP
! ln_velfb
Logical switch for feedback velocity data
! ln_grid_global
Global distribtion of observations
! ln_grid_search_lookup
Logical switch for obs grid search w/lookup table
! grid_search_file
Grid search lookup file header
! enactfiles
ENACT input observation file names
! coriofiles
Coriolis input observation file name
! profbfiles
Profile feedback input observation file name
! ln_profb_enatim
Enact feedback input time setting switch
! slafilesact
Active SLA input observation file name
! slafilespas
Passive SLA input observation file name
! slafbfiles
Feedback SLA input observation file name
! sstfiles
GHRSST input observation file name
! sstfbfiles
Feedback SST input observation file name
! seaicefiles
Sea Ice input observation file name
! velavcurfiles
Vel. cur. daily av. input file name
! velhvcurfiles
Vel. cur. high freq. input file name
! velavadcpfiles
Vel. ADCP daily av. input file name
! velhvadcpfiles
Vel. ADCP high freq. input file name
! velfbfiles
Vel. feedback input observation file name
! dobsini
Initial date in window YYYYMMDD.HHMMSS
! dobsend
Final date in window YYYYMMDD.HHMMSS
! n1dint
Type of vertical interpolation method
! n2dint
Type of horizontal interpolation method
! ln_nea
Rejection of observations near land switch
! nmsshc
MSSH correction scheme
! mdtcorr
MDT correction
! mdtcutoff
MDT cutoff for computed correction
! ln_altbias
Logical switch for alt bias
! ln_ignmis
Logical switch for ignoring missing files
! endailyavtypes
ENACT daily average types
&namobs
ln_t3d = .true.
ln_s3d = .true.
ln_ena = .true.
enactfiles = profiles_01.nc
ln_grid_global = .true.
ln_grid_search_lookup = .true.
ln_ignmis = .true.
/
The option ln t3d and ln s3d switch on the temperature and salinity profile observation operator code. The ln ena switch turns on the reading of ENACT/ENSEMBLES type
profile data. The filename or array of filenames are specified using the enactfiles variable.
The model grid points for a particular observation latitude and longitude are found using
the grid searching part of the code. This can be expensive, particularly for large numbers
of observations, setting ln grid search lookup allows the use of a lookup table which is
saved into an xypos file (or files). This will need to be generated the first time if it does
not exist in the run directory. However, once produced it will significantly speed up future grid searches. Setting ln grid global means that the code distributes the observations
evenly between processors. Alternatively each processor will work with observations located within the model subdomain.
210
The NEMOVAR system contains utilities to plot the feedback files, convert and recombine the files. These are available on request from the NEMOVAR team.
12.2
Technical details
Here we show a more complete example namelist and also show the NetCDF headers
of the observation files that may be used with the observation operator
!----------------------------------------------------------------------&namobs
! observation usage switch
(key_diaobs)
!----------------------------------------------------------------------ln_t3d
= .false.
! Logical switch for T profile observations
ln_s3d
= .false.
! Logical switch for S profile observations
ln_ena
= .false.
! Logical switch for ENACT insitu data set
!
!
ln_cor
Logical switch for Coriolis insitu data set
ln_profb
= .false.
! Logical switch for feedback insitu data set
ln_sla
= .false.
! Logical switch for SLA observations
ln_sladt
= .false.
ln_slafb
= .false.
ln_sst
= .false.
ln_sstfb
= .false.
This name list uses the feedback type observation file input format for profile, sea level anomaly and sea surface temperature data. All the observation files must be in NetCDF
211
format. Some example headers (produced using ncdump -h) for profile data, sea level anomaly and sea surface temperature are in the following subsections.
12.2.1
212
12.2.2
213
214
The mean dynamic topography (MDT) must be provided in a separate file defined
on the model grid called slaReferenceLevel.nc. The MDT is required in order to produce
the model equivalent sea level anomaly from the model sea surface height. Below is an
example header for this file (on the ORCA025 grid).
dimensions:
x = 1442 ;
y = 1021 ;
variables:
float nav_lon(y, x) ;
nav_lon:units = "degrees_east" ;
float nav_lat(y, x) ;
nav_lat:units = "degrees_north" ;
float sossheig(y, x) ;
sossheig:_FillValue = -1.e+30f ;
sossheig:coordinates = "nav_lon nav_lat" ;
sossheig:long_name = "Mean Dynamic Topography" ;
sossheig:units = "metres" ;
sossheig:grid = "orca025T" ;
12.2.3
215
216
SST_QC_FLAGS:_Fillvalue = 0 ;
int SST_LEVEL_QC(N_OBS, N_LEVELS) ;
SST_LEVEL_QC:long_name = "Quality for each level on sea surface temperature" ;
SST_LEVEL_QC:Conventions = "q where q =[0,9]" ;
SST_LEVEL_QC:_Fillvalue = 0 ;
int SST_LEVEL_QC_FLAGS(N_OBS, N_LEVELS, N_QCF) ;
SST_LEVEL_QC_FLAGS:long_name = "Quality flags for each level on sea surface temperature" ;
SST_LEVEL_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
SST_LEVEL_QC_FLAGS:_Fillvalue = 0 ;
int SST_IOBSI(N_OBS) ;
SST_IOBSI:long_name = "ORCA grid search I coordinate" ;
int SST_IOBSJ(N_OBS) ;
SST_IOBSJ:long_name = "ORCA grid search J coordinate" ;
int SST_IOBSK(N_OBS, N_LEVELS) ;
SST_IOBSK:long_name = "ORCA grid search K coordinate" ;
char SST_GRID(STRINGGRID) ;
SST_GRID:long_name = "ORCA grid search grid (T,U,V)" ;
// global attributes:
:title = "NEMO observation operator output" ;
:Convention = "NEMO unified observation operator output" ;
}
12.3
Theoretical details
12.3.1
1
(w x + w B x B + w C x C + w D x D )
w A A
(12.1)
where w A , w B etc. are the respective weights for the model field at points A, B etc., and
w = wA + wB + wC + wD.
Four different possibilities are available for computing the weights.
1. Great-Circle distance-weighted interpolation. The weights are computed as a
function of the great-circle distance s(P, ) between P and the model grid points
A, B etc. For example, the weight given to the field x A is specified as the product
of the distances from P to the other points :
w A = s(P, B) s(P, C) s(P, D)
where
s (P, M) = cos1 {sin P sin M + cos P cos M cos( M P )} (12.2)
and M corresponds to B, C or D. A more stable form of the great-circle distance
formula for small distances (x near 1) involves the arcsine function (e.g. see p. 101
of Daley and Barker [2001] :
np
o
s (P, M) = sin1
1 x2
217
where
x = aMaP + bMbP + cMcP
and
a M = sin M ,
a P = sin P ,
b M = cos M cos M ,
b P = cos P cos P ,
c M = cos M sin M ,
c P = cos P sin P .
2. Great-Circle distance-weighted interpolation with small angle approximation.
Similar to the previous interpolation but with the distance s computed as
q
(12.3)
s (P, M) = ( M P )2 + ( M P )2 cos2 M
where M corresponds to A, B, C or D.
3. Bilinear interpolation for a regular spaced grid. The interpolation is split into
two 1D interpolations in the longitude and latitude directions, respectively.
4. Bilinear remapping interpolation for a general grid. An iterative scheme that
involves first mapping a quadrilateral cell into a cell with coordinates (0,0), (1,0),
(0,1) and (1,1). This method is based on the SCRIP interpolation package [Jones
1998].
12.3.2
Grid search
For many grids used by the NEMO model, such as the ORCA family, the horizontal
grid coordinates i and j are not simple functions of latitude and longitude. Therefore, it
is not always straightforward to determine the grid points surrounding any given observational position. Before the interpolation can be performed, a search algorithm is then
required to determine the corner points of the quadrilateral cell in which the observation is
located. This is the most difficult and time consuming part of the 2D interpolation procedure. A robust test for determining if an observation falls within a given quadrilateral cell
is as follows. Let P( P , P ) denote the observation point, and let A( A , A ), B( B , B ),
C( C , C ) and D( D , D ) denote the bottom left, bottom right, top left and top right corner points of the cell, respectively. To determine if P is inside the cell, we verify that the
cross-products
r PA r PC
r PB r PA
r PC r PD
r PD r PB
=
=
=
=
[( A
[( B
[( C
[( D
P )( C
P )( A
P )( D
P )( B
P ) ( C
P ) ( A
P ) ( D
P ) ( B
P )( A
P )( B
P )( C
P )( D
b
P )] k
b
P )] k
b
P )] k
b
P )] k
(12.4)
218
12.3.3
20E
40E
60E
80E
219
100E
120E
140E
160E
180E
200E
220E
240E
260E
280E
300E
320E
340E
80N
80N
70N
70N
60N
60N
50N
50N
40N
40N
30N
30N
20N
20N
10N
10N
0N
0N
10S
10S
20S
20S
30S
30S
40S
40S
50S
50S
60S
60S
70S
70S
80S
80S
20E
40E
60E
80E
Magics++ 2.4.1 - cranmer - ne1 - Mon Mar 3 14:05:09 2008
100E
120E
140E
160E
180E
200E
220E
240E
260E
280E
300E
320E
340E
220
20E
40E
60E
80E
100E
120E
140E
160E
180E
200E
220E
240E
260E
280E
300E
320E
340E
80N
80N
70N
70N
60N
60N
50N
50N
40N
40N
30N
30N
20N
20N
10N
10N
0N
0N
10S
10S
20S
20S
30S
30S
40S
40S
50S
50S
60S
60S
70S
70S
80S
80S
20E
40E
60E
80E
Magics++ 2.4.1 - cranmer - ne1 - Mon Mar 3 14:08:38 2008
100E
120E
140E
160E
180E
200E
220E
240E
260E
280E
300E
320E
340E
221
decomposition with ORCA2 for the same input data as in Fig. 12.1. The observations are
now clearly randomly distributed on the globe. In order to be able to perform horizontal
interpolation in this case, a subroutine has been developed that retrieves any grid points in
the global space.
12.3.4
Contents
13.1 Direct initialization . . . . . . . . . . . . . . . . . . . . . . 224
13.2 Incremental Analysis Updates . . . . . . . . . . . . . . . . 224
13.3 Implementation details . . . . . . . . . . . . . . . . . . . . 225
224
The ASM code adds the functionality to apply increments to the model variables :
temperature, salinity, sea surface height, velocity and sea ice concentration. These are read
into the model from a NetCDF file which may be produced by data assimilation. The code
can also output model background fields which are used as an input to data assimilation
code. This is all controlled by the namelist nam asminc. There is a brief description of all
the namelist options provided. To build the ASM code key asminc must be set.
13.1
Direct initialization
Direct initialization (DI) refers to the instantaneous correction of the model background state using the analysis increment. DI is used when ln asmdin is set to true.
13.2
(13.1)
Fi
0
1/M
=
if ti < tm
if tm < ti tn
if ti > tn
(13.2)
where M = m n. The second function employs peaked hat-like weights in order to give
maximum weight in the centre of the sub-window, with the weighting reduced linearly to
i
(2)
Fi =
(M i + 1)
225
if
if
if
if
ti < tm
tm ti tM/2
tM/2 < ti tn
ti > tn
(13.3)
PM/2
where 1 = i=1 2i and M is assumed to be even. The weights described by (13.3)
provide a smoother transition of the analysis trajectory from one assimilation cycle to the
next than that described by (13.2).
13.3
Implementation details
Here we show an example namelist and the header of an example assimilation increments file on the ORCA2 grid.
!----------------------------------------------------------------------&nam_asminc
!
assimilation increments
(key_asminc)
!----------------------------------------------------------------------ln_bkgwri = .false.
! Logical switch for writing out background state
ln_trjwri = .false.
! Logical switch for writing out state trajectory
ln_trainc = .false.
! Logical switch for applying tracer increments
ln_dyninc = .false.
! Logical switch for applying velocity increments
ln_sshinc = .false.
! Logical switch for applying SSH increments
ln_asmdin = .false.
! Logical switch for Direct Initialization (DI)
ln_asmiau = .false.
! Logical switch for Incremental Analysis Updating (IAU)
nitbkg
= 0
! Timestep of background in [0,nitend-nit000-1]
nitdin
= 0
! Timestep of background for DI in [0,nitend-nit000-1]
nitiaustr = 1
! Timestep of start of IAU interval in [0,nitend-nit000-1]
nitiaufin = 15
! Timestep of end of IAU interval in [0,nitend-nit000-1]
niaufn
= 0
! Type of IAU weighting function
nittrjfrq = 0
! Frequency of trajectory output for 4D-VAR
ln_salfix = .false.
! Logical switch for ensuring that the sa > salfixmin
salfixmin = -9999
! Minimum salinity after applying the increments
/
The header of an assimilation increments file produced using the NetCDF tool ncdump -h
is shown below
netcdf assim_background_increments {
dimensions:
x = 182 ;
y = 149 ;
z = 31 ;
t = UNLIMITED ; // (1 currently)
variables:
float nav_lon(y, x) ;
float nav_lat(y, x) ;
float nav_lev(z) ;
double time_counter(t) ;
double time ;
double z_inc_dateb ;
double z_inc_datef ;
double bckint(t, z, y, x) ;
double bckins(t, z, y, x) ;
double bckinu(t, z, y, x) ;
double bckinv(t, z, y, x) ;
double bckineta(t, y, x) ;
// global attributes:
:DOMAIN_number_total = 1 ;
:DOMAIN_number = 0 ;
:DOMAIN_dimensions_ids = 1, 2 ;
:DOMAIN_size_global = 182, 149 ;
226
14 Miscellaneous Topics
Contents
14.1 Representation of Unresolved Straits . . . . . . . . . . . . 228
14.1.1 Hand made geometry changes . . . . . . . . . . . . . 228
14.1.2 Cross Land Advection (tracla.F90) . . . . . . . . . . 228
14.2 Closed seas (closea.F90) . . . . . . . . . . . . . . . . . . . . 230
14.3 Sub-Domain Functionality (jpizoom, jpjzoom) . . . . . . . . 230
14.4 Accelerating the Convergence (nn acc = 1) . . . . . . . . . 230
14.5 Accuracy and Reproducibility (lib fortran.F90) . . . . . . . 232
14.5.1 Issues with intrinsinc SIGN function (key nosignedzero)232
14.5.2 MPP reproducibility . . . . . . . . . . . . . . . . . . 233
14.6 Model Optimisation, Control Print and Benchmark . . . . 233
14.7 Elliptic solvers (SOL) . . . . . . . . . . . . . . . . . . . . . 234
14.7.1 Successive Over Relaxation (nn solv=2, solsor.F90) . 235
14.7.2 Preconditioned Conjugate Gradient (nn solv=1, solpcg.F90)
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 237
228
14.1
Miscellaneous Topics
14.1.1
14.1.2
229
38oN
36oN
34oN
10oW
8oW
6oW
4oW
2oW
0o
38oN
36oN
Viscous Boundary
layer
34oN
10oW
8oW
6oW
4oW
2oW
0o
230
Miscellaneous Topics
Add a short description of CLA staff here or in lateral boundary condition chapter ?
14.2
14.3
14.4
jpjdta
231
input data
domain
jpjglo
model
domain
jpjzoom
1
jpiglo
jpizoom
jpidta
F IG . 14.2 Position of a model domain compared to the data input domain when
the zoom functionality is used.
rn_atfp
nn_acc
=
=
0.1
0
rn_rdtmin
rn_rdtmax
rn_rdth
= 28800.
= 28800.
= 800.
!
!
Searching an equilibrium state with an global ocean model requires a very long time
integration period (a few thousand years for a global model). Due to the size of the time
step required for numerical stability (less than a few hours), this usually requires a large
elapsed time. In order to overcome this problem, Bryan [1984] introduces a technique
that is intended to accelerate the spin up to equilibrium. It uses a larger time step in the
tracer evolution equations than in the momentum evolution equations. It does not affect
the equilibrium solution but modifies the trajectory to reach it.
The acceleration of convergence option is used when nn acc=1. In that case, t =
f = rdttra is the tracer time-step. the former
rn rdt is the time step of dynamics while t
is set from the rn rdt namelist parameter while the latter is computed using a hyperbolic
tangent profile and the following namelist parameters : rn rdtmin, rn rdtmax and rn rdth.
Those three parameters correspond to the surface value the deep ocean value and the
depth at which the transition occurs, respectively. The set of prognostic equations to solve
232
Miscellaneous Topics
becomes :
Ut+1 Ut1
Uh
h
h
= ...
t
2t
T
T t+1 T t1
= ...
f
t
2t
S
S t+1 S t1
= ...
f
t
2t
(14.1)
Bryan [1984] has examined the consequences of this distorted physics. Free waves
have a slower phase speed, their meridional structure is slightly modified, and the growth
rate of baroclinically unstable waves is reduced but with a wider range of instability. This
technique is efficient for searching for an equilibrium state in coarse resolution models.
However its application is not suitable for many oceanic problems : it cannot be used
for transient or time evolving problems (in particular, it is very questionable to use this
technique when there is a seasonal cycle in the forcing fields), and it cannot be used in
high-resolution models where baroclinically unstable processes are important. Moreover,
f implies that the heat and salt contents are no longer conserthe vertical variation of t
ved due to the vertical coupling of the ocean level through both advection and diffusion.
Therefore rn rdtmin = rn rdtmax should be a more clever choice.
14.5
14.5.1
14.5.2
233
MPP reproducibility
The numerical reproducibility of simulations on distributed memory parallel computers is a critical issue. In particular, within NEMO global summation of distributed arrays
is most susceptible to rounding errors, and their propagation and accumulation cause uncertainty in final simulation reproducibility on different numbers of processors. To avoid
so, based on He and Ding [2001] review of different technics, we use a so called selfcompensated summation method. The idea is to estimate the roundoff error, store it in a
buffer, and then add it back in the next addition.
Suppose we need to calculate b = a1 + a2 + a3 . The following algorithm will allow
to split the sum in two (sum1 = a1 + a2 and b = sum2 = sum1 + a3 ) with exactly the
same rounding errors as the sum performed all at once.
sum1 = a1 + a2
error1 = a2 + (a1 sum1 )
sum2 = sum1 + a3 + error1
error2 = a3 + error1 + (sum1 sum2 )
b
= sum2
This feature can be found in lib fortran.F90 module and is effective when key mpp rep.
In that case, all calls to glob sum function (summation over the entire basin excluding
duplicated rows and columns due to cyclic or north fold boundary condition as well as
overlap MPP areas). Note this implementation may be sensitive to the optimization level.
14.6
Vector optimisation :
key vectopt loop enables the internal loops to collapse. This is very a very efficient
way to increase the length of vector calculations and thus to speed up the model on vector
computers.
Control print
1- ln ctl : compute and print the trends averaged over the interior domain in all TRA,
DYN, LDF and ZDF modules. This option is very helpful when diagnosing the origin of
an undesired change in model results.
234
Miscellaneous Topics
2- also ln ctl but using the nictl and njctl namelist parameters to check the source of
differences between mono and multi processor runs.
3- key esopa (to be rename key nemo) : which is another option for model management. When defined, this key forces the activation of all options and CPP keys. For
example, all tracer and momentum advection schemes are called ! Therefore the model
results have no physical meaning. However, this option forces both the compiler and the
model to run through all the F ORTRAN lines of the model. This allows the user to check
for obvious compilation or execution errors with all CPP options, and errors in namelist
options.
4- last digit comparison (nn bit cmp). In an MPP simulation, the computation of a
sum over the whole domain is performed as the summation over all processors of each
of their sums over their interior domains. This double sum never gives exactly the same
result as a single sum over the whole domain, due to truncation differences. The bit
comparison option has been introduced in order to be able to check that mono-processor
and multi-processor runs give exactly the same results.
Benchmark (nn bench). This option defines a benchmark run based on a GYRE
configuration (see ??) in which the resolution remains the same whatever the domain
size. This allows a very large model domain to be used, just by changing the domain size
(jpiglo, jpjglo) and without adjusting either the time-step or the physical parameterisations.
14.7
When the filtered sea surface height option is used, the surface pressure gradient is
computed in dynspg flt.F90. The force added in the momentum equation is solved implicitely. It is thus solution of an elliptic equation (2.6) for which two solvers are available :
a Successive-Over-Relaxation scheme (SOR) and a preconditioned conjugate gradient
scheme(PCG) [Madec et al. 1988, Madec 1990]. The solver is selected trough the the
value of nn solv (namelist parameter).
The PCG is a very efficient method for solving elliptic equations on vector computers.
It is a fast and rather easy method to use ; which are attractive features for a large number
of ocean situations (variable bottom topography, complex coastal geometry, variable grid
spacing, open or cyclic boundaries, etc ...). It does not require a search for an optimal
parameter as in the SOR method. However, the SOR has been retained because it is a
linear solver, which is a very useful property when using the adjoint model of NEMO .
235
At each time step, the time derivative of the sea surface height at time step t + 1 (or
equivalently the divergence of the after barotropic transport) that appears in the filtering
forced is the solution of the elliptic equation obtained from the horizontal divergence of
the vertical summation of (2.6). Introducing the following coefficients :
Hv (i, j) e1v (i, j)
e2v (i, j)
H
(i,
j) e2u (i, j)
u
= 2t2
e1u (i, j)
= i [e2u Mu ] j [e1v Mv ] ,
S
cN
i,j
= 2t2
cEW
i,j
bi,j
(14.2)
(14.3)
(14.3) is a linear symmetric system of equations. All the elements of the corresponding
matrix A vanish except those of five diagonals. With the natural ordering of the grid points
(i.e. from west to east and from south to north), the structure of A is block-tridiagonal with
tridiagonal or diagonal blocks. A is a positive-definite symmetric matrix of size (jpi
jpj)2 , and B, the right hand side of (14.3), is a vector.
Note that in the linear free surface case, the depth that appears in (14.2) does not vary
with time, and thus the matrix can be computed once for all. In non-linear free surface
(key vvl defined) the matrix have to be updated at each time step.
14.7.1
EW
aW
i,j = ci,j /di,j
EW
aE
i,j = ci,j+1 /di,j
NS
aN
i,j = ci+1,j /di,j
S
NS
EW
EW
where di,j = cN
i,j + ci+1,j + ci,j + ci,j+1 (i.e. the diagonal of the matrix). (14.3) can be
rewritten as :
E
S
W
aN
i,j Di+1,j + ai,j Di,j+1 + ai,j Di1,j + ai,j Di,j1 Di,j = bi,j
(14.4)
with bi,j = bi,j /di,j . (14.4) is the equation actually solved with the SOR method. This
method used is an iterative one. Its algorithm can be summarised as follows (see Haltiner
and Williams [1980] for a further discussion) :
initialisation (evaluate a first guess from previous time step computations)
t1
0
t
Di,j
= 2 Di,j
Di,j
(14.5)
236
Miscellaneous Topics
Ri,j
=aN
i,j Di+1,j + ai,j Di,j+1 + ai,j Di1,j + ai,j Di,j1 Di,j bi,j
n+1
n
n
Di,j
=Di,j
+ Ri,j
(14.6)
= P n n
b b
i,j i,j
(14.7)
i,j
where is the absolute precision that is required. It is recommended that a value smaller
or equal to 106 is used for since larger values may lead to numerically induced basin
scale barotropic oscillations. The precision is specified by setting rn eps (namelist parameter). In addition, two other tests are used to halt the iterative algorithm. They involve
the number of iterations and the modulus of the right hand side. If the former exceeds
a specified value, nn max (namelist parameter), or the latter is greater than 1015 , the
whole model computation is stopped and the last computed time step fields are saved in a
abort.nc NetCDF file. In both cases, this usually indicates that there is something wrong
in the model configuration (an error in the mesh, the initial state, the input forcing, or the
magnitude of the time step or of the mixing coefficients). A typical value of nn max is
a few hundred when = 106 , increasing to a few thousand when = 1012 . The vectorization of the SOR algorithm is not straightforward. The scheme contains two linear
recurrences on i and j. This inhibits the vectorisation. (14.6) can be been rewritten as :
n
n
E
n
S
n
Ri,j
=aN
i,j Di+1,j + ai,j Di,j+1 + ai,j Di1,j +
n
n
n
Ri,j
=Ri,j
aSi,j Ri,j1
W n
i,j Di,j1
n
Di,j
bi,j
(14.8)
n
n
n
Ri,j
=Ri,j
aW
i,j Ri1,j
This technique slightly increases the number of iteration required to reach the convergence, but this is largely compensated by the gain obtained by the suppression of the
recurrences.
Another technique have been chosen, the so-called red-black SOR. It consist in solving successively (14.6) for odd and even grid points. It also slightly reduced the convergence rate but allows the vectorisation. In addition, and this is the reason why it has been
chosen, it is able to handle the north fold boundary condition used in ORCA configuration
(i.e. tri-polar global ocean mesh).
The SOR method is very flexible and can be used under a wide range of conditions,
including irregular boundaries, interior boundary points, etc. Proofs of convergence, etc.
may be found in the standard numerical methods texts for partial differential equations.
14.7.2
237
where h, i is the canonical dot product. The idea of the conjugate gradient method is to
search for the solution in the following iterative way : assuming that xn has been obtained,
xn+1 is found from xn+1 = xn + n dn which satisfies :
xn+1 = inf y= xn +n
dn
( y)
d
=0
d
and expressing (y) as a function of , we obtain the value that minimises the functional :
n = hrn , rn i/h A dn , dn i
where rn = b A xn = A(x xn ) is the error at rank n. The descent vector dn s chosen
to be dependent on the error : dn = rn + n dn1 . n is searched such that the descent
vectors form an orthogonal basis for the dot product linked to A. Expressing the condition
hA dn , dn1 i = 0 the value of n is found : n = hrn , rn i/hrn1 , rn1 i. As a result, the
errors rn form an orthogonal base for the canonic dot product while the descent vectors
dn form an orthogonal base for the dot product linked to A. The resulting algorithm is
thus the following one :
initialisation :
t1
0
t
x0 = Di,j
= 2Di,j
Di,j
0
r =d =bAx
0 = hr0 , r0 i
iteration n, from n = 0 until convergence, do :
zn = A dn
n = n /hzn , dn i
xn+1 = xn + n dn
rn+1 = rn n zn
n+1
n+1 = hr
n+1
,r
(14.9)
i
n+1 = n+1 /n
dn+1 = rn+1 + n+1 dn
The convergence test is :
= n /hb, bi
(14.10)
where is the absolute precision that is required. As for the SOR algorithm, the whole
model computation is stopped when the number of iterations, nn max, or the modulus of
238
Miscellaneous Topics
the right hand side of the convergence equation exceeds a specified value (see 14.7.1
for a further discussion). The required precision and the maximum number of iterations
allowed are specified by setting rn eps and nn max (namelist parameters).
It can be demonstrated that the above algorithm is optimal, provides the exact solution in a number of iterations equal to the size of the matrix, and that the convergence
rate is faster as the matrix is closer to the identity matrix, i.e. its eigenvalues are closer
to 1. Therefore, it is more efficient to solve a better conditioned system which has the
same solution. For that purpose, we introduce a preconditioning matrix Q which is an
approximation of A but much easier to invert than A, and solve the system :
Q1 A x = Q1 b
(14.11)
The same algorithm can be used to solve (14.11) if instead of the canonical dot product
= Q1 A are
the following one is used : ha, biQ = ha, Q bi, and if b = Q1 b and A
substituted to b and A [Madec et al. 1988]. In NEMO , Q is chosen as the diagonal of
A, i.e. the simplest form for Q so that it can be easily inverted. In this case, the discrete
formulation of (14.11) is in fact given by (14.4) and thus the matrix and right hand side
are computed independently from the solver used.
15 Configurations
Contents
15.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . 240
15.2 Water column model : 1D model (C1D) (key c1d) . . . . . 240
15.3 ORCA family : global ocean with tripolar grid (key orca rX)241
15.3.1 ORCA tripolar grid . . . . . . . . . . . . . . . . . . . 242
15.3.2 ORCA pre-defined resolution . . . . . . . . . . . . . 242
15.4 GYRE family : double gyre basin (key gyre) . . . . . . . . 244
15.5 EEL family : periodic channel . . . . . . . . . . . . . . . . 245
15.6 POMME : mid-latitude sub-domain . . . . . . . . . . . . . 246
240
15.1
Configurations
Introduction
The purpose of this part of the manual is to introduce the NEMO predefined configuration. These configurations are offered as means to explore various numerical and physical
options, thus allowing the user to verify that the code is performing in a manner consistent
with that we are running. This form of verification is critical as one adopts the code for his
or her particular research purposes. The test cases also provide a sense for some of the options available in the code, though by no means are all options exercised in the predefined
configurations.
15.2
15.3. ORCA family : global ocean with tripolar grid (key orca rX)
241
20oN
embedded ellipses
computed normals
geographic mesh
F IG . 15.1 ORCA mesh conception. The departure from an isotropic Mercator grid start poleward of 20N. The two north pole are the foci of a series of
embedded ellipses (blue curves) which are determined analytically and form the
i-lines of the ORCA mesh (pseudo latitudes). Then, following Madec and Imbard
[1996], the normal to the series of ellipses (red curves) is computed which provide
the j-lines of the mesh (pseudo longitudes).
15.3
ORCA family : global ocean with tripolar grid (key orca rX)
The ORCA family is a series of global ocean configurations that are run together with
the LIM sea-ice model (ORCA-LIM) and possibly with PISCES biogeochemical model
(ORCA-LIM-PISCES), using various resolutions.
242
Configurations
CPP key
key orca
key orca
key orca
key orca
key orca
r4
r2
r1
r05
r025
jp cfg
4
2
1
05
025
jpiglo
92
182
362
722
1442
jpiglo
76
149
292
511
1021
TAB . 15.1 Set of predefined parameters for ORCA family configurations. In all
cases, the name of the configuration is set to orca (i.e. cp cfg = orca).
15.3.1
15.3.2
15.3. ORCA family : global ocean with tripolar grid (key orca rX)
e1
e2
50
40
50
243
40
30
20
20
30
C.I.= 2.5 km
e1 / e2
1.2
1.0
1.0
1.2
20 oN
C.I. = 0.05
F IG . 15.2 Top : Horizontal scale factors (e1 , e2 ) and Bottom : ratio of anisotropy
(e1 /e2 ) for ORCA 0.5 mesh. South of 20N a Mercator grid is used (e1 = e2 ) so
that the anisotropy ratio is 1. Poleward of 20N, the two north pole introduce a
weak anisotropy over the ocean areas (< 1.2) except in vicinity of Victoria Island
(Canadian Arctic Archipelago).
244
Configurations
Seas, so that the resolution is 1 there. A local transformation were also applied with in
the Tropics in order to refine the meridional resolution up to 0.5at the Equator.
The ORCA R1 configuration has only a local tropical transformation to refine the
meridional resolution up to 1/3 at the Equator. Note that the tropical mesh refinements in
ORCA R2 and R1 strongly increases the mesh anisotropy there.
The ORCA R05 and higher global configurations do not incorporate any regional
refinements.
For ORCA R1 and R025, setting the configuration key to 75 allows to use 75 vertical
levels, otherwise 46 are used. In the other ORCA configurations, 31 levels are used (see
Tab. 4.2 and Fig. 4.6).
Only the ORCA R2 is provided with all its input files in the NEMO distribution. It
is very similar to that used as part of the climate model developed at IPSL for the 4th
IPCC assessment of climate change (Marti et al., 2009). It is also the basis for the NEMO
contribution to the Coordinate Ocean-ice Reference Experiments (COREs) documented
in Griffies et al. [2009].
This version of ORCA R2 has 31 levels in the vertical, with the highest resolution
(10m) in the upper 150m (see Tab. 4.2 and Fig. 4.6). The bottom topography and the
coastlines are derived from the global atlas of Smith and Sandwell (1997). The default
forcing employ the boundary forcing from Large and Yeager [2004] (see 7.5.1), which
was developed for the purpose of running global coupled ocean-ice simulations without
an interactive atmosphere. This Large and Yeager [2004] dataset is available through the
GFDL web site. The normal year of Large and Yeager [2004] has been chosen of the
NEMO distribution since release v3.3.
ORCA R2 pre-defined configuration can also be run with an AGRIF zoom over the
Agulhas current area ( key agrif defined) and, by setting the key key arctic or key antarctic,
a regional Arctic or peri-Antarctic configuration is extracted from an ORCA R2 or R05
configurations using sponge layers at open boundaries.
15.4
245
and its curl changes sign at 22N and 36N. It forces a subpolar gyre in the north, a
subtropical gyre in the wider part of the domain and a small recirculation gyre in the
southern corner. The net heat ux takes the form of a restoring toward a zonal apparent air
temperature profile. A portion of the net heat ux which comes from the solar radiation is
allowed to penetrate within the water column. The fresh water ux is also prescribed and
varies zonally. It is determined such as, at each time step, the basin-integrated ux is zero.
The basin is initialised at rest with vertical profiles of temperature and salinity uniformly
applied to the whole domain.
The GYRE configuration is set through the key gyre CPP key. Its horizontal resolution (and thus the size of the domain) is determined by setting jp cfg in par GYRE.h90
file :
jpiglo = 30 jp cfg + 2
jpjglo = 20 jp cfg + 2
Obviously, the namelist parameters have to be adjusted to the chosen resolution. In the
vertical, GYRE uses the default 30 ocean levels (jpk=31) (Fig. 4.6).
The GYRE configuration is also used in benchmark test as it is very simple to increase
its resolution and as it does not requires any input file. For example, keeping a same model
size on each processor while increasing the number of processor used is very easy, even
though the physical integrity of the solution can be compromised.
15.5
246
key eel r6
15.6
Configurations
Contents
A.1
A.2
A.3
A.4
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
248
248
250
254
248
A.1
and
1 z
2 =
e2 j s
(A.1)
The chain rule to establish the model equations in the curvilinear scoordinate system
is :
s
=
t z
t s s t
s
=
i z
i s s i
i s
s
=
j z
j s s j
j s
1
=
z
e3 s
e1
1
e3 s
e2
2
e3 s
(A.2)
In particular applying the time derivative chain rule to z provides the expression for
ws , the vertical velocity of the ssurfaces referenced to a fix z-coordinate :
z
z s
s
=
ws =
= e3
t s
s t
t
A.2
(A.3)
249
scoordinate system :
(e1 v)
j z
(e2 u)
e1
e3 1 s
(e1 v)
j s
U =
1
e1 e2
(e2 u)
i z
1
e1 e2
(e2 u)
i s
1
e1 e2
(e2 u)
i s
1
e1 e2 e3
Noting that
comes :
U =
1 e3
e1 i s
1
e1 e2 e3
(e2 e3 u)
i
s
1
e1 e2 e3
(e2 e3 u)
i
s
1
e3
w
(e1 v)
e2
e3 2 s
v
1 u
s 2 s
w s
s z
(e1 e3 v)
3
e1 v e
j
j s
s
u
+ e13 w
s 1 s
1 z
e1 i s
1
s
and
1
e2
2 v
s
2
e3
j = s , it bes
(e1 e3 v)
j
s
+ e13
=
(e1 v)
j s
w
z
3
e2 u e
i +
1 2z
e1 i s s
(e2 e3 u)
i
s
w
s
2
u
v
1
u
s v s 1 s 2 s
(e1 e3 v)
j
s
1
e3 s
[w u 1 v 2 ]
(A.5)
with ws given by (A.3), we obtain the expression for the divergence of the velocity in the
curvilinear scoordinate system :
i
h
1 ws
U = e1 e12 e3 (e2ie3 u) + (e1je3 v) + e13
s + e3 s
s
(e2 e3 u)
+
i
1
e1 e2 e3
1
e1 e2 e3
(e2 e3 u)
i
s
1
e1 e2 e3
(e2 e3 u)
i
s
i
(e1 e3 v)
+
j
s
(e1 e3 v)
j
s
(e1 e3 v)
j
s
1
e3 s
1
e3 s
1
e3 s
s
s t
1
e3 s
1 e3
e3 t
e3
+
s
t
1 s e3
e3 t s
(A.7)
A additional term has appeared that take into account the contribution of the time variation
of the vertical coordinate to the volume budget.
250
A.3
+w
u
t z
|z v +
1 (u2 +v 2 )
2e1
i
z
u
t z
|z v +
1
e1 e2
(e2 v)
i z
u
z
(e1 u)
j z
v+
1 (u2 +v 2 )
2e1
i
z
+w
u
z
+
v
= u
1
2
t z
e1 e2
i
j
e3
s
e3
s
s
s
2
2
2
2
+ 2e11 (u i+v ) ee13 1 (us+v ) + ew3 u
s
s
2
2
+ | v + 1 (u +v )
= u
s
t z
2 e1
i
s
h
w u
+ e3 s e31 v
s
=
u
t z
u
t z
+ |s v
1 (u2 +v 2 )
2e3
s
2
2
+ 2 1e1 (u i+v )
s
+ e13 w u
+
v v
1
s
s
+ |s v +
2 u
e3 s
1 (u2 +v 2 )
2 e1
i
s
u
v
2 v u
s 1 u s 1 v s
1
e3
[w 2 v 1 u]
u
s
Applying the time derivative chain rule (first equation of (A.2)) to u and using (A.3)
provides the expression of the last term of the right hand side,
s u
u
u
ws u
,
s = t s = t s t z
leads to the scoordinate formulation of the total zcoordinate time derivative, i.e. the
total scoordinate time derivative :
u
1 (u2 + v 2 )
1 u
Du
=
+ |s v +
(A.9)
+ e3 s
Dt s
t s
2 e1
i
s
251
Therefore, the vector invariant form of the total time derivative has exactly the same mathematical form in z and scoordinates. This is not the case for the flux form as shown
in next paragraph.
u
t s
v +
u
t s
+ e11e2
2
2
1 (u +v )
2 e1
i
(e2 u u)
i
1
e1 e2
e1ve2 v
(e2 u)
i
e2
i
u
1
e3 s
(e1 u v)
j
(e1 v)
j
e1
j
1 ( u)
e3 s
1
e3 s
Introducing the vertical scale factor inside the horizontal derivative of the first two terms
(i.e. the horizontal divergence), it becomes :
(e2 e3 u2 )
(e1 e3 uv)
u)
e3
e3
Du
u
1
=
+
+
e
uu
e
uv
+ e13 (
2
1
Dt s
t s
e1 e2 e3
i
j
i
j
s
u
1
e1 e2 e3
e1ve2 v
=
u
t s
+ e1 e12 e3
u
e2
i
(e2 e3 u)
i
e1
j
(e2 e3 u u)
i
1
e1 e2 e3
(e2 e3 u)
i
(e1 e3 v)
j
e2 u
e3
i
e1 v
(e1 e3 u v)
j
1 ( u)
e3 s
(e1 e3 v)
j
1
e3 s
v
e1 e2
e3
j
e2
i
1
e3 s
e1
j
Introducing a more compact form for the divergence of the momentum fluxes, and using
(A.7), the scoordinate continuity equation, it becomes :
+ (U u)| + u 1 e3 v v e2 u e1
= u
s
t s
e3 t
e1 e2
i
j
which leads to the scoordinate flux formulation of the total scoordinate time derivative, i.e. the total scoordinate time derivative in flux form :
1 (e3 u)
v
Du
e2
e1
=
+ (U u)|s
v
u
(A.11)
Dt s e3
t s
e1 e2
i
j
252
which is the total time derivative expressed in the curvilinear scoordinate system. It has
the same form as in the zcoordinate but for the vertical scale factor that has appeared
inside the time derivative which comes from the modification of (A.7), the continuity
equation.
1 p
1
p
e1 p
=
1
o e1 i z
o e1 i s e3 s
1 p
1
=
+
(g e3 )
o e1 i s o e3
g
1 p
1
=
o e1 i s
o
Applying similar manipulation to the second component and replacing 1 and 2 by their
expression (A.1), it comes :
1
o e1
1
o e2
p
1
p
z
=
+g
i z
o e1 i s
i s
1
z
p
p
=
+g
j z
o e2 j s
j s
(A.12)
An additional term appears in (A.14) which accounts for the tilt of ssurfaces with
respect to geopotential zsurfaces.
As in z-coordinate, the horizontal pressure gradient can be split in two parts following
Marsaleix et al. [2008]. Let defined a density
R anomaly, d, by d = ( o )/o , and a
0
0
hydrostatic pressure anomaly, ph , by ph = g z d e3 dk. The pressure is then given by :
Z
p=g
e3 dk = g
(o d + 1) e3 dk
z
z
Z
Z
= g o
d e3 dk + g
e3 dk
z
(A.13)
253
Substituing (A.13) in (A.14) and using the definition of the density anomaly it comes
the expression in two parts :
1 p
g
1 p0h
z
=
+g d
o e1 i z
e1
i
i s
e1 i
0 s
(A.14)
g
1 p
1 ph
z
=
+g d
o e2 j z
e2
j s
j s
e2 j
This formulation of the pressure gradient is characterised by the appearance of a term depending on the the sea surface height only (last term on the right hand side of expression
(A.14)). This term will be abusively named surface pressure gradient whereas the first
term will be named hydrostatic pressure gradient by analogy to the z-coordinate formulation. In fact, the the true surface pressure gradient is 1/o (), and is implicitly
included in the computation of p0h through the upper bound of the vertical integration.
+g d
e2 j
j
e2 j
whereas the flux form momentum equation differ from it by the formulation of both the
time derivative and the pressure gradient term :
1 (e3 u)
1
e2
e1
= (U u) + f +
v
u
v
e3 t
e1 e2
i
j
z
g
1 p0h
+g d
254
1 (e3 v)
e2
1
e1
v
u
= (U v) + f +
u
e3 t
e1 e2
i
j
g
1 p0h
z
+g d
+ DvU + FvU (A.16b)
e2 j
j
e2 j
Both formulation share the same hydrostatic pressure balance expressed in terms of hydrostatic pressure and density anmalies, p0h and d = ( o 1) :
p0h
= d g e3
k
(A.17)
It is important to realize that the change in coordinate system has only concerned the
position on the vertical. It has not affected (i,j,k), the orthogonal curvilinear set of unit
vector. (u,v) are always horizontal velocities so that their evolution is driven by horizontal
forces, in particular the pressure gradient. By contrast, is not w, the third component
of the velocity, but the dia-surface velocity component, i.e. the velocity relative to the
moving ssurfaces and normal to them.
A.4
Tracer Equation
The tracer equation is obtained using the same calculation as for the continuity equation and then regrouping the time derivative terms in the left hand side :
1 (e3 T )
1
=
(e2 e3 T u) +
(e1 e3 T v)
e3 t
e1 e2 e3 i
j
1
+
(T w) + DT + F T
e3 k
(A.18)
The expression for the advection term is a straight consequence of (A.4), the expression of the 3D divergence in the scoordinates established above.
Contents
B.1 Horizontal/Vertical 2nd Order Tracer Diffusive Operators 256
B.2 Iso/diapycnal 2nd Order Tracer Diffusive Operators . . . . 258
B.3 Lateral/Vertical Momentum Diffusive Operators . . . . . . 259
256
B.1
+
A
A
+ z
AvT T
(B.1)
DT = e11e2 i
e1
i z
j e2
j
z
z
In the s-coordinate, we defined the slopes of s-surfaces, 1 and 2 by (A.1) and the
vertical/horizontal ratio of diffusion coefficient by = AvT /AlT . The diffusion operator
is given by :
DT = |s AlT < |s T
or in expanded form :
h
DT = e1 e12 e3
e2 e3 AlT
+e1 e3 AlT
+e1 e2 AlT
1
0
1
1
2
where < = 0
2
2
1 2 + 1 + 2
s
1 T
T
j e2 j s
s
s
1 T
2 T
2
2
s
e1 i s
e2 j + + 1 + 2
1
e1
T
i s
1
e3
2
e3
(B.2)
T
s
1 T
e3 s
i
Equation (B.2) is obtained from (B.1) without any additional assumption. Indeed, for
the special case k = z and thus e3 = 1, we introduce an arbitrary vertical coordinate s =
s(i, j, z) as in Appendix A and use (A.1) and (A.2). Since no cross horizontal derivative
i j appears in (B.1), the (i,z) and (j,z) planes are independent. The derivation can then
be demonstrated for the (i,z) (j,s) transformation without any loss of generality :
DT
=
=
e1 e2 i
1
e1 e2
1
e1 e2 e3
e2 lT
e1 A
+
T
i z
e2 lT
T
e1 A
i s
e2 lT
e1e31 s
e1 A
AvT
e1 1 T
e3 s
T
i s
T
z
s
e1 1 T
e3 s s
1
e3 s
AvT T
e3 s
e2 e3 lT T
e2 lT e3 T
e1 A
i s s e1 A
i s i s
e2 1 lT T
e2 lT T
e3 i
A
A
1
1
e3
s
s e1
i s
s
e2 1 lT T
e1 1 s e3 A s
+ s
e1 e2 vT T
e3 A
s
Noting that
=
1 e3
e1 i s
1
e1 e2 e3
1
e1 e2 e3
1
s ,
257
it becomes :
e2 e3 lT T
e2 1 lT T
e1 A
i s s e3 i
e3 A
s s
e2 lT T
1 T
e2 AlT
A
1
1
s
i s
1
i s
s e
e2 1 lT T
e1 e2 vT T
+e1 1 s e3 A s + s e3 A z
e2 e3 lT T
lT T
i
e1 A
i s s i e2 1 A
s s
e2 1 lT T e3
1 T
lT
+ e3 A s i e2 A s i s
s
2
+ e1 e2 1 AlT T
AlT T
e2 1 s
s
i s s e3
(e1 e2 1 ) 1 lT T
e1 e2 vT T
s
e3 A
s + s
e3 A
s
lT T
= e1 e12 e3
A
A
2 1
i
e1
i s
s
s
1 lT (e1 e2 1 ) T
T 1
A
s s
e3
s
s
lT T 1
1 T
e2 AlT
+
A
1
s i s
s
i s i
s
e1 e2 12 lT T
e1 e2 vT T
+ s
e3 A
s + e3 A
s
+ e1 ee23 1 AlT
AlT
T
i s
Since the horizontal scale factors do not depend on the vertical coordinate, the last term
of the first line and the first term of the last line cancel, while the second line reduces to a
single vertical derivative, so it becomes :
h
e2 e3 lT T
lT T
= e1 e12 e3
A
A
2 1
i
i s
s s
e1
i
+ AlT e1 e2 + 2 T
+ s
e2 1 AlT T
1 s
i s
e3
in other words, the horizontal Laplacian operator in the (i,s) plane takes the following
form :
! "
#
!
(e2 e3 )
1
1
1
1
T
lT
i
e
i
s
1
s
(T )
D =
A
1
(e1 e2 )
1 21
e1 e2 e3
e3 s
s
258
B.2
1 + a21 a1 a2 a1
AlT
a1 a2 1 + a22 a2
AI =
1 + a21 + a22
2
2
a1
a2
+ a1 + a2
where (a1 , a2 ) are the isopycnal slopes in (i, j) directions :
1
1
e3
e3
,
a2 =
a1 =
e1 i
k
e2 j
k
In practice, the isopycnal slopes are generally less than 102 in the ocean, so AI can
be simplified appreciably [Cox 1987] :
1
0
a1
1
a2
AI AlT 0
2
2
a1 a2 + a1 + a2
The resulting isopycnal operator conserves the quantity and dissipates its square. The
demonstration of the first property is trivial as (B.2) is the divergence of fluxes. Let us
demonstrate the second one :
ZZZ
ZZZ
T . (AI T ) dv =
T . (AI T ) dv
D
since
T . (AI T ) =
AlT
= Ah
T 2
i
T
i
2a1 T
i
T
k
T
j
2
T 2 i
T
2 + a2
2a2 T
+
a
1
2
j k
k
2
2
T
a1 T
+ T
k
j a2 k
0
the property becomes obvious.
The resulting diffusion operator in z-coordinate has the following form :
1
e2 T
e2 T
e1 T
e1 T
T
D =
Ah
a1
+
Ah
a2
e1 e2 i
e1 i
e3 k
j
e2 j
e3 k
"
!#
2
a1 + a22 T
a1 T
1
a2 T
+
Ah
+
e3 k
e1 i
e2 j
e3
k
It has to be emphasised that the simplification introduced, leads to a decoupling between (i,z) and (j,z) planes. The operator has therefore the same expression as (??), the
diffusion operator obtained for geopotential diffusion in the s-coordinate.
B.3
259
1
e1
1
e2
1
e3
1
e1
1
e2
+
0
1
e2
1
e1
1 u
1
e13 k
e2 j
e3 k
1
1 v
1
e3 kh e3 k e1 i
i
e2 u
e1 v
1
e1 e2 i e3 k
j
e3 k
+
e3
1 u
k e3 k
1 v
k
2 e3 k
2 (e1 v)
(e2 u)
1
+
e1 e2
ik
jk
Using (2.11b), the definition of the horizontal divergence, the third componant of the
second vector is obviously zero and thus :
1
1 Uh
Uh = h () h () +
e3 k e3 k
Note that this operator ensures a full separation between the vorticity and horizontal divergence fields (see Appendix E). It is only equal to a Laplacian applied to each
component in Cartesian coordinates, not on the sphere.
The horizontal/vertical second order (Laplacian type) operator used to diffuse horizontal momentum in the z-coordinate therefore takes the following form :
1 Avm Uh
DU = h Alm h Alm k +
(B.6)
e3 k
e3 k
that is, in expanded form :
lm
A
1
1
DuU =
e1
i
e2
lm
A
1
1
DvU =
+
e2
j
e1
Alm
1 u
+
j
e3 k
Alm
1 v
+
i
e3 k
Note Bene : introducing a rotation in (B.6) does not lead to a useful expression for
the iso/diapycnal Laplacian operator in the z-coordinate. Similarly, we did not found an
expression of practical use for the geopotential horizontal/vertical Laplacian operator in
the s-coordinate. Generally, (B.6) is used in both z- and s-coordinate systems, that is a
Laplacian diffusion is applied on momentum along the coordinate directions.
Contents
C.1 Introduction / Notations . . . . . . . . . . . . . . . . . . . .
C.2 Continuous conservation . . . . . . . . . . . . . . . . . . .
C.3 Discrete total energy conservation : vector invariant form .
C.3.1 Total energy conservation . . . . . . . . . . . . . . .
C.3.2 Vorticity term (coriolis + vorticity part of the advection)
C.3.3 Pressure Gradient Term . . . . . . . . . . . . . . . . .
C.4 Discrete total energy conservation : flux form . . . . . . . .
C.4.1 Total energy conservation . . . . . . . . . . . . . . .
C.4.2 Coriolis and advection terms : flux form . . . . . . . .
C.5 Discrete enstrophy conservation . . . . . . . . . . . . . . .
C.6 Conservation Properties on Tracers . . . . . . . . . . . . .
C.6.1 Advection Term . . . . . . . . . . . . . . . . . . . . .
C.7 Conservation Properties on Lateral Momentum Physics . .
C.7.1 Conservation of Potential Vorticity . . . . . . . . . . .
C.7.2 Dissipation of Horizontal Kinetic Energy . . . . . . .
C.7.3 Dissipation of Enstrophy . . . . . . . . . . . . . . . .
C.7.4 Conservation of Horizontal Divergence . . . . . . . .
C.7.5 Dissipation of Horizontal Divergence Variance . . . .
C.8 Conservation Properties on Vertical Momentum Physics . .
C.9 Conservation Properties on Tracer Physics . . . . . . . . .
C.9.1 Conservation of Tracers . . . . . . . . . . . . . . . .
C.9.2 Dissipation of Tracer Variance . . . . . . . . . . . . .
262
263
266
266
266
270
272
272
273
274
276
276
277
277
278
279
279
280
280
283
284
284
262
C.1
Introduction / Notations
Notation used in this appendix in the demonstations :
fluxes at the faces of a T -box :
U = e2u e3u u
V = e1v e3v v
W = e1w e2w
dk =
e3 (k)
z(k) =
k=k
Zks
e3 dk
1
t (e3 Q) dv = 0
e3
equation of evolution of Q written as the time evolution of the vertical content of Q like
for tracers, or momentum in flux form, the quadratic quantity 21 Q2 is conserved when :
Z
Z
1 2
1
1
2
t
Q dv =
t
(e3 Q) e1 e2 di dj dk
e3
D 2
D 2
Z
Z
1 2
=
Q t (e3 ) e1 e2 di dj dk
Q t (e3 Q) e1 e2 di dj dk
2
D
D
263
1 2
Q dv
2
Z
=
D
Q
1
t (e3 Q) dv
e3
2
Z
D
Q2
t (e3 ) dv
e3
(C.1)
equation of evolution of Q written as the time evolution of Q like for momentum in vector
invariant form, the quadratic quantity 21 Q2 is conserved when :
Z
t
D
1 2
Q dv
2
1
t e3 Q2 e1 e2 di dj dk
2
Z
ZD
1 2
Qt Q e1 e2 e3 di dj dk +
Q t e3 e1 e2 di dj dk
=
D 2
D
C.2
(C.2)
Continuous conservation
The discretization of pimitive equation in s-coordinate (i.e. time and space varying
vertical coordinate) must be chosen so that the discrete equation of the model satisfy
integral constrains on energy and enstrophy.
Let us first establish those constraint in the continuous world. The total energy (i.e.
kinetic plus potential energies) is conserved :
Z
1 2
t
Uh + g z dv =0
(C.3)
D 2
under the following assumptions : no dissipation, no forcing (wind, buoyancy flux, atmospheric pressure variations), mass conservation, and closed domain.
This equation can be transformed to obtain several sub-equalities. The transformation
for the advection term depends on whether the vector invariant form or the flux form is
used for the momentum equation. Using (C.2) and introducing (A.15) in (C.3) for the
former form and Using (C.1) and introducing (A.16) in (C.3) for the latter form leads to :
advection term (vector invariant form) :
Z
(k Uh ) Uh dv = 0
(C.4a)
D
Z
Uh h
D
Uh 2
2
Z
Uh z Uh dv
dv +
D
Uh 2 1
t e3 dv = 0
2 e3
(C.4b)
264
(C.4c)
Z
Uh
(U u)
(U v)
1
dv +
2
Uh 2
1
t e3 dv = 0
e3
(C.4d)
coriolis term
Z
f (k Uh ) Uh dv = 0
(C.4e)
pressure gradient :
Z
Z
Z
p|z Uh dv = ( U) g z dv + g t z dv
D
(C.4f)
Z
Uh VOR dv = 0
(C.5a)
Z
Uh KEG dv +
Z
Uh ZAD dv
Z
Uh (HPG + SPG) dv =
Z
( U) g z dv +
Flux form :
(C.5b)
Uh 2 1
t e3 dv = 0
2 e3
g t z dv
(C.5c)
Z
Uh COR dv = 0
(C.6a)
1
Uh ADV dv +
2
Uh 2
1
t e3 dv = 0
e3
(C.6b)
Z
Uh (HPG + SPG) dv =
Z
( U) g z dv +
g t z dv
D
(C.6c)
265
(C.6c) is the balance between the conversion KE to PE and PE to KE. Indeed the left
hand side of (C.6c) can be transformed as follows :
Z
Z
Z
1
t (e3 ) g z dv + g t z dv
t g z dv = +
e3
D
D
Z
ZD
= ( U) g z dv + g t z dv
D
Z
=+
1
g Uh h z + k z
e3
Z
dv +
g t z dv
D
Z
g ( + t z + Uh h z) dv
=+
D
Z
=+
g w dv
D
where the last equality is obtained by noting that the brackets is exactly the expression of
w, the vertical velocity referenced to the fixe z-coordinate system (see (A.5)).
The left hand side of (C.6c) can be transformed as follows :
Z
Z
p|z Uh dv = (h p + gh z) Uh dv
D
Z
=
Z
h p Uh dv
g h z Uh dv
Z
p h Uh dv +
=+
D
g ( w + t z) dv
D
Z
1
1
= p
t e3 + k dv + g ( w + t z) dv
e3
e3
D
D
Z
Z
Z
p
1
=
t e3 dv +
k p dv + g ( w + t z) dv
e3
e3
D
D
Z
Z D
Z
p
=
t e3 dv g dv + g ( w + t z) dv
e3
D
D
D
Z
Z
Z
p
=
t e3 dv g w dv + g t z dv
e3
Z
266
p
t e3 dv
e3
Z
=
p
t e3 dv
e3
Z
g w dv
D
Z
g w dv +
1
k p t z dv
e3
p
t (k z)dv
e3
Z
=
g w dv
D
C.3
C.3.1
2
X u2
v
t
bu +
bv + g zt bt = 0
2
2
i,j,k
1 X u2
v2
u t u bu + v t v bv +
t e3u bu +
t e3v bv
2
e3u
e3v
i,j,k
X
X 1
=
t (e3t ) g zt bt
g t (zt ) bt
e3t
i,j,k
(C.7)
i,j,k
Substituting the discrete expression of the time derivative of the velocity either in
vector invariant, leads to the discrete equivalent of the four equations (C.6).
C.3.2
267
i+1/2
q (e1v e3v v)
+
e3 q k Uh e1u
i
j+1/2
e12v q (e2u e3u u)
This formulation does not conserve the enstrophy but it does conserve the total kinetic
energy. Indeed, the kinetic energy tendency associated to the vorticity term and averaged
over the ocean domain can be transformed as follows :
Z
(e3 q k Uh ) Uh dv
D
1
e1u
i,j,k
qV
i,j,k
P
q V
qV
i+1/2
i+1/2
i+1/2
u bu
U qU
U
j+1/2
1
e2v
qU
j+1/2
j+1/2
v bv
V
j+1/2
i+1/2
0
i,j,k
In other words, the domain averaged kinetic energy does not change due to the vorticity
term.
1 X i+1/2ip ip
i+i 1/2
+q e3 v +
Qjp (e1v e3v v)j+jpp
1u
ip , k p
X
1
ip
i+ip
i
q e3 u
j+1/2jp Qjp (e2u e3u u)j+jp 1/2
e
2v
(C.8)
ip , k p
where the indices ip and kp take the following value : ip = 1/2 or 1/2 and jp = 1/2
i
or 1/2, and the vorticity triads, ij Qjpp , defined at T -point, are given by :
j ip
i Qjp
1 iip
i+j
i+i
qj+jp + qj+ipp + qjjpp
12
(C.9)
268
X X
i,j,k
i+1/2ip ip
Qjp
j
i+1/2ip
Vj+jp
i+1/2
Uj
ip
i
j+1/2jp Qjp
i+i
p
V i
Uj+1/2j
j+1/2
p
ip , k p
ip , k p
X X
i+1/2ip ip
Qjp
j
i+1/2i
Vj+jp p
i+1/2
Uj
ip
i
j+1/2jp Qjp
i+ip
Uj+1/2j
p
i
Vj+1/2
i,j,k ip , kp
X
i+1 1/2
j Q+1/2
1/2
i1/2
i
Vj+1/2
1/2
i1/2
i
Vj+1/2
+1/2
i+1/2
i
Vj+1/2
+1/2
i
j+1 Q1/2
i+1/2
Uj+1
i
Vj+1/2
i+1/2
ij
1/2
i+1/2
+1/2
i+1/2
ij
i+1
Uj
Vj+1/2
Q+1/2 Uj
i,j,k
i+1
+ i+1
j Q1/2 Vj1/2 Uj
+ ij
+
i
j
i
Q+1/2 Vj+1/2
Uj
+1/2
Q1/2
i
Vj1/2
i+1/2
Uj
Q+1/2 Uj
The summation is done over all i and j indices, it is therefore possible to introduce a
shift of 1 either in i or j direction in some of the term of the summation (first term of
the first and second lines, second term of the second and fourth lines). By doning so, we
can regroup all the terms of the summation by triad at a (i,j) point. In other words, we
regroup all the terms in the neighbourhood that contain a triad at the same (i,j) indices. It
becomes :
X
i 1/2
j Q+1/2
h
i
i1/2
i1/2
i
i
Vj+1/2
Uj
Uj
Vj+1/2
i,j,k
h
i
1/2
i1/2
i1/2
i
i
+ ij Q1/2 Vj1/2
Uj
Uj
Vj1/2
h
i
+1/2
i+1/2
i+1/2
i
i
+ ij Q+1/2 Vj+1/2
Uj
Uj
Vj+1/2
+
i +1/2
j Q1/2
h
i
i+1/2
i+1/2
i
i
Vj1/2 Uj
Uj1 Vj1/2
269
1
Uh k Uh dv =
e3
D
Z
Uh h
D
1
Uh 2
2
dv +
1
2
Z
D
Uh 2
t (e3 ) dv
e3
Indeed, using successively (4.11) (i.e. the skew symmetry property of the operator) and
the continuity equation, then (4.11) again, then the commutativity of operators and ,
and finally (4.12) (i.e. the symmetry property of the operator) applied in the horizontal
and vertical directions, it becomes :
1
2
dv
Uh
Uh KEG dv =
Uh h
2
D
D
i
i
h i
h i
X 1 1
1
j
j
i+1/2 u2 + v 2 u bu +
j+1/2 u2 + v 2 v bv
2 e1u
e2v
i,j,k
X1 i
j
+
u2 + v 2
i [U ] + j [V ]
2
i,j,k
b
X1 i
j
t
u2 + v 2
t (e3t ) + k [W ]
2
e3t
i,j,k
h i
i
X1
X1 i
j
j
+
k+1/2 u2 + v 2 W
u2 + v 2
t bt
2
2
i,j,k
i,j,k
X u2
X1
v2
i
j
i+1/2
j+1/2
2
2
t bt
t bt
[u ] + k+1/2 [v ]
W
+
+
2 k+1/2
2
2
Z
i,j,k
i,j,k
i+1/2
Assuming that bu = bt
and bv = bt
two equations is satisfied, it becomes :
j+1/2
v2
t bu +
t bv
2
2
2
i,j,k
i,j,k
X 2
X i+1/2
u
v2
j+1/2 k+1/2
k+1/2
W
u
k+1/2 [u] + W
v
k+1/2 [v]
t bu +
t bv
2
2
i,j,k
i,j,k
X 2
k
k
X 1
1
u
v2
i+1/2
j+1/2
W
k+1/2 [u] u bu +
W
k+1/2 [v] v bv
t bu +
t bv
bu
bv
2
2
X 1
i,j,k
i+1/2
j+1/2
k+1/2 u2 + W
k+1/2 v 2
X u2
i,j,k
270
The first term provides the discrete expression for the vertical advection of momentum
(ZAD), while the second term corresponds exactly to (C.7), therefore :
Z
1
Uh ZAD dv +
2
Z
D
1
Uh wk Uh dv +
2
Uh 2
Z
1
t (e3 ) dv
e3
Uh 2
1
t (e3 ) dv
e3
There is two main points here. First, the satisfaction of this property links the choice
of the discrete formulation of the vertical advection and of the horizontal gradient of KE.
2
Choosing one imposes the other. For example KE can also be discretized as 1/2 (u i +
2
v j ). This leads to the following expression for the vertical advection :
1
k Uh
e3
1
e1u e2u e3u
1
e1v e2v e3v
i+1/2,k
e1t e2t k+1/2 u i+1/2
j+1/2 j+1/2,k
e1t e2t k+1/2 v
a formulation that requires an additional horizontal mean in contrast with the one used in
NEMO. Nine velocity points have to be used instead of 3. This is the reason why it has
not been chosen.
Second, as soon as the chosen s-coordinate depends on time, an extra constraint arises
on the time derivative of the volume at u- and v-points :
e1u e2u t (e3u ) = e1t e2t t (e3t )
e1v e2v t (e3v ) = e1t e2t t (e3t )
i+1/2
j+1/2
e3u =
(C.10)
e3v
(C.11)
C.3.3
p|z Uh dv =
( U) g z dv +
g t (z) dv
D
271
This property can be satisfied in a discrete sense for both z- and s-coordinates. Indeed,
defining the depth of a T -point, zt , as the sum of the vertical scale factors at w-points
starting from the surface, the work of pressure forces can be written as :
Z
X
1
p|z Uh dv
i+1/2 [pt ] g i+1/2 i+1/2 [zt ] u bu
e1u
D
i,j,k
1
j+1/2
[pt ] g
j+1/2 [zt ] v bv
e2v j+1/2
Using successively (4.11), i.e. the skew symmetry property of the operator, (6.4), the
continuity equation, (6.20), the hydrostatic equation in the s-coordinate, and k+1/2 [zt ]
e3w , which comes from the definition of zt , it becomes :
p
X
t
g i+1/2 U i+1/2 [zt ] + j+1/2 V j+1/2 [zt ] + i [U ] + j [V ]
g
i,j,k
X
pt
bt
t (e3t ) + k [W ]
+
g i+1/2 U i+1/2 [zt ] + j+1/2 V j+1/2 [zt ]
e3t
g
i,j,k
X
pt
W
+
g i+1/2 U i+1/2 [zt ] + j+1/2 V j+1/2 [zt ] +
k+1/2 [pt ] t bt
g
g
i,j,k
X
pt
i+1/2
j+1/2
k+1/2
+
g
U i+1/2 [zt ] +
V j+1/2 [zt ] W e3w
t bt
g
i,j,k
X
pt
i+1/2
j+1/2
k+1/2
+
g
U i+1/2 [zt ] +
V j+1/2 [zt ] + W
k+1/2 [zt ] t bt
g
i,j,k
i
h
i
h
i
h
X
X
i+1/2
j+1/2
k+1/2
+ j V
+ k W
g zt i U
pt t bt
+
i,j,k
i,j,k
g zt t (e3t )
X
bt
pt t bt
i,j,k
i,j,k
The first term is exactly the first term of the right-hand-side of (C.7).RIt remains to demonstrate that the last term, which is obviously a discrete analogue of D ep3 t (e3 ) dv is
equal to the last term of (C.7). In other words, the following property must be satisfied :
X
X
pt t bt
g t (zt ) bt
i,j,k
i,j,k
Let introduce pw the pressure at w-point such that k [pw ] = g e3t . The right-handside of the above equation can be transformed as follows :
272
X
g t (zt ) bt
X
k [pw ] t (zt ) e1t e2t
i,j,k
i,j,k
X
pw k+1/2 [t (zt )] e1t e2t
pw t (e3w ) e1t e2t
i,j,k
i,j,k
X
X
pw t (bw )
i,j,k
i,j,k
Defining pw = pt k+1/2
Note that this property strongly constrains the discrete expression of both the depth of
T points and of the term added to the pressure gradient in the s-coordinate. Nevertheless,
it is almost never satisfied since a linear equation of state is rarely used.
C.4
C.4.1
2
X u2
v
t
bu +
bv + g zt bt = 0
2
2
i,j,k
i,j,k
Substituting the discrete expression of the time derivative of the velocity either in
vector invariant or in flux form, leads to the discrete equivalent of the
C.4.2
273
Z
Uh
(U u)
(U v)
1
dv
2
Uh 2
1 e3
dv = 0
e3 t
(C.12)
Let us first consider the first term of the scalar product (i.e. just the the terms associated with the i-component of the advection) :
Z
u (U u) dv
D
i
h
i
h
i
h
X 1
i i
i+1/2 j+1/2
i+1/2 k+1/2
+ k W
bu u
U u + j V
u
u
bu i+1/2
i,j,k
h
i
h
i
h
i
X
i i
i+1/2 j+1/2
i+12 k+1/2
i+1/2 U u + j V
+ k W
u
u
u
i,j,k
X
U u i [u] + V
i+1/2
j+1/2
j+1/2 [u] + W
i+1/2
k+1/2
i,j,k
2
2
1X
i 2
i+1/2
i+1/2
+
U i u + V
j+/2 u + W
k+1/2 u
2
i,j,k
h ii
h ii
h i i
X 1
2
2
+ V j+1/2 u
+ W k+1/2 u2
U i+1/2 u
2
i,j,k
X 1 i
2
u
i+1/2 [U ] + j+1/2 [V ] + k+1/2 [W ]
2
i,j,k
k+1/2 [u]
274
+
u2
1 e3t
e3t t
bt
Applying similar manipulation applied to the second term of the scalar product leads to :
Z
1 e
X1 i
j
(U u)
3t
2
2
Uh
dv +
u +v
bt
(U
v)
2
e
t
3t
D
i,j,k
R
1
C.5
i,j+1/2
1 i
q
(e1v e3v v)
+
e1u
(C.13)
i+1/2,j
1 j
q (e2u e3u u)
e2v
The scheme does not allow but the conservation of the total kinetic energy but the
conservation of q 2 , the potential enstrophy for a horizontally non-divergent flow (i.e.
when =0). Indeed, using the symmetry or skew symmetry properties of the operators
(Eqs (4.12) and (4.11)), it can be shown that :
Z
1
q k (e3 q k Uh ) dv 0
(C.14)
e3
D
where dv = e1 e2 e3 di dj dk is the volume element. Indeed, using (C.13), the discrete
form of the right hand side of (C.14) can be transformed as follow :
Z
1
q k (e3 q k Uh ) dv
e3
D
i,j+1/2
i+1/2,j
P
i
j
q i+1/2 q U
j+1/2 q V
i,j,k
i,j+1/2
i+1/2,j
P
i
j
i [q] q U
+ j [q] q V
i,j,k
i,j+1/2
i+1/2,j
P
12
i q 2 U
+ j q 2 V
i,j,k
i,j+1/2
i+1/2,j
1 P 2
2
q
i+1/2 U
+ j+1/2 V
i,j,k
275
i+1/2
Since and operators commute : i+1/2 a i = i [a]
, and introducing the horizontal divergence , it becomes :
P
i,j,k
i+1/2,j+1/2
The later equality is obtain only when the flow is horizontally non-divergent, i.e. =0.
1 X i+1/2ip ip
i+i 1/2
+q e3 v +
Qjp (e1v e3v v)j+jpp
e1u
ip , k p
1 X
q e3 u
e2v
ip
i
j+1/2jp Qjp
i+i
(e2u e3u u)j+jpp 1/2
(C.15)
ip , k p
where the indices ip and kp take the following value : ip = 1/2 or 1/2 and jp = 1/2
i
or 1/2, and the vorticity triads, ij Qjpp , defined at T -point, are given by :
j ip
i Qjp
1 iip
i+j
i+i
qj+jp + qj+ipp + qjjpp
12
(C.16)
This formulation does conserve the potential enstrophy for a horizontally non-divergent
flow (i.e. = 0).
+1/2
Let consider one of the vorticity triad, for example ij Q+1/2 , similar manipulation can
be done for the 3 others. The discrete form of the right hand side of (C.14) applied to this
triad only can be transformed as follow :
Z
1
q k (e3 q k Uh ) dv
e3
D
h
i
h
i
X
i+1/2
i +1/2
i +1/2
i
q
i+1/2 j Q+1/2 Uj
j+1/2 j Q+1/2 Vj+1/2
i,j,k
X
i [q]
i +1/2
j Q+1/2
i+1/2
Uj
+ j [q]
i +1/2
j Q+1/2
i
Vj+1/2
i,j,k
...
Demonstation to be done...
...
h
2 i i,j+1/2
h
2 i i+1/2,j
1X
i +1/2
i +1/2
U
+ j j Q+1/2
V
i j Q+1/2
2
i,j,k
i,j+1/2
i+1/2,j
1 X i +1/2 2
i+1/2 U
+ j+1/2 V
j Q+1/2
2
i,j,k
276
X
i,j,k
i+1/2, j+1/2
1 i +1/2 2
j Q+1/2
bt
2
C.6
C.6.1
Advection Term
conservation of a tracer, T :
Z
Z
1 (e3 T )
T dv =
dv = 0
t
e
t
D
D 3
conservation of its variance :
Z
Z
Z
1 2
1 (e3 T )
1
1 e3
T dv =
dv
T2
dv
Q
t
t
2 D
e3 t
D 2
D e3
Whatever the advection scheme considered it conserves of the tracer content as all
the scheme are written in flux form. Indeed, let T be the tracer and u , v , and w its
interpolated values at velocity point (whatever the interpolation is), the conservation of
the tracer content due to the advection tendency is obtained as follows :
Z
Z
1 (e3 T )
dv =
(T U) dv
t
D e3
D
X 1
1
(i [U u ] + j [V v ]) +
k [w w ] bt
bt
e3t
i,j,k
X
{i [U u ] + j [V v ] + k [W w ]}
i,j,k
0
The conservation of the variance of tracer due to the advection tendency can be
i+1/2
j+1/2
achieved only with the CEN2 scheme, i.e. when u = T
, v = T
, and
277
k+1/2
w = T
. It can be demonstarted as follows :
Z
Z
1 (e3 T )
Q
dv = (T U) dv
t
D e3
D
i
h
i
io
h
X n h
i+1/2
j+1/2
k+1/2
T i U T
+ j V T
+ k W T
i,j,k
o
Xn
i+1/2
j+1/2
k+1/2
i+1/2 [T ] + V T
j+1/2 [T ] + W T
k+1/2 [T ]
+
UT
i,j,k
o
1 Xn
U i+1/2 T 2 + V j+1/2 T 2 + W k+1/2 T 2
2
i,j,k
o
1 X 2n
T i [U ] + j [V ] + k [W ]
2
i,j,k
n 1 e T o
X
1
3t
+
T2
2
e3t t
+
i,j,k
C.7
1
2
R
D
3
T 2 e13 e
t dv.
C.7.1
278
Z
=
D
h
i
h
i
X
e2v
e1u
lm
lm
i+1/2
i Af e3f + j+1/2
j Af e3f
e1v e3v
e2u e3u
i,j
X
i,j,k
C.7.2
h
i
h
i
e2v
e1u
i Aflm e3f i [1] +
j Aflm e3f j [1]
e1v e3v
e2u e3u
0
i
A lm h A lm k
dv
i
h
i
h
X 1
1
lm
lm
e1u e2u e3u u
A
j Af e3f
e1u i+1/2 T
e2u e3u
i,j,k
i
h
i
h
1
1
lm
lm
+
A +
i Af e3f
e1v e2u e3v v
e2u j+1/2 T
e1v e3v
h
i
h
io
Xn
e2u e3u u i+1/2 ATlm e1u u j Aflm e3f
i,j,k
n
h
i
h
io
+ e1v e3v v j+1/2 ATlm + e2v v i Aflm e3f
X
i [e2u e3u u] + j [e1v e3v v] ATlm
i,j,k
i+1/2 [e2v v] j+1/2 [e1u u] Aflm e3f
X
i,j,k
C.7.3
279
Dissipation of Enstrophy
The lateral momentum diffusion term dissipates the enstrophy when the eddy coefficients are horizontally uniform :
Z
h
i
k h A lm h A lm k
dv
=A
lm
Z
k [h ( k)] dv
D
lm
X
i,j,k
e2v
e1u
e3f i+1/2
i [e3f ] + j+1/2
j [e3f ]
e1v e3v
e2u e3u
A lm
(
X
i,j,k
1
i [e3f ]
e1v e3v
2
bv +
2 )
1
j [e3f ] bu
e2u e3u
C.7.4
Z
i
h
lm
lm
h h A h A k dv = h h A lm dv
X
lm e2u e3u
lm e1v e3v
[] + j Av
[]
i Au
e1u i+1/2
e2v j+1/2
i,j,k
X
i,j,k
e2u e3u lm
e1v e3v lm
Au i+1/2 [] i+1/2 [1] +
Av j+1/2 [] j+1/2 [1]
e1u
e2v
280
C.7.5
Z
h
i
lm
lm
lm
h h A h A k
h h () dv
dv = A
A lm
X
i,j,k
1
e2u e3u
e1v e3v
i
i+1/2 [] + j
j+1/2 []
e1t e2t e3t
e1t e2t e3t
e1u
e2v
[] bu +
[] bv
e1u i+1/2
e2v j+1/2
i,j,k
C.8
and
Z
Uh
1
e3 k
A vm Uh
e3 k
dv
1
Uh
e3 k
A vm Uh
e3 k
dv
vm
vm
X
Au
Av
u k
281
X A vm
u
i,j,k
e3uw
k+1/2 [u]
2
2
A vm
k+1/2 [v] e1v e2v
e1u e2u + v
e3vw
0
1
k
e3
1
e3 k
A vm Uh
e3 k
dv
X 1
1
e3f e1f e2f
i,j,k
e2v
1
k
k+1/2 [v]
e3v
e3vw
1
e1u
k
[u]
e1f e2f e3f 0
j+1/2
e3u
e3uw k+1/2
i+1/2
If the vertical diffusion coefficient is uniform over the whole domain, the enstrophy is
dissipated, i.e.
Z
k
1
e3 k
A vm Uh
e3 k
dv = 0
Z
k
1
e3 k
A vm Uh
e3 k
dv
X
i,j,k
e3f
vm
Av
e2v
i+1/2
k
[v]
e3v
e3vw k+1/2
vm
e1u
Au
j+1/2
k
[u]
e3u
e3uw k+1/2
282
e3f
i,j,k
vm
Av
1
k
[e2v v]
e3v
e3vw k+1/2 i+1/2
vm
1
Au
[e1u u]
e3u
e3uw k+1/2 j+1/2
Using the fact that the vertical diffusion coefficients are uniform, and that in z-coordinate,
the vertical scale factors do not depend on i and j so that : e3f = e3u = e3v = e3t and
e3w = e3uw = e3vw , it follows :
A
vm
k
i,j,k
A vm
1
e3w
k+1/2
i
i+1/2 [e2v v] j+1/2 [e1u u]
X 1
2
k+1/2 [] e1f e2f 0
e3w
i,j,k
1
e3 k
A vm Uh
e3 k
dv = 0
and the square of the horizontal divergence decreases (i.e. the horizontal divergence is
dissipated) if the vertical diffusion coefficient is uniform over the whole domain :
1
e3 k
A vm Uh
e3 k
dv = 0
1
e3 k
A vm Uh
e3 k
dv
X
i,j,k
e1t e2t
vm
vm
e2u
Au
i+1/2
k
[u]
e3u
e3uw k+1/2
vm
)
Av
e1v
k
[v]
e1t e2t e3t
+j+1/2
e3v
e3vw k+1/2
X
i,j,k
vm
A vm
1
i+1/2 k
[e2u u]
e3uw k+1/2
1
+j+1/2 k
[e1v v]
e3vw k+1/2
X k+1/2 []
i,j,k
283
e3w
i
X 1
A vm
X e1t e2t
i,j,k
C.9
e3w
2
k+1/2 []
284
C.9.1
Conservation of Tracers
constraint of conservation of tracers :
Z
(A T ) dv
D
X
lT e2u e3u
lT e1v e3v
i Au
[T ] + j Av
[T ]
e1u i+1/2
e2v j+1/2
i,j,k
e1t e2t
+ k AwvT
k+1/2 [T ]
e3t
In fact, this property simply results from the flux form of the operator.
C.9.2
X
i,j,k
lT e2u e3u
T i Au
[T ]
e1u i+1/2
+j
e1v e3v
AvlT
[T ]
e2v j+1/2
vT e1t e2t
+k Aw
[T ]
e3t k+1/2
X
i,j,k
2
1
AulT
D Coding Rules
Contents
D.1
D.2
D.3
D.4
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
286
286
288
289
286
Coding Rules
A model life is more than ten years. Its software, composed of a few hundred modules, is used by many people who are scientists or students and do not necessarily know
every aspect of computing very well. Moreover, a well thought-out program is easier to
read and understand, less difficult to modify, produces fewer bugs and is easier to maintain. Therefore, it is essential that the model development follows some rules :
- well planned and designed
- well written
- well documented (both on- and off-line)
- maintainable
- easily portable
- flexible.
To satisfy part of these aims, NEMO is written with a coding standard which is close to
the ECMWF rules, named DOCTOR [Gibson 1986]. These rules present some advantages
like :
- to provide a well presented program
- to use rules for variable names which allow recognition of their type (integer, real,
parameter, local or shared variables, etc. ).
This facilitates both the understanding and the debugging of an algorithm.
D.1
D.2
Coding conventions
- Use of the universal language F ORTRAN 90, and try to avoid obsolescent features
like statement functions, do not use GO TO and EQUIVALENCE statements.
287
- A continuation line begins with the character & indented by three spaces compared
to the previous line, while the previous line ended with the character &.
- All the variables must be declared. The code is usually compiled with implicit none.
- Never use continuation lines in the declaration of a variable. When searching a variable in the code through a grep command, the declaration line will be found.
- In the declaration of a PUBLIC variable, the comment part at the end of the line
should start with the two characters !:. the following UNIX command,
grep var_name *90 \ grep \!:
will display the module name and the line where the var name declaration is.
- Always use a three spaces indentation in DO loop, CASE, or IF-ELSEIF-ELSEENDIF statements.
- use a space after a comma, except when it appears to separate the indices of an array.
- use call to ctl stop routine instead of just a STOP.
288
D.3
Coding Rules
Naming Conventions
The purpose of the naming conventions is to use prefix letters to classify model variables. These conventions allow the variable type to be easily known and rapidly identified. The naming conventions are summarised in the Table below :
Type
/ Status
public
or
module
variable
integer
real
mn
but not
nn
abefg l
hoqr
but not
t to x
lp ld
but not
ll ln
fs rn
p
ld
but not
pp pf
z
ll
dummy
k
argument but not
kf
local
i
variable
loop
j
control
but not
jp
parameter jp
namelist nn
CPP
kf
macro
pp
rn
fs
logical
lp
ln
complex
cd
sd
dd
yd
cl
sl
dl
yl
cp
cn
sp
sn
dp
dn
yp
yn
y
but not
yp yd
yl yn
D.4
289
Contents
E.1 Griffiess formulation of iso-neutral diffusion . . . . . . .
E.1.1 Introduction . . . . . . . . . . . . . . . . . . . . . .
E.1.2 The standard discretization . . . . . . . . . . . . . .
E.1.3 Expression of the skew-flux in terms of triad slopes .
E.1.4 The full triad fluxes . . . . . . . . . . . . . . . . . .
E.1.5 Ensuring the scheme cannot increase tracer variance
E.1.6 Triad volumes in Griffess scheme and in NEMO . .
E.1.7 Summary of the scheme . . . . . . . . . . . . . . .
E.2 Eddy induced velocity and Skew flux formulation . . . .
E.2.1 Discrete Invariants of the skew flux formulation . . .
E.1
E.1.1
Introduction
.
.
.
.
.
.
.
.
.
.
291
291
292
293
295
296
297
298
299
301
We define a scheme that get its inspiration from the scheme of Griffies et al. [1998],
but is formulated within the NEMO framework, using scale factors rather than grid-sizes.
The off-diagonal terms of the small angle diffusion tensor (2.37) produce skew-fluxes
along the i- and j-directions resulting from the vertical tracer gradient :
+ r1
1 T
,
e3 k
+r2
1 T
e3 k
(E.1)
292
1 T
1 T
+ r2
e1 i
e1 i
(E.2)
where (2.38)
e3
r1 =
e1
e3
=
e1
1
T
T
S
S 1
+
+
i
i
k
k
is the i-component of the slope of the isoneutral surface relative to the computational
surface, and r2 is the j-component.
The extra vertical diffusive flux associated with the 33 component of the small angle
diffusion tensor is
1 T
(r12 + r22 )
.
(E.3)
e3 k
Since there are no cross terms involving r1 and r2 in the above, we can consider the
isoneutral diffusive fluxes separately in the i-k and j-k planes, just adding together the
vertical components from each plane. The following description will describe the fluxes
on the i-k plane.
There is no natural discretization for the i-component of the skew-flux, (E.1), as although it must be evaluated at u-points, it involves vertical gradients (both for the tracer
and the slope r1 ), defined at w-points. Similarly, the vertical skew flux, (E.2), is evaluated
at w-points but involves horizontal gradients defined at u-points.
E.1.2
the 1/e3uk
i+1/2
i+1/2
i+1/2
Fuskew
k
i+ 12
r1
e3uk
i+1/2 []
where
r1
i,k
i,k
= ki+ 1 e2uk
i+1/2
i+1/2
e1uk
i+1/2
i,k
k T
i,k
293
i,k
Unfortunately the resulting combination k of a k average and a k difference reduces to k+1 k1 , so two-grid-point oscillations are invisible to this discretization of
the iso-neutral operator. These computational modes will not be damped by this operator,
and may even possibly be amplified by it. Consequently, applying this operator to a tracer
does not guarantee the decrease of its global-average variance. To correct this, we introduced a smoothing of the slopes of the iso-neutral surfaces (see 9). This technique works
fine for T and S as they are active tracers (i.e. they enter the computation of density), but
it does not work for a passive tracer.
E.1.3
F IG . E.1 (a) Arrangement of triads Si and tracer gradients to give lateral tracer
flux from box i, k to i + 1, k (b) Triads Si0 and tracer gradients to give vertical
tracer flux from box i, k to i, k + 1.
gradients at each w-point surrounding the u-point with the corresponding triad slope
calculated from the lateral density gradient across the u-point divided by the vertical density gradient at the same w-point as the tracer gradient. See Fig. E.1a, where the thick
lines denote the tracer gradients, and the thin lines the corresponding triads, with slopes
s1 , . . . s4 . The total area-integrated skew-flux from tracer cell i, k to i + 1, k
Fu13
k
i+ 21
k+ 12
k+ 21
= ki+1 a1 s1 k+ 1 T i+1 /e3wi+1
+ ki a2 s2 k+ 1 T i /e3wi+1
2
+ ki+1 a3 s3 k 1 T
i+1
k+ 12
/e3wi+1
k+ 12
+ ki a4 s4 k 1 T i /e3wi+1
, (E.4)
2
where the contributions of the triad fluxes are weighted by areas a1 , . . . a4 , and is now
defined at the tracer points rather than the u-points. This discretization gives a much closer
stencil, and disallows the two-point computational modes.
294
The vertical skew flux (E.2) from tracer cell i, k to i, k + 1 at the w-point i, k + 12 is
constructed similarly (Fig. E.1b) by multiplying lateral tracer gradients from each of the
four surrounding u-points by the appropriate triad slope :
h
i
h
i
k+ 1
k+1 0 0
k+1
Fw31 i 2 = k+1
a01 s01 i 1 T k+1 /e3u k+1
a
s
/e3u k+1
1 T
1 + i
2
2
i
i+
i 2
i+ 12
2
2
h i
h i
+ ki a03 s03 i 1 T k /e3u ki 1 + ki a04 s04 i+ 1 T k /e3u ki+ 1 . (E.5)
2
We notate the triad slopes in terms of the anchor point i, k (appearing in both the
vertical and lateral gradient), and the u- and w-points (i + ip , k), (i, k + kp ) at the centres
of the arms of the triad as follows (see also Fig. E.1) :
k kp
i R ip
k+k
k
e3w i p (/)i i+ip [T k ] i+ip [S k ]
.
e1u ki+ip (/)ki k+kp [T i ] k+kp [S i ]
(E.6)
In calculating the slopes of the local neutral surfaces, the expansion coefficients and
are evaluated at the anchor points of the triad 1 , while the metrics are calculated at the uand w-points on the arms.
F IG . E.2 Triad notation for quarter cells.T-cells are inside boxes, while the
i + 12 , k u-cell is shaded in green and the i, k + 12 w-cell is shaded in pink.
k
Each triad {ki ipp } is associated (Fig. E.2) with the quarter cell that is the intersection
of the i, k T-cell, the i + ip , k u-cell and the i, k + kp w-cell. Expressing the slopes si and
1
Note that in (E.6) we use the ratio / instead of multiplying the temperature derivative by
and the salinity derivative by . This is more efficient as the ratio / can to be evaluated directly
295
k R1/2 .
i 1/2
k Rk p
i ip
is used once (as an s) to calculate the lateral flux along its u-arm, at (i + ip , k),
and then again as an s0 to calculate the vertical flux along its w-arm at (i, k + kp ). Each
vertical area ai used to calculate the lateral flux and horizontal area a0i used to calculate
the vertical flux can also be identified as the area across the u- and w-arms of a unique
k
k
triad, and we can notate these areas, similarly to the triad slopes, as ki Au ipp , ki Aw ipp , where
1/2
1/2
E.1.4
can be identified with each triad. Then, because the same metric factors e3w i p and
k
e1u ki+ip are employed for both the density gradients in ki Ripp and the tracer gradients, the
lateral density flux associated with each triad separately disappears.
k
and slopes s0
[T
k+k
i+i
k
k
k
k
p
p
p
p
p
k
kk
k
ki Ripp
(E.11)
i Fw ip (T ) = Ai i Aw ip
i R ip
k+kp
e1u ki+ip
e3w i
.
k
k
k
k
(E.12)
= ki Aw ipp ki Au ipp ki Ripp ki Fu ipp (T )
296
may be associated with each triad. Each vertical density flux ki Fw ipp () associated with
k
a triad then separately disappears (because the lateral flux ki Fu ipp () disappears). Consek+ 1
k+ 1
quently the total vertical density flux Fw31 i 2 + Fw33 i 2 from tracer cell i, k to i, k+1
must also vanish since it is a sum of four such triad fluxes.
We can explicitly identify (Fig. E.2) the triads associated with the si , ai , and s0i , a0i
used in the definition of the u-fluxes and w-fluxes in (E.5), (E.4), (E.7) (E.10) and Fig. E.1
to write out the iso-neutral fluxes at u- and w-points as sums of the triad fluxes that cross
the u- and w-faces :
kp
k
X i+1/2ip Fu ip (T )
(E.13)
Fiso (T )
.
ip , kp k+1/2kp F kp (T )
w ip
i
E.1.5
and a vertical flux ki Fw ipp (T ) across the w-point i, k + kp . The lateral flux drives a net rate
of change of variance at points i + ip 12 , k and i + ip + 21 , k of
bT ki+ip 1/2
T
T
t
k
+
i+ip 1/2
=
=
bT ki+ip +1/2
T
T
t
k
k
k
Ti+i
F p (T )
p 1/2 i u ip
kp
k
k
i Fu ip (T ) i+ip [T ],
k
i+ip +1/2
k
k
Ti+i
F p (T )
p +1/2 i u ip
(E.14)
while the vertical flux similarly drives a net rate of change of variance at points i, k+kp 12
and i, k + kp + 12 of
kp
k
i
(E.15)
i Fw ip (T ) k+kp [T ].
k
The total variance tendency driven by the triad is the sum of these two. Expanding ki Fu ipp (T )
k
kp
k
i A u ip
i+ip [T k ] k kp k+kp [T i ]
i R ip
k+k
e1u ki+ip
e3w i p
kp
k
i A w ip
!
i+ip [T k ]
i
i+ip [T k ]
k kp k+kp [T ]
R
i ip
k+k
e1u ki+ip
e3w i p
k
)
k kp
i
i Rip k+kp [T ]
The key point is then that if we require ki Au ipp and ki Aw ipp to be related to a triad volume
k Vkp
i ip
by
k kp
i Vip
kp
k
k
i Au ip e1u i+ip
kp
k+kp
k
,
i Aw ip e3w i
(E.16)
297
i
i+ip [T k ]
k kp k+kp [T ]
R
i ip
k+k
e1u ki+ip
e3w i p
!2
0.
(E.17)
k
Thus, the constraint (E.16) ensures that the fluxes associated with a given slope triad ki Ripp
do not increase the net variance. Since the total fluxes are sums of such fluxes from the
various triads, this constraint, applied to all triads, is sufficient to ensure that the globally
integrated variance does not increase.
The expression (E.16) can be interpreted as a discretization of the global integral
Z
R
1 2
T
dV
=
F T dV,
(E.18)
2
t
k
where, within each triad volume ki Vipp , the lateral and vertical fluxes/unit area
F=
kp
kp k
kp
kp
k
k
k
i Fu ip (T )/i Au ip , i Fw ip (T )/i Aw ip
E.1.6
To complete the discretization we now need only specify the triad volumes ki Vipp .
k
Griffies et al. [1998] identify these ki Vipp as the volumes of the quarter cells, defined in
terms of the distances between T, u,f and w-points. This is the natural discretization of
(E.18). The NEMO model, however, operates with scale factors instead of grid sizes, and
scale factors for the quarter cells are not defined. Instead, therefore we simply choose
k kp
i V ip
= 41 bu ki+ip ,
(E.19)
as a quarter of the volume of the u-cell inside which the triad quarter-cell lies. This has the
nice property that when the slopes R vanish, the lateral flux from tracer cell i, k to i + 1, k
reduces to the classical form
k
A i+1/2
bu ki+1/2 i+1/2 [T k ]
e1u ki+ip
e1u ki+ip
k
A i+1/2
(E.20)
In fact if the diffusive coefficient is defined at u-points, so that we employ Aki+ip instead
k
of Aki in the definitions of the triad fluxes (E.8) and (E.11), we can replace A i+1/2 by
Aki+1/2 in the above.
298
E.1.7
i
h
io
1 X n hk
k
k+1/2kp
k
i i+1/2ip Fu ipp + k i
Fw ipp
bT
(E.21)
ip , k p
where bT = e1T e2T e3T is the volume of T -cells. The diffusion scheme satisfies the
following six properties :
horizontal diffusion The discretization of the diffusion operator recovers (E.20) the
traditional five-point Laplacian in the limit of flat iso-neutral direction :
e2u e3u i
1
k
T
i
(E.22)
Dl =
A i+1/2 [T ]
when ki Ripp = 0
bT
e1u
implicit treatment in the vertical Only tracer values associated with a single water
column appear in the expression (E.10) for the 33 fluxes, vertical fluxes driven by
vertical gradients. This is of paramount importance since it means that an implicit
in time algorithm can be used to solve the vertical diffusion equation. This is a
necessity since the vertical eddy diffusivity associated with this term,
2
1 X k kp k k kp 2
1 X
k
k k kp
bu i+ip Ai i Rip
=
, (E.23)
i V ip Ai
i R ip
bw
4bw
ip , k p
ip , k p
(where bw = e1w e2w e3w is the volume of w-cells) can be quite large.
pure iso-neutral operator The iso-neutral flux of locally referenced potential density
is zero. See (E.9) and (E.12).
conservation of tracer The iso-neutral diffusion conserves tracer content, i.e.
X
DlT bT = 0
(E.24)
i,j,k
This property is trivially satisfied since the iso-neutral diffusive operator is written
in flux form.
no increase of tracer variance The iso-neutral diffusion does not increase the tracer
variance, i.e.
X
T DlT bT 0
(E.25)
i,j,k
299
(E.26)
i,j,k
In other word, there is no need to develop a specific routine from the adjoint of this
operator. We just have to apply the same routine. This property can be demonstrated similarly to the proof of the no increase of tracer variance property. The
contribution by a single triad towards the left hand side of (E.26), can be found by
replacing [T ] by [S] in (E.14) and (E.14). This results in a term similar to (E.17),
!
i]
[S
i+ip [S k ]
k+k
k
p
ki Ripp
.
k+k
e1u ki+ip
e3w i p
(E.27)
This is symmetrical in T and S, so exactly the same term arises from the discretization of this triads contribution towards the RHS of (E.26).
k
Aki ki Vipp
E.2
i
i+ip [T k ]
k kp k+kp [T ]
R
i
ip
k+k
e1u ki+ip
e3w i p
(E.28)
where Ae is the eddy induced velocity coefficient, and ri and rj the slopes between the
iso-neutral and the geopotential surfaces.
The traditional way to implement this additional advection is to add it to the Eulerian
velocity prior to computing the tracer advection. This allows us to take advantage of all
the advection schemes offered for the tracers (see 5.1) and not just a 2nd order advection
scheme. This is particularly useful for passive tracers where positivity of the advection
scheme is of paramount importance.
300
Griffies [1998] introduces another way to implement the eddy induced advection, the
so-called skew form. It is based on a transformation of the advective fluxes using the nondivergent nature of the eddy induced velocity. For example in the (i,k) plane, the tracer
advective fluxes can be transformed as follows :
e2 e3 u
k (e2 Ae ri ) T
T
Feiv =
T =
e1 e2 w
+i (e2 Ae ri ) T
k (e2 Ae ri T )
+e2 Ae ri k T
=
+
+i (e2 Ae ri T )
e2 Ae ri i T
and since the eddy induces velocity field is no-divergent, we end up with the skew form
of the eddy induced advective fluxes :
+e2 Ae ri k T
FTeiv =
(E.29)
e2 Ae ri i T
The tendency associated with eddy induced velocity is then simply the divergence of the
(E.29) fluxes. It naturally conserves the tracer content, as it is expressed in flux form. It
also preserve the tracer variance.
The discrete form of (E.29) using the slopes (E.6) and defining Ae at T -point is then
given by :
kp
k
k
k
X +e2u i+1/2ip Ae i+1/2ip i+1/2ip Rip k+kp [Ti+1/2ip ]
FTeiv
(E.30)
k+1/2k
p
ip , kp e k+1/2kp A k+1/2kp k+1/2kp Rkp
]
2u i
ei
i
ip i+ip [T
Note that (E.30) is valid in z-coordinate with or without partial cells. In z or s-coordinate,
the the slope between the level and the geopotential surfaces must be added to R for the
discret form to be exact.
Such a choice of discretisation is consistent with the iso-neutral operator as it uses the
same definition for the slopes. It also ensures the conservation of the tracer variance (see
Appendix E.2.1), i.e. it does not include a diffusive component but is a pure advection
term.
E.2.1
301
The discrete form of its left hand side is obtained using (E.30)
(
i
h
XX
kp
k
k
k
i e2u i+ip +1/2 Ae i+ip +1/2 i+ip +1/2 Rip k+kp [Ti+ip +1/2 ] Tik
i,k ip , kp
h
k+k +1/2
k+k +1/2
k e2u i p
Ae i p
k+kp +1/2 kp
R ip
i
i+ip [T
k+kp +1/2
i
] Tik
k+kp [Ti+ip +1/2 ] i+1/2 [T k ]
i,k ip , kp
k+k +1/2
e2u i p
i+ip [T
k+kp +1/2
] k+1/2 [Ti ]
+e2u ki
Ae ki
+e2u ki+1
Ae ki+1
+e2u ki
Ae ki
e2u k+1
Ae k+1
i
i
e2u ki
Ae ki
e2u k+1
i
e2u ki
Ae k+1
i
Ae ki
k R1/2
i +1/2
k R+1/2
i+1 1/2
k R+1/2
i +1/2
k+1 1/2
R1/2
i
k R+1/2
i 1/2
k+1 1/2
R+1/2
i
k R+1/2
i +1/2
k1/2 [Ti
] i+1/2 [T k ]
] i+1/2 [T k ]
k+1/2 [Ti ]
[T k+1 ]
k+1/2 [Ti ]
i+1/2 [T k ]
k+1/2 [Ti ]
i+1/2
+1/2
The two terms associated with the triad ki R+1/2 are the same but of opposite signs, they
1/2
cancel out. Exactly the same thing occurs for the triad ki R1/2 . The two terms associated
1/2
with the triad ki R+1/2 are the same but both of opposite signs and shifted by 1 in k direction. When summing over k they cancel out with the neighbouring grid points. Exactly
+1/2
the same thing occurs for the triad ki R1/2 in the i direction. Therefore the sum over the
domain is zero, i.e. the variance of the tracer is preserved by the discretisation of the skew
fluxes.
Index
CPP keys
key agrif, 244
key antarctic, 158, 244
key arctic, 158, 244
key asminc, 224
key bdy, 150
key c1d, 240
key coupled, 125
key cpl carbon cycle, 125
key diaar5, 201, 202, 205
key diahth, 201
key diainstant, 190
key diaobs, 208
key dimgout, 190
key dtasal, 85
key dtatem, 85
key dynldf c1d, 156, 157
key dynldf c2d, 156, 157
key dynldf c3d, 156, 158
key dynspg exp, 106, 185
key dynspg flt, 106, 151, 185
key dynspg ts, 106, 151, 185
key eel r2, 245
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
INDEX
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
303
304
ppdzmin, 60
ppe1 deg, 54
ppe1 m, 55
ppe2 deg, 54
ppe2 m, 55
ppglam0, 55
ppglamt0, 55
ppgphi0, 55
pphmax, 58, 60
ppkth, 60
ppsur, 60
Modules
closea, 230
diaar5, 202, 205
diahth, 201
diaptr, 201
diawri, 190
divcur, 95, 126, 137
domask, 137
domhgr, 51, 53, 54, 228
dommsk, 228
domzgr, 53, 55, 58, 62, 63
dynadv, 101
dynadv ubs, 102
dynbfr, 182, 184, 185
dynhpg, 89, 102
dynkeg, 99
dynldf, 94, 107
dynnxt, 38, 105, 106, 111
dynsp flt, 111
dynspg, 105, 125
dynspg exp, 106
dynspg flt, 105, 106, 234
dynvor, 96, 100
dynzad, 100
dynzdf, 94, 109, 115, 166
eosbn2, 66, 87, 89, 181
fldread, 9, 85, 117
geo2ocean, 129
lbclnk, 137, 139
ldfdyn, 156, 157
ldfdyn c2d, 158
ldfeiv, 163
INDEX
ldfslp, 73, 159
ldftra, 73, 156, 157
lib fortran, 232, 233
lib mpp, 139
obc dta, 146
obc ini, 149
obc par, 143, 144
obcdta, 143
obcrad, 143
par oce, 51, 53, 60, 137, 140, 142, 230
phycst, 53, 66, 8789
sbc ana gyre, 122
sbcana, 121, 122
sbcapr, 125
sbcblk clio, 122, 123
sbcblk core, 122
sbccpl, 124
sbcdcy, 127
sbcflx, 122
sbcfwb, 131
sbcice if, 131
sbcmod, 76, 116
sbcrnf, 125
sbcssr, 125, 130
solpcg, 237
solsor, 235
sshwzv, 95
traadv, 67
traadv cen2, 69
traadv eiv, 163
traadv lap, 74
traadv qck, 73
traadv tvd, 70, 71
traadv tvd2, 71
traadv ubs, 72
trabbc, 80
trabbl, 81
tracla, 228
tradmp, 8486
traldf, 7, 73, 89
traldf bilap, 75
traldf bilapg, 75
traldf iso, 74
INDEX
traldf lap, 74
tranpc, 66
tranxt, 38, 86, 87
traqsr, 78, 79, 115
trasbc, 76, 115
trazdf, 74, 75, 87, 166
trc oce, 79
trdmod, 200
zdfbfr, 181185
zdfddm, 180
zdfini, 166
zdfkpp, 166, 180
zdfric, 166
zdftke, 166
zpsdhe, 103
zpshde, 74, 89, 91
Namelist parameters
namnc4, 200
cn dir, 117
cn dta fla T, 152
cn dta fla U, 152
cn dta fla V, 152
cn dta frs T, 152
cn dta frs U, 152
cn dta frs V, 152
enactfiles, 208, 209
endailyavtypes, 208
iom put, 200
ln ana, 114
ln apr dyn, 114, 125
ln asmdin, 224
ln asmiau, 224
ln bfr2d, 183, 184
ln blk core, 127
ln clim, 152, 153
ln clio, 114, 122, 123, 128
ln core, 114, 122, 128
ln cpl, 114, 125
ln crban, 176
ln ctl, 233, 234
ln diaptr, 201
ln dm2dc, 114, 127
ln dyn fla, 151
305
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
ln
306
INDEX
ln t3d, 209
ln tides, 151
ln tmx itf, 187
ln tra frs, 151
ln traadv cen2, 69
ln traadv cen4, 69
ln traadv muscl, 71
ln traadv muscl2, 71
ln traadv ppm, 73
ln traadv qck, 72
ln traadv tvd, 70
ln traadv ubs, 71
ln trabbc, 80
ln traldf bilap, 75
ln traldf grif, 75
ln traldf hor, 74, 75, 159
ln traldf iso, 74, 75
ln traldf lap, 73, 74
ln traldf level, 74, 75
ln tranpc, 177
ln traqsr, 115
ln trdmld instant, 200
ln trdmld restart, 200
ln zco, 57, 58, 74, 75
ln zdfevd, 179, 180
ln zdfexp, 40, 76, 110, 166, 179
ln zdfnpc, 177, 180
ln zdftmx itf, 187
ln zps, 57, 60, 74, 75, 89, 90
nf sbc, 116
nn acc, 230, 231
nn atfp, 111
nn baro, 106, 185
nn bathy, 57, 58
nn bbl adv, 82, 83
nn bbl ldf, 82
nn bench, 234
nn bit cmp, 234
nn botfr, 183
nn chdta, 79
nn clo, 175, 176
nn clos, 176
nn ctls, 200
nn dtactl, 153
nn dynhpg rst, 42, 44, 105
nn ediff, 168
nn ediss, 168
nn eos, 87, 88, 160
nn etau, 172
nn evdm, 179
nn fsbc, 114, 118, 128, 193
nn fwb, 114, 131
nn geoflx, 80, 81
nn geoflx cst, 81
nn hdmp, 85
nn htau, 172
nn ice, 114
nn max, 236238
nn msh, 55, 142
nn mxl, 169
nn npc, 177
nn obcdta, 145
nn pdl, 168
nn ric, 167
nn rimwidth, 151
nn solv, 234, 235, 237
nn stab func, 175
nn tau000, 121
nn tkebc bot, 176
nn tkebc surf, 176
nn ucf, 200
nn volctl, 153
nn zdfexp, 40, 76, 110
nn zdmp, 85
nn ice, 130
nz rnf, 126
opa.F90, 208
profiles 01nc, 208
rn abs, 78
rn aeiv, 163
rn ahm0, 157, 158
rn ahmb0, 158
rn aht0, 157, 158
rn ahtb0, 158
rn ahtbbl, 82
rn alp, 167
INDEX
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
rn
alpha, 88
atfp, 39, 86
avevd, 179
avm0, 167, 168
avmri, 167
avt0, 167, 168
beta, 88
bfeb2, 183, 184
bfri2, 184
bfric1, 183
bfric2, 183
bfrien, 183
bot, 86
charn, 176
clim galp, 176
crban, 176
dep, 86
dpein, 146, 148
dpeob, 146
dpwin, 146
dpwob, 146
e3zps min, 60
e3zps rat, 60
ebb, 168, 171
efr, 172
emin, 168
emin0, 171
emp0, 121
eps, 236, 238
gambbl, 84
htmx, 186
lc, 172
lmin0, 169
lsurf, 170
me, 186
n2min, 186
qns0, 121
qsr0, 121
rdt, 185, 193, 231
rdth, 231
rdtmax, 231, 232
rdtmin, 231, 232
shlat, 134, 135, 137
307
rn si0, 79
rn sor, 236
rn surf, 86
rn tfe, 186
rn tfe itf, 187
rn utau0, 121
rn vtau0, 121
sn apr, 125
sn qsr, 128
step.F90, 208
xmlio server.def, 200
Routines
cofdis, 86
dom msk nsa, 137
dtacof, 85, 86
dyn spg ts, 185
dyncor c1d, 240
dynnxt c1d, 240
fld read, 117, 120
hgr read, 54
inimpp2, 142
ldf dyn c2d orca, 158
ldfslp init, 159
sbc blk init, 117
sbc rnf div, 126
step, 240
step c1d, 240
trc oce rgb, 79
zdf bfr, 185
zgr sco, 62
Bibliographie
Adcroft, A. and J.-M. Campin, 2004 : Re-scaled height coordinates for accurate representation of free-surface flows in ocean circulation models. Ocean Modelling, 7, 269
284, doi :10.1016/j.ocemod.2003.09.003, URL http://dx.doi.org/10.1016/
j.ocemod.2003.09.003.
Arakawa, A. and Y.-J. G. Hsu, 1990 : Energy conserving and potential-enstrophy dissipating schemes for the shallow water equations. Mon. Wea. Rev., 118 (10), 19601969.
Arakawa, A. and V. R. Lamb, 1981 : A potential enstrophy and energy conserving scheme
for the shallow water equations. Mon. Wea. Rev., 109 (1), 1836.
Asselin, R., 1972 : Frequency filter for time integrations. Mon. Wea. Rev., 100 (6), 487
490.
Axell, L. B., 2002 : Wind-driven internal waves and langmuir circulations in a numerical ocean model of the southern baltic sea. J. Geophys. Res, 107, doi :10.1029/
2001JC000922, URL http://dx.doi.org/10.1029/2001JC000922.
Barnier, B., G. Madec, T. Penduff, J.-M. Molines, A.-M. Treguier, J. L. Sommer,
A. Beckmann, A. Biastoch, C. Boning, J. Dengg, C. Derval, E. Durand, S. Gulev, E. Remy, C. Talandier, S. Theetten, M. Maltrud, J. McClean, and B. D. Cuevas, 2006 : Impact of partial steps and momentum advection schemes in a global ocean circulation model at eddy-permitting resolution. Ocean Dyn., 56, 543
567, doi :10.1007/s10236-006-0082-1, URL http://dx.doi.org/10.1007/
s10236-006-0082-1.
310
BIBLIOGRAPHIE
Barnier, B., P. Marchesiello, and A. de Miranda, 1996 : Modeling the ocean circulation
in the south atlantic : A strategy for dealing with open boundaries. The South Atlantic : Present and Past Circulation, G.Wefer, W. Berger, G. Siedler, and D. Webb, Eds.,
Springer-Verlag, Berlin, 289304.
Barnier, B., P. Marchesiello, A. P. de Miranda, J. Molines, and M. Coulibaly, 1998 : A
sigma-coordinate primitive equation model for studying the circulation in the south
atlantic i, model configuration with error estimates. Deep-Sea Res., 45, 543572.
Beckmann, A. and R. Doscher, 1997 : A method for improved representation of dense water spreading over topography in geopotential-coordinate models. J. Phys. Oceanogr.,
27, 581591.
Beckmann, A. and D. B. Haidvogel, 1993 : Numerical simulation of flow around a tall isolated seamount. part i - problem formulation and model accuracy. J. Phys. Oceanogr.,
23 (8), 17361753.
Bernie, D., E. Guilyardi, G. Madec, J. M. Slingo, and S. J. Woolnough, 2007 : Impact
of resolving the diurnal cycle in an oceanatmosphere gcm. part 1 : a diurnally forced
ogcm. Clim. Dyn., 29 (6), 575590.
Bernie, D. J., S. J. Woolnough, J. M. Slingo, and E. Guilyardi, 2005 : Modelling diurnal
and intraseasonal variability of the ocean mixed layer. J. Climate, 18 (8), 11901200.
Blanke, B. and P. Delecluse, 1993 : Low frequency variability of the tropical atlantic ocean
simulated by a general circulation model with mixed layer physics. J. Phys. Oceanogr.,
23, 13631388.
Blanke, B. and S. Raynaud, 1997 : Kinematics of the pacific equatorial undercurrent : An
eulerian and lagrangian approach from gcm results. J. Phys. Oceanogr., 27 (6), 1038
1053.
Blayo, E. and L. Debreu, 2005 : Revisiting open boundary conditions from the point of
view of characteristic variables. Ocean Modelling, 9, 231252.
Bloom, S. C., L. L. Takacs, A. M. D. Silva, and D. Ledvina, 1996 : Data assimilation
using incremental analysis updates. Mon. Wea. Rev., 124, 12561271.
Bougeault, P. and P. Lacarrere, 1989 : Parameterization of orography-induced turbulence
in a mesobetascale model. Mon. Wea. Rev., 117 (8), 18721890.
Bouillon, S., M. M. Maqueda, V. Legat, and T. Fichefet, 2009 : An elastic-viscousplastic sea ice model formulated on arakawa b and c grids. Ocean Modelling, 27, 174
184, doi :10.1016/j.ocemod.2009.01.004, URL http://dx.doi.org/10.1016/
j.ocemod.2009.01.004.
BIBLIOGRAPHIE
311
Brodeau, L., B. Barnier, A.-M. Treguier, T. Penduff, and S. Gulev, 2009 : An era40-based
atmospheric forcing for global ocean circulation models. Ocean Modelling, 31 (3-4),
88104.
Brown, J. A. and K. A. Campana, 1978 : An economical time-differencing system for
numerical weather prediction. Mon. Wea. Rev., 106 (8), 11251136.
Bryan, K., 1984 : Accelerating the convergence to equilibrium of ocean-climate models.
J. Phys. Oceanogr., 14, 666673.
Bryden, H. L., 1973 : New polynomials for thermal expansion, adiabatic temperature
gradient and potential temperature of sea water. Deep-Sea Res., 20, 401408.
Burchard, H., 2002 : Energy-conserving discretisation of turbulent shear
and buoyancy production. Ocean Modelling, 4 (3-4), 347361, doi :
10.1016/S1463-5003(02)00009-4,
URL
http://dx.doi.org/10.1016/
S1463-5003(02)00009-4.
Campin, J.-M., A. Adcroft, C. Hill, and J. Marshall, 2004 : Conservation of properties in
a free-surface model. Ocean Modelling, 6 (3-4), 221244.
Campin, J.-M. and H. Goosse, 1999 : Parameterization of density-driven downsloping
flow for a coarse-resolution ocean model in z-coordinate. Tellus, 51, 412430.
Campin, J.-M., J. Marshall, and D. Ferreira, 2008 : Sea ice-ocean coupling using a rescaled vertical coordinate z*. Ocean Modelling, 24 (1-2), 114, doi :10.1016/j.ocemod.
2008.05.005, URL http://dx.doi.org/10.1016/j.ocemod.2008.05.
005.
Canuto, V. M., A. Howard, Y. Cheng, and M. S. Dubovikov, 2001 : Ocean turbulence.
parti : One-point closure model-momentum and heat vertical diffusivities. J. Phys.
Oceanogr., 24 (12), 25462559.
Carr`ere, L. and F. Lyard, 2003 : Modelling the barotropic response of the global ocean
to atmospheric wind and pressure forcing - comparisons with observations. Geophys.
Res. Let., 30 (6), doi :10.1029/2002GL016473, URL http://dx.doi.org/10.
1029/2002GL016473.
Chanut, J., 2005 : Nesting code for nemo. Tech. rep., European Union : Marine Environment and Security for the European Area (MERSEA) Integrated Project, mERSEAWP09-MERCA-TASK-9.1.1.
Chassignet, E. P., L. T. Smith, and G. R. Halliwell, 2003 : North atlantic simulations with
the hybrid coordinate ocean model (hycom) : Impact of the vertical coordinate choice,
reference pressure, and thermobaricity. J. Phys. Oceanogr., 33, 25042526.
312
BIBLIOGRAPHIE
Cox, M., 1987 : Isopycnal diffusion in a z-coordinate ocean model. Ocean Modelling, 74,
19.
Craig, P. D. and M. L. Banner, 1994 : Modeling wave-enhanced turbulence in the ocean
surface layer. J. Phys. Oceanogr., 24 (12), 25462559.
Craik, A. D. D. and S. Leibovich, 1976 : A rational model for langmuir circulations. J.
Fluid Mech., 73, 401426.
DAlessio, S. J. D., K. Abdella, and N. A. McFarlane, 1998 : A new second-order turbulence closure scheme for modeling the oceanic mixed layer. J. Phys. Oceanogr., 28,
16241641.
Daley, R. and E. Barker, 2001 : NAVDAS Source Book 2001. NRL/PU/7530-01-441, Available from the Naval Research Laboratory, Monterey, CA., 93943-5502, 163pp pp.
Davies, H., 1976 : A lateral boundary formulation for multi-level prediction models.
Quart. J. Roy. Meteor. Soc., 102, 405418.
de Boyer Montegut, C., G. Madec, A. Fischer, A. Lazar, and D. Iudicone, 2004 : Mixed
layer depth over the global ocean : An examination of profile data and a profile-based
climatology. J. Geophys. Res, 109, C12 003, doi :10.1029/2004JC002378, URL http:
//dx.doi.org/10.1029/2004JC002378.
Debreu, L., C. Vouland, and E. Blayo, 2008 : Agrif : Adaptive grid refinement in fortran.
Computers and Geosciences, 34, 813.
Delecluse, P. and G. Madec, 2000 : Ocean modelling and the role of the ocean in the
climate system. In Modeling the Earths Climate and its Variability, Les Houches, Session, LXVII 1997, Eds. W. R. Holland, S. Joussaume and F. David, Elsevier Science,
237313.
Drijfhout, S. S., 1994 : Heat transport by mesoscale eddies in an ocean circulation model.
J. Phys. Oceanogr., 24, 353369.
Dukowicz, J. K. and R. D. Smith, 1994 : Implicit free-surface method for the bryan-coxsemtner ocean model. J. Geophys. Res, 99, 79918014.
Durran, D., 2001 : Open boundary conditions : fact and fiction. Advances in Mathematical
Modelling of Atmosphere and Ocean Dynamics, Hodnett, P., Ed., Kluwer Academic
Publishers.
Egbert, G. and R. Ray, 2000 : Significant dissipation of tidal energy in the deep ocean
inferred from satellite altimeter data. Nature, 405, 775778.
, 2001 : Estimates of m2 tidal energy dissipation from topex/poseidon altimeter
data. J. Geophys. Res, 106, 22 47522 502.
BIBLIOGRAPHIE
313
314
BIBLIOGRAPHIE
BIBLIOGRAPHIE
315
316
BIBLIOGRAPHIE
BIBLIOGRAPHIE
317
Leclair, M. and G. Madec, 2009 : A conservative leap-frog time stepping method. Ocean
Modelling, 30 (2-3), 8894, doi :10.1016/j.ocemod.2009.06.006, URL http://dx.
doi.org/.
, 2010 : z-coordinate, an arbitrary lagrangian-eulerian coordinate separating high
and low frequency. Ocean Modelling, submitted.
Lengaigne, M., G. Madec, G. Alory, and C. Menkes, 2003 : Sensitivity of the tropical pacific ocean to isopycnal diffusion on tracer and dynamics. J. Geophys. Res,
108 (C11), 3345, doi :10.1029/2002JC001704, URL http://dx.doi.org/10.
1029/2002JC001704.
Lengaigne, M., C. Menkes, O. Aumont, T. Gorgues, L. Bopp, and J.-M. A. G. Madec,
2007 : Bio-physical feedbacks on the tropical pacific climate in a coupled general circulation model. Clim. Dyn., 28, 503516.
Leonard, B. P., 1979 : A stable and accurate convective modelling procedure based on
quadratic upstream interpolation. Computer Methods in Applied Mechanics and Engineering, 19, 5998.
, 1991 : The ultimate conservative difference scheme applied to unsteady one
dimensional advection. Computer Methods in Applied Mechanics and Engineering,
1774.
Levier, B., A.-M. Treguier, G. Madec, and V. Garnier, 2007 : Free surface and variable
volume in the nemo code. Tech. rep., MERSEA MERSEA IP report WP09-CNRSSTR-03-1A, 47pp, available on the NEMO web site.
Levy, M., A. Estubier, and G. Madec, 2001 : Choice of an advection scheme for biogeochemical models. Geophys. Res. Let., 28.
Levy, M., P. Klein, A.-M. Treguier, D. Iovino, G. Madec, S. Masson, and T. Takahashi,
2010 : Impacts of sub-mesoscale physics on idealized gyres. Ocean Modelling, 34 (12), doi :10.1016/j.ocemod.2010.04.001, URL http://dx.doi.org/10.1016/
j.ocemod.2010.04.001.
Li, M. and C. Garrett, 1993 : Cell merging and the jet/downwelling ratio in langmuir
circulation. J. Mar. Res., 51, 737769.
Lott, F., G. Madec, and J. Verron, 1990 : Topographic experiments in an ocean general
circulation model. Ocean Modelling, 88, 14.
Madec, G., 1990 : La formation deau profonde et son impact sur la circulation regionale
en mediterranee occidentale - une approche numerique. Ph.D. thesis, Universite Pierre
et Marie Curie, Paris, France, 194pp.
318
BIBLIOGRAPHIE
Madec, G., M. Chartier, and M. Crepon, 1991a : Effect of thermohaline forcing variability
on deep water formation in the northwestern mediterranean sea - a high resulution
three-dimensional study. Dyn. Atmos. Ocean, 15, 301332.
Madec, G., M. Chartier, P. Delecluse, and M. Crepon, 1991b : A three-dimensional numerical study of deep water formation in the northwestern mediterranean sea . J. Phys.
Oceanogr., 21, 13491371.
Madec, G. and M. Crepon, 1991 : Deep convection and deep water formation in the
oceans, chap. Thermohaline-driven deep water formation in the Northwestern Mediterranean Sea, 241265. Elsevier Oceanographic Series, P.C. Chu and J.C. Gascard
(Eds.).
Madec, G. and P. Delecluse, 1997 : The opa/arpege and opa/lmd global ocean-atmosphere
coupled model. Int. WOCE Newsletter, 26, 1215.
Madec, G., P. Delecluse, M. Imbard, and C. Levy, 1998 : Opa 8 ocean general circulation
model - reference manual. Tech. rep., LODYC/IPSL Note 11.
Madec, G. and M. Imbard, 1996 : A global ocean mesh to overcome the north pole singularity. Clim. Dyn., 12, 381388.
Madec, G., F. Lott, P. Delecluse, and M. Crepon, 1996 : Large-scale preconditioning
of deep-water formation in the northwestern mediterranean sea. J. Phys. Oceanogr.,
26 (8), 13931408.
Madec, G., C. Rahier, and M. Chartier, 1988 : A comparison of two-dimensional elliptic
solvers for the streamfunction in a multilevel ogcm. Ocean Modelling, 78, 16.
Maltrud, M. E., R. D. Smith, A. J. Semtner, and R. C. Malone, 1998 : Global eddyresolving ocean simulations driven by 1985-1995 atmospheric winds. J. Geophys. Res,
103 (C13), 30,82530,854.
Marchesiello, P., J. M. Williams, and A. Shchepetkin, 2001 : Open boundary conditions
for long-term integrations of regional oceanic models. Ocean Modelling, 3, 120.
Marsaleix, P., F. Auclair, J. W. Floor, M. J. Herrmann, C. Estournel, I. Pairaud, and
C. Ulses, 2008 : Energy conservation issues in sigma-coordinate free-surface ocean
models. Ocean Modelling, 20 (1), 6189, doi :10.1016/j.ocemod.2007.07.005, URL
http://dx.doi.org/10.1016/j.ocemod.2007.07.005.
Marti, O., 1992 : Etude de locean mondial : modelisation de la circulation et du transport
de traceurs anthropogeniques. Ph.D. thesis, Universite Pierre et Marie Curie, Paris,
France, 201pp.
BIBLIOGRAPHIE
319
Marti, O., G. Madec, and P. Delecluse, 1992 : Comment on net diffusivity in ocean
general circulation models with nonuniform grids by f. l. yin and i. y. fung. J. Geophys.
Res, 97, 12,76312,766.
McDougall, T. J., 1987 : Neutral surfaces. J. Phys. Oceanogr., 17 (11), 19501964.
McDougall, T. J. and J. R. Taylor, 1984 : Flux measurements across a finger interface at
low values of the stability ratio. J. Mar. Res., 42, 114.
Mellor, G. and A. Blumberg, 2004 : Wave breaking and ocean surface layer thermal
response. J. Phys. Oceanogr., 34 (3), 693698, doi :10.1175/2517.1, URL http:
//journals.ametsoc.org/doi/abs/10.1175/2517.1.
Mellor, G. L. and T. Yamada, 1982 : Development of a turbulence closure model for
geophysical fluid problems. Rev. Geophys. Space Phys., 20, 851875.
Merryfield, W. J., G. Holloway, and A. E. Gargett, 1999 : A global ocean model with
double-diffusive mixing. J. Phys. Oceanogr., 29 (6), 11241142.
Mesinger, F. and A. Arakawa, 1976 : Numerical methods used in Atmospheric models.
GARP Publication Series No 17.
Morel, A., 1988 : Optical modeling of the upper ocean in relation to its biogenous matter
content (case i waters). J. Geophys. Res, 93, 10,74910,768.
Morel, A. and S. Maritorena, 2001 : Bio-optical properties of oceanic waters : a reappraisal. J. Geophys. Res, 106 (C4), 71637180.
Murray, R. J., 1996 : Explicit generation of orthogonal grids for ocean models. J. Comput.
Phys., 126 (2), 251273.
Olivier, F., 2001 : Etude de lactivite biologique et de la circulation oceanique dans un jet
geostrophique : le front almeria-oran. Ph.D. thesis, Universite Pierre et Marie Curie,
Paris, France.
Pacanowski, R. and S. Philander, 1981 : Parameterization of vertical mixing in numerical
models of tropical oceans. J. Phys. Oceanogr., 11 (11), 14431451.
Pacanowski, R. C. and A. Gnanadesikan, 1998 : Transient response in a z-level ocean
model that resolves topography with partial-cells. Mon. Wea. Rev., 126, 32483270.
Paulson, C. A. and J. J. Simpson, 1977 : Irradiance measurements in the upper ocean. J.
Phys. Oceanogr., 7 (6), 952956.
Penduff, T., B. Barnier, and A. C. de Verdi`ere, 2000 : Self-adapting open boundaries for a
regional model of the eastern north atlantic. J. Geophys. Res, 105, 11,27911,297.
320
BIBLIOGRAPHIE
Penduff, T., J. L. Sommer, B. Barnier, A. Treguier, J. Molines, and G. Madec, 2007 : Influence of numerical schemes on current-topography interactions in 1/4 global ocean
simulations. Ocean Sc., 3, 509524.
Redi, M. H., 1982 : Oceanic isopycnal mixing by coordinate rotation. J. Phys. Oceanogr.,
13, 11541158.
Reverdin, G., P. Delecluse, C. Levy, P. Andrich, A. Morli`ere, and J. M. Verstraete, 1991 :
The near surface tropical atlantic in 1982-1984 : results from a numerical simulation
and a data analysis. Prog. Oceangr., 27, 273340.
Richtmyer, R. D. and K. W. Morton, 1967 : Difference methods for initial-value problems.
Interscience Publisher, Second Edition, 405pp pp.
Robert, A. J., 1966 : The integration of a low order spectral form of the primitive meteorological equations. J. Met. Soc. Japan, 44 (2).
Rodi, W., 1987 : Examples of calculation methods for flow and mixing in stratified fluids.
J. Geophys. Res, 92 (C5), 53055328.
Roed, L. and C. Cooper, 1986 : Open boundary conditions in numerical ocean models.
Advanced Physical Oceanography Numerical Modelling, OBrien, J., Ed., NATO ASI
Series, vol. 186.
Roullet, G. and G. Madec, 2000 : salt conservation, free surface, and varying levels : a
new formulation for ocean general circulation models. J. Geophys. Res, 105, 23,927
23,942.
Sarmiento, J. L. and K. Bryan, 1982 : Ocean transport model for the north atlantic. J.
Geophys. Res, 87, 394409.
Shchepetkin, A. F. and J. C. McWilliams, 2005 : The regional oceanic modeling system
(roms) - a split-explicit, free-surface, topography-following-coordinate oceanic modelr.
Ocean Modelling, 9 (4), 347404.
Shchepetkin, A. F. and J. J. OBrien, 1996 : A physically consistent formulation of lateral
friction in shallow-water equation ocean models. Mon. Wea. Rev., 124 (6), 12851300.
Simmons, H. L., S. R. Jayne, L. C. St. Laurent, and A. J. Weaver, 2004 : Tidally driven
mixing in a numerical model of the ocean general circulation. Ocean Modelling, 245
263.
Song, Y. and D. Haidvogel, 1994 : A semi-implicit ocean circulation model using a generalized topography-following coordinate system. J. Comput. Phys., 115 (1), 228244.
Song, Y. T., 1998 : A general pressure gradient formulation for ocean models. part i :
Scheme design and diagnostic analysis. Mon. Wea. Rev., 126 (12), 32133230.
BIBLIOGRAPHIE
321
Speich, S., 1992 : Etude du forcage de la circulation generale oceanique par les detroits cas de la mer dalboran. Ph.D. thesis, Universite Pierre et Marie Curie, Paris, France.
Speich, S., G. Madec, and M. Crepon, 1996 : The circulation in the alboran sea - a sensitivity study. J. Phys. Oceanogr., 26 (3), 320340.
St. Laurent, L. and J. D. Nash, 2004 : An examination of the radiative and dissipative properties of deep ocean internal tides. Deep-Sea Res., II (51), 30293042, doi :10.1016/j.
dsr2.2004.09.008, URL http://dx.doi.org/10.1016/j.dsr2.2004.09.
008.
St. Laurent, L., H. Simmons, and S. Jayne, 2002 : Estimating tidally driven mixing in the
deep ocean. Geophys. Res. Let., 29, 2106, doi :10.1029/2002GL015633, URL http:
//dx.doi.org/10.1029/2002GL015633.
Stacey, M. W., 1999 : Simulations of the wind-forced near-surface circulation in knight
inlet : A parameterization of the roughness length. J. Phys. Oceanogr., 29, 13631367.
Steele, M., R. Morley, and W. Ermold, 2001 : Phc- a global ocean hydrography with a
high-quality arctic ocean. J. Climate, 14 (9), 20792087.
Stein, C. A. and S. Stein, 1992 : A model for the global variation in oceanic depth and
heat flow with lithospheric age. Nature, 359, 123129.
Thiem, O. and J. Berntsen, 2006 : Internal pressure errors in sigma-coordinate ocean
models due to anisotropy. Ocean Modelling, 12 (1-2).
Treguier, A., 1992 : Kinetic energy analysis of an eddy resolving, primitive equation north
atlantic model. J. Geophys. Res, 97, 687701.
Treguier, A., B. Barnier, A. de Miranda, J. Molines, N. Grima, M. Imbard, G. Madec,
C. Messager, T. Reynaud, and S. Michel, 2001 : An eddy permitting model of the atlantic circulation : evaluating open boundary conditions. J. Geophys. Res, 106, 22,115
22,129.
Treguier, A.-M., J. Dukowicz, and K. Bryan, 1996 : Properties of nonuniform grids used
in ocean general circulation models. J. Geophys. Res, 101, 20,87720,881.
Treguier, A. M., I. M. Held, and V. D. Larichev, 1997 : Parameterization of quasigeostrophic eddies in primitive equation ocean models. J. Phys. Oceanogr., 27 (4), 567580.
Umlauf, L. and H. Burchard, 2003 : A generic length-scale equation for geophysical turbulence models. J. Mar. Sys., 61 (2), 235265.
, 2005 : Second-order turbulence closure models for geophysical boundary layers.
a review of recent work. J. Mar. Sys., 25, 795827.
322
BIBLIOGRAPHIE