0% found this document useful (0 votes)
667 views332 pages

NEMO Ocean Engine: Gurvan Madec, and The NEMO Team

Uploaded by

Mohab Shalabi
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
667 views332 pages

NEMO Ocean Engine: Gurvan Madec, and The NEMO Team

Uploaded by

Mohab Shalabi
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 332

NEMO ocean engine

Gurvan Madec, and the NEMO team


[email protected]
nemo [email protected]

January 2011
version 3.3
Note du Pole de modelisation de lInstitut Pierre-Simon Laplace No 27

ISSN No 1288-1619.

Table des mati`eres

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

Time Domain (STP)


3.1 Time stepping environment . . . . . . . . . . . . . . . . . . . . .

37
38

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

ii
3.2
3.3
3.4
3.5
3.6
4

Non-Diffusive Part Leapfrog Scheme . . . . . . . .


Diffusive Part Forward or Backward Scheme . . . .
Hydrostatic Pressure Gradient semi-implicit scheme
The Modified Leapfrog Asselin Filter scheme . . . .
Start/Restart strategy . . . . . . . . . . . . . . . . . .

.
.
.
.
.

38
39
40
42
43

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

45
46
46
47
49
51
51
53
55
55
57
58
60
62
62
62

Ocean Tracers (TRA)


5.1 Tracer Advection (traadv) . . . . . . . . . . . . . . . . . . . . .
5.1.1 2nd order centred scheme (cen2) (ln traadv cen2) . . . . .
5.1.2 4nd order centred scheme (cen4) (ln traadv cen4) . . . . .
5.1.3 Total Variance Dissipation scheme (TVD) (ln traadv tvd)
5.1.4 MUSCL scheme (ln traadv muscl) . . . . . . . . . . . .
5.1.5 Upstream-Biased Scheme (UBS) (ln traadv ubs) . . . . .
5.1.6 QUICKEST scheme (QCK) (ln traadv qck) . . . . . . . .
5.1.7 Piecewise Parabolic Method (PPM) (ln traadv ppm) . . .
5.2 Tracer Lateral Diffusion (traldf ) . . . . . . . . . . . . . . . . . .
5.2.1 Iso-level laplacian operator (lap) (ln traldf lap) . . . . . .
5.2.2 Rotated laplacian operator (iso) (ln traldf lap) . . . . . .
5.2.3 Iso-level bilaplacian operator (bilap) (ln traldf bilap) . . .
5.2.4 Rotated bilaplacian operator (bilapg) (ln traldf bilap) . . .
5.3 Tracer Vertical Diffusion (trazdf ) . . . . . . . . . . . . . . . . . .
5.4 External Forcing . . . . . . . . . . . . . . . . . . . . . . . . . .
5.4.1 Surface boundary condition (trasbc) . . . . . . . . . . . .
5.4.2 Solar Radiation Penetration (traqsr) . . . . . . . . . . . .

65
67
69
69
70
71
71
72
73
73
73
74
75
75
75
76
76
78

Space Domain (DOM)


4.1 Fundamentals of the Discretisation . . . . . .
4.1.1 Arrangement of Variables . . . . . .
4.1.2 Discrete Operators . . . . . . . . . .
4.1.3 Numerical Indexing . . . . . . . . .
4.2 Domain : Horizontal Grid (mesh) (domhgr) .
4.2.1 Coordinates and scale factors . . . . .
4.2.2 Choice of horizontal grid . . . . . . .
4.2.3 Output Grid files . . . . . . . . . . .
4.3 Domain : Vertical Grid (domzgr) . . . . . . .
4.3.1 Meter Bathymetry . . . . . . . . . .
4.3.2 z-coordinate (ln zco . . . . . . . . .
4.3.3 z-coordinate with partial step (ln zps)
4.3.4 s-coordinate (ln sco) . . . . . . . . .
4.3.5 z - or s -coordinate (add key vvl) . .
4.3.6 level bathymetry and mask . . . . . .

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

iii
.
.
.
.
.
.
.
.
.
.
.
.

80
81
82
82
84
86
87
87
88
88
89
89

Ocean Dynamics (DYN)


6.1 Sea surface height and diagnostic variables (, , , w) . . . . . .
6.1.1 Horizontal divergence and relative vorticity (divcur) . . .
6.1.2 Sea surface height evolution and vertical velocity (sshwzv)
6.2 Coriolis and Advection : vector invariant form . . . . . . . . . . .
6.2.1 Vorticity term (dynvor) . . . . . . . . . . . . . . . . . . .
6.2.2 Kinetic Energy Gradient term (dynkeg) . . . . . . . . . .
6.2.3 Vertical advection term (dynzad) . . . . . . . . . . . . .
6.3 Coriolis and Advection : flux form . . . . . . . . . . . . . . . . .
6.3.1 Coriolis plus curvature metric terms (dynvor) . . . . . . .
6.3.2 Flux form Advection term (dynadv) . . . . . . . . . . . .
6.4 Hydrostatic pressure gradient (dynhpg) . . . . . . . . . . . . . . .
6.4.1 z-coordinate with full step (ln dynhpg zco) . . . . . . . .
6.4.2 z-coordinate with partial step (ln dynhpg zps) . . . . . . .
6.4.3 s- and z-s-coordinates . . . . . . . . . . . . . . . . . . .
6.4.4 Time-scheme (ln dynhpg imp) . . . . . . . . . . . . . .
6.5 Surface pressure gradient (dynspg) . . . . . . . . . . . . . . . . .
6.5.1 Explicit free surface (key dynspg exp) . . . . . . . . . .
6.5.2 Split-Explicit free surface (key dynspg ts) . . . . . . . .
6.5.3 Filtered free surface (key dynspg flt) . . . . . . . . . . .
6.6 Lateral diffusion term (dynldf ) . . . . . . . . . . . . . . . . . . .
6.6.1 Iso-level laplacian operator (ln dynldf lap) . . . . . . . .
6.6.2 Rotated laplacian operator (ln dynldf iso) . . . . . . . . .
6.6.3 Iso-level bilaplacian operator (ln dynldf bilap) . . . . . .
6.7 Vertical diffusion term (dynzdf.F90) . . . . . . . . . . . . . . . .
6.8 External Forcings . . . . . . . . . . . . . . . . . . . . . . . . . .
6.9 Time evolution term (dynnxt) . . . . . . . . . . . . . . . . . . . .

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

5.4.3 Bottom Boundary Condition (trabbc) . . . . . . . . . .


Bottom Boundary Layer (trabbl.F90 - key trabbl) . . . . . . .
5.5.1 Diffusive Bottom Boundary layer (nn bbl ldf =1) . . . .
5.5.2 Advective Bottom Boundary Layer (nn bbl adv= 1 or 2)
Tracer damping (tradmp) . . . . . . . . . . . . . . . . . . . . .
Tracer time evolution (tranxt) . . . . . . . . . . . . . . . . . . .
Equation of State (eosbn2) . . . . . . . . . . . . . . . . . . . .
5.8.1 Equation of State (nn eos = 0, 1 or 2) . . . . . . . . . .
5.8.2 Brunt-Vaisala Frequency (nn eos = 0, 1 or 2) . . . . . .
5.8.3 Specific Heat (phycst) . . . . . . . . . . . . . . . . . .
5.8.4 Freezing Point of Seawater . . . . . . . . . . . . . . . .
Horizontal Derivative in zps-coordinate (zpshde) . . . . . . . . .

iv
7

Surface Boundary Condition (SBC)


7.1 Surface boundary condition for the ocean . . . . . . . . . . .
7.2 Input Data generic interface . . . . . . . . . . . . . . . . . . .
7.2.1 Input Data specification (fldread.F90) . . . . . . . . .
7.2.2 Interpolation on-the-Fly . . . . . . . . . . . . . . . .
7.3 Analytical formulation (sbcana) . . . . . . . . . . . . . . . .
7.4 Flux formulation (sbcflx) . . . . . . . . . . . . . . . . . . . .
7.5 Bulk formulation (sbcblk core or sbcblk clio) . . . . . . . . .
7.5.1 CORE Bulk formulea (ln core=true) . . . . . . . . . .
7.5.2 CLIO Bulk formulea (ln clio=true) . . . . . . . . . .
7.6 Coupled formulation (sbccpl) . . . . . . . . . . . . . . . . .
7.7 Atmospheric pressure (sbcapr) . . . . . . . . . . . . . . . . .
7.8 River runoffs (sbcrnf ) . . . . . . . . . . . . . . . . . . . . . .
7.9 Miscellaneous options . . . . . . . . . . . . . . . . . . . . .
7.9.1 Diurnal cycle (sbcdcy) . . . . . . . . . . . . . . . . .
7.9.2 Rotation of vector pairs onto the model grid directions
7.9.3 Surface restoring to observed SST and/or SSS (sbcssr)
7.9.4 Handling of ice-covered area (sbcice ...) . . . . . . . .
7.9.5 Freshwater budget control (sbcfwb) . . . . . . . . . .

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

113
115
116
117
119
121
122
122
122
123
124
125
125
127
127
128
130
130
131

Lateral Boundary Condition (LBC)


8.1 Boundary Condition at the Coast (rn shlat) . . . . . . . .
8.2 Model Domain Boundary Condition (jperio) . . . . . . . .
8.2.1 Closed, cyclic, south symmetric (jperio = 0, 1 or 2)
8.2.2 North-fold (jperio = 3 to 6) . . . . . . . . . . . .
8.3 Exchange with neighbouring processors (lbclnk, lib mpp) .
8.4 Open Boundary Conditions (key obc) (OBC) . . . . . . .
8.4.1 Boundary geometry . . . . . . . . . . . . . . . . .
8.4.2 Boundary data . . . . . . . . . . . . . . . . . . .
8.4.3 Radiation algorithm . . . . . . . . . . . . . . . .
8.4.4 Domain decomposition (key mpp mpi) . . . . . .
8.4.5 Volume conservation . . . . . . . . . . . . . . . .
8.5 Unstructured Open Boundary Conditions (key bdy) (BDY)
8.5.1 The Flow Relaxation Scheme . . . . . . . . . . .
8.5.2 The Flather radiation scheme . . . . . . . . . . . .
8.5.3 Choice of schemes . . . . . . . . . . . . . . . . .
8.5.4 Boundary geometry . . . . . . . . . . . . . . . . .
8.5.5 Input boundary data files . . . . . . . . . . . . . .
8.5.6 Volume correction . . . . . . . . . . . . . . . . .
8.5.7 Tidal harmonic forcing . . . . . . . . . . . . . . .

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

133
134
137
137
138
139
143
143
145
146
149
149
150
150
151
151
152
152
153
153

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

v
9

Lateral Ocean Physics (LDF)


9.1 Lateral Mixing Coefficient (ldftra, ldfdyn) . . . . . . . . . . . .
9.2 Direction of Lateral Mixing (ldfslp) . . . . . . . . . . . . . . .
9.2.1 slopes for tracer geopotential mixing in the s-coordinate
9.2.2 slopes for tracer iso-neutral mixing . . . . . . . . . . .
9.2.3 slopes for momentum iso-neutral mixing . . . . . . . .
9.3 Eddy Induced Velocity (traadv eiv, ldfeiv) . . . . . . . . . . . .

.
.
.
.
.
.

155
156
159
159
159
162
163

10 Vertical Ocean Physics (ZDF)


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 ) . . .

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

165
166
166
167
167
172
174
176
177
177
179
179
180
181
183
183
184
185
186
186
187

11 Ouput and Diagnostics (IOM, DIA, TRD, FLO)


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) .

.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.

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

13 Apply assimilation increments (ASM)


223
13.1 Direct initialization . . . . . . . . . . . . . . . . . . . . . . . . . 224
13.2 Incremental Analysis Updates . . . . . . . . . . . . . . . . . . . 224
13.3 Implementation details . . . . . . . . . . . . . . . . . . . . . . . 225
14 Miscellaneous Topics
227
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
15 Configurations
15.1 Introduction . . . . . . . . . . . . . . . . . . . . .
15.2 Water column model : 1D model (C1D) (key c1d) .
15.3 ORCA family : global ocean with tripolar grid (key
15.3.1 ORCA tripolar grid . . . . . . . . . . . . .

. . . . . .
. . . . . .
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

B Appendix B : Diffusive Operators


255
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
C Discrete Invariants of the Equations
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 . . . . . . . . . . . . . .

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

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

E Griffiess iso-neutral diffusion


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 . . .

.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.

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.

NEMO reference in papers and other publications is as follows :


Madec, G., and the NEMO team, 2008 : NEMO ocean engine. Note du Pole de
modelisation, Institut Pierre-Simon Laplace (IPSL), France, No 27, ISSN No 1288-1619.

Additional information can be found on nemo-ocean.eu website.

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

OPA = Ocean PArallelise


LIM= Louvain)la-neuve Ice Model
3
TOP = Tracer in the Ocean Paradigm
4
Both LOBSTER and PISCES are not acronyms just name
2

Introduction

second (MKS) international system are used throughout.


The following chapters deal with the discrete equations. Chapter 3 presents the time
domain. The model time stepping environment is a three level scheme in which the tendency terms of the equations are evaluated either centered in time, or forward, or backward depending of the nature of the term. Chapter 4 presents the space domain. The
model is discretised on a staggered grid (Arakawa C grid) with masking of land areas.
Vertical discretisation used depends on both how the bottom topography is represented
and whether the free surface is linear or not. Full step or partial step z-coordinate or s(terrain-following) coordinate is used with linear free surface (level position are then fixed
in time). In non-linear free surface, the corresponding rescaled height coordinate formulation (z* or s*) is used (the level position then vary in time as a function of the sea surface
heigh). The following two chapters (5 and 6) describe the discretisation of the prognostic
equations for the active tracers and the momentum. Explicit, split-explicit and filtered free
surface formulations are implemented. A number of numerical schemes are available for
momentum advection, for the computation of the pressure gradients, as well as for the
advection of tracers (second or higher order advection schemes, including positive ones).
Surface boundary conditions (chapter 7) can be implemented as prescribed fluxes, or
bulk formulations for the surface fluxes (wind stress, heat, freshwater). The model allows
penetration of solar radiation There is an optional geothermal heating at the ocean bottom.
Within the NEMO system the ocean model is interactively coupled with a sea ice model
(LIM) and with biogeochemistry models (PISCES, LOBSTER). Interactive coupling to
Atmospheric models is possible via the OASIS coupler [Valcke 2006]. Two-way nesting
is also available through an interface to the AGRIF package (Adaptative Grid Refinement
in F ORTRAN) [Debreu et al. 2008].
Other model characteristics are the lateral boundary conditions (chapter 8). Global
configurations of the model make use of the ORCA tripolar grid, with special north fold
boundary condition. Free-slip or no-slip boundary conditions are allowed at land boundaries. Closed basin geometries as well as periodic domains and open boundary conditions
are possible.
Physical parameterisations are described in chapters 9 and 10. The model includes an
implicit treatment of vertical viscosity and diffusivity. The lateral Laplacian and biharmonic viscosity and diffusion can be rotated following a geopotential or neutral direction.
There is an optional eddy induced velocity [Gent and Mcwilliams 1990] with a space and
time variable coefficient Treguier et al. [1997]. The model has vertical harmonic viscosity
and diffusion with a space and time variable coefficient, with options to compute the coefficients with Blanke and Delecluse [1993], Large et al. [1994], Pacanowski and Philander
[1981], or Umlauf and Burchard [2003] mixing schemes.
Model outputs management and specific online diagnostics are described in chapters 11. The diagnostics includes the output of all the tendencies of the momentum and
tracers equations, the output of tracers tendencies averaged over the time evolving mixed
layer, the output of the tendencies of the barotropic vorticity equation, the computation of
on-line floats trajectories... Chapter 12 describes a tool which reads in observation files
(profile temperature and salinity, sea surface temperature, sea level anomaly and sea ice

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
-

model time STePping environment


model DOMain
TRAcer equations (potential temperature and salinity)
DYNamic equations (momentum)
Surface Boundary Conditions
Lateral Boundary Conditions (also OBC and BDY)
Lateral DiFfusion (parameterisations)
vertical (Z) DiFfusion (parameterisations)
I/O and DIAgnostics (also IOM, FLO and TRD)
OBServation and model comparison
ASsiMilation increment
Miscellaneous topics (including solvers)
predefined configurations (including C1D)

concentration) and calculates an interpolated model equivalent value at the observation


location and nearest model timestep. Originally developed of data assimilation, it is a fantastic tool for model and data comparison. Chapter 13 describes how increments produced
by data assimilation may be applied to the model equations. Finally, Chapter 15 provides
a brief introduction to the pre-defined model configurations (water column model, ORCA
and GYRE families of configurations).
The model is implemented in F ORTRAN 90, with preprocessing (C-pre-processor).
It runs under UNIX. It is optimized for vector computers and parallelised by domain
decomposition with MPI. All input and output is done in NetCDF (Network Common
Data Format) with a optional direct access format for output. To ensure the clarity and
readability of the code it is necessary to follow coding rules. The coding rules for OPA
include conventions for naming variables, with different starting letters for different types
of variables (real, integer, parameter. . . ). Those rules are briefly presented in Appendix D
and a more complete document is available on the NEMO web site.
The model is organized with a high internal modularity based on physics. For example,
each trend (i.e., a term in the RHS of the prognostic equation) for momentum and tracers
is computed in a dedicated module. To make it easier for the user to find his way around
the code, the module names follow a three-letter rule. For example, traldf.F90 is a module related to the TRAcers equation, computing the Lateral DiFfussion. Furthermore,
modules are organized in a few directories that correspond to their category, as indicated
by the first three letters of their name (Tab. 1.1).
The manual mirrors the organization of the model. After the presentation of the continuous equations (Chapter 2), the following chapters refer to specific terms of the equations
each associated with a group of modules (Tab. 1.1).

Introduction

Changes between releases


NEMO/OPA, like all research tools, is in perpetual evolution. The present document
describes the OPA version include in the release 3.3 of NEMO. This release differs significantly from version 8, documented in Madec et al. [1998].
The main modifications from OPA v8 and NEMO/OPA v3.2 are :
1. transition to full native F ORTRAN 90, deep code restructuring and drastic reduction
of CPP keys ;
2. introduction of partial step representation of bottom topography [Barnier et al.
2006, Le Sommer et al. 2009, Penduff et al. 2007] ;
3. partial reactivation of a terrain-following vertical coordinate (s- and hybrid s-z)
with the addition of several options for pressure gradient computation 5 ;
4. more choices for the treatment of the free surface : full explicit, split-explicit or
filtered schemes, and suppression of the rigid-lid option ;
5. non linear free surface associated with the rescaled height coordinate z* or s ;
6. additional schemes for vector and flux forms of the momentum advection ;
7. additional advection schemes for tracers ;
8. implementation of the AGRIF package (Adaptative Grid Refinement in F ORTRAN)
[Debreu et al. 2008] ;
9. online diagnostics : tracers trend in the mixed layer and vorticity balance ;
10. rewriting of the I/O management with the use of an I/O server ;
11. generalized ocean-ice-atmosphere-CO2 coupling interface, interfaced with OASIS
3 coupler ;
12. surface module (SBC) that simplify the way the ocean is forced and include two
bulk formulea (CLIO and CORE) and which includes an on-the-fly interpolation
of input forcing fields ;
13. RGB light penetration and optional use of ocean color
14. major changes in the TKE schemes : it now includes a Langmuir cell parameterization [Axell 2002], the Mellor and Blumberg [2004] surface wave breaking parameterization, and has a time discretization which is energetically consistent with
the ocean model equations [Burchard 2002, Marsaleix et al. 2008] ;
15. tidal mixing parametrisation (bottom intensification) + Indonesian specific tidal
mixing [Koch-Larrouy et al. 2007] ;
5

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]

The main modifications from NEMO/OPA v3.2 and v3.3 are :


1. introduction of a modified leapfrog-Asselin filter time stepping scheme [Leclair
and Madec 2009] ;
2. additional scheme for iso-neutral mixing [Griffies et al. 1998], although it is still a
work in progress ;
3. a rewriting of the bottom boundary layer scheme, following Campin and Goosse
[1999] ;
4. addition of a Generic Length Scale vertical mixing scheme, following Umlauf and
Burchard [2003] ;
5. addition of the atmospheric pressure as an external forcing on both ocean and seaice dynamics ;
6. addition of a diurnal cycle on solar radiation [Bernie et al. 2007] ;
7. river runoffs added through a non-zero depth, and having its own temperature and
salinity ;
8. CORE II normal year forcing set as the default forcing of ORCA2-LIM configuration ;
9. generalisation of the use of fldread.F90 for all input fields (ocean climatology, seaice damping...) ;
10. addition of an on-line observation and model comparison (thanks to NEMOVAR
project) ;
11. optional application of an assimilation increment (thanks to NEMOVAR project) ;
12. coupling interface adjusted for WRF atmospheric model ;
13. C-grid ice rheology now available fro both LIM-2 and LIM-3 [Bouillon et al.
2009] ;
14. LIM-3 ice-ocean momentum coupling applied to LIM-2 ;
15. a deep re-writting and simplification of the off-line tracer component (OFF SRC) ;
16. the merge of passive and active advection and diffusion modules ;
17. Use of the Flexible Configuration Manager (FCM) to build configurations, generate
the Makefile and produce the executable ;
18. Linear-tangent and Adjoint component (TAM) added, phased with v3.0

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)

2.1. Primitive Equations

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

2.2. The Horizontal Pressure Gradient

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

The Horizontal Pressure Gradient


Pressure Formulation
The total pressure at a given depth z is composed of a surface pressure ps at a reference geopotential surface (z = 0) and a hydrostatic pressure ph such that : p(i, j, k, t) =
ps (i, j, t) + ph (i, j, k, t). The latter is computed by integrating (2.1b), assuming that pressure in decibars can be approximated by depth in meters in (2.1f). The hydrostatic pressure
is then given by :
Z
=0

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

Free Surface Formulation


In the free surface formulation, a variable , the sea-surface height, is introduced
which describes the shape of the air-sea interface. This variable is solution of a prognostic
equation which is established by forming the vertical average of the kinematic surface
condition (2.2) :

= D + P E
t



where D = (H + ) Uh

(2.5)

and using (2.1b) the surface pressure is given by : ps = g .


Allowing the air-sea interface to move introduces the external gravity waves (EGWs)
as a class of solution of the primitive equations. These waves are barotropic because of

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

2.2. The Horizontal Pressure Gradient

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

Curvilinear z-coordinate System


Tensorial Formalism
In many ocean circulation problems, the flow field has regions of enhanced dynamics (i.e. surface layers, western boundary currents, equatorial currents, or ocean fronts).
The representation of such dynamical processes can be improved by specifically increasing the model resolution in these regions. As well, it may be convenient to use a lateral
boundary-following coordinate system to better represent coastal dynamics. Moreover,
the common geographical coordinate system has a singular point at the North Pole that
cannot be easily treated in a global model without filtering. A solution consists of introducing an appropriate coordinate transformation that shifts the singular point onto land
[Madec and Imbard 1996, Murray 1996]. As a consequence, it is important to solve the
primitive equations in various curvilinear coordinate systems. An efficient way of introducing an appropriate coordinate transform can be found when using a tensorial formalism.
This formalism is suited to any multidimensional curvilinear coordinate system. Ocean
modellers mainly use three-dimensional orthogonal grids on the sphere (spherical earth
approximation), with preservation of the local vertical. Here we give the simplified equations for this particular case. The general case is detailed by Eiseman and Stone [1980] in
their survey of the conservation laws of fluid dynamics.
Let (i,j,k) be a set of orthogonal curvilinear coordinates on the sphere associated with
the positively oriented 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. along geopotential
surfaces (Fig.2.2). Let (, , z) be the geographical coordinate system in which a position
is defined by the latitude (i, j), the longitude (i, j) and the distance from the centre of
the earth a + z(k) where a is the earths radius and z the altitude above a reference sea
level (Fig.2.2). The local deformation of the curvilinear coordinate system is given by e1 ,
e2 and e3 , the three scale factors :
"
2  2 #1/2

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

2.3. Curvilinear z-coordinate System

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)

where q is a scalar quantity and A = (a1 , a2 , a3 ) a vector in the (i, j, k) coordinate


system.

20

2.3.2

Model basics

Continuous Model Equations


In order to express the Primitive Equations in tensorial formalism, it is necessary to
compute the horizontal component of the non-linear and viscous terms of the equation
using (2.11a)) to (2.11e). Let us set U = (u, v, w) = Uh + w k, the velocity in the (i, j, k)
coordinate system and define the relative vorticity and the divergence of the horizontal
velocity field , by :


1
(e2 v) (e1 u)
=
(2.12)

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

2.3. Curvilinear z-coordinate System


=

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

+ DuU + FuU (2.18a)


e1 i
o



v
e2
1
e1
v
u
= f+
u
t
e1 e2
i
j


(e2 u v) (e1 v v)
1 (w v)
1

+
e1 e2
i
j
e3 k


1 ps + ph

+ DvU + FvU (2.18b)


e2 j
o
where , the relative vorticity, is given by (2.12) and ps , the surface pressure, is given by :

standard free surface


g
ps =
(2.19)
g + o
filtered free surface
t
with is solution of (2.5)
The vertical velocity and the hydrostatic pressure are diagnosed from the following
equations :
w
= e3
(2.20)
k
ph
= g e3
k
where the divergence of the horizontal velocity, is given by (2.13).
tracer equations :


1
(e2 T u) (e1 T v)
1 (T w)
T
=
+

+ 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)

The expression of DU , DS and DT depends on the subgrid scale parameterisation


used. It will be defined in 2.5.1. The nature and formulation of FU , F T and F S , the
surface forcing terms, are discussed in Chapter 7.

2.4. Curvilinear generalised vertical coordinate System

2.4

23

Curvilinear generalised vertical coordinate System


The ocean domain presents a huge diversity of situation in the vertical. First the ocean
surface is a time dependent surface (moving surface). Second the ocean floor depends
on the geographical position, varying from more than 6,000 meters in abyssal trenches
to zero at the coast. Last but not least, the ocean stratification exerts a strong barrier to
vertical motions and mixing. Therefore, in order to represent the ocean with respect to the
first point a space and time dependent vertical coordinate that follows the variation of the
sea surface height e.g. an z*-coordinate ; for the second point, a space variation to fit the
change of bottom topography e.g. a terrain-following or -coordinate ; and for the third
point, one will be tempted to use a space and time dependent coordinate that follows the
isopycnal surfaces, e.g. an isopycnic coordinate.
In order to satisfy two or more constrains one can even be tempted to mixed these
coordinate systems, as in HYCOM (mixture of z-coordinate at the surface, isopycnic
coordinate in the ocean interior and at the ocean bottom) [Chassignet et al. 2003] or
OPA (mixture of z-coordinate in vicinity the surface and steep topography areas and coordinate elsewhere) [Madec et al. 1996] among others.
In fact one is totally free to choose any space and time vertical coordinate by introducing an arbitrary vertical coordinate :
s = s(i, j, k, t)

(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

The s-coordinate Formulation


Starting from the set of equations established in 2.3 for the special case k = z
and thus e3 = 1, we introduce an arbitrary vertical coordinate s = s(i, j, k, t), which
includes z-, z*- and coordinates as special cases (s = z, s = z*, and s = = z/H
or = z/ (H + ), resp.). A formal derivation of the transformed equations is given in
Appendix A. Let us define the vertical scale factor by e3 = s z (e3 is now a function of
(i, j, k, t) ), and the slopes in the (i,j) directions between s and zsurfaces by :

1 z
1 =
e1 i s

, and


1 z
2 =
e2 j s

(2.26)

We also introduce , a dia-surface velocity component, defined as the velocity relative to


the moving s-surfaces and normal to them :

= 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 :

2.4. Curvilinear generalised vertical coordinate System

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

Curvilinear z*coordinate System


In that case, the free surface equation is nonlinear, and the variations of volume are
fully taken into account. These coordinates systems is presented in a report [Levier et al.
2007] available on the NEMO web site.
The z* coordinate approach is an unapproximated, non-linear free surface implementation which allows one to deal with large amplitude free-surface variations relative to the

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] ).

2.4. Curvilinear generalised vertical coordinate System

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

Curvilinear Terrain-following scoordinate


Introduction
Several important aspects of the ocean circulation are influenced by bottom topography. Of course, the most important is that bottom topography determines deep ocean
sub-basins, barriers, sills and channels that strongly constrain the path of water masses,
but more subtle effects exist. For example, the topographic -effect is usually larger than
the planetary one along continental slopes. Topographic Rossby waves can be excited and
can interact with the mean current. In the zcoordinate system presented in the previous
section (2.3), zsurfaces are geopotential surfaces. The bottom topography is discretised by steps. This often leads to a misrepresentation of a gradually sloping bottom and
to large localized depth gradients associated with large localized vertical velocities. The
response to such a velocity field often leads to numerical dispersion effects. One solution
to strongly reduce this error is to use a partial step representation of bottom topography
instead of a full step one Pacanowski and Gnanadesikan [1998]. Another solution is to
introduce a terrain-following coordinate system (hereafter scoordinate)
The s-coordinate avoids the discretisation error in the depth field since the layers of
computation are gradually adjusted with depth to the ocean bottom. Relatively small topographic features as well as gentle, large-scale slopes of the sea floor in the deep ocean,
which would be ignored in typical z-model applications with the largest grid spacing
at greatest depths, can easily be represented (with relatively low vertical resolution). A
terrain-following model (hereafter smodel) also facilitates the modelling of the boundary layer flows over a large depth range, which in the framework of the z-model would
require high vertical resolution over the whole depth range. Moreover, with a s-coordinate
it is possible, at least in principle, to have the bottom and the sea surface as the only
boundaries of the domain (nomore lateral boundary condition to specify). Nevertheless,
a s-coordinate also has its drawbacks. Perfectly adapted to a homogeneous ocean, it has
strong limitations as soon as stratification is introduced. The main two problems come
from the truncation error in the horizontal pressure gradient and a possibly increased diapycnal diffusion. The horizontal pressure force in s-coordinate consists of two terms (see
Appendix A),
p|z = p|s

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-

2.4. Curvilinear generalised vertical coordinate System

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. Subgrid Scale Physics

2.5

31

Subgrid Scale Physics


The primitive equations describe the behaviour of a geophysical fluid at space and
time scales larger than a few kilometres in the horizontal, a few meters in the vertical and
a few minutes. They are usually solved at larger scales : the specified grid spacing and
time step of the numerical model. The effects of smaller scale motions (coming from the
advective terms in the Navier-Stokes equations) must be represented entirely in terms of
large-scale patterns to close the equations. These effects appear in the equations as the
divergence of turbulent fluxes (i.e. fluxes associated with the mean correlation of small
scale perturbations). Assuming a turbulent closure hypothesis is equivalent to choose a
formulation for these fluxes. It is usually called the subgrid scale physics. It must be
emphasized that this is the weakest part of the primitive equations, but also one of the
most important for long-term simulations as small scale processes in fine balance the
surface input of kinetic energy and heat.
The control exerted by gravity on the flow induces a strong anisotropy between the
lateral and vertical motions. Therefore subgrid-scale physics DU , DS and DT in (2.1a),
(2.1d) and (2.1e) are divided into a lateral part DlU , DlS and DlT and a vertical part DvU ,
DvS and DvT . The formulation of these terms and their underlying physics are briefly
discussed in the next two subsections.

2.5.1

Vertical Subgrid Scale Physics


The model resolution is always larger than the scale at which the major sources of
vertical turbulence occur (shear instability, internal wave breaking...). Turbulent motions
are thus never explicitly solved, even partially, but always parameterized. The vertical
turbulent fluxes are assumed to depend linearly on the gradients of large-scale quantities
(for example, the turbulent heat flux is given by T 0 w0 = AvT z T , where AvT is an
eddy coefficient). This formulation is analogous to that of molecular diffusion and dissipation. This is quite clearly a necessary compromise : considering only the molecular
viscosity acting on large scale severely underestimates the role of turbulent diffusion and
dissipation, while an accurate consideration of the details of turbulent motions is simply
impractical. The resulting vertical momentum and tracer diffusive operators are of second
order :



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

Lateral Diffusive and Viscous Operators Formulation


Lateral turbulence can be roughly divided into a mesoscale turbulence associated with
eddies (which can be solved explicitly if the resolution is sufficient since their underlying
physics are included in the primitive equations), and a sub mesoscale turbulence which
is never explicitly solved even partially, but always parameterized. The formulation of
lateral eddy fluxes depends on whether the mesoscale is below or above the grid-spacing
(i.e. the model is eddy-resolving or not).
In non-eddy-resolving configurations, the closure is similar to that used for the vertical physics. The lateral turbulent fluxes are assumed to depend linearly on the lateral
gradients of large-scale quantities. The resulting lateral diffusive and dissipative operators
are of second order. Observations show that lateral mixing induced by mesoscale turbulence tends to be along isopycnal surfaces (or more precisely neutral surfaces McDougall
[1987]) rather than across them. As the slope of neutral surfaces is small in the ocean,
a common approximation is to assume that the lateral direction is the horizontal, i.e.
the lateral mixing is performed along geopotential surfaces. This leads to a geopotential
second order operator for lateral subgrid scale physics. This assumption can be relaxed :
the eddy-induced turbulent fluxes can be better approached by assuming that they depend linearly on the gradients of large-scale quantities computed along neutral surfaces.
In such a case, the diffusive operator is an isoneutral second order operator and it has components in the three space directions. However, both horizontal and isoneutral operators
have no effect on mean (i.e. large scale) potential energy whereas potential energy is a
main source of turbulence (through baroclinic instabilities). Gent and Mcwilliams [1990]
have proposed a parameterisation of mesoscale eddy-induced turbulence which associates
an eddy-induced velocity to the isoneutral diffusion. Its mean effect is to reduce the mean
potential energy of the ocean. This leads to a formulation of lateral subgrid-scale physics
made up of an isoneutral second order operator and an eddy induced advective part. In
all these lateral diffusive formulations, the specification of the lateral eddy coefficients
remains the problematic point as there is no really satisfactory formulation of these coefficients as a function of large-scale features.
In eddy-resolving configurations, a second order operator can be used, but usually a
more scale selective one (biharmonic operator) is preferred as the grid-spacing is usually
not small enough compared to the scale of the eddies. The role devoted to the subgridscale physics is to dissipate the energy that cascades toward the grid scale and thus ensures
the stability of the model while not interfering with the solved mesoscale activity. Another
approach is becoming more and more popular : instead of specifying explicitly a sub-grid
scale term in the momentum and tracer time evolution equations, one uses a advective
scheme which is diffusive enough to maintain the model stability. It must be emphasised
that then, all the sub-grid scale physics is in this case include in the formulation of the
advection scheme.

2.5. Subgrid Scale Physics

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).

lateral second order tracer diffusive operator


The lateral second order tracer diffusive operator is defined by (see Appendix B) :

DlT = . AlT < T

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

city field is defined by :


1  eiv 
A r1
e3 k
1  eiv 
v = +
A r2
e3 k




1

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).

lateral fourth order tracer diffusive operator


The lateral fourth order tracer diffusive operator is defined by :




DlT = AlT T
where DlT = AlT T

(2.42)

It is the second order operator given by (2.37) applied twice with the eddy diffusion
coefficient correctly placed.

lateral second order momentum diffusive operator


The second order momentum diffusive operator along z- or s-surfaces is found by
applying (2.11e) to the horizontal velocity vector (see Appendix B) :




DlU =
h Alm h Alm k



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.

2.5. Subgrid Scale Physics

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].

lateral fourth order momentum diffusive operator


As for tracers, the fourth order momentum diffusive operator along z or s-surfaces
is a re-entering second order operator (2.43) or (2.43) with the eddy viscosity coefficient
correctly placed :
geopotential diffusion in z-coordinate :
n
h
io
DlU = h h . Alm h ()
n
h
io
(2.45)
+ h k Alm h ( k)
geopotential diffusion in s-coordinate :



DulU = Alm u

 where () = (<())
DlU = Alm v
v

(2.46)

3 Time Domain (STP)

Contents
3.1
3.2
3.3
3.4
3.5
3.6

Time stepping environment . . . . . . . . . . . . . . . .


Non-Diffusive Part Leapfrog Scheme . . . . . . . . .
Diffusive Part Forward or Backward Scheme . . . .
Hydrostatic Pressure Gradient semi-implicit scheme
The Modified Leapfrog Asselin Filter scheme . . . . .
Start/Restart strategy . . . . . . . . . . . . . . . . . . .

.
.
.
.
.
.

.
.
.
.
.
.

38
38
39
40
42
43

38

Time Domain (STP)

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

Time stepping environment


The time stepping used in NEMO is a three level scheme that can be represented as
follows :
t, t+t
xt+t = xtt + 2 t RHStt,
(3.1)
x
where x stands for u, v, T or S ; RHS is the Right-Hand-Side of the corresponding time
evolution equation ; t is the time step ; and the superscripts indicate the time at which a
quantity is evaluated. Each term of the RHS is evaluated at a specific time step depending
on the physics with which it is associated.
The choice of the time step used for this evaluation is discussed below as well as the
implications for starting or restarting a model simulation. Note that the time stepping calculation is generally performed in a single operation. With such a complex and nonlinear
system of equations it would be dangerous to let a prognostic variable evolve in time for
each term separately.
The three level scheme requires three arrays for each prognostic variable. For each
variable x there is xb (before), xn (now) and xa . The third array, although referred to as
xa (after) in the code, is usually not the variable at the after time step ; but rather it is used
to store the time derivative (RHS in (3.1)) prior to time-stepping the equation. Generally,
the time stepping is performed once at each time step in the tranxt.F90 and dynnxt.F90
modules, except when using implicit vertical diffusion or calculating sea surface height in
which case time-splitting options are used.

3.2

Non-Diffusive Part Leapfrog Scheme


The time stepping used for processes other than diffusion is the well-known leapfrog
scheme [Mesinger and Arakawa 1976]. This scheme is widely used for advection processes in low-viscosity fluids. It is a time centred scheme, i.e. the RHS in (3.1) is evaluated at time step t, the now time step. It may be used for momentum and tracer advection,
pressure gradient, and Coriolis terms, but not for diffusion terms. It is an efficient method that achieves second-order accuracy with just one right hand side evaluation per time
step. Moreover, it does not artificially damp linear oscillatory motion nor does it produce
instability by amplifying the oscillations. These advantages are somewhat diminished by
the large phase-speed error of the leapfrog scheme, and the unsuitability of leapfrog differencing for the representation of diffusion and Rayleigh damping processes. However, the

3.3. Diffusive Part Forward or Backward Scheme

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

Diffusive Part Forward or Backward Scheme


The leapfrog differencing scheme is unsuitable for the representation of diffusion and
damping processes. For a tendancy Dx , representing a diffusion term or a restoring term
to a tracer climatology (when present, see 5.6), a forward time differencing scheme is
used :
xt+t = xtt + 2 t Dx tt
(3.3)
This is diffusive in time and conditionally stable. The conditions for stability of second
and fourth order horizontal diffusion schemes are [Griffies 2004] :
2
e

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

Time Domain (STP)

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

Hydrostatic Pressure Gradient semi-implicit scheme


The range of stability of the Leap-Frog scheme can be extended by a factor of two by
introducing a semi-implicit computation of the hydrostatic pressure gradient term [Brown
and Campana 1978]. Instead of evaluating the pressure at t, a linear combination of values

3.4. Hydrostatic Pressure Gradient semi-implicit scheme

41

model time step


ssh equation

Update vertical coordinate

continuity equation

tracer equation
T

semi implicit hydrostatic pressure gradient


momentum equation

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

Time Domain (STP)

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 Modified Leapfrog Asselin Filter scheme


Significant changes have been introduced by Leclair and Madec [2009] in the LFRA scheme in order to ensure tracer conservation and to allow the use of a much smaller
value of the Asselin filter parameter. The modifications affect both the forcing and filtering
treatments in the LF-RA scheme.
In a classical LF-RA environment, the forcing term is centred in time, i.e. it is timestepped over a 2t period : xt = xt + 2tQt where Q is the forcing applied to x, and
the time filter is given by (3.2) so that Q is redistributed over several time step. In the
modified LF-RA environment, these two formulations have been replaced by :


(3.9)
xt+t = xtt + t Qtt/2 + Qt+t/2
i
h
i
h
xtF = xt + xFtt 2xt + xt+t t Qt+t/2 Qtt/2
(3.10)
The change in the forcing formulation given by (3.9) (see Fig.3.2) has a significant effect :
the forcing term no longer excites the divergence of odd and even time steps [Leclair and
Madec 2009]. This property improves the LF-RA scheme in two respects. First, the LFRA can now ensure the local and global conservation of tracers. Indeed, time filtering is
no longer required on the forcing part. The influence of the Asselin filter on the forcing
is be removed by adding a new term in the filter (last term in (3.10) compared to (3.2)).
1

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.

3.6. Start/Restart strategy


Q1

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

Time Domain (STP)


=
5475
=
5475
= .false.
= .false.
= .false.
=
0

!
!
!
!
!
!

frequency of creation of a restart file (modulo referenced to 1)


frequency of write in the output file
(modulo referenced to nn_it000)
DIMG file format: 1 file for all processors (F) or by processor (T)
mask land points in NetCDF outputs (costly: + 15%)
clobber (overwrite) an existing file
chunksize (bytes) for NetCDF file (works only with iom_nf90 routines)

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.

4 Space Domain (DOM)

Contents
4.1

4.2

4.3

Fundamentals of the Discretisation . . . . .


4.1.1 Arrangement of Variables . . . . . .
4.1.2 Discrete Operators . . . . . . . . . .
4.1.3 Numerical Indexing . . . . . . . . .
Domain : Horizontal Grid (mesh) (domhgr)
4.2.1 Coordinates and scale factors . . . . .
4.2.2 Choice of horizontal grid . . . . . . .
4.2.3 Output Grid files . . . . . . . . . . .
Domain : Vertical Grid (domzgr) . . . . . .
4.3.1 Meter Bathymetry . . . . . . . . . .
4.3.2 z-coordinate (ln zco . . . . . . . . .
4.3.3 z-coordinate with partial step (ln zps)
4.3.4 s-coordinate (ln sco) . . . . . . . . .
4.3.5 z - or s -coordinate (add key vvl) .
4.3.6 level bathymetry and mask . . . . . .

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

.
.
.
.
.
.
.
.
.
.
.
.
.
.
.

46
46
47
49
51
51
53
55
55
57
58
60
62
62
62

46

Space Domain (DOM)

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

Fundamentals of the Discretisation


Arrangement of Variables
The numerical techniques used to solve the Primitive Equations in this model are
based on the traditional, centred second-order finite difference approximation. Special
attention has been given to the homogeneity of the solution in the three space directions.
The arrangement of variables is the same in all directions. It consists of cells centred on
scalar points (t, S, p, ) with vector points (u, v, w) defined in the centre of each face of
the cells (Fig. 4.1). This is the generalisation to three dimensions of the well-known C
grid in Arakawas classification [Mesinger and Arakawa 1976]. The relative and planetary
vorticity, and f , are defined in the centre of each vertical edge and the barotropic stream
function is defined at horizontal points overlying the and f -points.
The ocean mesh (i.e. the position of all the scalar and vector points) is defined by the
transformation that gives ( , ,z) as a function of (i, j, k). The grid-points are located at
integer or integer and a half value of (i, j, k) as indicated on Table 4.1. In all the following,
subscripts u, v, w, f , uw, vw or f w indicate the position of the grid-point where the scale
factors are defined. Each scale factor is defined as the local analytical value provided by

(2.10). As a result, the mesh on which partial derivatives


,
, and z
are evaluated
is a uniform mesh with a grid size of unity. Discrete partial derivatives are formulated
by the traditional, centred second order finite difference approximation while the scale
factors are chosen equal to their local analytical value. An important point here is that
the partial derivative of the scale factors must be evaluated by centred finite difference
approximation, not from their analytical expression. This preserves the symmetry of the
discrete set of equations and therefore satisfies many of the continuous properties (see
Appendix E). A similar, related remark can be made about the domain size : when needed,
an area, volume, or the total ocean depth must be evaluated as the sum of the relevant scale
factors (see (4.8)) in the next section).

4.1. Fundamentals of the Discretisation

f
f

47

F IG . 4.1 Arrangement of variables. t indicates scalar points where temperature,


salinity, density, pressure and horizontal divergence are defined. (u,v,w) indicates
vector points, and f indicates vorticity points where both relative and planetary
vorticities are defined

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

q = {q(i + 1/2) + q(i 1/2)} / 2

(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

Space Domain (DOM)


i
i + 1/2
i
i
i + 1/2
i + 1/2
i
i + 1/2

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

TAB . 4.1 Location of grid-points as a function of integer or integer and a half


value of the column, line or level. This indexing is only used for the writing of the
semi-discrete equation. In the code, the indexing uses integer values only and has
a reverse direction in the vertical (see 4.1.3)

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

Following (2.11c) and (2.11b), a vector A = (a1 , a2 , a3 ) defined at vector points


(u, v, w) has its three curl components defined at vw-, uw, and f -points, and its divergence defined at t-points :
A
+
+

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

4.1. Fundamentals of the Discretisation

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)

It is straightforward to demonstrate that these properties are verified locally in discrete


form as soon as the scalar q is taken at t-points and the vector A has its components defined
at vector points (u, v, w).
Let a and b be two fields defined on the mesh, with value zero inside continental area.
Using integration by parts it can be shown that the differencing operators (i , j and k )
are anti-symmetric linear operators, and further that the averaging operators i , k and
k ) are symmetric linear operators, i.e.
X

ai i [b]

i+1/2 [a] bi+1/2

(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

Space Domain (DOM)

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.

4.2. Domain : Horizontal Grid (mesh) (domhgr)

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

Domain : Horizontal Grid (mesh) (domhgr.F90 module)


Coordinates and scale factors
The ocean mesh (i.e. the position of all the scalar and vector points) is defined by the
transformation that gives (, , z) as a function of (i, j, k). The grid-points are located
at integer or integer and a half values of as indicated in Table 4.1. The associated scale
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

Space Domain (DOM)

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.

4.2. Domain : Horizontal Grid (mesh) (domhgr)

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)

e1t e1t = ra |0 (i) cos (j)|

e2t e2t = ra |0 (j)|

e1u e1t = ra |0 (i + 1/2) cos (j)|

e2u e2t = ra |0 (j)|

e1v e1t = ra |0 (i) cos (j + 1/2)|

e2v e2t = ra |0 (j + 1/2)|

e1f e1t = ra |0 (i + 1/2) cos (j + 1/2)|

e2f e2t = ra |0 (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

Choice of horizontal grid


The user has three options available in defining a horizontal grid, which involve the
parameter jphgr mesh of the par oce.F90 module.

54

Space Domain (DOM)

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)

F IG . 4.4 Comparison of (a) traditional definitions of grid-point position and


grid-size in the vertical, and (b) analytically derived grid-point position and scale
factors. For both grids here, the same w-point depth has been chosen but in (a) the
t-points are set half way between w-points while in (b) they are defined from an
analytical function : z(k) = 5 (i 1/2)3 45 (i 1/2)2 + 140 (i 1/2) 150.
Note the resulting difference between the value of the grid-size k and those of
the scale factor ek .

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

4.3. Domain : Vertical Grid (domzgr)

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

Output Grid files


All the arrays relating to a particular ocean model configuration (grid-point position,
scale factors, masks) can be saved in files if nn msh 6= 0 (namelist parameter). This
can be particularly useful for plots and off-line diagnostics. In some cases, the user may
choose to make a local modification of a scale factor in the code. This is the case in global
configurations when restricting the width of a specific strait (usually a one-grid-point strait
that happens to be too wide due to insufficient model resolution). An example is Gibraltar
Strait in the ORCA2 configuration. When such modifications are done, the output grid
written when nn msh 6= 0 is no more equal to the input grid.

4.3

Domain : Vertical Grid (domzgr.F90 module)


!----------------------------------------------------------------------&namzgr
!
vertical coordinate
!----------------------------------------------------------------------ln_zco
= .false.
! z-coordinate - full
steps
(T/F)
("key_zco" may also be defined)
ln_zps
= .true.
! z-coordinate - partial steps
(T/F)
ln_sco
= .false.
! s- or hybrid z-s-coordinate
(T/F)
/

!----------------------------------------------------------------------&namdom
!
space and time domain (bathymetry, mesh, timestep)
!-----------------------------------------------------------------------

56

Space Domain (DOM)

(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.

!
!
!
!
!
!
!
!
!
!
!

compute (=0) or read (=1) the bathymetry file


remove (=0) or keep (=1) closed seas and lakes (ORCA)
create (=1) a mesh file or not (=0)
min depth of the ocean (>0) or min number of ocean level (<0)
partial step thickness is set larger than the minimum of
rn_e3zps_min and rn_e3zps_rat*e3t, with 0<rn_e3zps_rat<1
time step for the dynamics (and tracer if nn_acc=0)
number of barotropic time step
("key_dynspg_ts")
asselin time filter parameter
acceleration of convergence : =1
used, rdt < rdttra(k)
!
=0, not used, rdt = rdttra
! minimum time step on tracers (used if nn_acc=1)
! maximum time step on tracers (used if nn_acc=1)
! depth variation of tracer time step (used if nn_acc=1)

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

4.3. Domain : Vertical Grid (domzgr)

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

Space Domain (DOM)

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

z-coordinate (ln zco=true) and reference coordinate


The reference coordinate transformation z0 (k) defines the arrays gdept0 and gdepw0
for t- and w-points, respectively. As indicated on Fig.4.3 jpk is the number of w-levels.
gdepw0 (1) is the ocean surface. There are at most jpk-1 t-points inside the ocean, the
additional t-point at jk = jpk is below the sea floor and is not used. The vertical location of w- and t-levels is defined from the analytic expression of the depth z0 (k) whose
analytical derivative with respect to k provides the vertical scale factors. The user must
provide the analytical expression of both z0 and its first derivative with respect to k. This
is done in routine domzgr.F90 through statement functions, using parameters provided in
the par oce.h90 file.
It is possible to define a simple regular vertical grid by giving zero stretching (ppacr=0).
In that case, the parameters jpk (number of w-levels) and pphmax (total ocean depth in
meters) fully define the grid.
For climate-related studies it is often desirable to concentrate the vertical resolution
near the ocean surface. The following function is proposed as a standard for a z-coordinate
(with either full or partial steps) :
z0 (k) = hsur h0 k h1 log [ cosh ((k hth )/hcr ) ]
e03 (k) = |h0 h1 tanh ((k hth )/hcr )|

(4.13)

where k = 1 to jpk for w-levels and k = 1 to k = 1 for T levels. Such an expression


allows us to define a nearly uniform vertical location of levels at the ocean top and bottom
with a smooth hyperbolic tangent transition in between (Fig. 4.6).
The most used vertical grid for ORCA2 has 10 m (500 m) resolution in the surface
(bottom) layers and a depth which varies from 0 at the sea surface to a minimum of

4.3. Domain : Vertical Grid (domzgr)

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.

5000 m. This leads to the following conditions :


e3 (1 + 1/2) = 10.
e3 (jpk 1/2) = 500.
z(1) = 0.

(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

Space Domain (DOM)

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

z-coordinate with partial step (ln zps=.true.)


!----------------------------------------------------------------------&namdom
!
space and time domain (bathymetry, mesh, timestep)
!----------------------------------------------------------------------nn_bathy
=
1
! compute (=0) or read (=1) the bathymetry file
nn_closea
=
0
! remove (=0) or keep (=1) closed seas and lakes (ORCA)
nn_msh
=
0
! create (=1) a mesh file or not (=0)
rn_hmin
=
-3.
! min depth of the ocean (>0) or min number of ocean level (<0)
rn_e3zps_min=
20.
! partial step thickness is set larger than the minimum of
rn_e3zps_rat=
0.1
! rn_e3zps_min and rn_e3zps_rat*e3t, with 0<rn_e3zps_rat<1
!
rn_rdt
= 5760.
! time step for the dynamics (and tracer if nn_acc=0)
nn_baro
=
64
! number of barotropic time step
("key_dynspg_ts")
rn_atfp
=
0.1
! asselin time filter parameter
nn_acc
=
0
! acceleration of convergence : =1
used, rdt < rdttra(k)
!
=0, not used, rdt = rdttra
rn_rdtmin
= 28800.
! minimum time step on tracers (used if nn_acc=1)
rn_rdtmax
= 28800.
! maximum time step on tracers (used if nn_acc=1)
rn_rdth
= 800.
! depth variation of tracer time step (used if nn_acc=1)
/

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)).

4.3. Domain : Vertical Grid (domzgr)

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

Space Domain (DOM)


Add a figure here of pstep especially at last ocean level

4.3.4

s-coordinate (ln sco=true)


!----------------------------------------------------------------------&namzgr_sco
!
s-coordinate or hybrid z-s-coordinate
!----------------------------------------------------------------------rn_sbot_min = 300.
! minimum depth of s-bottom surface (>0) (m)
rn_sbot_max = 5250.
! maximum depth of s-bottom surface (= ocean depth) (>0) (m)
rn_theta
=
6.0
! surface control parameter (0<=rn_theta<=20)
rn_thetb
=
0.75
! bottom control parameter (0<=rn_thetb<= 1)
rn_rmax
=
0.15
! maximum cut-off r-value allowed (0<rn_max<1)
ln_s_sigma = .false.
! hybrid s-sigma coordinates
rn_bb
=
0.8
! stretching with s-sigma
rn_hc
= 150.0
! critical depth with s-sigma
/

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

z - or s -coordinate (add key vvl)


This option is described in the Report by Levier et al. (2007), available on the NEMO
web site.

4.3.6

level bathymetry and mask


Whatever the vertical coordinate used, the model offers the possibility of representing
the bottom topography with steps that follow the face of the model cells (step like topography) [Madec et al. 1996]. The distribution of the steps in the horizontal is defined in

4.3. Domain : Vertical Grid (domzgr)

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).

5 Ocean Tracers (TRA)

Contents
5.1

5.2

5.3
5.4

5.5

5.6

Tracer Advection (traadv) . . . . . . . . . . . . . . . . . . .


5.1.1 2nd order centred scheme (cen2) (ln traadv cen2) . . .
5.1.2 4nd order centred scheme (cen4) (ln traadv cen4) . . .
5.1.3 Total Variance Dissipation scheme (TVD) (ln traadv tvd)
5.1.4 MUSCL scheme (ln traadv muscl) . . . . . . . . . .
5.1.5 Upstream-Biased Scheme (UBS) (ln traadv ubs) . . .
5.1.6 QUICKEST scheme (QCK) (ln traadv qck) . . . . . .
5.1.7 Piecewise Parabolic Method (PPM) (ln traadv ppm) .
Tracer Lateral Diffusion (traldf ) . . . . . . . . . . . . . . .
5.2.1 Iso-level laplacian operator (lap) (ln traldf lap) . . . .
5.2.2 Rotated laplacian operator (iso) (ln traldf lap) . . . .
5.2.3 Iso-level bilaplacian operator (bilap) (ln traldf bilap) .
5.2.4 Rotated bilaplacian operator (bilapg) (ln traldf bilap) .
Tracer Vertical Diffusion (trazdf ) . . . . . . . . . . . . . . .
External Forcing . . . . . . . . . . . . . . . . . . . . . . . .
5.4.1 Surface boundary condition (trasbc) . . . . . . . . . .
5.4.2 Solar Radiation Penetration (traqsr) . . . . . . . . . .
5.4.3 Bottom Boundary Condition (trabbc) . . . . . . . . .
Bottom Boundary Layer (trabbl.F90 - key trabbl) . . . . .
5.5.1 Diffusive Bottom Boundary layer (nn bbl ldf =1) . . .
5.5.2 Advective Bottom Boundary Layer (nn bbl adv= 1 or 2)
Tracer damping (tradmp) . . . . . . . . . . . . . . . . . . .

67
69
69
70
71
71
72
73
73
73
74
75
75
75
76
76
78
80
81
82
82
84

66

Ocean Tracers (TRA)


5.7
5.8

5.9

Tracer time evolution (tranxt) . . . . . . . . . . . .


Equation of State (eosbn2) . . . . . . . . . . . . .
5.8.1 Equation of State (nn eos = 0, 1 or 2) . . . .
5.8.2 Brunt-Vaisala Frequency (nn eos = 0, 1 or 2)
5.8.3 Specific Heat (phycst) . . . . . . . . . . . .
5.8.4 Freezing Point of Seawater . . . . . . . . . .
Horizontal Derivative in zps-coordinate (zpshde) .

.
.
.
.
.
.
.

.
.
.
.
.
.
.

.
.
.
.
.
.
.

.
.
.
.
.
.
.

.
.
.
.
.
.
.

86
87
87
88
88
89
89

Using the representation described in Chap. 4, several semi-discrete space forms of


the tracer equations are available depending on the vertical coordinate used and on the
physics used. In all the equations presented here, the masking has been omitted for simplicity. One must be aware that all the quantities are masked fields and that each time a
mean or difference operator is used, the resulting field is multiplied by a mask.
The two active tracers are potential temperature and salinity. Their prognostic equations can be summarized as follows :
NXT = ADV + LDF + ZDF + SBC (+QSR) (+BBC) (+BBL) (+DMP)
NXT stands for next, referring to the time-stepping. From left to right, the terms on the
rhs of the tracer equations are the advection (ADV), the lateral diffusion (LDF), the vertical diffusion (ZDF), the contributions from the external forcings (SBC : Surface Boundary
Condition, QSR : penetrative Solar Radiation, and BBC : Bottom Boundary Condition),
the contribution from the bottom boundary Layer (BBL) parametrisation, and an internal damping (DMP) term. The terms QSR, BBC, BBL and DMP are optional. The external forcings and parameterisations require complex inputs and complex calculations
(e.g. bulk formulae, estimation of mixing coefficients) that are carried out in the SBC,
LDF and ZDF modules and described in chapters 7, 9 and 10, respectively. Note that
tranpc.F90, the non-penetrative convection module, although (temporarily) located in the
NEMO/OPA/TRA directory, is described with the model vertical physics (ZDF).
In the present chapter we also describe the diagnostic equations used to compute the
sea-water properties (density, Brunt-Vaisala frequency, specific heat and freezing point
with associated modules eosbn2.F90 and phycst.F90).
The different options available to the user are managed by namelist logicals or CPP
keys. For each equation term ttt, the namelist logicals are ln trattt xxx, where xxx is a 3
or 4 letter acronym corresponding to each optional scheme. The CPP key (when it exists)
is key trattt. The equivalent code can be found in the trattt or trattt xxx module, in the
NEMO/OPA/TRA directory.
The user has the option of extracting each tendency term on the rhs of the tracer
equation for output (key trdtra is defined), as described in Chap. 14.

5.1. Tracer Advection (traadv)

5.1

67

Tracer Advection (traadv.F90)


!----------------------------------------------------------------------&namtra_adv
!
advection scheme for tracer
!----------------------------------------------------------------------ln_traadv_cen2
= .false. ! 2nd order centered scheme
ln_traadv_tvd
= .true.
! TVD scheme
ln_traadv_muscl = .false. ! MUSCL scheme
ln_traadv_muscl2 = .false. ! MUSCL2 scheme + cen2 at boundaries
ln_traadv_ubs
= .false. ! UBS scheme
ln_traadv_qck
= .false. ! QUCIKEST scheme
/

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

Ocean Tracers (TRA)

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

F IG . 5.1 Schematic representation of some ways used to evaluate the tracer


value at u-point and the amount of tracer exchanged between two neighbouring
grid points. Upsteam biased scheme (ups) : the upstream value is used and the
black area is exchanged. Piecewise parabolic method (ppm) : a parabolic interpolation is used and the black and dark grey areas are exchanged. Monotonic upstream scheme for conservative laws (muscl) : a parabolic interpolation is used and
black, dark grey and grey areas are exchanged. Second order scheme (cen2) : the
mean value is used and black, dark grey, grey and light grey areas are exchanged.
Note that this illustration does not include the flux limiter used in ppm and muscl
schemes.

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

5.1. Tracer Advection (traadv)

69

of tracer, as well as the issue of numerical cost.


Note that (1) cen2, cen4 and TVD schemes require an explicit diffusion operator while
the other schemes are diffusive enough so that they do not require additional diffusion ; (2)
cen2, cen4, MUSCL2, and UBS are not positive schemes 1 , implying that false extrema
are permitted. Their use is not recommended on passive tracers ; (3) It is recommended
that the same advection-diffusion scheme is used on both active and passive tracers. Indeed, if a source or sink of a passive tracer depends on an active one, the difference of
treatment of active and passive tracers can create very nice-looking frontal structures that
are pure numerical artefacts. Nevertheless, most of our users set a different treatment on
passive and active tracers, thats the reason why this possibility is offered. We strongly
suggest them to perform a sensitivity experiment using a same treatment to assess the
robustness of their results.

5.1.1

2nd order centred scheme (cen2) (ln traadv cen2=true)


In the centred second order formulation, the tracer at velocity points is evaluated as
the mean of the two neighbouring T -point values. For example, in the i-direction :
ucen2 = T

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

4nd order centred scheme (cen4) (ln traadv cen4=true)


In the 4th order formulation (to be implemented), tracer values are evaluated at velocity points as a 4th order interpolation, and thus depend on the four neighbouring T -points.
For example, in the i-direction :
ucen4 = T
1


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

Ocean Tracers (TRA)

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

Total Variance Dissipation scheme (TVD) (ln traadv tvd=true)


In the Total Variance Dissipation (TVD) formulation, the tracer at velocity points is
evaluated using a combination of an upstream and a centred scheme. For example, in the
i-direction :
uups

(
Ti+1
=
Ti

if ui+1/2 < 0
if ui+1/2 0

utvd = uups + cu ucen2 uups

(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. Tracer Advection (traadv)

5.1.4

71

Monotone Upstream Scheme for Conservative Laws (MUSCL)


(ln traadv muscl=T)
The Monotone Upstream Scheme for Conservative Laws (MUSCL) has been implemented by Levy et al. [2001]. In its formulation, the tracer at velocity points is evaluated
assuming a linear tracer variation between two T -points (Fig.5.1). For example, in the
i-direction :



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

Upstream-Biased Scheme (UBS) (ln traadv ubs=true)


The UBS advection scheme is an upstream-biased third order scheme based on an
upstream-biased parabolic interpolation. It is also known as the Cell Averaged QUICK
scheme (Quadratic Upstream Interpolation for Convective Kinematics). For example, in
the i-direction :
(
if ui+1/2 > 0
1 i
i+1/2
ubs
u = T

(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

Ocean Tracers (TRA)

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

QUICKEST scheme (QCK) (ln traadv qck=true)


The Quadratic Upstream Interpolation for Convective Kinematics with Estimated
Streaming Terms (QUICKEST) scheme proposed by Leonard [1979] is the third order Godunov scheme. It is associated with the ULTIMATE QUICKEST limiter [Leonard 1991].
It has been implemented in NEMO by G. Reffray (MERCATOR-ocean) and can be found

5.2. Tracer Lateral Diffusion (traldf )

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

Piecewise Parabolic Method (PPM) (ln traadv ppm=true)


The Piecewise Parabolic Method (PPM) proposed by Colella and Woodward (1984)
is based on a quadradic piecewise construction. Like the QCK scheme, it is associated
with the ULTIMATE QUICKEST limiter [Leonard 1991]. It has been implemented in
NEMO by G. Reffray (MERCATOR-ocean) but is not yet offered in the reference version
3.3.

5.2

Tracer Lateral Diffusion (traldf.F90)


!----------------------------------------------------------------------&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")
/

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

Iso-level laplacian operator (lap) (ln traldf lap=true)


A laplacian diffusion operator (i.e. a harmonic operator) acting along the model surfaces is given by :
 



1
lT
lT e2u e3u
lT e1v e3v
DT =
i Au
i+1/2 [T ] + j Av
j+1/2 [T ]
(5.9)
bt T
e1u
e2v

74

Ocean Tracers (TRA)

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

Rotated laplacian operator (iso) (ln traldf lap=true)


The general form of the second order lateral tracer subgrid scale physics (2.36) takes
the following semi-discrete space form in z- and s-coordinates :
DTlT

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

e1w r2w j+1/2 [T ]

(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

5.3. Tracer Vertical Diffusion (trazdf )

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

Iso-level bilaplacian operator (bilap) (ln traldf bilap=true)


The lateral fourth order bilaplacian operator on tracers is obtained by applying (5.9)
twice. The operator requires an additional assumption on boundary conditions : both first
and third derivative terms normal to the coast are set to zero. It is used when, in addition to ln traldf bilap=true, we have ln traldf level=true, or both ln traldf hor=true and
ln zco=false. In both cases, it can contribute diapycnal mixing, although less than in the
laplacian case. It is therefore not recommended.
Note that in the code, the bilaplacian routine does not call the laplacian routine twice
but is rather a separate routine that can be found in the traldf bilap.F90 module. This is
due to the fact that we introduce the eddy diffusivity coefficient,
p A, in the operator as :
(A T ), instead of a ( aT ) where a = |A| and A < 0. This was
a mistake : both formulations ensure the total variance decrease, but the former requires a
larger number of code-lines.

5.2.4

Rotated bilaplacian operator (bilapg) (ln traldf bilap=true)


The lateral fourth order operator formulation on tracers is obtained by applying (5.10)
twice. It requires an additional assumption on boundary conditions : first and third derivative terms normal to the coast, normal to the bottom and normal to the surface are set to
zero. It can be found in the traldf bilapg.F90.
It is used when, in addition to ln traldf bilap=true, we have ln traldf iso= .true, or
both ln traldf hor=true and ln zco=true. This rotated bilaplacian operator has never been
seriously tested. There are no guarantees that it is either free of bugs or correctly formulated. Moreover, the stability range of such an operator will be probably quite narrow,
requiring a significantly smaller time-step than the one used with an unrotated operator.

5.3

Tracer Vertical Diffusion (trazdf.F90)


!----------------------------------------------------------------------&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

76

Ocean Tracers (TRA)

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) :

5.4. External Forcing

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 =

(Qns emp Cp T |k=1 )


((empS emp) S|k=1 )

(5.12)

In the linear free surface case (key vvl not defined) :


1
o Cp e3t |k=1
1
FS =
o e3t |k=1
FT =

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

Ocean Tracers (TRA)

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

Solar Radiation Penetration (traqsr.F90)


!----------------------------------------------------------------------&namtra_qsr
!
penetrative solar radiation
!----------------------------------------------------------------------!
! file name ! frequency (hours) ! variable ! time interp. ! clim ! yearly/ ! weights ! rotation !
!
!
! (if <0 months) !
name
!
(logical) ! (T/F) ! monthly ! filename ! pairing !
sn_chl
=chlorophyll,
-1
, CHLA
,
.true.
, .true. , yearly ,
,
cn_dir
ln_traqsr
ln_qsr_rgb
ln_qsr_2bd
ln_qsr_bio
nn_chldta
rn_abs
rn_si0
rn_si1

=
=
=
=
=
=
=
=
=

./
.true.
.true.
.false.
.false.
1
0.58
0.35
23.0

!
!
!
!
!
!
!
!
!

root directory for the location of the runoff files


Light penetration (T) or not (F)
RGB (Red-Green-Blue) light penetration
2 bands
light penetration
bio-model light penetration
RGB : Chl data (=1) or cst value (=0)
RGB & 2 bands: fraction of light (rn_si1)
RGB & 2 bands: shortess depth of extinction
2 bands: longest depth of extinction

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)

Qns = QTotal Qsr


where Qsr is the penetrative part of the surface heat flux (i.e. the shortwave radiation) and
I is the downward irradiance ( I|z= = Qsr ). The additional term in (5.14) is discretized
as follows :
I
1
1

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

5.4. External Forcing

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

Ocean Tracers (TRA)

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

F IG . 5.2 Penetration profile of the downward solar irradiance calculated


by four models. Two waveband chlorophyll-independent formulation (blue), a
chlorophyll-dependent monochromatic formulation (green), 4 waveband RGB
formulation (red), 61 waveband Morel (1988) formulation (black) for a chlorophyll concentration of (a) Chl=0.05 mg/m3 and (b) Chl=0.5 mg/m3 . From Lengaigne et al. [2007].

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

Bottom Boundary Condition (trabbc.F90)


!----------------------------------------------------------------------&nambbc
!
bottom temperature boundary condition
!----------------------------------------------------------------------ln_trabbc
= .true.
! Apply a geothermal heating at the ocean bottom
nn_geoflx
=
2
! geothermal heat flux: = 0 no flux
!
= 1 constant flux
!
= 2 variable flux (read in geothermal_heating.nc in mW/m2)
rn_geoflx_cst = 86.4e-3 ! Constant value of geothermal heat flux [W/m2]
/

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-

5.5. Bottom Boundary Layer (trabbl.F90 - key trabbl)

81

Geothermal Heat flux (mW/m2)

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

Bottom Boundary Layer (trabbl.F90 - key trabbl)


!----------------------------------------------------------------------&nambbl
!
bottom boundary layer scheme
!----------------------------------------------------------------------nn_bbl_ldf = 1
! diffusive bbl (=1)
or not (=0)
nn_bbl_adv = 0
! advective bbl (=1/2) or not (=0)
rn_ahtbbl
= 1000. ! lateral mixing coefficient in the bbl [m2/s]
rn_gambbl
= 10.
! advective bbl coefficient
[s]
/

In a z-coordinate configuration, the bottom topography is represented by a series of


discrete steps. This is not adequate to represent gravity driven downslope flows. Such
flows arise either downstream of sills such as the Strait of Gibraltar or Denmark Strait,
where dense water formed in marginal seas flows into a basin filled with less dense water, or along the continental slope when dense water masses are formed on a continental
shelf. The amount of entrainment that occurs in these gravity plumes is critical in determining the density and volume flux of the densest waters of the ocean, such as Antarctic
Bottom Water, or North Atlantic Deep Water. z-coordinate models tend to overestimate
the entrainment, because the gravity flow is mixed vertically by convection as it goes

82

Ocean Tracers (TRA)

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

Diffusive Bottom Boundary layer (nn bbl ldf =1)


When applying sigma-diffusion (key trabbl defined and nn bbl ldf set to 1), the diffusive flux between two adjacent cells at the ocean floor is given by
F = Al T

(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

Advective Bottom Boundary Layer (nn bbl adv= 1 or 2)


When applying an advective BBL (nn bbl adv = 1 or 2), an overturning circulation is
added which connects two adjacent bottom grid-points only if dense water overlies less
dense water on the slope. The density difference causes dense water to move down the
slope.

5.5. Bottom Boundary Layer (trabbl.F90 - key trabbl)


i

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

Ocean Tracers (TRA)

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

e1u min e3ukup , e3ukdwn


o

(5.20)

where , expressed in seconds, is the coefficient of proportionality provided as rn gambbl,


a namelist parameter, and kup and kdwn are the vertical index of the higher and lower cells,
respectively. The parameter should take a different value for each bathymetric step, but
for simplicity, and because no direct estimation of this parameter is available, a uniform
value has been assumed. The possible values for range between 1 and 10 s [Campin and
Goosse 1999].
tr
Scalar properties are advected by this additional transport (utr
bbl , vbbl ) using the upwind scheme. Such a diffusive advective scheme has been chosen to mimic the entrainment between the downslope plume and the surrounding water at intermediate depths.
The entrainment is replaced by the vertical mixing implicit in the advection scheme. Let
us consider as an example the case displayed in Fig.5.4 where the density at level (i, kup)
is larger than the one at level (i, kdwn). The advective BBL scheme modifies the tracer
time tendency of the ocean cells near the topographic step by the downslope flow (5.21),
the horizontal (5.22) and the upward (5.23) return flows as follows :


utr
sh
do
bbl
T

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)

and for k = kdw 1, ..., kup :


t Tkdo t Skdo +



utr
sh
do
bbl

T
T
k+1
k
bt do
k

(5.23)

where bt is the T -cell volume.


tr
Note that the BBL transport, (utr
bbl , vbbl ), is available in the model outputs. It has to be
used to compute the effective velocity as well as the effective overturning circulation.

5.6

Tracer damping (tradmp.F90)


!----------------------------------------------------------------------&namtra_dmp
!
tracer: T & S newtonian damping
(key_tradmp)
!----------------------------------------------------------------------nn_hdmp
=
-1
! horizontal shape =-1, damping in Med and Red Seas only
!
=XX, damping poleward of XX degrees (XX>0)
!
+ F(distance-to-coast) + Red and Med Seas
nn_zdmp
=
1
! vertical
shape =0
damping throughout the water column
!
=1 no damping in the mixing layer (kz criteria)
!
=2 no damping in the mixed layer (rho crieria)
rn_surf
=
50.
! surface time scale of damping
[days]
rn_bot
= 360.
! bottom time scale of damping
[days]
rn_dep
= 800.
! depth of transition between rn_surf and rn_bot [meters]
nn_file
=
0
! create a damping.coeff NetCDF file (=1) or not (=0)
/

5.6. Tracer damping (tradmp)

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

Ocean Tracers (TRA)

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

Tracer time evolution (tranxt.F90)


!----------------------------------------------------------------------&namdom
!
space and time domain (bathymetry, mesh, timestep)
!----------------------------------------------------------------------nn_bathy
=
1
! compute (=0) or read (=1) the bathymetry file
nn_closea
=
0
! remove (=0) or keep (=1) closed seas and lakes (ORCA)
nn_msh
=
0
! create (=1) a mesh file or not (=0)
rn_hmin
=
-3.
! min depth of the ocean (>0) or min number of ocean level (<0)
rn_e3zps_min=
20.
! partial step thickness is set larger than the minimum of
rn_e3zps_rat=
0.1
! rn_e3zps_min and rn_e3zps_rat*e3t, with 0<rn_e3zps_rat<1
!
rn_rdt
= 5760.
! time step for the dynamics (and tracer if nn_acc=0)
nn_baro
=
64
! number of barotropic time step
("key_dynspg_ts")
rn_atfp
=
0.1
! asselin time filter parameter
nn_acc
=
0
! acceleration of convergence : =1
used, rdt < rdttra(k)
!
=0, not used, rdt = rdttra
rn_rdtmin
= 28800.
! minimum time step on tracers (used if nn_acc=1)
rn_rdtmax
= 28800.
! maximum time step on tracers (used if nn_acc=1)
rn_rdth
= 800.
! depth variation of tracer time step (used if nn_acc=1)
/

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 .

5.8. Equation of State (eosbn2)

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

Equation of State (eosbn2.F90)


!----------------------------------------------------------------------&nameos
!
ocean physical parameters
!----------------------------------------------------------------------nn_eos
=
0
! type of equation of state and Brunt-Vaisala frequency
!
= 0, UNESCO (formulation of Jackett and McDougall (1994) and of McDougall (1987) )
!
= 1, linear: rho(T)
= rau0 * ( 1.028 - ralpha * T )
!
= 2, linear: rho(T,S) = rau0 * ( rbeta * S - ralpha * T )
rn_alpha
=
2.0e-4 ! thermal expension coefficient (nn_eos= 1 or 2)
rn_beta
=
7.7e-4 ! saline expension coefficient (nn_eos= 2)
/

5.8.1

Equation of State (nn eos = 0, 1 or 2)


It is necessary to know the equation of state for the ocean very accurately to determine stability properties (especially the Brunt-Vaisala frequency), particularly in the deep
ocean. The ocean seawater volumic mass, , abusively called density, is a non linear empirical function of in situ temperature, salinity and pressure. The reference equation of
state is that defined by the Joint Panel on Oceanographic Tables and Standards [UNESCO
1983]. It was the standard equation of state used in early releases of OPA. However, even
though this computation is fully vectorised, it is quite time consuming (15 to 20% of the
total CPU time) since it requires the prior computation of the in situ temperature from the
model potential temperature using the [Bryden 1973] polynomial for adiabatic lapse rate
and a 4t h order Runge-Kutta integration scheme. Since OPA6, we have used the Jackett
and McDougall [1995] equation of state for seawater instead. It allows the computation
of the in situ ocean density directly as a function of potential temperature relative to
the surface (an NEMO variable), the practical salinity (another NEMO variable) and the
pressure (assuming no pressure variation along geopotential surfaces, i.e. the pressure in
decibars is approximated by the depth in meters). Both the UNESCO [1983] and Jackett
and McDougall [1995] equations of state have exactly the same except that the values of
the various coefficients have been adjusted by Jackett and McDougall [1995] in order to
directly use the potential temperature instead of the in situ one. This reduces the CPU time
of the in situ density computation to about 3% of the total CPU time, while maintaining a
quite accurate equation of state.
In the computer code, a true density anomaly, da = /o 1, is computed, with
o a reference volumic mass. Called rau0 in the code, o is defined in phycst.F90, and
a value of 1, 035 Kg/m3 . This is a sensible choice for the reference density used in a
Boussinesq ocean climate model, as, with the exception of only a small percentage of the
ocean, density in the World Ocean varies by no more than 2% from 1, 035 kg/m3 [Gill
1982].

88

Ocean Tracers (TRA)

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

Brunt-Vaisala Frequency (nn eos = 0, 1 or 2)


An accurate computation of the ocean stability (i.e. of N , the brunt-Vaisala frequency)
is of paramount importance as it is used in several ocean parameterisations (namely TKE,
KPP, Richardson number dependent vertical diffusion, enhanced vertical diffusion, nonpenetrative convection, iso-neutral diffusion). In particular, one must be aware that N 2
has to be computed with an in situ reference. The expression for N 2 depends on the type
of equation of state used (nn eos namelist parameter).
For nn eos=0 (Jackett and McDougall [1995] equation of state), the McDougall [1987]
polynomial expression is used (with the pressure in decibar approximated by the depth in
meters) :

g
N2 =
/ k+1/2 [T ] k+1/2 [S]
(5.27)
e3w
where and are the thermal and haline expansion coefficients. They are a function of
k+1/2 e
k+1/2
T
,S = S
35., and zw , with T the potential temperature and Se a salinity
anomaly. Note that both and depend on potential temperature and salinity which are
averaged at w-points prior to the computation instead of being computed at T -points and
then averaged to w-points.
When a linear equation of state is used (nn eos=1 or 2, (5.27) reduces to :
N2 =

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

Specific Heat (phycst.F90)


The specific heat of sea water, Cp , is a function of temperature, salinity and pressure [UNESCO 1983]. It is only used in the model to convert surface heat fluxes into

5.9. Horizontal Derivative in zps-coordinate (zpshde)

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

Freezing Point of Seawater


The freezing point of seawater is a function of salinity and pressure [UNESCO 1983] :




Tf (S, p) = 0.0575 + 1.710523 103 S 2.154996 104 S S


7.53 103 p

(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

Horizontal Derivative in zps-coordinate (zpshde.F90)


With partial bottom cells (ln zps=true), in general, tracers in horizontally adjacent
cells live at different depths. Horizontal gradients of tracers are needed for horizontal diffusion (traldf.F90 module) and for the hydrostatic pressure gradient (dynhpg.F90 module)
to be active. Before taking horizontal gradients between the tracers next to the bottom, a
linear interpolation in the vertical is used to approximate the deeper tracer as if it actually
lived at the depth of the shallower tracer point (Fig. 5.5). For example, for temperature in
the i-direction the needed interpolated temperature, Te, is :

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

Ocean Tracers (TRA)

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

F IG . 5.5 Discretisation of the horizontal difference and average of tracers in the


z-partial step coordinate (ln zps=true) in the case (e3wki+1 e3wki ) > 0. A linear
interpolation is used to estimate Teki+1 , the tracer value at the depth of the shallower
tracer point of the two adjacent bottom T -points. The horizontal difference is then
i+1/2
i+1/2
given by : i+1/2 Tk = Teki+1 Tki and the average by : T k
= (Tek
Tki )/2.

5.9. Horizontal Derivative in zps-coordinate (zpshde)

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

The computation of horizontal derivative of tracers as well as of density is performed


once for all at each time step in zpshde.F90 module and stored in shared arrays to be used
when needed. It has to be emphasized that the procedure used to compute the interpolated
density, e, is not the same as that used for T and S. Instead of forming a linear approximation of density, we compute e from the interpolated values of T and S, and the pressure
at a u-point (in the equation of state pressure is approximated by depth, see 5.8.1 ) :

e zu ) where zu = min z i+1 , z i
(5.31)
e = (Te, S,
T
T
This is a much better approximation as the variation of with depth (and thus pressure) is highly non-linear with a true equation of state and thus is badly approximated with
a linear interpolation. This approximation is used to compute both the horizontal pressure
gradient (6.4) and the slopes of neutral surfaces (9.2)
Note that in almost all the advection schemes presented in this Chapter, both averaging
and differencing operators appear. Yet (5.30) has not been used in these schemes : in
contrast to diffusion and pressure gradient computations, no correction for partial steps
is applied for advection. The main motivation is to preserve the domain averaged mean
variance of the advected field when using the 2nd order centred scheme. Sensitivity of the
advection schemes to the way horizontal averages are performed in the vicinity of partial
cells should be further investigated in the near future.

6 Ocean Dynamics (DYN)

Contents
6.1

6.2

6.3

6.4

6.5

6.6

Sea surface height and diagnostic variables (, , , w) . . . 95


6.1.1 Horizontal divergence and relative vorticity (divcur) . 95
6.1.2 Sea surface height evolution and vertical velocity (sshwzv) 95
Coriolis and Advection : vector invariant form . . . . . . . 96
6.2.1 Vorticity term (dynvor) . . . . . . . . . . . . . . . . . 96
6.2.2 Kinetic Energy Gradient term (dynkeg) . . . . . . . . 99
6.2.3 Vertical advection term (dynzad) . . . . . . . . . . . 100
Coriolis and Advection : flux form . . . . . . . . . . . . . . 100
6.3.1 Coriolis plus curvature metric terms (dynvor) . . . . . 100
6.3.2 Flux form Advection term (dynadv) . . . . . . . . . . 101
Hydrostatic pressure gradient (dynhpg) . . . . . . . . . . . 102
6.4.1 z-coordinate with full step (ln dynhpg zco) . . . . . . 103
6.4.2 z-coordinate with partial step (ln dynhpg zps) . . . . . 103
6.4.3 s- and z-s-coordinates . . . . . . . . . . . . . . . . . 103
6.4.4 Time-scheme (ln dynhpg imp) . . . . . . . . . . . . 104
Surface pressure gradient (dynspg) . . . . . . . . . . . . . 105
6.5.1 Explicit free surface (key dynspg exp) . . . . . . . . 106
6.5.2 Split-Explicit free surface (key dynspg ts) . . . . . . 106
6.5.3 Filtered free surface (key dynspg flt) . . . . . . . . . 106
Lateral diffusion term (dynldf ) . . . . . . . . . . . . . . . . 107
6.6.1 Iso-level laplacian operator (ln dynldf lap) . . . . . . 108
6.6.2 Rotated laplacian operator (ln dynldf iso) . . . . . . . 108

94

Ocean Dynamics (DYN)

6.7
6.8
6.9

6.6.3 Iso-level bilaplacian operator (ln


Vertical diffusion term (dynzdf.F90) .
External Forcings . . . . . . . . . . .
Time evolution term (dynnxt) . . . . .

dynldf bilap)
. . . . . . . .
. . . . . . . .
. . . . . . . .

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

109
109
111
111

Using the representation described in Chapter 4, several semi-discrete space forms of


the dynamical equations are available depending on the vertical coordinate used and on
the conservation properties of the vorticity term. In all the equations presented here, the
masking has been omitted for simplicity. One must be aware that all the quantities are
masked fields and that each time an average or difference operator is used, the resulting
field is multiplied by a mask.
The prognostic ocean dynamics equation can be summarized as follows :


VOR + KEG + ZAD
NXT =
+ HPG + SPG + LDF + ZDF
COR + ADV
NXT stands for next, referring to the time-stepping. The first group of terms on the rhs
of this equation corresponds to the Coriolis and advection terms that are decomposed into
either a vorticity part (VOR), a kinetic energy part (KEG) and a vertical advection part
(ZAD) in the vector invariant formulation, or a Coriolis and advection part (COR+ADV)
in the flux formulation. The terms following these are the pressure gradient contributions
(HPG, Hydrostatic Pressure Gradient, and SPG, Surface Pressure Gradient) ; and contributions from lateral diffusion (LDF) and vertical diffusion (ZDF), which are added to the
rhs in the dynldf.F90 and dynzdf.F90 modules. The vertical diffusion term includes the
surface and bottom stresses. The external forcings and parameterisations require complex
inputs (surface wind stress calculation using bulk formulae, estimation of mixing coefficients) that are carried out in modules SBC, LDF and ZDF and are described in Chapters
7, 9 and 10, respectively.
In the present chapter we also describe the diagnostic equations used to compute
the horizontal divergence, curl of the velocities (divcur module) and the vertical velocity
(wzvmod module).
The different options available to the user are managed by namelist variables. For term
ttt in the momentum equations, the logical namelist variables are ln dynttt xxx, where xxx
is a 3 or 4 letter acronym corresponding to each optional scheme. If a CPP key is used
for this term its name is key ttt. The corresponding code can be found in the dynttt xxx
module in the DYN directory, and it is usually computed in the dyn ttt xxx subroutine.
The user has the option of extracting and outputting each tendency term from the 3D
momentum equations (key trddyn defined), as described in Chap.14. Furthermore, the
tendency terms associated with the 2D barotropic vorticity balance (when key trdvor is
defined) can be derived from the 3D terms.

6.1. Sea surface height and diagnostic variables (, , , w)

6.1
6.1.1

95

Sea surface height and diagnostic variables (, , ,


w)
Horizontal divergence and relative vorticity (divcur.F90)
The vorticity is defined at an f -point (i.e. corner point) as follows :
=

1
e1f e2f

i+1/2 [e2v v] j+1/2 [e1u u]

(6.1)

The horizontal divergence is defined at a T -point. It is given by :


=

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

Horizontal divergence and relative vorticity (sshwzv.F90)


The sea surface height is given by :

1 X
emp

{i [e2u e3u u] + j [e1v e3v v]}


t
e1t e2t
w
k
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

Ocean Dynamics (DYN)

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 :

where kb is the level just above the sea floor


w|kb 1/2 = 0
(6.4)


1
t1
w|

et+1
3t k e3t k
k+1/2 = w|k1/2 + e3t |k |k
2t
In the case of a non-linear free surface (key vvl), the top vertical velocity is emp/w ,
as changes in the divergence of the barotropic transport are absorbed into the change of
the level thicknesses, re-orientated downward. In the case of a linear free surface, the
time derivative in (6.4) disappears. The upper boundary condition applies at a fixed level
z = 0. The top vertical velocity is thus equal to the divergence of the barotropic transport
(i.e. the first term in the right-hand-side of (6.3)).
Note also that whereas the vertical velocity has the same discrete expression in zand s-coordinates, its physical meaning is not the same : in the second case, w is the
velocity normal to the s-surfaces. Note also that the k-axis is re-orientated downwards in
the FORTRAN code compared to the indexing used in the semi-discrete equations such as
(6.4) (see 4.1.3).

6.2

Coriolis and Advection : vector invariant form


!----------------------------------------------------------------------&namdyn_adv
!
formulation of the momentum advection
!----------------------------------------------------------------------ln_dynadv_vec = .true. ! vector form (T) or flux form (F)
ln_dynadv_cen2= .false. ! flux form - 2nd order centered scheme
ln_dynadv_ubs = .false. ! flux form - 3rd order UBS
scheme
/

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

Vorticity term (dynvor.F90)


!----------------------------------------------------------------------&namdyn_vor
!
option of physics/algorithm (not control by CPP keys)
!----------------------------------------------------------------------ln_dynvor_ene = .false. ! enstrophy conserving scheme
ln_dynvor_ens = .false. ! energy conserving scheme
ln_dynvor_mix = .false. ! mixed scheme
ln_dynvor_een = .true. ! energy & enstrophy scheme
/

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.

6.2. Coriolis and Advection : vector invariant form

97

Enstrophy conserving scheme (ln dynvor ens=true)


In the enstrophy conserving case (ENS scheme), the discrete formulation of the vorticity term provides a global conservation of the enstrophy ([( +f )/e3f ]2 in s-coordinates)
for a horizontally non-divergent flow (i.e. =0), but does not conserve the total kinetic
energy. It is given by :


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

Energy conserving scheme (ln dynvor ene=true)


The kinetic energy conserving scheme (ENE scheme) conserves the global kinetic
energy but not the global enstrophy. It is given by :



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

Mixed energy/enstrophy conserving scheme (ln dynvor mix=true)


For the mixed energy/enstrophy conserving scheme (MIX scheme), a mixture of the
two previous schemes is used. It consists of the ENS scheme (C.13) for the relative vorticity term, and of the ENE scheme (6.6) applied to the planetary vorticity term.


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

Energy and enstrophy conserving scheme (ln dynvor een=true)


In both the ENS and ENE schemes, it is apparent that the combination of i and j
averages of the velocity allows for the presence of grid point oscillation structures that will
be invisible to the operator. These structures are computational modes that will be at least
partly damped by the momentum diffusion operator (i.e. the subgrid-scale advection),
but not by the resolved advection term. The ENS and ENE schemes therefore do not
contribute to dump any grid point noise in the horizontal velocity field. Such noise would
result in more noise in the vertical velocity field, an undesirable feature. This is a wellknown characteristic of C-grid discretization where u and v are located at different grid

98

Ocean Dynamics (DYN)

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].

6.2. Coriolis and Advection : vector invariant form

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

Kinetic Energy Gradient term (dynkeg.F90)


As demonstrated in Appendix E, there is a single discrete formulation of the kinetic
energy gradient term that, together with the formulation chosen for the vertical advection
(see below), conserves the total kinetic energy :

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

Ocean Dynamics (DYN)

Vertical advection term (dynzad.F90)


The discrete formulation of the vertical advection, together with the formulation chosen for the gradient of kinetic energy (KE) term, conserves the total kinetic energy. Indeed,
the change of KE due to the vertical advection is exactly balanced by the change of KE
due to the gradient of KE (see Appendix E).

k
1
e1t e2t w i+1/2 k+1/2 [u]
e1u e2u e3u
k
1

e1t e2t w j+1/2 k+1/2 [u]


e1v e2v e3v

6.3

(6.13)

Coriolis and Advection : flux form


!----------------------------------------------------------------------&namdyn_adv
!
formulation of the momentum advection
!----------------------------------------------------------------------ln_dynadv_vec = .true. ! vector form (T) or flux form (F)
ln_dynadv_cen2= .false. ! flux form - 2nd order centered scheme
ln_dynadv_ubs = .false. ! flux form - 3rd order UBS
scheme
/

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

Coriolis plus curvature metric terms (dynvor.F90)


In flux form, the vorticity term reduces to a Coriolis term in which the Coriolis parameter has been modified to account for the metric term. This altered Coriolis parameter
is thus discretised at f -points. It is given by :
1
f+
e1 e2



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. Coriolis and Advection : flux form

6.3.2

101

Flux form Advection term (dynadv.F90)


The discrete expression of the advection term is given by :


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

e1u e2u e3u

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

e1v e2v e3v

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.

2nd order centred scheme (cen2) (ln dynadv cen2=true)


In the centered 2nd order formulation, the velocity is evaluated as the mean of the two
neighbouring points :
( cen2
k+1/2
uT = ui
ucen2
= uj+1/2
ucen2
F
uw = u
(6.16)
cen2
vFcen2 = v i+1/2
vFcen2 = v j
vvw
= v k+1/2
The scheme is non diffusive (i.e. conserves the kinetic energy) 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 timefilter, so u and v are the now velocities.

Upstream Biased Scheme (UBS) (ln dynadv ubs=true)


The UBS advection scheme is an upstream biased third order scheme based on an
upstream-biased parabolic interpolation. For example, the evaluation of uubs
T is done as
follows :
(
1 ui1/2 if e2u e3u ui > 0
ubs
i
uT = u
(6.17)
6 ui+1/2 if e2u e3u ui < 0
where ui+1/2 = i+1/2 [i [u]]. This results in a dissipatively dominant (i.e. hyperdiffusive) truncation error [Shchepetkin and McWilliams 2005]. The overall performance

102

Ocean Dynamics (DYN)

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

Hydrostatic pressure gradient (dynhpg.F90)


!----------------------------------------------------------------------&namdyn_hpg
!
Hydrostatic pressure gradient option
!----------------------------------------------------------------------ln_hpg_zco = .false.
! z-coordinate - full steps
ln_hpg_zps = .true.
! z-coordinate - partial steps (interpolation)
ln_hpg_sco = .false.
! s-coordinate (standard jacobian formulation)
ln_hpg_hel = .false.
! s-coordinate (helsinki modification)
ln_hpg_wdj = .false.
! s-coordinate (weighted density jacobian)
ln_hpg_djc = .false.
! s-coordinate (Density Jacobian with Cubic polynomial)
ln_hpg_rot = .false.
! s-coordinate (ROTated axes scheme)
rn_gamma
= 0.e0
! weighting coefficient (wdj scheme)
ln_dynhpg_imp = .false. ! time stepping: semi-implicit time scheme (T)
!
centered
time scheme (F)
/

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. Hydrostatic pressure gradient (dynhpg)

6.4.1

103

z-coordinate with full step (ln dynhpg zco=true)


The hydrostatic pressure can be obtained by integrating the hydrostatic equation vertically from the surface. However, the pressure is large at great depth while its horizontal
gradient is several orders of magnitude smaller. This may lead to large truncation errors
in the pressure gradient terms. Thus, the two horizontal components of the hydrostatic
pressure gradient are computed directly as follows :
for k = km (surface layer, jk = 1 in the code)

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


+ g i+1/2 e3w k+1/2


i+1/2 ph = i+1/2 ph
2
k
k
k1
i
h
h i
h i
1




h
h

+ g j+1/2 e3w k+1/2


j+1/2 p = j+1/2 p
2
k
k1
k

(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

z-coordinate with partial step (ln dynhpg zps=true)


With partial bottom cells, tracers in horizontally adjacent cells generally live at different depths. Before taking horizontal gradients between these tracer points, a linear interpolation is used to approximate the deeper tracer as if it actually lived at the depth of
the shallower tracer point.
Apart from this modification, the horizontal hydrostatic pressure gradient evaluated in
the z-coordinate with partial step is exactly as in the pure z-coordinate case. As explained
in detail in section 5.9, the nonlinearity of pressure effects in the equation of state is
such that it is better to interpolate temperature and salinity vertically before computing the
density. Horizontal gradients of temperature and salinity are needed for the TRA modules,
which is the reason why the horizontal gradients of density at the deepest model level are
computed in module zpsdhe.F90 located in the TRA directory and described in 5.9.

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

Ocean Dynamics (DYN)

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

Time-scheme (ln dynhpg imp= true/false)


The default time differencing scheme used for the horizontal pressure gradient is a
leapfrog scheme and therefore the density used in all discrete expressions given above is
the now density, computed from the now temperature and salinity. In some specific cases
(usually high resolution simulations over an ocean domain which includes weakly stratified regions) the physical phenomenon that controls the time-step is internal gravity waves
(IGWs). A semi-implicit scheme for doubling the stability limit associated with IGWs can
be used [Brown and Campana 1978, Maltrud et al. 1998]. It involves the evaluation of the
hydrostatic pressure gradient as an average over the three time levels t t, t, and t + t
(i.e. before, now and after time-steps), rather than at the central time level t only, as in the
standard leapfrog scheme.
leapfrog scheme (ln dynhpg imp=true) :
 
ut+t utt
1
=
i+1/2 pth
2t
o e1u
semi-implicit scheme (ln dynhpg imp=true) :
h
i
ut+t utt
1
=
i+1/2 pht+t + 2 pth + ptt
h
2t
4 o e1u

(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

6.5. Surface pressure gradient (dynspg)

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

Surface pressure gradient (dynspg.F90)


!----------------------------------------------------------------------!namdyn_spg
!
surface pressure gradient
(CPP key only)
!----------------------------------------------------------------------!
! explicit free surface
("key_dynspg_exp")
!
! filtered free surface
("key_dynspg_flt")
!
! split-explicit free surface
("key_dynspg_ts")

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

Ocean Dynamics (DYN)

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

Explicit free surface (key dynspg exp)


In the explicit free surface formulation (key dynspg exp defined), the model time
step is chosen to be small enough to resolve the external gravity waves (typically a few
tens of seconds). The surface pressure gradient, evaluated using a leap-frog scheme (i.e.
centered in time), is thus simply given by :

[]
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

Split-Explicit free surface (key dynspg ts)


The split-explicit free surface formulation used in NEMO (key dynspg ts defined),
also called the time-splitting formulation, follows the one proposed by Griffies [2004].
The general idea is to solve the free surface equation and the associated barotropic velocity
equations with a smaller time step than t, the time step used for the three dimensional
prognostic variables (Fig. 6.2). The size of the small time step, te (the external mode
or barotropic time step) is provided through the nn baro namelist parameter as : te =
t/nn baro.
The split-explicit formulation has a damping effect on external gravity waves, which
is weaker damping than that for the filtered free surface but still significant, as shown by
Levier et al. [2007] in the case of an analytical barotropic Kelvin wave.

6.5.3

Filtered free surface (key dynspg flt)


The filtered formulation follows the Roullet and Madec [2000] implementation. The
extra term introduced in the equations (see 2.2.2) is solved implicitly. The elliptic solvers
available in the code are documented in 14.
Note that in the linear free surface formulation (key vvl not defined), the ocean depth
is time-independent and so is the matrix to be inverted. It is computed once and for all and
applies to all ocean time steps.

6.6. Lateral diffusion term (dynldf )

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

Lateral diffusion term (dynldf.F90)


!----------------------------------------------------------------------&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]
/

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

Ocean Dynamics (DYN)

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

Iso-level laplacian operator (ln dynldf lap=true)


For lateral iso-level diffusion, the discrete operator is :

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

Rotated laplacian operator (ln dynldf iso=true)


A rotation of the lateral momentum diffusion operator is needed in several cases :
for iso-neutral diffusion in the z-coordinate (ln dynldf iso=true) and for either iso-neutral
(ln dynldf iso=true) or geopotential (ln dynldf hor=true) diffusion in the s-coordinate. In
the partial step case, coordinates are horizontal except at the deepest level and no rotation is performed when ln dynldf hor=true. The diffusion operator is defined simply as
the divergence of down gradient momentum fluxes on each momentum component. It
must be emphasized that this formulation ignores constraints on the stress tensor such as

6.7. Vertical diffusion term (dynzdf.F90)

109

symmetry. The resulting discrete representation is :


1
DulU =
e e e
 1u 2u 3u 

i, k
lm e2t e3t
i+1/2 AT
i [u] e2t r1t k+1/2 [u]
e1t



j+1/2, k
lm e1f e3f
j+1/2 [u] e1f r2f k+1/2 [u]
+ j Af
e2f


i+1/2, k+1/2
+ k Alm
uw e2u r1uw i+1/2 [u]
e1u r2uw j+1/2 [u]

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

Iso-level bilaplacian operator (ln dynldf bilap=true)


The lateral fourth order operator formulation on momentum is obtained by applying
(6.25) twice. It requires an additional assumption on boundary conditions : the first derivative term normal to the coast depends on the free or no-slip lateral boundary conditions
chosen, while the third derivative terms normal to the coast are set to zero (see Chap.8).

6.7

Vertical diffusion term (dynzdf.F90)


!----------------------------------------------------------------------&namzdf
!
vertical physics

110

Ocean Dynamics (DYN)

!----------------------------------------------------------------------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. External Forcings

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

Time evolution term (dynnxt.F90)


!----------------------------------------------------------------------&namdom
!
space and time domain (bathymetry, mesh, timestep)
!----------------------------------------------------------------------nn_bathy
=
1
! compute (=0) or read (=1) the bathymetry file
nn_closea
=
0
! remove (=0) or keep (=1) closed seas and lakes (ORCA)
nn_msh
=
0
! create (=1) a mesh file or not (=0)
rn_hmin
=
-3.
! min depth of the ocean (>0) or min number of ocean level (<0)
rn_e3zps_min=
20.
! partial step thickness is set larger than the minimum of
rn_e3zps_rat=
0.1
! rn_e3zps_min and rn_e3zps_rat*e3t, with 0<rn_e3zps_rat<1
!
rn_rdt
= 5760.
! time step for the dynamics (and tracer if nn_acc=0)
nn_baro
=
64
! number of barotropic time step
("key_dynspg_ts")
rn_atfp
=
0.1
! asselin time filter parameter
nn_acc
=
0
! acceleration of convergence : =1
used, rdt < rdttra(k)
!
=0, not used, rdt = rdttra
rn_rdtmin
= 28800.
! minimum time step on tracers (used if nn_acc=1)
rn_rdtmax
= 28800.
! maximum time step on tracers (used if nn_acc=1)
rn_rdth
= 800.
! depth variation of tracer time step (used if nn_acc=1)
/

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) :

ut+t = uftt + 2t RHStu


i
h
(6.29)
t
t+t
utf
= ut + utt

2u
+
u
f
flux form and nonlinear free surface (ln dynhpg vec=false ; key vvl defined) :

(e3u u)t+t = (e3u u)tt


+ 2t e3u RHStu
f
h
i
(6.30)
t
tt
t
t+t
(e3u u)t
=
(e
u)
+

(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.

7 Surface Boundary Condition (SBC)

Contents
7.1
7.2

7.3
7.4
7.5

7.6
7.7
7.8
7.9

Surface boundary condition for the ocean . . . . . . . . . .


Input Data generic interface . . . . . . . . . . . . . . . . .
7.2.1 Input Data specification (fldread.F90) . . . . . . . . .
7.2.2 Interpolation on-the-Fly . . . . . . . . . . . . . . . .
Analytical formulation (sbcana) . . . . . . . . . . . . . . .
Flux formulation (sbcflx) . . . . . . . . . . . . . . . . . . .
Bulk formulation (sbcblk core or sbcblk clio) . . . . . . . .
7.5.1 CORE Bulk formulea (ln core=true) . . . . . . . . . .
7.5.2 CLIO Bulk formulea (ln clio=true) . . . . . . . . . .
Coupled formulation (sbccpl) . . . . . . . . . . . . . . . . .
Atmospheric pressure (sbcapr) . . . . . . . . . . . . . . . .
River runoffs (sbcrnf ) . . . . . . . . . . . . . . . . . . . . .
Miscellaneous options . . . . . . . . . . . . . . . . . . . . .
7.9.1 Diurnal cycle (sbcdcy) . . . . . . . . . . . . . . . . .
7.9.2 Rotation of vector pairs onto the model grid directions
7.9.3 Surface restoring to observed SST and/or SSS (sbcssr)
7.9.4 Handling of ice-covered area (sbcice ...) . . . . . . . .
7.9.5 Freshwater budget control (sbcfwb) . . . . . . . . . .

115
116
117
119
121
122
122
122
123
124
125
125
127
127
128
130
130
131

114

Surface Boundary Condition (SBC)

!----------------------------------------------------------------------&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 ocean needs six fields as surface boundary condition :


the two components of the surface ocean stress (u , v )
the incoming solar and non solar heat fluxes (Qns , Qsr )
the surface freshwater budget (emp, empS )
plus an optional field :
the atmospheric pressure at the ocean surface (pa )
Four different ways to provide the first six fields to the ocean are available which are
controlled by namelist variables : an analytical formulation (ln ana = true), a flux formulation (ln flx = true), a bulk formulae formulation (CORE (ln core = true) or CLIO
(ln clio = true) bulk formulae) and a coupled formulation (exchanges with a atmospheric model via the OASIS coupler) (ln cpl = true). When used, the atmospheric pressure
forces both ocean and ice dynamics (ln apr dyn = true) 1 . The frequency at which the six
or seven fields have to be updated is the nn fsbc namelist parameter. When the fields are
supplied from data files (flux and bulk formulations), the input fields need not be supplied on the model grid. Instead a file of coordinates and weights can be supplied which
maps the data from the supplied grid to the model points (so called Interpolation on the
Fly, see 7.2.2). In addition, the resulting fields can be further modified using several
namelist options. These options control the rotation of vector components supplied relative to an east-north coordinate system onto the local grid directions in the model ; the
addition of a surface restoring term to observed SST and/or SSS (ln ssr = true) ; the modification of fluxes below ice-covered areas (using observed ice-cover or a sea-ice model)
(nn ice = 0,1, 2 or 3) ; the addition of river runoffs as surface freshwater fluxes or lateral
inflow (ln rnf = true) ; the addition of a freshwater flux adjustment in order to avoid a
mean sea-level drift (nn fwb = 0, 1 or 2) ; and the transformation of the solar radiation (if
provided as daily mean) into a diurnal cycle (ln dm2dc = true).
1

The surface pressure field could be use in bulk formulae, nevertheless none of the current bulk
formulea (CLIO and CORE) uses the it.

7.1. Surface boundary condition for the ocean

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

Surface boundary condition for the ocean


The surface ocean stress is the stress exerted by the wind and the sea-ice on the ocean.
The two components of stress are assumed to be interpolated onto the ocean mesh, i.e. resolved onto the model (i,j) direction at u- and v-points They are applied as a surface boundary condition of the computation of the momentum vertical mixing trend (dynzdf.F90
module) :
 vm

 
A
1 u
Uh
=
(7.1)
e3 k z=1 o v
where (u , v ) = (utau, vtau) are the two components of the wind stress vector in the
(i, j) coordinate system.
The surface heat flux is decomposed into two parts, a non solar and a solar heat flux,
Qns and Qsr , respectively. The former is the non penetrative part of the heat flux (i.e.
the sum of sensible, latent and long wave heat fluxes). It is applied as a surface boundary
condition trend of the first level temperature time evolution equation (trasbc.F90 module).

T
Qns
+
(7.2)
t
o Cp e3t k=1
Qsr is the penetrative part of the heat flux. It is applied as a 3D trends of the temperature
equation (traqsr.F90 module) when ln traqsr=True.
T
Qsr
+
k [Iw ]
t
o Cp e3t

(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

Surface Boundary Condition (SBC)


Variable description
i-component of the surface current
j-component of the surface current
Sea surface temperature
Sea surface salinty

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

Input Data generic interface


A generic interface has been introduced to manage the way input data (2D or 3D
fields, like surface forcing or ocean T and S) are specify in NEMO . This task is archieved
by fldread.F90. The module was design with four main objectives in mind :
1. optionally provide a time interpolation of the input data at model time-step, whatever their input frequency is, and according to the different calendars available in
the model.
2. optionally provide an on-the-fly space interpolation from the native input data grid
to the model grid.

7.2. Input Data generic interface

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

Input Data specification (fldread.F90)


The structure associated with an input variable contains the following information :

!
!

file name

! frequency (hours) ! variable


! (if <0 months) !
name

! time interp. !
!
(logical) !

clim ! yearly/ ! weights ! rotation !


(T/F) ! monthly ! filename ! pairing !

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

Surface Boundary Condition (SBC)


daily or weekLLL
monthly
yearly
clim = false fn yYYYYmMMdDD fn yYYYYmMM fn yYYYY
clim = true
not possible
fn m ? ?.nc
fn

TAB . 7.2 naming nomenclature for climatological or interannual input file, as a


function of the Open/close frequency. The stem name is assumed to be fn. For
weekly files, the LLL corresponds to the first three letters of the first day of the
week (i.e. sun,sat,fri,thu,wed,tue,mon). The YYYY, MM and DD
should be replaced by the actual year/month/day, always coded with 4 or 2 digits.
Note that (1) in mpp, if the file is split over each subdomain, the suffix .nc is
replaced by PPPP.nc, where PPPP is the process number coded with 4 digits ;
O
is added to files, where N is the child
(2) when using AGRIF, the prefix ON
grid number.
will have a broken line shape. Records are assumed to be dated the middle of the
forcing period. For example, when using a daily forcing with time interpolation,
linear interpolation will be performed between mid-day of two consecutive days.
Climatological forcing : a logical to specify if a input file contains climatological forcing
which can be cycle in time, or an interannual forcing which will requires additional
files if the period covered by the simulation exceed the one of the file. See the above
the file naming strategy which impacts the expected name of the file to be opened.
Open/close frequency : the frequency at which forcing files must be opened/closed. Four
cases are coded : daily, weekLLL (with LLL the first 3 letters of the first day
of the week), monthly and yearly which means the forcing files will contain
data for one day, one week, one month or one year. Files are assumed to contain
data from the beginning of the open/close period. For example, the first record of a
yearly file containing daily data is Jan 1st even if the experiment is not starting at
the beginning of the year.
Others : weights filename and pairing rotation are associted with on-the-fly interpolation which is described in 7.2.2.
Additional remarks :
(1) The time interpolation is a simple linear interpolation between two consecutive records of the input data. The only tricky point is therefore to specify the date at which we
need to do the interpolation and the date of the records read in the input files. Following
Leclair and Madec [2009], the date of a time step is set at the middle of the time step.
For example, for an experiment starting at 0h0000 with a one hour time-step, a time interpolation will be performed at the following time : 0h3000, 1h3000, 2h3000, etc.
However, for forcing data related to the surface module, values are not needed at every
time-step but at every nn fsbc time-step. For example with nn fsbc = 3, the surface module will be called at time-steps 1, 4, 7, etc. The date used for the time interpolation is
thus redefined to be at the middle of nn fsbc time-step period. In the previous example,

7.2. Input Data generic interface

119

this leads to : 1h3000, 4h3000, 7h3000, etc.


(2) For code readablility and maintenance issues, we dont take into account the NetCDF
input file calendar. The calendar associated with the forcing field is build according to the
information provided by user in the record frequency, the open/close frequency and the
type of temporal interpolation. For example, the first record of a yearly file containing
daily data that will be interpolated in time is assumed to be start Jan 1st at 12h0000 and
end Dec 31st at 12h0000.
(3) If a time interpolation is requested, the code will pick up the needed data in the previous (next) file when interpolating data with the first (last) record of the open/close period. For example, if the input file specifications are yearly, containing daily data to be
interpolated in time, the values given by the code between 00h0000 and 11h5959 on
Jan 1st will be interpolated values between Dec 31st 12h0000 and Jan 1st 12h0000. If
the forcing is climatological, Dec and Jan will be keep-up from the same year. However, if
the forcing is not climatological, at the end of the open/close period the code will automatically close the current file and open the next one. Note that, if the experiment is starting
(ending) at the beginning (end) of an open/close period we do accept that the previous
(next) file is not existing. In this case, the time interpolation will be performed between
two identical values. For example, when starting an experiment on Jan 1st of year Y with
yearly files and daily data to be interpolated, we do accept that the file related to year Y-1
is not existing. The value of Jan 1st will be used as the missing one for Dec 31st of year
Y-1. If the file of year Y-1 exists, the code will read its last record. Therefore, this file can
contain only one record corresponding to Dec 31st, a useful feature for user considering
that it is too heavy to manipulate the complete file for year Y-1.

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

Surface Boundary Condition (SBC)

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.

7.3. Analytical formulation (sbcana)

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

Analytical formulation (sbcana.F90 module)


!----------------------------------------------------------------------&namsbc_ana
!
analytical surface boundary condition
!----------------------------------------------------------------------nn_tau000
=
0
! gently increase the stress over the first ntau_rst time-steps
rn_utau0
=
0.5
! uniform value for the i-stress
rn_vtau0
=
0.e0
! uniform value for the j-stress
rn_qns0
=
0.e0
! uniform value for the total heat flux
rn_qsr0
=
0.e0
! uniform value for the solar radiation
rn_emp0
=
0.e0
! uniform value for the freswater budget (E-P)
/

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

Surface Boundary Condition (SBC)

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

Flux formulation (sbcflx.F90 module)


!----------------------------------------------------------------------&namsbc_flx
!
surface boundary condition : flux formulation
!----------------------------------------------------------------------!
! file name ! frequency (hours) ! variable ! time interp.
!
!
! (if <0 months) !
name
!
(logical)
sn_utau
= utau
,
24
, utau
, .false.
sn_vtau
= vtau
,
24
, vtau
, .false.
sn_qtot
= qtot
,
24
, qtot
, .false.
sn_qsr
= qsr
,
24
, qsr
, .false.
sn_emp
= emp
,
24
, emp
, .false.
cn_dir

= ./

!
!
,
,
,
,
,

clim !
(T/F) !
.false.,
.false.,
.false.,
.false.,
.false.,

yearly/
monthly
yearly
yearly
yearly
yearly
yearly

!
!
,
,
,
,
,

weights
filename

!
!
,
,
,
,
,

rotation !
pairing !

root directory for the location of the flux files

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

Bulk formulation (sbcblk core.F90 or sbcblk clio.F90 module)


In the bulk formulation, the surface boundary condition fields are computed using
bulk formulae and atmospheric fields and ocean (and ice) variables.
The atmospheric fields used depend on the bulk formulae used. Two bulk formulations
are available : the CORE and CLIO bulk formulea. The choice is made by setting to true
one of the following namelist variable : ln core and ln clio.
Note : in forced mode, when a sea-ice model is used, a bulk formulation have to be
used. Therefore the two bulk formulea provided include the computation of the fluxes
over both an ocean and an ice surface.

7.5.1

CORE Bulk formulea (ln core=true, sbcblk core.F90)


!----------------------------------------------------------------------&namsbc_core
!
namsbc_core CORE bulk formulea
!----------------------------------------------------------------------!
! file name ! frequency (hours) ! variable ! time interp.
!
!
! (if <0 months) !
name
!
(logical)
sn_wndi = u_10.15JUNE2009_orca2
, 6 , U_10_MOD,
.false.
sn_wndj = v_10.15JUNE2009_orca2
, 6 , V_10_MOD,
.false.
sn_qsr = ncar_rad.15JUNE2009_orca2
, 24 , SWDN_MOD,
.false.
sn_qlw = ncar_rad.15JUNE2009_orca2
, 24 , LWDN_MOD,
.false.
sn_tair = t_10.15JUNE2009_orca2
, 6 , T_10_MOD,
.false.
sn_humi = q_10.15JUNE2009_orca2
, 6 , Q_10_MOD,
.false.
sn_prec = ncar_precip.15JUNE2009_orca2, -1 , PRC_MOD1,
.false.
sn_snow = ncar_precip.15JUNE2009_orca2, -1 , SNOW
,
.false.
sn_tdif = taudif_core
, 24 , taudif ,
.false.

!
!
,
,
,
,
,
,
,
,
,

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

7.5. Bulk formulation (sbcblk core or sbcblk clio)


cn_dir
ln_2m
ln_taudif
rn_pfac

=
=
=
=

./
.false.
.false.
1.

!
!
!
!

123

root directory for the location of the bulk files


air temperature and humidity referenced at 2m (T) instead 10m (F)
HF tau contribution: use "mean of stress module - module of the mean stress" data
multiplicative factor for precipitation (total & snow)

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

CLIO Bulk formulea (ln clio=true, sbcblk clio.F90)


!----------------------------------------------------------------------&namsbc_clio
!
namsbc_clio CLIO bulk formulea
!----------------------------------------------------------------------!
! file name ! frequency (hours) ! variable ! time interp.
!
!
! (if <0 months) !
name
!
(logical)
sn_utau
= taux_1m
,
-1
, sozotaux,
.true.
sn_vtau
= tauy_1m
,
-1
, sometauy,
.true.
sn_wndm
= flx
,
-1
, socliowi,
.true.
sn_tair
= flx
,
-1
, socliot2,
.true.
sn_humi
= flx
,
-1
, socliohu,
.true.
sn_ccov
= flx
,
-1
, socliocl,
.false.
sn_prec
= flx
,
-1
, socliopl,
.false.
cn_dir

= ./

!
!
,
,
,
,
,
,
,

clim
(T/F)
.true.
.true.
.true.
.true.
.true.
.true.
.true.

!
!
,
,
,
,
,
,
,

yearly/
monthly
yearly
yearly
yearly
yearly
yearly
yearly
yearly

!
!
,
,
,
,
,
,
,

weights
filename

!
!
,
,
,
,
,
,
,

root directory for the location of the bulk files are

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

Surface Boundary Condition (SBC)

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

Coupled formulation (sbccpl.F90 module)


!----------------------------------------------------------------------&namsbc_cpl
!
coupled ocean/atmosphere model
("key_coupled")
!----------------------------------------------------------------------!
! send
cn_snd_temperature= weighted oce and ice ! oce only weighted oce and ice mixed oce-ice
cn_snd_albedo
= weighted ice
! none weighted ice mixed oce-ice
cn_snd_thickness = none
! none weighted ice and snow
cn_snd_crt_nature = none
! none oce only weighted oce and ice mixed oce-ice
cn_snd_crt_refere = spherical
! spherical cartesian
cn_snd_crt_orient = eastward-northward
! eastward-northward or local grid
cn_snd_crt_grid
= T
! T
!
! receive
cn_rcv_w10m
= none
! none coupled
cn_rcv_taumod
= coupled
! none coupled
cn_rcv_tau_nature = oce only
! oce only oce and ice mixed oce-ice
cn_rcv_tau_refere = cartesian
! spherical cartesian
cn_rcv_tau_orient = eastward-northward
! eastward-northward or local grid
cn_rcv_tau_grid
= U,V
! T U,V U,V,F U,V,I T,F T,I T,U,V
cn_rcv_dqnsdt
= coupled
! none coupled
cn_rcv_qsr
= oce and ice
! conservative oce and ice mixed oce-ice
cn_rcv_qns
= oce and ice
! conservative oce and ice mixed oce-ice
cn_rcv_emp
= conservative
! conservative oce and ice mixed oce-ice
cn_rcv_rnf
= coupled
! coupled climato mixed
cn_rcv_cal
= coupled
! none coupled
/

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.

7.7. Atmospheric pressure (sbcapr)

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

Atmospheric pressure (sbcapr.F90)


!----------------------------------------------------------------------&namsbc_apr
!
Atmospheric pressure used as ocean forcing or in bulk
!----------------------------------------------------------------------!
! file name ! frequency (hours) ! variable ! time interpol. ! clim
!
!
! (if <0 months) !
name
!
(logical)
! (T/F)
sn_apr
= patm
,
-1
,somslpre,
.true.
, .true.
cn_dir
ln_ref_apr

= ./
= .false.

!
!

! yearly/ ! weights ! rotation !


! monthly ! filename ! pairing !
, yearly ,
,

root directory for the location of the bulk files


ref. pressure: global mean Patm (T) or a constant (F)

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

River runoffs (sbcrnf.F90)


!----------------------------------------------------------------------&namsbc_rnf
!
runoffs namelist surface boundary condition
!----------------------------------------------------------------------!
! file name ! frequency (hours) ! variable ! time interp.
!
!
! (if <0 months) !
name
!
(logical)
sn_rnf
= runoff_core_monthly,
-1
, sorunoff,
.true.
sn_cnf
= runoff_core_monthly,
0
, socoefr0,
.false.
sn_s_rnf
= runoffs
,
24
, rosaline,
.true.
sn_t_rnf
= runoffs
,
24
, rotemper,
.true.
sn_dep_rnf = runoffs
,
0
, rodepth ,
.false.
cn_dir
ln_rnf_emp

= ./
= .false.

!
!

!
!
,
,
,
,
,

clim
(T/F)
.true.
.true.
.true.
.true.
.true.

!
!
,
,
,
,
,

yearly/
monthly
yearly
yearly
yearly
yearly
yearly

root directory for the location of the runoff files


runoffs included into precipitation field (T) or into a file (F)

!
!
,
,
,
,
,

weights
filename

!
!
,
,
,
,
,

rotation !
pairing !

126
ln_rnf_mouth
rn_hrnf
rn_avt_rnf
rn_rfact
ln_rnf_depth
ln_rnf_tem
ln_rnf_sal

Surface Boundary Condition (SBC)


=
=
=
=
=
=
=

.true.
15.e0
1.e-3
1.e0
.false.
.false.
.false.

!
!
!
!
!
!
!

specific treatment at rivers mouths


depth over which enhanced vertical mixing is used
value of the additional vertical mixing coef. [m2/s]
multiplicative factor for runoff
read in depth information for runoff
read in temperature information for runoff
read in salinity information for runoff

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.

7.9. Miscellaneous options

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

Diurnal cycle (sbcdcy.F90)


Bernie et al. [2005] have shown that to capture 90% of the diurnal variability of SST
requires a vertical resolution in upper ocean of 1 m or better and a temporal resolution of
the surface fluxes of 3 h or less. Unfortunately high frequency forcing fields are rare, not to
say inexistent. Nevertheless, it is possible to obtain a reasonable diurnal cycle of the SST
knowning only short wave flux (SWF) at high frequency [Bernie et al. 2007]. Furthermore,
only the knowledge of daily mean value of SWF is needed, as higher frequency variations
can be reconstructed from them, assuming that the diurnal cycle of SWF is a scaling of
the top of the atmosphere diurnal cycle of incident SWF. The Bernie et al. [2007] reconstruction algorithm is available in NEMO by setting ln dm2dc = true (a namsbc namelist
parameter) when using CORE bulk formulea (ln blk core = true) or the flux formulation
(ln flx = true). The reconstruction is performed in the sbcdcy.F90 module. The detail of
the algoritm used can be found in the appendix A of Bernie et al. [2007]. The algorithm
preserve the daily mean incomming SWF as the reconstructed SWF at a given time step
is the mean value of the analytical cycle over this time step (Fig.7.1). The use of diurnal
cycle reconstruction requires the input SWF to be daily (i.e. a frequency of 24 and a time

128

Surface Boundary Condition (SBC)

analytical solution
reconstructed (mean of
analytical solution at ti

over t)

Qsr

t1

t2

t5
t3
t4
time of day (t)

t6

F IG . 7.1 Example of recontruction of the diurnal cycle variation of short wave


flux from daily mean values. The reconstructed diurnal cycle (black line) is chosen
as the mean value of the analytical cycle (blue line) over a time step, not as the mid
time step value of the analytically cycle (red square). From Bernie et al. [2007].

interpolation set to true in sn qsr namelist parameter). Furthermore, it is recommended to


have a least 8 surface module time step per day, that is t nn fsbc < 10, 800 s = 3 h. An
example of recontructed SWF is given in Fig.7.2 for a 12 reconstructed diurnal cycle, one
every 2 hours (from 1am to 11pm).
Note also that the setting a diurnal cycle in SWF is highly recommended when the
top layer thickness approach 1 m or less, otherwise large error in SST can appear due to
an inconsistency between the scale of the vertical resolution and the forcing acting on that
scale.

7.9.2

Rotation of vector pairs onto the model grid directions


When using a flux (ln flx=true) or bulk (ln clio=true or ln core=true) formulation,
pairs of vector components can be rotated from east-north directions onto the local grid
directions. This is particularly useful when interpolation on the fly is used since here any
vectors are likely to be defined relative to a rectilinear grid. To activate this option a nonempty string is supplied in the rotation pair column of the relevant namelist. The eastward

7.9. Miscellaneous options


140

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

F IG . 7.2 Example of recontruction of the diurnal cycle variation of short wave


flux from daily mean values on an ORCA2 grid with a time sampling of 2 hours
(from 1am to 11pm). The display is on (i,j) plane.

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

Surface Boundary Condition (SBC)

Surface restoring to observed SST and/or SSS (sbcssr.F90)


!----------------------------------------------------------------------&namsbc_ssr
!
surface boundary condition : sea surface restoring
!----------------------------------------------------------------------!
! file name ! frequency (hours) ! variable ! time interp.
!
!
! (if <0 months) !
name
!
(logical)
sn_sst
= sst_data ,
24
, sst
,
.false.
sn_sss
= sss_data ,
-1
, sss
,
.true.
cn_dir
nn_sstr
nn_sssr

= ./
=
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

!
!
,
,

root directory for the location of the runoff files


add a retroaction term in the surface heat
flux (=1) or not (=0)
add a damping
term in the surface freshwater flux (=2)
or to SSS only (=1) or no damping term (=0)
magnitude of the retroaction on temperature
[W/m2/K]
magnitude of the damping on salinity
[mm/day]
flag to bound erp term (associated with nn_sssr=2)
ABS(Max/Min) value of the damping erp term [mm/day]

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

Handling of ice-covered area (sbcice ...)


The presence at the sea surface of an ice covered area modifies all the fluxes transmitted to the ocean. There are several way to handle sea-ice in the system depending on the
value of the nn ice namelist parameter.
nn ice = 0 there will never be sea-ice in the computational domain. This is a typical namelist value used for tropical ocean domain. The surface fluxes are simply specified
for an ice-free ocean. No specific things is done for sea-ice.

rotation !
pairing !

7.9. Miscellaneous options

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

Freshwater budget control (sbcfwb.F90)


For global ocean simulation it can be useful to introduce a control of the mean sea
level in order to prevent unrealistic drift of the sea surface height due to inaccuracy in the
freshwater fluxes. In NEMO , two way of controlling the the freshwater budget.
nn fwb=0 no control at all. The mean sea level is free to drift, and will certainly do so.
nn fwb=1 global mean emp set to zero at each model time step.
nn fwb=2 freshwater budget is adjusted from the previous year annual mean budget
which is read in the EMPave old.dat file. As the model uses the Boussinesq approximation, the annual mean fresh water budget is simply evaluated from the
change in the mean sea level at January the first and saved in the EMPav.dat file.

8 Lateral Boundary Condition (LBC)

Contents
8.1
8.2

8.3
8.4

8.5

Boundary Condition at the Coast (rn shlat) . . . . . . . . .


Model Domain Boundary Condition (jperio) . . . . . . . .
8.2.1 Closed, cyclic, south symmetric (jperio = 0, 1 or 2) . .
8.2.2 North-fold (jperio = 3 to 6) . . . . . . . . . . . . . .
Exchange with neighbouring processors (lbclnk, lib mpp) .
Open Boundary Conditions (key obc) (OBC) . . . . . . . .
8.4.1 Boundary geometry . . . . . . . . . . . . . . . . . . .
8.4.2 Boundary data . . . . . . . . . . . . . . . . . . . . .
8.4.3 Radiation algorithm . . . . . . . . . . . . . . . . . .
8.4.4 Domain decomposition (key mpp mpi) . . . . . . . .
8.4.5 Volume conservation . . . . . . . . . . . . . . . . . .
Unstructured Open Boundary Conditions (key bdy) (BDY)
8.5.1 The Flow Relaxation Scheme . . . . . . . . . . . . .
8.5.2 The Flather radiation scheme . . . . . . . . . . . . . .
8.5.3 Choice of schemes . . . . . . . . . . . . . . . . . . .
8.5.4 Boundary geometry . . . . . . . . . . . . . . . . . . .
8.5.5 Input boundary data files . . . . . . . . . . . . . . . .
8.5.6 Volume correction . . . . . . . . . . . . . . . . . . .
8.5.7 Tidal harmonic forcing . . . . . . . . . . . . . . . . .

134
137
137
138
139
143
143
145
146
149
149
150
150
151
151
152
152
153
153

134

8.1

Lateral Boundary Condition (LBC)

Boundary Condition at the Coast (rn shlat)


!----------------------------------------------------------------------&namlbc
!
lateral momentum boundary condition
!----------------------------------------------------------------------rn_shlat
=
2.
! shlat = 0 ! 0 < shlat < 2 ! shlat = 2 ! 2 < shlat
! free slip !
partial slip !
no slip
! strong slip
/

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

8.1. Boundary Condition at the Coast (rn shlat)

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

Lateral Boundary Condition (LBC)

(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.

8.2. Model Domain Boundary Condition (jperio)

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

Model Domain Boundary Condition (jperio)


At the model domain boundaries several choices are offered : closed, cyclic east-west,
south symmetric across the equator, a north-fold, and combination closed-north fold or
cyclic-north-fold. The north-fold boundary condition is associated with the 3-pole ORCA
mesh.

8.2.1

Closed, cyclic, south symmetric (jperio = 0, 1 or 2)


The choice of closed, cyclic or symmetric model domain boundary condition is made
by setting jperio to 0, 1 or 2 in file par oce.F90. Each time such a boundary condition is
needed, it is set by a call to routine lbclnk.F90. The computation of momentum and tracer
trends proceeds from i = 2 to i = jpi 1 and from j = 2 to j = jpj 1, i.e. in the

138

Lateral Boundary Condition (LBC)

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...

8.3. Exchange with neighbouring processors (lbclnk, lib mpp)

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

Exchange with neighbouring processors (lbclnk.F90,


lib mpp.F90)
For massively parallel processing (mpp), a domain decomposition method is used.
The basic idea of the method is to split the large computation domain of a numerical
experiment into several smaller domains and solve the set of equations by addressing
independent local problems. Each processor has its own local memory and computes the
model equation over a subdomain of the whole model domain. The subdomain boundary
conditions are specified through communications between processors which are organized
by explicit statements (message passing method).
A big advantage is that the method does not need many modifications of the initial
FORTRAN code. From the modellers point of view, each sub domain running on a processor is identical to the mono-domain code. In addition, the programmer manages the
communications between subdomains, and the code is faster when the number of processors is increased. The porting of OPA code on an iPSC860 was achieved during Guyons
PhD [Guyon et al. 1994, 1995] in collaboration with CETIIS and ONERA. The implementation in the operational context and the studies of performance on a T3D and T3E
Cray computers have been made in collaboration with IDRIS and CNRS. The present
implementation is largely inspired by Guyons work [Guyon 1995].
The parallelization strategy is defined by the physical characteristics of the ocean
model. Second order finite difference schemes lead to local discrete operators that depend

140

Lateral Boundary Condition (LBC)

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)

8.3. Exchange with neighbouring processors (lbclnk, lib mpp)

141

F IG . 8.5 Positioning of a sub-domain when massively parallel processing is


used.

with 1 i jpi, 1 j jpj , and 1 k jpk.


Processors are numbered from 0 to jpnij 1, the number is saved in the variable
nproc. In the standard version, a processor has no more than four neighbouring processors
named nono (for north), noea (east), noso (south) and nowe (west) and two variables,
nbondi and nbondj, indicate the relative position of the processor (see Fig.IV.3) :
nbondi = -1 an east neighbour, no west processor,
nbondi = 0 an east neighbour, a west neighbour,
nbondi = 1 no east processor, a west neighbour,
nbondi = 2 no splitting following the i-axis.
During the simulation, processors exchange data with their neighbours. If there is effectively a neighbour, the processor receives variables from this processor on its overlapping
row, and sends the data issued from internal domain corresponding to the overlapping row
of the other processor.
Figure IV.4 : pencil splitting with the additional outer halos
The NEMO model computes equation terms with the help of mask arrays (0 on land
points and 1 on sea points). It is easily readable and very efficient in the context of a
computer with vectorial architecture. However, in the case of a scalar processor, computations over the land regions become more expensive in terms of CPU time. It is worse
when we use a complex configuration with a realistic bathymetry like the global ocean
where more than 50 % of points are land points. For this reason, a pre-processing tool can
be used to choose the mpp domain decomposition with a maximum number of only land

142

Lateral Boundary Condition (LBC)

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. Open Boundary Conditions (key obc) (OBC)

8.4

143

Open Boundary Conditions (key obc) (OBC)


!----------------------------------------------------------------------&namobc
!
open boundaries parameters
("key_obc")
!----------------------------------------------------------------------ln_obc_clim = .false.
! climatological obc data files (T) or not (F)
ln_vol_cst = .true.
! impose the total volume conservation (T) or not (F)
ln_obc_fla = .false.
! Flather open boundary condition
nn_obcdta
=
1
! = 0 the obc data are equal to the initial state
! = 1 the obc data are read in obc.dta files
cn_obcdta
= annual ! set to annual if obc datafile hold 1 year of data
! set to monthly if obc datafile hold 1 month of data
rn_dpein
=
1.
! damping time scale for inflow at east open boundary
rn_dpwin
=
1.
!
west
rn_dpnin
=
1.
!
north
rn_dpsin
=
1.
!
south
rn_dpeob
= 3000.
! time relaxation (days) for the east open boundary
rn_dpwob
=
15.
!
west
rn_dpnob
= 3000.
!
north
rn_dpsob
=
15.
!
south
rn_volemp
=
1.
! = 0 the total volume change with the surface flux (E-P-R)
! = 1 the total volume remains constant
/

It is often necessary to implement a model configuration limited to an oceanic region


or a basin, which communicates with the rest of the global ocean through open boundaries. As stated by Roed and Cooper [1986], an open boundary is a computational border
where the aim of the calculations is to allow the perturbations generated inside the computational domain to leave it without deterioration of the inner model solution. However,
an open boundary also has to let information from the outer ocean enter the model and
should support inflow and outflow conditions.
The open boundary package OBC is the first open boundary option developed in
NEMO (originally in OPA8.2). It allows the user to
tell the model that a boundary is open and not closed by a wall, for example by
modifying the calculation of the divergence of velocity there ;
impose values of tracers and velocities at that boundary (values which may be taken
from a climatology) : this is thefixed OBC option.
calculate boundary values by a sophisticated algorithm combining radiation and
relaxation (radiative OBC option)
The package resides in the OBC directory. It is described here in four parts : the
boundary geometry (parameters to be set in obc par.F90), the forcing data at the boundaries (module obcdta.F90), the radiation algorithm involving the namelist and module
obcrad.F90, and a brief presentation of boundary update and restart files.

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

Lateral Boundary Condition (LBC)

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

8.4. Open Boundary Conditions (key obc) (OBC)

145

F IG . 8.7 Localization of the North open boundary points.

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

Lateral Boundary Condition (LBC)

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

8.4. Open Boundary Conditions (key obc) (OBC)

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

Lateral Boundary Condition (LBC)

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

(Cx > 0),

(Cx < 0),

(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

8.4. Open Boundary Conditions (key obc) (OBC)

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

Domain decomposition (key mpp mpi)


When key mpp mpi is active in the code, the computational domain is divided into
rectangles that are attributed each to a different processor. The open boundary code is
mpp-compatible up to a certain point. The radiation algorithm will not work if there is
an mpp subdomain boundary parallel to the open boundary at the index of the boundary, or
the grid point after (outside), or three grid points before (inside). On the other hand, there
is no problem if an mpp subdomain boundary cuts the open boundary perpendicularly.
These geometrical limitations must be checked for by the user (there is no safeguard in
the code). The general principle for the open boundary mpp code is that loops over the
open boundaries not sure what this means are performed on local indices (nie0, nie1,
nje0, nje1 for an eastern boundary for instance) that are initialized in module obc ini.F90.
Those indices have relevant values on the processors that contain a segment of an open
boundary. For processors that do not include an open boundary segment, the indices are
such that the calculations within the loops are not performed.
Arrays of climatological data that are read from files are seen by all processors and
have the same dimensions for all (for instance, for the eastern boundary, uedta(jpjglo,jpk,2)).
On the other hand, the arrays for the calculation of radiation are local to each processor
(uebnd(jpj,jpk,3,3) for instance). This allowed the CLIPPER model for example, to save
on memory where the eastern boundary crossed 8 processors so that jpj was much smaller
than (jpjef -jpjed+1).

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

Lateral Boundary Condition (LBC)

Unstructured Open Boundary Conditions (key bdy)


(BDY)
!----------------------------------------------------------------------&nambdy
! unstructured open boundaries
("key_bdy")
!----------------------------------------------------------------------cn_mask
=
! name of mask file (ln_mask=T)
cn_dta_frs_T= bdydata_grid_T.nc
! name of data file (T-points)
cn_dta_frs_U= bdydata_grid_U.nc
! name of data file (U-points)
cn_dta_frs_V= bdydata_grid_V.nc
! name of data file (V-points)
cn_dta_fla_T= bdydata_bt_grid_T.nc ! name of data file for Flather condition (T-points)
cn_dta_fla_U= bdydata_bt_grid_U.nc ! name of data file for Flather condition (U-points)
cn_dta_fla_V= bdydata_bt_grid_V.nc ! name of data file for Flather condition (V-points)
ln_clim
ln_vol
ln_mask
ln_tides
ln_dyn_fla
ln_tra_frs
ln_dyn_frs
nn_rimwidth
nn_dtactl

=
=
=
=
=
=
=
=
=

nn_volctl

.false.
.false.
.false.
.false.
.false.
.false.
.false.
9
1
0

!
!
!
!
!
!
!
!
!
!
!
!

contain 1 (T) or 12 (F) time dumps and be cyclic


total volume correction (see volbdy parameter)
boundary mask from filbdy_mask (T), boundaries are on edges of domain (F)
Apply tidal harmonic forcing with Flather condition
Apply Flather condition to velocities
Apply FRS condition to temperature and salinity
Apply FRS condition to velocities
width of the relaxation zone
= 0, bdy data are equal to the initial state
= 1, bdy data are read in bdydata
.nc files
= 0, the total water flux across open boundaries is zero
= 1, the total volume of the system is conserved

The BDY module is an alternative implementation of open boundary conditions for


regional configurations. It implements the Flow Relaxation Scheme algorithm for temperature, salinity, velocities and ice fields, and the Flather radiation condition for the depthmean transports. The specification of the location of the open boundary is completely
flexible and allows for example the open boundary to follow an isobath or other irregular
contour.
The BDY module was modelled on the OBC module and shares many features and a
similar coding structure [Chanut 2005].

8.5.1

The Flow Relaxation Scheme


The Flow Relaxation Scheme (FRS) [Davies 1976, Engerdahl 1995], applies a simple
relaxation of the model fields to externally-specified values over a zone next to the edge
of the model domain. Given a model prognostic variable
(d) = (d)e (d) + (1 (d))m (d)

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)

8.5. Unstructured Open Boundary Conditions (key bdy) (BDY)

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

The Flather radiation scheme


The Flather [1994] scheme is a radiation condition on the normal, depth-mean transport across the open boundary. It takes the form
U = Ue +

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

Lateral Boundary Condition (LBC)

F IG . 8.8 Example of geometry of unstructured open boundary

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

Input boundary data files


The input data files for the FRS conditions are defined in the namelist as cn dta frs T,
cn dta frs U, cn dta frs V. The input data files for the Flather conditions are defined in
the namelist as cn dta fla T, cn dta fla U, cn dta fla V.
The netcdf header of a typical input data file is shown in Fig. 8.9. The file contains the
index arrays which define the boundary geometry as noted above and the data arrays for
each field. The data arrays are dimensioned on : a time dimension ; xb which is the index
of the boundary data point in the horizontal ; and yb which is a degenerate dimension of 1
to enable the file to be read by the standard NEMO I/O routines. The 3D fields also have
a depth dimension.
If ln clim is set to false, the model expects the units of the time axis to have the form

8.5. Unstructured Open Boundary Conditions (key bdy) (BDY)

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

Tidal harmonic forcing


To be written....

154

Lateral Boundary Condition (LBC)


Nesting code for NEMO

Figure 11: Ncdump output example of boundary data file at T-points.

F IG . 8.9 Example of header of netcdf input data file for BDY

Ref.: MERSEA-WP09-MERCA-TASK-9.1.1

page 15

9 Lateral Ocean Physics (LDF)

Contents
9.1
9.2

9.3

Lateral Mixing Coefficient (ldftra, ldfdyn) . . . . . . . . . . 156


Direction of Lateral Mixing (ldfslp) . . . . . . . . . . . . . 159
9.2.1 slopes for tracer geopotential mixing in the s-coordinate 159
9.2.2 slopes for tracer iso-neutral mixing . . . . . . . . . . 159
9.2.3 slopes for momentum iso-neutral mixing . . . . . . . 162
Eddy Induced Velocity (traadv eiv, ldfeiv) . . . . . . . . . . 163

156

Lateral Ocean Physics (LDF)

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

Lateral Mixing Coefficient (ldftra.F90, ldfdyn.F90)


Introducing a space variation in the lateral eddy mixing coefficients changes the model core memory requirement, adding up to four extra three-dimensional arrays for the
geopotential or isopycnal second order operator applied to momentum. Six CPP keys
control the space variation of eddy coefficients : three for momentum and three for tracer.
The three choices allow : a space variation in the three space directions (key traldf c3d,
key dynldf c3d), in the horizontal plane (key traldf c2d, key dynldf c2d), or in the vertical only (key traldf c1d, key dynldf c1d). The default option is a constant value over
the whole ocean on both momentum and tracers.
The number of additional arrays that have to be defined and the gridpoint position at
which they are defined depend on both the space variation chosen and the type of operator

9.1. Lateral Mixing Coefficient (ldftra, ldfdyn)

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 :

Constant Mixing Coefficients (default option)


When none of the key dynldf ... and key traldf ... keys are defined, a constant value
is used over the whole ocean for momentum and tracers, which is specified through the
rn ahm0 and rn aht0 namelist parameters.

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

Ao for bilaplacian operator


e3max

(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

Lateral Ocean Physics (LDF)

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.

Space and Time Varying Mixing Coefficients


There is no default specification of space and time varying mixing coefficient. The
only case available is specific to the ORCA2 and ORCA05 global ocean configurations
(key orca r2 or key orca r05). It provides only a tracer mixing coefficient for eddy induced velocity (ORCA2) or both iso-neutral and eddy induced velocity (ORCA05) that
depends on the local growth rate of baroclinic instability. This specification is actually
used when an ORCA key and both key traldf eiv and key traldf c2d are defined.

A space variation in the eddy coefficient appeals several remarks :


(1) the momentum diffusion operator acting along model level surfaces is written in
terms of curl and divergent components of the horizontal current (see 2.5.2). Although
the eddy coefficient can be set to different values in these two terms, this option is not
available.
(2) with an horizontally varying viscosity, the quadratic integral constraints on enstrophy and on the square of the horizontal divergence for operators acting along modelsurfaces are no longer satisfied (Appendix C.7).
(3) for isopycnal diffusion on momentum or tracers, an additional purely horizontal
background diffusion with uniform coefficient can be added by setting a non zero value of
rn ahmb0 or rn ahtb0, a background horizontal eddy viscosity or diffusivity coefficient
(namelist parameters whose default values are 0). However, the technique used to compute the isopycnal slopes is intended to get rid of such a background diffusion, since it
introduces spurious diapycnal diffusion (see 9.2).
(4) when an eddy induced advection term is used (key traldf eiv), Aeiv , the eddy
induced coefficient has to be defined. Its space variations are controlled by the same CPP
variable as for the eddy diffusivity coefficient (i.e. key traldf cNd).

9.2. Direction of Lateral Mixing (ldfslp)

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

Direction of Lateral Mixing (ldfslp.F90)


A direction for lateral mixing has to be defined when the desired operator does not
act along the model levels. This occurs when (a) horizontal mixing is required on tracer
or momentum (ln traldf hor or ln dynldf hor) in s- or mixed s-z- coordinates, and (b)
isoneutral mixing is required whatever the vertical coordinate is. This direction of mixing
is defined by its slopes in the i- and j-directions at the face of the cell of the quantity to
be diffused. For a tracer, this leads to the following four slopes : r1u , r1w , r2v , r2w (see
(5.10)), while for momentum the slopes are r1t , r1uw , r2f , r2uw for u and r1f , r1vw , r2t ,
r2vw for v.

9.2.1

slopes for tracer geopotential mixing in the s-coordinate


In s-coordinates, geopotential mixing (i.e. horizontal mixing) r1 and r2 are the slopes
between the geopotential and computational surfaces. Their discrete formulation is found
by locally solving (5.10) when the diffusive fluxes in the three directions are set to zero
and T is assumed to be horizontally uniform, i.e. a linear function of zT , the depth of a
T -point.
r1u = 
r2v = 
r1w =
r2w

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

slopes for tracer iso-neutral mixing


In iso-neutral mixing r1 and r2 are the slopes between the iso-neutral and computational surfaces. Their formulation does not depend on the vertical coordinate used. Their

160

Lateral Ocean Physics (LDF)

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)

9.2. Direction of Lateral Mixing (ldfslp)

161

This constraint leads to the following definition for the slopes :

r1u =

r2v =

e3u
e1u
e3v
e2v

u i+1/2 [T ] u i+1/2 [S]


i+1/2, k

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

v j+1/2 [T ] v j+1/2 [S]

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

Lateral Ocean Physics (LDF)

F IG . 9.1 averaging procedure for isopycnal slope computation.

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

slopes for momentum iso-neutral mixing


The iso-neutral diffusion operator on momentum is the same as the one used on tracers
but applied to each component of the velocity separately (see (6.26) in section 6.6.2). The
slopes between the surface along which the diffusion operator acts and the surface of
computation (z- or s-surfaces) are defined at T -, f -, and uw- points for the u-component,
and T -, f - and vw- points for the v-component. They are computed from the slopes used
for tracer diffusion, i.e. (9.2) and (9.3) :
r1t = r1u i

r1f = r1u i+1/2

r2f = r2v j+1/2


r1uw = r1w i+1/2
r2uw = r2w j+1/2

r2t = r2v j
and

r1vw = r1w j+1/2

(9.6)

r2vw = r2w j+1/2

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

9.3. Eddy Induced Velocity (traadv eiv, ldfeiv)

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

Eddy Induced Velocity (traadv eiv.F90, ldfeiv.F90)


When Gent and McWilliams [1990] diffusion is used (key traldf eiv defined), an
eddy induced tracer advection term is added, the formulation of which depends on the
slopes of iso-neutral surfaces. Contrary to the case of iso-neutral mixing, the slopes used
here are referenced to the geopotential surfaces, i.e. (9.2) is used in z-coordinates, and the
sum (9.2) + (9.3) in s-coordinates. The eddy induced velocity is given by :
h
i
1
i+1/2
k e2u Aeiv
r
1w
uw
e2u e3u
i
h
1
j+1/2
v =
k e1v Aeiv
vw r2w
e1u e3v
n h
i
h
io
1
i+1/2
j+1/2
w =
i e2u Aeiv
+ j e1v Aeiv
uw r1w
vw r2w
e1w e2w
u =

(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

Lateral Ocean Physics (LDF)

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).

10 Vertical Ocean Physics (ZDF)

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 Ocean Physics (ZDF)

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

Constant (key zdfcst)


!----------------------------------------------------------------------&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
/

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

AvT = AvS = 1.2 105 m2 .s1

10.1. Vertical Mixing

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

Richardson Number Dependent (key zdfric)


!----------------------------------------------------------------------&namzdf_ric
!
richardson number dependent vertical diffusion
("key_zdfric" )
!----------------------------------------------------------------------rn_avmri
= 100.e-4
! maximum value of the vertical viscosity
rn_alp
=
5.
! coefficient of the parameterization
nn_ric
=
2
! coefficient of the parameterization
/

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

TKE Turbulent Closure Scheme (key zdftke)


!----------------------------------------------------------------------&namzdf_tke
!
turbulent eddy kinetic dependent vertical diffusion ("key_zdftke")
!----------------------------------------------------------------------rn_ediff
=
0.1
! coef. for vertical eddy coef. (avt=rn_ediff*mxl*sqrt(e) )
rn_ediss
=
0.7
! coef. of the Kolmogoroff dissipation
rn_ebb
= 67.83
! coef. of the surface input of tke (=67.83 suggested when ln_mxl0=T)
rn_emin
=
1.e-6
! minimum value of tke [m2/s2]
rn_emin0
=
1.e-4
! surface minimum value of tke [m2/s2]
nn_mxl
=
2
! mixing length: = 0 bounded by the distance to surface and bottom
!
= 1 bounded by the local vertical scale factor
!
= 2 first vertical derivative of mixing length bounded by 1
!
= 3 as =2 with distinct disspipative an mixing length scale
nn_pdl
=
1
! Prandtl number function of richarson number (=1, avt=pdl(Ri)*avm) or not (=0, avt=avm)
ln_mxl0
= .true.
! surface mixing length scale = F(wind stress) (T) or not (F)
rn_mxl0
=
0.04
! surface buoyancy lenght scale minimum value
ln_lc
= .true.
! Langmuir cell parameterisation (Axell 2002)
rn_lc
=
0.15
! coef. associated to Langmuir cells
nn_etau
=
1
! penetration of tke below the mixed layer (ML) due to internal & intertial waves
!
= 0 no penetration
!
= 1 add a tke source below the ML
!
= 2 add a tke source just at the base of the ML

168

rn_efr
nn_htau

Vertical Ocean Physics (ZDF)

=
=

0.05
1

!
!
!
!
!

= 3 as = 1 applied on HF part of the stress


("key_coupled")
fraction of surface tke value which penetrates below the ML (nn_etau=1 or 2)
type of exponential decrease of tke penetration below the ML
= 0 constant 10 m length scale
= 1 0.5m at the equator to 30m poleward of 40 degrees

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).

10.1. Vertical Mixing

169

Turbulent length scale


For computational efficiency, the original formulation of the turbulent length scales
proposed by Gaspar et al. [1990] has been simplified. Four formulations are proposed, the
choice of which is controlled by the nn mxl namelist parameter. The first two are based
on the following first order approximation [Blanke and Delecluse 1993] :

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

Vertical Ocean Physics (ZDF)

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

F IG . 10.1 Illustration of the mixing length computation.

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

value (1.106 = Ck lmin emin ).

Surface wave breaking parameterization


Following Mellor and Blumberg [2004], the TKE turbulence closure model has been
modified to include the effect of surface wave breaking energetics. This results in a reduction of summertime surface temperature when the mixed layer is relatively shallow. The
Mellor and Blumberg [2004] modifications acts on surface length scale and TKE values
and air-sea drag coefficient. The latter concerns the bulk formulea and is not discussed
here.
Following Craig and Banner [1994], the boundary condition on surface TKE value
is :
1
| |
eo = (15.8 CB )2/3
(10.8)
2
o
where CB is the Craig and Banner [1994] constant of proportionality which depends
on the wave age, ranging from 57 for mature waves to 146 for younger waves [Mellor
and Blumberg 2004]. The boundary condition on the turbulent length scale follows the

10.1. Vertical Mixing

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

Vertical Ocean Physics (ZDF)

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)

Mixing just below the mixed layer


To be add here a description of penetration of TKE and the associated namelist
parameters nn etau, rn efr and nn htau.

10.1.4

TKE discretization considerations (key zdftke)


The production of turbulence by vertical shear (the first term of the right hand side of
(10.2)) should balance the loss of kinetic energy associated with the vertical momentum
diffusion (first line in (2.36)). To do so a special care have to be taken for both the time
and space discretization of the TKE equation [Burchard 2002, Marsaleix et al. 2008].
Let us first address the time stepping issue. Fig. 10.2 shows how the two-level LeapFrog time stepping of the momentum and tracer equations interplays with the one-level
forward time stepping of TKE equation. With this framework, the total loss of kinetic
energy (in 1D for the demonstration) due to the vertical momentum diffusion is obtained
by multiplying this quantity by ut and summing the result vertically :
Z

ut z Km t (z u)t+t dz
H
Z
(10.13)
h
i
t
t
t+t
t
t
t+t
= u Km (z u)

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

10.1. Vertical Mixing

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.

demonstration) due vertical mixing is obtained by multiplying vertical density diffusion

174

Vertical Ocean Physics (ZDF)

tendency by g z and and summing the result vertically :


Z

g z z K t (k )t+t dz
H
Z
h
i
t
t+t
g K t (k )t+t dz

= 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

GLS Generic Length Scale (key zdfgls)


!-----------------------------------------------------------------------

10.1. Vertical Mixing

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

Vertical Ocean Physics (ZDF)

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

K Profile Parametrisation (KPP) (key zdfkpp)


!-----------------------------------------------------------------------&namzdf_kpp
!
K-Profile Parameterization dependent vertical mixing ("key_zdfkpp", and optionally:
!------------------------------------------------------------------------ "key_kppcustom" or "key_kpplktb")
ln_kpprimix = .true.
! shear instability mixing
rn_difmiw
= 1.0e-04 ! constant internal wave viscosity [m2/s]
rn_difsiw
= 0.1e-04 ! constant internal wave diffusivity [m2/s]
rn_riinfty = 0.8
! local Richardson Number limit for shear instability
rn_difri
= 0.0050
! maximum shear mixing at Rig = 0
[m2/s]
rn_bvsqcon = -0.01e-07 ! Brunt-Vaisala squared for maximum convection [1/s2]
rn_difcon
= 1.
! maximum mixing in interior convection [m2/s]
nn_avb
= 0
! horizontal averaged (=1) or not (=0) on avt and amv
nn_ave
= 1
! constant (=0) or profile (=1) background on avt
/

The KKP scheme has been implemented by J. Chanut ...


Add a description of KPP here.

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

Non-Penetrative Convective Adjustment (ln tranpc=.true.)


!----------------------------------------------------------------------&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
/

The non-penetrative convective adjustment is used when ln zdfnpc=true. It is applied


at each nn npc time step and mixes downwards instantaneously the statically unstable
portion of the water column, but only until the density structure becomes neutrally stable
(i.e. until the mixed portion of the water column has exactly the density of the water
just below) [Madec et al. 1991b]. The associated algorithm is an iterative process used in
the following way (Fig. 10.3) : starting from the top of the ocean, the first instability is
found. Assume in the following that the instability is located between levels k and k + 1.
The potential temperature and salinity in the two levels are vertically mixed, conserving
the heat and salt contents of the water column. The new density is then computed by a
linear approximation. If the new density profile is still unstable between levels k + 1 and
k + 2, levels k, k + 1 and k + 2 are then mixed. This process is repeated until stability is
established below the level k (the mixing process can go down to the ocean bottom). The
algorithm is repeated to check if the density profile between level k 1 and k is unstable
and/or if there is no deeper instability.
This algorithm is significantly different from mixing statically unstable levels two by
two. The latter procedure cannot converge with a finite number of iterations for some

178

Vertical Ocean Physics (ZDF)

LEVELS

initial profile
st

step

nd

step

3
4
5

F IG . 10.3 Example of an unstable density profile treated by the non penetrative


convective adjustment algorithm. 1st step : the initial profile is checked from the
surface to the bottom. It is found to be unstable between levels 3 and 4. They
are mixed. The resulting is still larger than (5) : levels 3 to 5 are mixed. The
resulting is still larger than (6) : levels 3 to 6 are mixed. The 1st step ends since
the density profile is then stable below the level 3. 2nd step : the new profile is
checked following the same procedure as in 1st step : levels 2 to 5 are mixed. The
new density profile is checked. It is found stable : end of algorithm.

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

Enhanced Vertical Diffusion (ln zdfevd=true)


!----------------------------------------------------------------------&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
/

The enhanced vertical diffusion parameterisation is used when ln zdfevd=true. In this


case, the vertical eddy mixing coefficients are assigned very large values (a typical value
is 10 m2 s1 ) in regions where the stratification is unstable (i.e. when N 2 the BruntVaisala frequency is negative) [Lazar 1997, Lazar et al. 1999]. This is done either on
tracers only (nn evdm=0) or on both momentum and tracers (nn evdm=1).
vS
In practice, where N 2 1012 , AvT
T and AT , and if nn evdm=1, the four neighbouring Avm
and Avm
values also, are set equal to the namelist parameter rn avevd.
u
v
A typical value for rn avevd is between 1 and 100 m2 .s1 . This parameterisation of
convective processes is less time consuming than the convective adjustment algorithm
presented above when mixing both tracers and momentum in the case of static instabilities. It requires the use of an implicit time stepping on vertical diffusion terms (i.e.
ln zdfexp=false).
Note that the stability test is performed on both before and now values of N 2 . This
removes a potential source of divergence of odd and even time step in a leapfrog environment [Leclair 2010] (see 3.5).

10.2.3

Turbulent Closure Scheme (key zdftke or key zdfgls)


The turbulent closure scheme presented in 10.1.3 and 10.1.5 (key zdftke or key zdftke
is defined) in theory solves the problem of statically unstable density profiles. In such a

180

Vertical Ocean Physics (ZDF)

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 Mixing (key zdfddm)


!----------------------------------------------------------------------&namzdf_ddm
!
double diffusive mixing parameterization
("key_zdfddm")
!----------------------------------------------------------------------rn_avts
= 1.e-4
! maximum avs (vertical mixing on salinity)
rn_hsbfr
= 1.6
! heat/salt buoyancy flux ratio
/

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

where subscript f represents mixing by salt fingering, d by diffusive convection, and o by


processes other than double diffusion. The rates of double-diffusive mixing depend on the
buoyancy ratio R = z T /z S, where and are coefficients of thermal expansion
and saline contraction (see 5.8.1). To represent mixing of S and T by salt fingering, we
adopt the diapycnal diffusivities suggested by Schmitt (1981) :
Av
1+(R /Rc )n

if R > 1 and N 2 > 0

otherwise

(
AvS
f

vS
AvT
f = 0.7 Af /R

(10.20)
(10.21)

10.4. Bottom Friction (zdfbfr)

181

F IG . 10.4 From Merryfield et al. [1999] : (a) Diapycnal diffusivities AvT


f and
vS
Af for temperature and salt in regions of salt fingering. Heavy curves denote
Av = 103 m2 .s1 and thin curves Av = 104 m2 .s1 ; (b) diapycnal diffuvS
sivities AvT
d and Ad for temperature and salt in regions of diffusive convection.
Heavy curves denote the Federov parameterisation and thin curves the Kelley parameterisation. The latter is not implemented in NEMO .

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

Ad (1.85 R 0.85) if 0.5 R < 1 and N > 0


= AvT
if 0 < R < 0.5 and N 2 > 0
d 0.15 R

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

Bottom Friction (zdfbfr.F90 module)


!-----------------------------------------------------------------------

182

Vertical Ocean Physics (ZDF)

&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. Bottom Friction (zdfbfr)

10.4.1

183

Linear Bottom Friction (nn botfr = 0 or 1)


The linear bottom friction parameterisation (including the special case of a free-slip
condition) assumes that the bottom friction is proportional to the interior velocity (i.e. the
velocity of the last model level) :
FhU =

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

Non-Linear Bottom Friction (nn botfr = 2)


The non-linear bottom friction parameterisation assumes that the bottom friction is
quadratic :
q
Avm Uh
FhU =
= CD u2b + vb2 + eb Ubh
(10.29)
e3 k
where CD is a drag coefficient, and eb a bottom turbulent kinetic energy due to tides,
internal waves breaking and other short time scale currents. A typical value of the drag
coefficient is CD = 103 . As an example, the CME experiment [Treguier 1992] uses
CD = 103 and eb = 2.5 103 m2 s2 , while the FRAM experiment [Killworth 1992]
uses CD = 1.4 103 and eb = 2.5 103 m2 s2 . The CME choices have been set as
default values (rn bfric2 and rn bfeb2 namelist parameters).

184

Vertical Ocean Physics (ZDF)

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

Bottom Friction stability considerations


Some care needs to exercised over the choice of parameters to ensure that the implementation of bottom friction does not induce numerical instability. For the purposes of
stability analysis, an approximation to (10.25) is :
Fh u
2t
e3u
ru
=
2t
e3u

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)

which, using (10.31), gives :


r

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

10.4. Bottom Friction (zdfbfr)

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

Bottom Friction with split-explicit time splitting


When calculating the momentum trend due to bottom friction in dynbfr.F90, the bottom velocity at the before time step is used. This velocity includes both the baroclinic and
barotropic components which is appropriate when using either the explicit or filtered surface pressure gradient algorithms (key dynspg exp or key dynspg flt). Extra attention is
required, however, when using split-explicit time stepping (key dynspg ts). In this case
the free surface equation is solved with a small time step nn baro*rn rdt, while the three
dimensional prognostic variables are solved with a longer time step that is a multiple of
rn rdt. The trend in the barotropic momentum due to bottom friction appropriate to this
method is that given by the selected parameterisation (i.e. linear or non-linear bottom
friction) computed with the evolving velocities at each barotropic timestep.
In the case of non-linear bottom friction, we have elected to partially linearise the
problem by keeping the coefficients fixed throughout the barotropic time-stepping to those
computed in zdfbfr.F90 using the now timestep. This decision allows an efficient use of
the cU
b coefficients to :
1. On entry to dyn spg ts, remove the contribution of the before barotropic velocity to
the bottom friction component of the vertically integrated momentum trend. Note
the same stability check that is carried out on the bottom friction coefficient in
dynbfr.F90 has to be applied here to ensure that the trend removed matches that
which was added in dynbfr.F90.
2. At each barotropic step, compute the contribution of the current barotropic velocity
to the trend due to bottom friction. Add this contribution to the vertically integrated
momentum trend. This contribution is handled implicitly which eliminates the need
to impose a stability criteria on the values of the bottom friction coefficient within
the barotropic loop.
Note that the use of an implicit formulation for the bottom friction trend means that
any limiting of the bottom friction coefficient in dynbfr.F90 does not adversely affect the
solution when using split-explicit time splitting. This is because the major contribution to
bottom friction is likely to come from the barotropic component which uses the unrestricted value of the coefficient.
The implicit formulation takes the form :
 tt

t+t = U

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

Vertical Ocean Physics (ZDF)

components to the vertically integrated momentum trend except for that due to bottom
friction.

10.5

Tidal Mixing (key zdftmx)


!----------------------------------------------------------------------&namzdf_tmx
!
tidal mixing parameterization
("key_zdftmx")
!----------------------------------------------------------------------rn_htmx
= 500.
! vertical decay scale for turbulence (meters)
rn_n2min
= 1.e-8
! threshold of the Brunt-Vaisala frequency (s-1)
rn_tfe
= 0.333
! tidal dissipation efficiency
rn_me
= 0.2
! mixing efficiency
ln_tmx_itf = .true.
! ITF specific parameterisation
rn_tfe_itf = 1.
! ITF tidal dissipation efficiency
/

10.5.1

Bottom intensified tidal mixing


The parameterization of tidal mixing follows the general formulation for the vertical
eddy diffusivity proposed by St. Laurent et al. [2002] and first introduced in an OGCM by
[Simmons et al. 2004]. In this formulation an additional vertical diffusivity resulting from
internal tide breaking, AvT
tides is expressed as a function of E(x, y), the energy transfer
from barotropic tides to baroclinic tides :
AvT
tides = q

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.

10.5. Tidal Mixing (key zdftmx)

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

Indonesian area specific treatment (ln zdftmx itf )


When the Indonesian Through Flow (ITF) area is included in the model domain, a specific treatment of tidal induced mixing in this area can be used. It is activated through the
namelist logical ln tmx itf , and the user must provide an input NetCDF file, mask itf.nc,
which contains a mask array defining the ITF area where the specific treatment is applied.
When ln tmx itf =true, the two key parameters q and F (z) are adjusted following the
parameterisation developed by ?? :
First, the Indonesian archipelago is a complex geographic region with a series of
large, deep, semi-enclosed basins connected via numerous narrow straits. Once generated,
internal tides remain confined within this semi-enclosed area and hardly radiate away.
Therefore all the internal tides energy is consumed within this area. So it is assumed that
q = 1, i.e. all the energy generated is available for mixing. Note that for test purposed, the
ITF tidal dissipation efficiency is a namelist parameter (rn tfe itf ). A value of 1 or close
to is this recommended for this parameter.
Second, the vertical structure function, F (z), is no more associated with a bottom
intensification of the mixing, but with a maximum of energy available within the thermocline. ?? have suggested that the vertical distribution of the energy dissipation proportional
to N 2 below the core of the thermocline and to N above. The resulting F (z) is :

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

Vertical Ocean Physics (ZDF)

F IG . 10.5 (a) M2 and (b) K2 internal wave drag energy from Carr`ere and Lyard
[2003] (W/m2 ).

11 Ouput and Diagnostics (IOM, DIA, TRD, FLO

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

Ouput and Diagnostics (IOM, DIA, TRD, FLO)

Old Model Output (default or key dimgout)


The model outputs are of three types : the restart file, the output listing, and the output
file(s). The restart file is used internally by the code when the user wants to start the model
with initial conditions defined by a previous simulation. It contains all the information that
is necessary in order for there to be no changes in the model results (even at the computer
precision) between a run performed with several restarts and the same run performed in
one step. It should be noted that this requires that the restart file contain two consecutive
time steps for all the prognostic variables, and that it is saved in the same binary format as
the one used by the computer that is to read it (in particular, 32 bits binary IEEE format
must not be used for this file). The output listing and file(s) are predefined but should
be checked and eventually adapted to the users needs. The output listing is stored in the
ocean.output file. The information is printed from within the code on the logical unit
numout. To locate these prints, use the UNIX command grep -i numout in the source
code directory.
In the standard configuration, the user will find the model results in NetCDF files
containing mean values (or instantaneous values if key diainstant is defined) for every
time-step where output is demanded. These outputs are defined in the diawri.F90 module.
When defining key dimgout, the output are written in DIMG format, an IEEE output
format.
Since version 3.2, an I/O server has been added which provides more flexibility in the
choice of the fields to be output as well as how the writing work is distributed over the
processors in massively parallel computing. It is presented in next section.

11.2

Standard model Output (IOM)


Since version 3.2, iom put is the NEMO output interface. It was designed to be simple
to use, flexible and efficient. Two main functionalities are covered by iom put : (1) the
control of the output files through an external xml file defined by the user ; (2) the distribution (or not) of all task related to output files on dedicated processors. The first functionality allows the user to specify, without touching anything into the code, the way he
want to output data :
- choice of output frequencies that can be different for each file (including real months
and years)
- choice of file contents : decide which data will be written in which file (the same data
can be outputted in different files)
- possibility to extract a subdomain (for example all TAO-PIRATA-RAMA moorings are
already defined)
- choice of the temporal operation to perform : mean, instantaneous, min, max

11.2. Standard model Output (IOM)

191

- extremely large choice of data available


- redefine variables name and long name
In addition, iom put allows the user to output any variable (scalar, 2D or 3D) in the code
in a very easy way. All details of iom put functionalities are listed in the following subsections. An example of the iodef.xml file that control the outputs can be found here :
NEMOGCM/CONFIG/ORCA2 LIM/EXP00/iodef.xml
The second functionality targets outputs performances when running on a very large
number of processes. The idea is to dedicate N specific processes to write the outputs,
where N is defined by the user. In the current version, this functionality is technically
working however, its performance are usually poor (for known reasons). Users can therefore test this functionality but they must be aware that expected performance improvement will not be achieved before the release 3.4. An example of xmlio server.def NEMOGCM/CONFIG/ORCA2 LIM/EXP00/xmlio server.def

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.

Structure of the xml file used in NEMO


The xml file is split into 3 parts :
field definition : define all variables that can be output
all lines in between the following two tags
<field\_definition ...>
</field\_definition ...>
file definition : define the netcdf files to be created and the variables they will contain
all lines in between the following two tags
<field\_definition>
</field\_definition>
axis and grid definitions : define the horizontal and vertical grids
all lines in between the following two set of two tags
<axis\_definition ...>
</axis\_definition ...> and
<grid\_definition ...>
</grid\_definition ...>

192

Ouput and Diagnostics (IOM, DIA, TRD, FLO)

Inheritance and group


Xml extensively uses the concept of inheritance.
example 1 :
<field_definition operation="ave(X)" >
<field id="sst"
/>
<field id="sss" operation="inst(X)"/>
</field_definition>

<!-- 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>

<!-- default def -->


<!-- overwrite
-->

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>

<!-- 5d files -->


<!-- T grid file -->

<!-- U grid file -->

11.2. Standard model Output (IOM)

193

Control of the xml attributes from NEMO


The values of some attributes are automatically defined by NEMO (and any definition
given in the xml file is overwritten). By convention, these attributes are defined to auto
(for string) or 0000 (for integer) in the xml file (but this is not necessary).
Here is the list of these attributes :
tag ids affected by automatic
definition of some of their attributes
field definition
SBC
1h, 2h, 3h, 4h, 6h, 12h
grid T, grid U,
1d, 3d, 5d
grid V, grid W,
1m, 2m, 3m, 4m, 6m
icemod, ptrc T,
1y, 2y, 5y, 10y
diad T, scalar
EqT, EqU, EqW
TAO, RAMA and PIRATA moorings

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

Ouput and Diagnostics (IOM, DIA, TRD, FLO)

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.

11.2. Standard model Output (IOM)

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.

Control the io server : the namelist file xmlio server.def


The control of the use of the io server is done through the namelist file of the io server
called xmlio server.def.

196

Ouput and Diagnostics (IOM, DIA, TRD, FLO)

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.

Number of cpu used by the io server in detached mode


The number of cpu used by the io server is specified only when launching the model.
Here is an example of 2 cpus for the io server and 6 cpu for opa using mpirun :
-p 2 -e ./ioserver
-p 6 -e ./opa

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

11.3. NetCDF4 Support (key netcdf4)

197

<file id="file_1" .../>


...
<field ref="identifier" />
...
</file>

Several time axes in the output file


If your output file contains variables with different operations (see operation definition), IOIPSL will create one specific time axis for each operation. Note that inst(X) will
have a time axis corresponding to the end each output period whereas all other operators
will have a time axis centred in the middle of the output periods.

Error/bug messages from IOIPSL


If you get the following error in the standard output file :
FATAL ERROR FROM ROUTINE flio_dom_set
--> too many domains simultaneously defined
--> please unset useless domains
--> by calling flio_dom_unset

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.

Dont worry, there is no bug, everything is properly working !

11.3

NetCDF4 Support (key netcdf4)


Since version 3.3, support for NetCDF4 chunking and (loss-less) compression has
been included. These options build on the standard NetCDF output and allow the user
control over the size of the chunks via namelist settings. Chunking and compression can
lead to significant reductions in file sizes for a small runtime overhead. For a fuller discussion on chunking and other performance issues the reader is referred to the NetCDF4
documentation found here.
The new features are only available when the code has been linked with a NetCDF4
library (version 4.1 onwards, recommended) which has been built with HDF5 support
(version 1.8.4 onwards, recommended). Datasets created with chunking and compression
are not backwards compatible with NetCDF3 classic format but most analysis codes can

198

Ouput and Diagnostics (IOM, DIA, TRD, FLO)

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)

=
=
=
=

MIN( idomain_size,MAX( (idomain_size-1)/nn_nchunks_i + 1 ,16 ) )


MIN( jdomain_size,MAX( (jdomain_size-1)/nn_nchunks_j + 1 ,16 ) )
MIN( kdomain_size,MAX( (kdomain_size-1)/nn_nchunks_k + 1 , 1 ) )
1

As an example, setting :
nn_nchunks_i=4, nn_nchunks_j=4 and nn_nchunks_k=31

for a standard ORCA2 LIM configuration gives chunksizes of 46x38x1 respectively in


the mono-processor case (i.e. global domain of 182x149x31). An illustration of the
potential space savings that NetCDF4 chunking and compression provides is given in
table 11.1 which compares the results of two short runs of the ORCA2 LIM reference
configuration with a 4x2 mpi partitioning. Note the variation in the compression ratio
achieved which reflects chiefly the dry to wet volume ratio of each processing region.

11.3. NetCDF4 Support (key netcdf4)

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

NetCDF3 NetCDF4 Reduction


filesize
filesize
%
(KB)
(KB)
16420
8860
47%
16064
11456
29%
16064
9744
40%
16420
9404
43%
16200
5844
64%
15848
8172
49%
15848
8012
50%
16200
5148
69%
2200
1504
32%
2200
1748
21%
2200
1592
28%
2200
1540
30%
2200
1204
46%
2200
1444
35%
2200
1428
36%
2200
1148
48%
...
...
..
4416
2240
50%
4416
2924
34%
4416
2512
44%
4416
2368
47%
4416
1432
68%
4416
1972
56%
4416
2028
55%
4416
1368
70%

TAB . 11.1 Filesize comparison between NetCDF3 and NetCDF4 with chunking
and compression

200

Ouput and Diagnostics (IOM, DIA, TRD, FLO)

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

Tracer/Dynamics Trends (key trdtra, key trddyn,


key trddvor, key trdmld)
!----------------------------------------------------------------------&namtrd
!
diagnostics on dynamics and/or tracer trends
("key_trddyn" and/or "key_trdtra")
!
!
or mixed-layer trends or barotropic vorticity
("key_trdmld" or
"key_trdvor")
!----------------------------------------------------------------------nn_trd
= 365
! time step frequency dynamics and tracers trends
nn_ctls
=
0
! control surface type in mixed-layer trends (0,1 or n<jpk)
rn_ucf
=
1.
! unit conversion factor (=1 -> /seconds ; =86400. -> /day)
cn_trdrst_in
= "restart_mld"
! suffix of ocean restart name (input)
cn_trdrst_out
= "restart_mld"
! suffix of ocean restart name (output)
ln_trdmld_restart = .false.
! restart for ML diagnostics
ln_trdmld_instant = .false.
! flag to diagnose trends of instantantaneous or mean ML T/S
/

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.

11.5. On-line Floats trajectories (FLO) (key floats)

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

On-line Floats trajectories (FLO) (key floats)


!----------------------------------------------------------------------&namflo
!
float parameters
("key_float")
!----------------------------------------------------------------------ln_rstflo = .false.
! float restart (T) or not (F)
nn_writefl =
75
! frequency of writing in float output file
nn_stockfl =
5475
! frequency of creation of the float restart file
ln_argo
= .false.
! Argo type floats (stay at the surface each 10 days)
ln_flork4 = .false.
! trajectories computed with a 4th order Runge-Kutta (T)
! or computed with Blanke scheme (F)
/

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

Other Diagnostics (key diahth, key diaar5)


Aside from the standard model variables, other diagnostics can be computed on-line.
The available ready-to-add diagnostics routines can be found in directory DIA. Among
the available diagnostics the following ones are obtained when defining the key diahth
CPP key :
- the mixed layer depth (based on a density criterion, de Boyer Montegut et al. [2004])
(diahth.F90)
- the turbocline depth (based on a turbulent mixing coefficient criterion) (diahth.F90)
- the depth of the 20C isotherm (diahth.F90)
- the depth of the thermocline (maximum of the vertical temperature gradient) (diahth.F90)
The poleward heat and salt transports, their advective and diffusive component, and
the meriodional stream function can be computed on-line in diaptr.F90 by setting ln diaptr
to true (see the namptr namelist below). When ln subbas = true, transports and stream
function are computed for the Atlantic, Indian, Pacific and Indo-Pacific Oceans (defined
north of 30S) as well as for the World Ocean. The sub-basin decomposition requires an
input file (subbasins.nc) which contains three 2D mask arrays, the Indo-Pacific mask been
deduced from the sum of the Indian and Pacific mask (Fig 11.1).
!----------------------------------------------------------------------&namptr
!
Poleward Transport Diagnostic
!----------------------------------------------------------------------ln_diaptr = .false.
! Poleward heat and salt transport (T) or not (F)
ln_diaznl = .true.
! Add zonal means and meridional stream functions
ln_subbas = .true.
! Atlantic/Pacific/Indian basins computation (T) or not

202

Ouput and Diagnostics (IOM, DIA, TRD, FLO)

F IG . 11.1 Decomposition of the World Ocean (here ORCA2) into sub-basin


used in to compute the heat and salt transports as well as the meridional streamfunction : Atlantic basin (red), Pacific basin (green), Indian basin (bleue), IndoPacific basin (bleue+green). Note that semi-enclosed seas (Red, Med and Baltic
seas) as well as Hudson Bay are removed from the sub-basins. Note also that the
Arctic Ocean has been split into Atlantic and Pacific basins along the North fold
line.

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

Diagnosing the Steric effect in sea surface height


Changes in steric sea level are caused when changes in the density of the water column imply an expansion or contraction of the column. It is essentially produced through
surface heating/cooling and to a lesser extent through non-linear effects of the equation
of state (cabbeling, thermobaricity...). Non-Boussinesq models contain all ocean effects
within the ocean acting on the sea level. In particular, they include the steric effect. In
contrast, Boussinesq models, such as NEMO , conserve volume, rather than mass, and
so do not properly represent expansion or contraction. The steric effect is therefore not
explicitely represented. This approximation does not represent a serious error with res-

11.7. Diagnosing the Steric effect in sea surface height

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

Ouput and Diagnostics (IOM, DIA, TRD, FLO)

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

11.7. Diagnosing the Steric effect in sea surface height

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.

12 Observation and model comparison (OBS)

Authors : D. Lea, M. Martin, K. Mogensen, A. Vidard, A. Weaver...

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

Observation and model comparison (OBS)

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

Running the observation operator code example


This section describes an example of running the observation operator code using
profile data which can be freely downloaded. It shows how to adapt an existing run and
build of NEMO to run the observation operator.
1. Compile NEMO with key diaobs set.
2. Download some ENSEMBLES EN3 data from http ://www.hadobs.org. Choose
observations which are valid for the period of your test run because the observation
operator compares the model and observations for a matching date and time.
3. Add the following to the NEMO namelist to run the observation operator on this
data. Set the enactfiles namelist parameter to the observation file name (or link in
to profiles 01nc) :

12.1. Running the observation operator code example

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

Observation and model comparison (OBS)

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.

! Logical switch for AVISO SLA data

ln_slafb

= .false.

! Logical switch for feedback SLA data


!
ln_ssh
Logical switch for SSH observations

ln_sst

= .false.

! Logical switch for SST observations


!
ln_reysst
Logical switch for Reynolds observations
!
ln_ghrsst
Logical switch for GHRSST observations

ln_sstfb

= .false.

! 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
profbfiles = profiles_01.nc
!
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
slafbfiles = sla_01.nc
!
sstfiles
GHRSST input observation file name
!
! sstfbfiles: Feedback SST input observation file name
sstfbfiles = sst_01.nc sst_02.nc sst_03.nc sst_04.nc sst_05.nc
!
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
= 0
! MSSH correction scheme
!
mdtcorr
MDT correction
!
mdtcutoff
MDT cutoff for computed correction
ln_altbias = .false.
! Logical switch for alt bias
ln_ignmis = .true.
! Logical switch for ignoring missing files
!
endailyavtypes
ENACT daily average types
ln_grid_global = .true.
ln_grid_search_lookup = .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

12.2. Technical details

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

Profile feedback type observation file header


netcdf profiles_01 {
dimensions:
N_OBS = 603 ;
N_LEVELS = 150 ;
N_VARS = 2 ;
N_QCF = 2 ;
N_ENTRIES = 1 ;
N_EXTRA = 1 ;
STRINGNAM = 8 ;
STRINGGRID = 1 ;
STRINGWMO = 8 ;
STRINGTYP = 4 ;
STRINGJULD = 14 ;
variables:
char VARIABLES(N_VARS, STRINGNAM) ;
VARIABLES:long_name = "List of variables in feedback files" ;
char ENTRIES(N_ENTRIES, STRINGNAM) ;
ENTRIES:long_name = "List of additional entries for each variable in feedback files" ;
char EXTRA(N_EXTRA, STRINGNAM) ;
EXTRA:long_name = "List of extra variables" ;
char STATION_IDENTIFIER(N_OBS, STRINGWMO) ;
STATION_IDENTIFIER:long_name = "Station identifier" ;
char STATION_TYPE(N_OBS, STRINGTYP) ;
STATION_TYPE:long_name = "Code instrument type" ;
double LONGITUDE(N_OBS) ;
LONGITUDE:long_name = "Longitude" ;
LONGITUDE:units = "degrees_east" ;
LONGITUDE:_Fillvalue = 99999.f ;
double LATITUDE(N_OBS) ;
LATITUDE:long_name = "Latitude" ;
LATITUDE:units = "degrees_north" ;
LATITUDE:_Fillvalue = 99999.f ;
double DEPTH(N_OBS, N_LEVELS) ;
DEPTH:long_name = "Depth" ;
DEPTH:units = "metre" ;
DEPTH:_Fillvalue = 99999.f ;
int DEPTH_QC(N_OBS, N_LEVELS) ;
DEPTH_QC:long_name = "Quality on depth" ;
DEPTH_QC:Conventions = "q where q =[0,9]" ;
DEPTH_QC:_Fillvalue = 0 ;
int DEPTH_QC_FLAGS(N_OBS, N_LEVELS, N_QCF) ;
DEPTH_QC_FLAGS:long_name = "Quality flags on depth" ;
DEPTH_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
double JULD(N_OBS) ;
JULD:long_name = "Julian day" ;
JULD:units = "days since JULD_REFERENCE" ;
JULD:Conventions = "relative julian days with decimal part (as parts of day)" ;
JULD:_Fillvalue = 99999.f ;
char JULD_REFERENCE(STRINGJULD) ;
JULD_REFERENCE:long_name = "Date of reference for julian days" ;
JULD_REFERENCE:Conventions = "YYYYMMDDHHMMSS" ;
int OBSERVATION_QC(N_OBS) ;
OBSERVATION_QC:long_name = "Quality on observation" ;
OBSERVATION_QC:Conventions = "q where q =[0,9]" ;
OBSERVATION_QC:_Fillvalue = 0 ;
int OBSERVATION_QC_FLAGS(N_OBS, N_QCF) ;
OBSERVATION_QC_FLAGS:long_name = "Quality flags on observation" ;
OBSERVATION_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
OBSERVATION_QC_FLAGS:_Fillvalue = 0 ;
int POSITION_QC(N_OBS) ;
POSITION_QC:long_name = "Quality on position (latitude and longitude)" ;
POSITION_QC:Conventions = "q where q =[0,9]" ;
POSITION_QC:_Fillvalue = 0 ;
int POSITION_QC_FLAGS(N_OBS, N_QCF) ;
POSITION_QC_FLAGS:long_name = "Quality flags on position" ;
POSITION_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
POSITION_QC_FLAGS:_Fillvalue = 0 ;
int JULD_QC(N_OBS) ;
JULD_QC:long_name = "Quality on date and time" ;
JULD_QC:Conventions = "q where q =[0,9]" ;
JULD_QC:_Fillvalue = 0 ;
int JULD_QC_FLAGS(N_OBS, N_QCF) ;

212

Observation and model comparison (OBS)

JULD_QC_FLAGS:long_name = "Quality flags on date and time" ;


JULD_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
JULD_QC_FLAGS:_Fillvalue = 0 ;
int ORIGINAL_FILE_INDEX(N_OBS) ;
ORIGINAL_FILE_INDEX:long_name = "Index in original data file" ;
ORIGINAL_FILE_INDEX:_Fillvalue = -99999 ;
float POTM_OBS(N_OBS, N_LEVELS) ;
POTM_OBS:long_name = "Potential temperature" ;
POTM_OBS:units = "Degrees Celsius" ;
POTM_OBS:_Fillvalue = 99999.f ;
float POTM_Hx(N_OBS, N_LEVELS) ;
POTM_Hx:long_name = "Model interpolated potential temperature" ;
POTM_Hx:units = "Degrees Celsius" ;
POTM_Hx:_Fillvalue = 99999.f ;
int POTM_QC(N_OBS) ;
POTM_QC:long_name = "Quality on potential temperature" ;
POTM_QC:Conventions = "q where q =[0,9]" ;
POTM_QC:_Fillvalue = 0 ;
int POTM_QC_FLAGS(N_OBS, N_QCF) ;
POTM_QC_FLAGS:long_name = "Quality flags on potential temperature" ;
POTM_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
POTM_QC_FLAGS:_Fillvalue = 0 ;
int POTM_LEVEL_QC(N_OBS, N_LEVELS) ;
POTM_LEVEL_QC:long_name = "Quality for each level on potential temperature" ;
POTM_LEVEL_QC:Conventions = "q where q =[0,9]" ;
POTM_LEVEL_QC:_Fillvalue = 0 ;
int POTM_LEVEL_QC_FLAGS(N_OBS, N_LEVELS, N_QCF) ;
POTM_LEVEL_QC_FLAGS:long_name = "Quality flags for each level on potential temperature" ;
POTM_LEVEL_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
POTM_LEVEL_QC_FLAGS:_Fillvalue = 0 ;
int POTM_IOBSI(N_OBS) ;
POTM_IOBSI:long_name = "ORCA grid search I coordinate" ;
int POTM_IOBSJ(N_OBS) ;
POTM_IOBSJ:long_name = "ORCA grid search J coordinate" ;
int POTM_IOBSK(N_OBS, N_LEVELS) ;
POTM_IOBSK:long_name = "ORCA grid search K coordinate" ;
char POTM_GRID(STRINGGRID) ;
POTM_GRID:long_name = "ORCA grid search grid (T,U,V)" ;
float PSAL_OBS(N_OBS, N_LEVELS) ;
PSAL_OBS:long_name = "Practical salinity" ;
PSAL_OBS:units = "PSU" ;
PSAL_OBS:_Fillvalue = 99999.f ;
float PSAL_Hx(N_OBS, N_LEVELS) ;
PSAL_Hx:long_name = "Model interpolated practical salinity" ;
PSAL_Hx:units = "PSU" ;
PSAL_Hx:_Fillvalue = 99999.f ;
int PSAL_QC(N_OBS) ;
PSAL_QC:long_name = "Quality on practical salinity" ;
PSAL_QC:Conventions = "q where q =[0,9]" ;
PSAL_QC:_Fillvalue = 0 ;
int PSAL_QC_FLAGS(N_OBS, N_QCF) ;
PSAL_QC_FLAGS:long_name = "Quality flags on practical salinity" ;
PSAL_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
PSAL_QC_FLAGS:_Fillvalue = 0 ;
int PSAL_LEVEL_QC(N_OBS, N_LEVELS) ;
PSAL_LEVEL_QC:long_name = "Quality for each level on practical salinity" ;
PSAL_LEVEL_QC:Conventions = "q where q =[0,9]" ;
PSAL_LEVEL_QC:_Fillvalue = 0 ;
int PSAL_LEVEL_QC_FLAGS(N_OBS, N_LEVELS, N_QCF) ;
PSAL_LEVEL_QC_FLAGS:long_name = "Quality flags for each level on practical salinity" ;
PSAL_LEVEL_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
PSAL_LEVEL_QC_FLAGS:_Fillvalue = 0 ;
int PSAL_IOBSI(N_OBS) ;
PSAL_IOBSI:long_name = "ORCA grid search I coordinate" ;
int PSAL_IOBSJ(N_OBS) ;
PSAL_IOBSJ:long_name = "ORCA grid search J coordinate" ;
int PSAL_IOBSK(N_OBS, N_LEVELS) ;
PSAL_IOBSK:long_name = "ORCA grid search K coordinate" ;
char PSAL_GRID(STRINGGRID) ;
PSAL_GRID:long_name = "ORCA grid search grid (T,U,V)" ;
float TEMP(N_OBS, N_LEVELS) ;
TEMP:long_name = "Insitu temperature" ;
TEMP:units = "Degrees Celsius" ;
TEMP:_Fillvalue = 99999.f ;
// global attributes:
:title = "NEMO observation operator output" ;
:Convention = "NEMO unified observation operator output" ;
}

12.2. Technical details

12.2.2

Sea level anomaly feedback type observation file header


netcdf sla_01 {
dimensions:
N_OBS = 41301 ;
N_LEVELS = 1 ;
N_VARS = 1 ;
N_QCF = 2 ;
N_ENTRIES = 1 ;
N_EXTRA = 1 ;
STRINGNAM = 8 ;
STRINGGRID = 1 ;
STRINGWMO = 8 ;
STRINGTYP = 4 ;
STRINGJULD = 14 ;
variables:
char VARIABLES(N_VARS, STRINGNAM) ;
VARIABLES:long_name = "List of variables in feedback files" ;
char ENTRIES(N_ENTRIES, STRINGNAM) ;
ENTRIES:long_name = "List of additional entries for each variable in feedback files" ;
char EXTRA(N_EXTRA, STRINGNAM) ;
EXTRA:long_name = "List of extra variables" ;
char STATION_IDENTIFIER(N_OBS, STRINGWMO) ;
STATION_IDENTIFIER:long_name = "Station identifier" ;
char STATION_TYPE(N_OBS, STRINGTYP) ;
STATION_TYPE:long_name = "Code instrument type" ;
double LONGITUDE(N_OBS) ;
LONGITUDE:long_name = "Longitude" ;
LONGITUDE:units = "degrees_east" ;
LONGITUDE:_Fillvalue = 99999.f ;
double LATITUDE(N_OBS) ;
LATITUDE:long_name = "Latitude" ;
LATITUDE:units = "degrees_north" ;
LATITUDE:_Fillvalue = 99999.f ;
double DEPTH(N_OBS, N_LEVELS) ;
DEPTH:long_name = "Depth" ;
DEPTH:units = "metre" ;
DEPTH:_Fillvalue = 99999.f ;
int DEPTH_QC(N_OBS, N_LEVELS) ;
DEPTH_QC:long_name = "Quality on depth" ;
DEPTH_QC:Conventions = "q where q =[0,9]" ;
DEPTH_QC:_Fillvalue = 0 ;
int DEPTH_QC_FLAGS(N_OBS, N_LEVELS, N_QCF) ;
DEPTH_QC_FLAGS:long_name = "Quality flags on depth" ;
DEPTH_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
double JULD(N_OBS) ;
JULD:long_name = "Julian day" ;
JULD:units = "days since JULD_REFERENCE" ;
JULD:Conventions = "relative julian days with decimal part (as parts of day)" ;
JULD:_Fillvalue = 99999.f ;
char JULD_REFERENCE(STRINGJULD) ;
JULD_REFERENCE:long_name = "Date of reference for julian days" ;
JULD_REFERENCE:Conventions = "YYYYMMDDHHMMSS" ;
int OBSERVATION_QC(N_OBS) ;
OBSERVATION_QC:long_name = "Quality on observation" ;
OBSERVATION_QC:Conventions = "q where q =[0,9]" ;
OBSERVATION_QC:_Fillvalue = 0 ;
int OBSERVATION_QC_FLAGS(N_OBS, N_QCF) ;
OBSERVATION_QC_FLAGS:long_name = "Quality flags on observation" ;
OBSERVATION_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
OBSERVATION_QC_FLAGS:_Fillvalue = 0 ;
int POSITION_QC(N_OBS) ;
POSITION_QC:long_name = "Quality on position (latitude and longitude)" ;
POSITION_QC:Conventions = "q where q =[0,9]" ;
POSITION_QC:_Fillvalue = 0 ;
int POSITION_QC_FLAGS(N_OBS, N_QCF) ;
POSITION_QC_FLAGS:long_name = "Quality flags on position" ;
POSITION_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
POSITION_QC_FLAGS:_Fillvalue = 0 ;
int JULD_QC(N_OBS) ;
JULD_QC:long_name = "Quality on date and time" ;
JULD_QC:Conventions = "q where q =[0,9]" ;
JULD_QC:_Fillvalue = 0 ;
int JULD_QC_FLAGS(N_OBS, N_QCF) ;
JULD_QC_FLAGS:long_name = "Quality flags on date and time" ;
JULD_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
JULD_QC_FLAGS:_Fillvalue = 0 ;
int ORIGINAL_FILE_INDEX(N_OBS) ;
ORIGINAL_FILE_INDEX:long_name = "Index in original data file" ;
ORIGINAL_FILE_INDEX:_Fillvalue = -99999 ;
float SLA_OBS(N_OBS, N_LEVELS) ;

213

214

Observation and model comparison (OBS)

SLA_OBS:long_name = "Sea level anomaly" ;


SLA_OBS:units = "metre" ;
SLA_OBS:_Fillvalue = 99999.f ;
float SLA_Hx(N_OBS, N_LEVELS) ;
SLA_Hx:long_name = "Model interpolated sea level anomaly" ;
SLA_Hx:units = "metre" ;
SLA_Hx:_Fillvalue = 99999.f ;
int SLA_QC(N_OBS) ;
SLA_QC:long_name = "Quality on sea level anomaly" ;
SLA_QC:Conventions = "q where q =[0,9]" ;
SLA_QC:_Fillvalue = 0 ;
int SLA_QC_FLAGS(N_OBS, N_QCF) ;
SLA_QC_FLAGS:long_name = "Quality flags on sea level anomaly" ;
SLA_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
SLA_QC_FLAGS:_Fillvalue = 0 ;
int SLA_LEVEL_QC(N_OBS, N_LEVELS) ;
SLA_LEVEL_QC:long_name = "Quality for each level on sea level anomaly" ;
SLA_LEVEL_QC:Conventions = "q where q =[0,9]" ;
SLA_LEVEL_QC:_Fillvalue = 0 ;
int SLA_LEVEL_QC_FLAGS(N_OBS, N_LEVELS, N_QCF) ;
SLA_LEVEL_QC_FLAGS:long_name = "Quality flags for each level on sea level anomaly" ;
SLA_LEVEL_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
SLA_LEVEL_QC_FLAGS:_Fillvalue = 0 ;
int SLA_IOBSI(N_OBS) ;
SLA_IOBSI:long_name = "ORCA grid search I coordinate" ;
int SLA_IOBSJ(N_OBS) ;
SLA_IOBSJ:long_name = "ORCA grid search J coordinate" ;
int SLA_IOBSK(N_OBS, N_LEVELS) ;
SLA_IOBSK:long_name = "ORCA grid search K coordinate" ;
char SLA_GRID(STRINGGRID) ;
SLA_GRID:long_name = "ORCA grid search grid (T,U,V)" ;
float MDT(N_OBS, N_LEVELS) ;
MDT:long_name = "Mean Dynamic Topography" ;
MDT:units = "metre" ;
MDT:_Fillvalue = 99999.f ;
// global attributes:
:title = "NEMO observation operator output" ;
:Convention = "NEMO unified observation operator output" ;
}

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

Sea surface temperature feedback type observation file header


netcdf sst_01 {
dimensions:
N_OBS = 33099 ;
N_LEVELS = 1 ;
N_VARS = 1 ;
N_QCF = 2 ;
N_ENTRIES = 1 ;

12.2. Technical details


STRINGNAM = 8 ;
STRINGGRID = 1 ;
STRINGWMO = 8 ;
STRINGTYP = 4 ;
STRINGJULD = 14 ;
variables:
char VARIABLES(N_VARS, STRINGNAM) ;
VARIABLES:long_name = "List of variables in feedback files" ;
char ENTRIES(N_ENTRIES, STRINGNAM) ;
ENTRIES:long_name = "List of additional entries for each variable in feedback files" ;
char STATION_IDENTIFIER(N_OBS, STRINGWMO) ;
STATION_IDENTIFIER:long_name = "Station identifier" ;
char STATION_TYPE(N_OBS, STRINGTYP) ;
STATION_TYPE:long_name = "Code instrument type" ;
double LONGITUDE(N_OBS) ;
LONGITUDE:long_name = "Longitude" ;
LONGITUDE:units = "degrees_east" ;
LONGITUDE:_Fillvalue = 99999.f ;
double LATITUDE(N_OBS) ;
LATITUDE:long_name = "Latitude" ;
LATITUDE:units = "degrees_north" ;
LATITUDE:_Fillvalue = 99999.f ;
double DEPTH(N_OBS, N_LEVELS) ;
DEPTH:long_name = "Depth" ;
DEPTH:units = "metre" ;
DEPTH:_Fillvalue = 99999.f ;
int DEPTH_QC(N_OBS, N_LEVELS) ;
DEPTH_QC:long_name = "Quality on depth" ;
DEPTH_QC:Conventions = "q where q =[0,9]" ;
DEPTH_QC:_Fillvalue = 0 ;
int DEPTH_QC_FLAGS(N_OBS, N_LEVELS, N_QCF) ;
DEPTH_QC_FLAGS:long_name = "Quality flags on depth" ;
DEPTH_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
double JULD(N_OBS) ;
JULD:long_name = "Julian day" ;
JULD:units = "days since JULD_REFERENCE" ;
JULD:Conventions = "relative julian days with decimal part (as parts of day)" ;
JULD:_Fillvalue = 99999.f ;
char JULD_REFERENCE(STRINGJULD) ;
JULD_REFERENCE:long_name = "Date of reference for julian days" ;
JULD_REFERENCE:Conventions = "YYYYMMDDHHMMSS" ;
int OBSERVATION_QC(N_OBS) ;
OBSERVATION_QC:long_name = "Quality on observation" ;
OBSERVATION_QC:Conventions = "q where q =[0,9]" ;
OBSERVATION_QC:_Fillvalue = 0 ;
int OBSERVATION_QC_FLAGS(N_OBS, N_QCF) ;
OBSERVATION_QC_FLAGS:long_name = "Quality flags on observation" ;
OBSERVATION_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
OBSERVATION_QC_FLAGS:_Fillvalue = 0 ;
int POSITION_QC(N_OBS) ;
POSITION_QC:long_name = "Quality on position (latitude and longitude)" ;
POSITION_QC:Conventions = "q where q =[0,9]" ;
POSITION_QC:_Fillvalue = 0 ;
int POSITION_QC_FLAGS(N_OBS, N_QCF) ;
POSITION_QC_FLAGS:long_name = "Quality flags on position" ;
POSITION_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
POSITION_QC_FLAGS:_Fillvalue = 0 ;
int JULD_QC(N_OBS) ;
JULD_QC:long_name = "Quality on date and time" ;
JULD_QC:Conventions = "q where q =[0,9]" ;
JULD_QC:_Fillvalue = 0 ;
int JULD_QC_FLAGS(N_OBS, N_QCF) ;
JULD_QC_FLAGS:long_name = "Quality flags on date and time" ;
JULD_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;
JULD_QC_FLAGS:_Fillvalue = 0 ;
int ORIGINAL_FILE_INDEX(N_OBS) ;
ORIGINAL_FILE_INDEX:long_name = "Index in original data file" ;
ORIGINAL_FILE_INDEX:_Fillvalue = -99999 ;
float SST_OBS(N_OBS, N_LEVELS) ;
SST_OBS:long_name = "Sea surface temperature" ;
SST_OBS:units = "Degree centigrade" ;
SST_OBS:_Fillvalue = 99999.f ;
float SST_Hx(N_OBS, N_LEVELS) ;
SST_Hx:long_name = "Model interpolated sea surface temperature" ;
SST_Hx:units = "Degree centigrade" ;
SST_Hx:_Fillvalue = 99999.f ;
int SST_QC(N_OBS) ;
SST_QC:long_name = "Quality on sea surface temperature" ;
SST_QC:Conventions = "q where q =[0,9]" ;
SST_QC:_Fillvalue = 0 ;
int SST_QC_FLAGS(N_OBS, N_QCF) ;
SST_QC_FLAGS:long_name = "Quality flags on sea surface temperature" ;
SST_QC_FLAGS:Conventions = "NEMOVAR flag conventions" ;

215

216

Observation and model comparison (OBS)

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

Horizontal interpolation methods


Consider an observation point P with with longitude and latitude ( P , P ) and the
four nearest neighbouring model grid points A, B, C and D with longitude and latitude
(A , A ), (B , B ) etc. All horizontal interpolation methods implemented in NEMO estimate the value of a model variable x at point P as a weighted linear combination of the
values of the model variables at the grid points A, B etc. :
xP =

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

12.3. Theoretical details

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

Observation and model comparison (OBS)

b (i.e., that the coefficients of k


b are
point in the opposite direction to the unit normal k
negative), where r PA , r PB , etc. correspond to the vectors between points P and A, P and
B, etc.. The method used is similar to the method used in the SCRIP interpolation package
[Jones 1998].
In order to speed up the grid search, there is the possibility to construct a lookup table
for a user specified resolution. This lookup table contains the lower and upper bounds on
the i and j indices to be searched for on a regular grid. For each observation position, the
closest point on the regular grid of this position is computed and the i and j ranges of this
point searched to determine the precise four points surrounding the observation.

12.3.3

Parallel aspects of horizontal interpolation


For horizontal interpolation, there is the basic problem that the observations are unevenly distributed on the globe. In numerical models, it is common to divide the model grid
into subgrids (or domains) where each subgrid is executed on a single processing element
with explicit message passing for exchange of information along the domain boundaries
when running on a massively parallel processor (MPP) system. This approach is used by
NEMO .
For observations there is no natural distribution since the observations are not equally
distributed on the globe. Two options have been made available : 1) geographical distribution ; and 2) round-robin.

Geographical distribution of observations among processors


This is the simplest option in which the observations are distributed according to the
domain of the grid-point parallelization. Figure 12.1 shows an example of the distribution
of the in situ data on processors with a different colour for each observation on a given
processor for a 4 2 decomposition with ORCA2. The grid-point domain decomposition
is clearly visible on the plot.
The advantage of this approach is that all information needed for horizontal interpolation is available without any MPP communication. Of course, this is under the assumption
that we are only using a 2 2 grid-point stencil for the interpolation (e.g., bilinear interpolation). For higher order interpolation schemes this is no longer valid. A disadvantage
with the above scheme is that the number of observations on each processor can be very
different. If the cost of the actual interpolation is expensive relative to the communication
of data needed for interpolation, this could lead to load imbalance.

Round-robin distribution of observations among processors


An alternative approach is to distribute the observations equally among processors and
use message passing in order to retrieve the stencil for interpolation. The simplest distribution of the observations is to distribute them using a round-robin scheme. Figure 12.2
shows the distribution of the in situ data on processors for the round-robin distribution of
observations with a different colour for each observation on a given processor for a 4 2

12.3. Theoretical details

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

F IG . 12.1 Example of the distribution of observations with the geographical


distribution of observational data.

220

Observation and model comparison (OBS)

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

F IG . 12.2 Example of the distribution of observations with the round-robin


distribution of observational data.

12.3. Theoretical details

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

Vertical interpolation operator


The vertical interpolation is achieved using either a cubic spline or linear interpolation. For the cubic spline, the top and bottom boundary conditions for the second derivative of the interpolating polynomial in the spline are set to zero. At the bottom boundary,
this is done using the land-ocean mask.

13 Apply assimilation increments (ASM)

Authors : D. Lea, M. Martin, K. Mogensen, A. Weaver, ...

Contents
13.1 Direct initialization . . . . . . . . . . . . . . . . . . . . . . 224
13.2 Incremental Analysis Updates . . . . . . . . . . . . . . . . 224
13.3 Implementation details . . . . . . . . . . . . . . . . . . . . 225

224

Apply assimilation increments (ASM)

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

Incremental Analysis Updates


Rather than updating the model state directly with the analysis increment, it may be
preferable to introduce the increment gradually into the ocean model in order to minimize
spurious adjustment processes. This technique is referred to as Incremental Analysis Updates (IAU) [Bloom et al. 1996]. IAU is a common technique used with 3D assimilation
methods such as 3D-Var or OI. IAU is used when ln asmiau is set to true.
With IAU, the model state trajectory x in the assimilation window (t0 ti tN ) is
corrected by adding the analysis increments for temperature, salinity, horizontal velocity
and SSH as additional tendency terms to the prognostic equations :
xa (ti ) = M (ti , t0 )[xb (t0 )] + Fi
xa

(13.1)

where Fi is a weighting function for applying the increments


xa defined such that
P
N
b
a
i=1 Fi = 1. x denotes the model initial state and x is the model state after the increments are applied. To control the adjustment time of the model to the increment, the
increment can be applied over an arbitrary sub-window, tm ti tn , of the main assimilation window, where t0 tm ti and ti tn tN , Typically the increments are
spread evenly over the full window. In addition, two different weighting functions have
been implemented. The first function employs constant weights,
(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

13.3. Implementation details


a small value at the window end-points :

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

Apply assimilation increments (ASM)


:DOMAIN_size_local = 182, 149 ;
:DOMAIN_position_first = 1, 1 ;
:DOMAIN_position_last = 182, 149 ;
:DOMAIN_halo_size_start = 0, 0 ;
:DOMAIN_halo_size_end = 0, 0 ;
:DOMAIN_type = "BOX" ;

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

Representation of Unresolved Straits


In climate modeling, it often occurs that a crucial connections between water masses
is broken as the grid mesh is too coarse to resolve narrow straits. For example, coarse grid
spacing typically closes off the Mediterranean from the Atlantic at the Strait of Gibraltar.
In this case, it is important for climate models to include the effects of salty water entering
the Atlantic from the Mediterranean. Likewise, it is important for the Mediterranean to replenish its supply of water from the Atlantic to balance the net evaporation occurring over
the Mediterranean region. This problem occurs even in eddy permitting simulations. For
example, in ORCA 1/4several straits of the Indonesian archipelago (Ombai, Lombok...)
are much narrow than even a single ocean grid-point.
We describe briefly here the three methods that can be used in NEMO to handle such
improperly resolved straits. The first two consist of opening the strait by hand while ensuring that the mass exchanges through the strait are not too large by either artificially
reducing the surface of the strait grid-cells or, locally increasing the lateral friction. In the
third one, the strait is closed but exchanges of mass, heat and salt across the land are allowed. Note that such modifications are so specific to a given configuration that no attempt
has been made to set them in a generic way. However, examples of how they can be set up
is given in the ORCA 2and 0.5configurations (search for key orca r2 or key orca r05
in the code).

14.1.1

Hand made geometry changes


reduced scale factor in the cross-strait direction to a value in better agreement with
the true mean width of the strait. (Fig. 14.1). This technique is sometime called partially
open face or partially closed cells. The key issue here is only to reduce the faces of
T -cell (i.e. change the value of the horizontal scale factors at u- or v-point) but not the
volume of the T -cell. Indeed, reducing the volume of strait T -cell can easily produce a
numerical instability at that grid point that would require a reduction of the model time
step. The changes associated with strait management are done in domhgr.F90, just after
the definition or reading of the horizontal scale factors.
increase of the viscous boundary layer thickness by local increase of the fmask
value at the coast (Fig. 14.1). This is done in dommsk.F90 together with the setting of the
coastal value of fmask (see Section 8.1)

14.1.2

Cross Land Advection (tracla.F90)


!----------------------------------------------------------------------&namcla
!
cross land advection
!----------------------------------------------------------------------nn_cla
=
0
! advection between 2 ocean pts separates by land
/

14.1. Representation of Unresolved Straits

229

38oN

36oN

34oN
10oW

8oW

6oW

4oW

2oW

0o

fmask set to value > 2

38oN

36oN

Viscous Boundary
layer

34oN
10oW

8oW

6oW

4oW

2oW

0o

F IG . 14.1 Example of the Gibraltar strait defined in a 1 1 mesh. Top :


using partially open cells. The meridional scale factor at v-point is reduced on
both sides of the strait to account for the real width of the strait (about 20 km).
Note that the scale factors of the strait T -point remains unchanged. Bottom : using
viscous boundary layers. The four fmask parameters along the strait coastlines are
set to a value larger than 4, i.e. strong no-slip case (see Fig.8.2) creating a large
viscous boundary layer that allows a reduced transport through the strait.

230

Miscellaneous Topics
Add a short description of CLA staff here or in lateral boundary condition chapter ?

14.2

Closed seas (closea.F90)


Add here a short description of the way closed seas are managed

14.3

Sub-Domain Functionality (jpizoom, jpjzoom)


The sub-domain functionality, also improperly called the zoom option (improperly
because it is not associated with a change in model resolution) is a quite simple function
that allows a simulation over a sub-domain of an already defined configuration (i.e. without defining a new mesh, initial state and forcings). This option can be useful for testing
the user settings of surface boundary conditions, or the initial ocean state of a huge ocean
model configuration while having a small computer memory requirement. It can also be
used to easily test specific physics in a sub-domain (for example, see [Madec et al. 1996]
for a test of the coupling used in the global ocean version of OPA between sea-ice and
ocean model over the Arctic or Antarctic ocean, using a sub-domain). In the standard model, this option does not include any specific treatment for the ocean boundaries of the
sub-domain : they are considered as artificial vertical walls. Nevertheless, it is quite easy
to add a restoring term toward a climatology in the vicinity of such boundaries (see 5.6).
In order to easily define a sub-domain over which the computation can be performed,
the dimension of all input arrays (ocean mesh, bathymetry, forcing, initial state, ...) are defined as jpidta, jpjdta and jpkdta (par oce.F90 module), while the computational domain
is defined through jpiglo, jpjglo and jpk (par oce.F90 module). When running the model
over the whole domain, the user sets jpiglo=jpidta jpjglo=jpjdta and jpk=jpkdta. When
running the model over a sub-domain, the user has to provide the size of the sub-domain,
(jpiglo, jpjglo, jpkglo), and the indices of the south western corner as jpizoom and jpjzoom
in the par oce.F90 module (Fig. 14.2).
Note that a third set of dimensions exist, jpi, jpj and jpk which is actually used to
perform the computation. It is set by default to jpi=jpjglo and jpj=jpjglo, except for massively parallel computing where the computational domain is laid out on local processor
memories following a 2D horizontal splitting.

14.4

Accelerating the Convergence (nn acc = 1)


!----------------------------------------------------------------------&namdom
!
space and time domain (bathymetry, mesh, timestep)
!----------------------------------------------------------------------nn_bathy
=
1
! compute (=0) or read (=1) the bathymetry file
nn_closea
=
0
! remove (=0) or keep (=1) closed seas and lakes (ORCA)
nn_msh
=
0
! create (=1) a mesh file or not (=0)
rn_hmin
=
-3.
! min depth of the ocean (>0) or min number of ocean level (<0)
rn_e3zps_min=
20.
! partial step thickness is set larger than the minimum of
rn_e3zps_rat=
0.1
! rn_e3zps_min and rn_e3zps_rat*e3t, with 0<rn_e3zps_rat<1
!
rn_rdt
= 5760.
! time step for the dynamics (and tracer if nn_acc=0)
nn_baro
=
64
! number of barotropic time step
("key_dynspg_ts")

14.4. Accelerating the Convergence (nn acc = 1)

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.

!
!

asselin time filter parameter


acceleration of convergence : =1
used, rdt < rdttra(k)
!
=0, not used, rdt = rdttra
! minimum time step on tracers (used if nn_acc=1)
! maximum time step on tracers (used if nn_acc=1)
! depth variation of tracer time step (used if nn_acc=1)

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

Accuracy and Reproducibility (lib fortran.F90)

14.5.1

Issues with intrinsinc SIGN function (key nosignedzero)


The SIGN(A, B) is the F ORTRAN intrinsic function delivers the magnitude of A with
the sign of B. For example, SIGN(-3.0,2.0) has the value 3.0. The problematic case is
when the second argument is zero, because, on platforms that support IEEE arithmetic,
zero is actually a signed number. There is a positive zero and a negative zero.
In F ORTRAN 90, the processor was required always to deliver a positive result for
SIGN(A, B) if B was zero. Nevertheless, in F ORTRAN 95, the processor is allowed to do
the correct thing and deliver ABS(A) when B is a positive zero and -ABS(A) when B
is a negative zero. This change in the specification becomes apparent only when B is of
type real, and is zero, and the processor is capable of distinguishing between positive and
negative zero, and B is negative real zero. Then SIGN delivers a negative result where,
under F ORTRAN 90 rules, it used to return a positive result. This change may be especially
sensitive for the ice model, so we overwrite the intrinsinc function with our own function
simply performing :
IF( B >= 0.e0 ) THEN
;
SIGN(A,B) = ABS(A)
ELSE
;
SIGN(A,B) =-ABS(A)
ENDIF
This feature can be found in lib fortran.F90 module and is effective when key nosignedzero
is defined. We use a CPP key as the overwritting of a intrinsic function can present performance issues with some computers/compilers.

14.6. Model Optimisation, Control Print and Benchmark

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

Model Optimisation, Control Print and Benchmark


!----------------------------------------------------------------------&namctl
!
Control prints & Benchmark
!----------------------------------------------------------------------ln_ctl
= .false.
! trends control print (expensive!)
nn_print
=
0
! level of print (0 no extra print)
nn_ictls
=
0
! start i indice of control sum (use to compare mono versus
nn_ictle
=
0
! end
i indice of control sum
multi processor runs
nn_jctls
=
0
! start j indice of control
over a subdomain)
nn_jctle
=
0
! end
j indice of control
nn_isplt
=
1
! number of processors in i-direction
nn_jsplt
=
1
! number of processors in j-direction
nn_bench
=
0
! Bench mode (1/0): CAUTION use zero except for bench
!
(no physical validity of the results)
/

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

Elliptic solvers (SOL)


!----------------------------------------------------------------------&namsol
!
elliptic solver / island / free surface
!----------------------------------------------------------------------nn_solv
=
1
! elliptic solver: =1 preconditioned conjugate gradient (pcg)
!
=2 successive-over-relaxation (sor)
nn_sol_arp =
0
! absolute/relative (0/1) precision convergence test
rn_eps
= 1.e-6
! absolute precision of the solver
nn_nmin
=
300
! minimum of iterations for the SOR solver
nn_nmax
=
800
! maximum of iterations for the SOR solver
nn_nmod
=
10
! frequency of test for the SOR solver
rn_resmax
= 1.e-10
! absolute precision for the SOR solver
rn_sor
= 1.92
! optimal coefficient for SOR solver (to be adjusted with the domain)
/

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 .

14.7. Elliptic solvers (SOL)

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)

the resulting five-point finite difference equation is given by :


S
EW
NS
EW
cN
i+1,j Di+1,j + ci,j+1 Di,j+1 + ci,j Di1,j + ci,j Di,j1

S
EW
NS
EW
cN
Di,j = bi,j
i+1,j + ci,j+1 + ci,j + ci,j

(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

Successive Over Relaxation (nn solv=2, solsor.F90)


Let us introduce the four cardinal coefficients :
S
aSi,j = cN
i,j /di,j

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

iteration n, from n = 0 until convergence, do :


n+1
n
n
E
n
S
W n+1
n

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)

where satisfies 1 2. An optimal value exists for which significantly accelerates


the convergence, but it has to be adjusted empirically for each model domain (except for
a uniform grid where an analytical expression for can be found [Richtmyer and Morton
1967]). The value of is set using rn sor, a namelist parameter. The convergence test is
of the form :
P n n
Ri,j Ri,j
i,j

= 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. Elliptic solvers (SOL)

14.7.2

237

Preconditioned Conjugate Gradient (nn solv=1, solpcg.F90)


A is a definite positive symmetric matrix, thus solving the linear system (14.3) is
equivalent to the minimisation of a quadratic functional :
Ax = b x = infy (y) ,

(y) = 1/2hAy, yi hb, yi

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

, the initial guess

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

Water column model : 1D model (C1D) (key c1d)


The 1D model option simulates a stand alone water column within the 3D NEMO
system. It can be applied to the ocean alone or to the ocean-ice system and can include
passive tracers or a biogeochemical model. It is set up by defining the key c1d CPP key.
The 1D model is a very useful tool (a) to learn about the physics and numerical treatment
of vertical mixing processes ; (b) to investigate suitable parameterisations of unresolved
turbulence (surface wave breaking, Langmuir circulation, ...) ; (c) to compare the behaviour of different vertical mixing schemes ; (d) to perform sensitivity studies on the vertical diffusion at a particular point of an ocean domain ; (d) to produce extra diagnostics,
without the large memory requirement of the full 3D model.
The methodology is based on the use of the zoom functionality over the smallest
possible domain : a 3 x 3 domain centred on the grid point of interest (see 14.3), with
some extra routines. There is no need to define a new mesh, bathymetry, initial state or
forcing, since the 1D model will use those of the configuration it is a zoom of. The chosen
grid point is set in par oce.F90 module by setting the jpizoom and jpjzoom parameters to
the indices of the location of the chosen grid point.
The 1D model has some specifies. First, all the horizontal derivatives are assumed
to be zero. Therefore a simplified step routine is used (step c1d) in which both lateral
tendancy terms and lateral physics are not called, and the vertical velocity is zero (so far,
no attempt at introducing a Ekman pumping velocity has been made). Second, the two
components of the velocity are moved on a T -point. This requires a specific treatment of
the Coriolis term (see dyncor c1d) and of the dynamic time stepping (dynnxt c1d). All
the relevant modules can be found in the NEMOGCM/NEMO/OPA SRC/C1D directory
of the NEMO distribution.

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

ORCA tripolar grid


The ORCA grid is a tripolar is based on the semi-analytical method of Madec and
Imbard [1996]. It allows to construct a global orthogonal curvilinear ocean mesh which
has no singularity point inside the computational domain since two north mesh poles are
introduced and placed on lands. The method involves defining an analytical set of mesh
parallels in the stereographic polar plan, computing the associated set of mesh meridians,
and projecting the resulting mesh onto the sphere. The set of mesh parallels used is a series
of embedded ellipses which foci are the two mesh north poles (Fig. 15.1). The resulting
mesh presents no loss of continuity in either the mesh lines or the scale factors, or even
the scale factor derivatives over the whole ocean domain, as the mesh is not a composite
mesh.
The method is applied to Mercator grid (i.e. same zonal and meridional grid spacing)
poleward of 20N, so that the Equator is a mesh line, which provides a better numerical
solution for equatorial dynamics. The choice of the series of embedded ellipses (position
of the foci and variation of the ellipses) is a compromise between maintaining the ratio
of mesh anisotropy (e1 /e2 ) close to one in the ocean (especially in area of strong eddy
activities such as the Gulf Stream) and keeping the smallest scale factor in the northern
hemisphere larger than the smallest one in the southern hemisphere. The resulting mesh
is shown in Fig. 15.1 and 15.2 for a half a degree grid (ORCA R05). The smallest ocean
scale factor is found in along Antarctica, while the ratio of anisotropy remains close to
one except near the Victoria Island in the Canadian Archipelago.

15.3.2

ORCA pre-defined resolution


The NEMO system is provided with five built-in ORCA configurations which differ in
the horizontal resolution. The value of the resolution is given by the resolution at the Equator expressed in degrees. Each of configuration is set through a CPP key, key orca rX
(with X being an indicator of the resolution), which set the grid size and configuration
name parameters (Tab. 15.1). .
The ORCA R2 configuration has the following specificity : starting from a 2 ORCA
mesh, local mesh refinements were applied to the Mediterranean, Red, Black and Caspian

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

GYRE family : double gyre basin (key gyre)


The GYRE configuration [Levy et al. 2010] have been built to simulated the seasonal
cycle of a double-gyre box model. It consist in an idealized domain similar to that used
in the studies of Drijfhout [1994] and Hazeleger and Drijfhout [1998; 1999; 2000b;a],
over which an analytical seasonal forcing is applied. This allows to investigate the spontaneous generation of a large number of interacting, transient mesoscale eddies and their
contribution to the large scale circulation.
The domain geometry is a closed rectangular basin on the -plane centred at 30N
and rotated by 45, 3180 km long, 2120 km wide and 4 km deep (Fig. 14.1). The domain
is bounded by vertical walls and by a at bottom. The configuration is meant to represent
an idealized North Atlantic or North Pacific basin. The circulation is forced by analytical
profiles of wind and buoyancy uxes. The applied forcings vary seasonally in a sinusoidal
manner between winter and summer extrema [Levy et al. 2010]. The wind stress is zonal

15.5. EEL family : periodic channel

245

F IG . 15.3 Snapshot of relative vorticity at the surface of the model domain in


GYRE R9, R27 and R54. From Levy et al. [2010].

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

EEL family : periodic channel


key eel r2 to be described....
key eel r5

246
key eel r6

15.6

POMME : mid-latitude sub-domain


key pomme r025 : to be described....

Configurations

A Curvilinear sCoordinate Equations

Contents
A.1
A.2
A.3
A.4

Chain rule of scoordinate . . . . . .


Continuity Equation in scoordinate
Momentum Equation in scoordinate
Tracer Equation . . . . . . . . . . . .

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

248
248
250
254

Curvilinear sCoordinate Equations

248

A.1

Chain rule of scoordinate


In order to establish the set of Primitive Equation in curvilinear scoordinates (i.e. an
orthogonal curvilinear coordinate in the horizontal and an Arbitrary Lagrangian Eulerian
(ALE) coordinate in the vertical), we start from the set of equations established in 2.3.2
for the special case k = z and thus e3 = 1, and we introduce an arbitrary vertical coordinate a = a(i, j, z, t). Let us define a new vertical scale factor by e3 = z/s (which now
depends on (i, j, z, t)) and the horizontal slope of ssurfaces by :

1 z
1 =
e1 i s

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)

Continuity Equation in scoordinate


Using (A.2) and the fact that the horizontal scale factors e1 and e2 do not depend
on the vertical coordinate, the divergence of the velocity relative to the (i,j,z) coordinate system is transformed as follows in order to obtain its expression in the curvilinear

A.2. Continuity Equation in scoordinate

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 ]

Here, w is the vertical velocity relative to the zcoordinate system. Introducing


the dia-surface velocity component, , defined as the velocity relative to the moving
ssurfaces and normal to them :
= w ws 1 u 2 v

(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

As a result, the continuity equation (2.1c) in the scoordinates is :





1 e3
1
(e2 e3 u)
(e1 e3 v)
1
+
+
+
=0


e3 t
e1 e2 e3
i
j
e3 s
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.

Curvilinear sCoordinate Equations

250

A.3

Momentum Equation in scoordinate


Here we only consider the first component of the momentum equation, the generalization to the second one being straightforward.

Total derivative in vector invariant form


Let us consider (2.17), the first component of the momentum
equation in the vector

can be transformed as follows
invariant form. Its total zcoordinate time derivative, Du
Dt z
in order to obtain its expression in the curvilinear scoordinate system :
Du
Dt z

+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

introducing the chain rule (A.2)




h
i

(e2 v)
(e1 u)
(e2 v)
(e1 u)
e1
e2
1

+
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

Introducing , the dia-a-surface velocity given by (A.5)




2
2
+ | v + 1 (u +v ) + 1 ( ws ) u
= u
s
t z
2 e1
i
e3
s
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

A.3. Momentum Equation in scoordinate

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.

Total derivative in flux form


Let us start from the total time derivative in the curvilinear scoordinate system we
have just establish. Following the procedure used to establish (2.15), it can be transformed
into :
Du
Dt s

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

Curvilinear sCoordinate Equations

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.

horizontal pressure gradient


The horizontal pressure gradient term can be transformed as follows :




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

Therefore, p and p0h are linked through :


p = o p0h + g (z + )
and the hydrostatic pressure balance expressed in terms of p0h and d is :
p0h
= d g e3
k

(A.13)

A.3. Momentum Equation in scoordinate

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.

The other terms of the momentum equation


The coriolis and forcing terms as well as the the vertical physics remain unchanged as
they involve neither time nor space derivatives. The form of the lateral physics is discussed
in appendix B.

Full momentum equation


To sum up, in a curvilinear s-coordinate system, the vector invariant momentum equation solved by the model has the same mathematical expression as the one in a curvilinear
zcoordinate, but the pressure gradient term :

u
1
1 u
= + ( + f ) v
u2 + v 2
t
2 e1 i
e3 k


z
g
1 p0h

+g d

+ DuU + FuU (A.15a)


e1 i
i
e1 i

v
1
1 v
= ( + f ) u
u2 + v 2
t
2 e2 j
e3 k


1 p0h
z
g
+g d

+ DvU + FvU (A.15b)

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

+ DuU + FuU (A.16a)


e1 i
i
e1 i

254

Curvilinear sCoordinate Equations




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.

B Appendix B : Diffusive Operators

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

Appendix B : Diffusive Operators

Horizontal/Vertical 2nd Order Tracer Diffusive Operators


In the z-coordinate, the horizontal/vertical second order tracer diffusion operator is
given by :
 i
h 



e2 lT T
e1 lT T

+
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

B.1. Horizontal/Vertical 2nd Order Tracer Diffusive Operators

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

using the same remark as just above, it becomes :


h



e2 e3 lT T

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

Appendix B : Diffusive Operators

Iso/diapycnal 2nd Order Tracer Diffusive Operators


The iso/diapycnal diffusive tensor AI expressed in the (i,j,k) curvilinear coordinate
system in which the equations of the ocean circulation model are formulated, takes the
following form [Redi 1982] :

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. Lateral/Vertical Momentum Diffusive Operators

B.3

259

Lateral/Vertical Momentum Diffusive Operators


The second order momentum diffusion operator (Laplacian) in the z-coordinate is
found by applying (2.11e), the expression for the Laplacian of a vector, to the horizontal
velocity vector :
Uh = ( Uh ) ( Uh )

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.

C Discrete Invariants of the Equations

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

Discrete Invariants of the Equations

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

volume of cells at u-, v-, and T -points :


bu = e1u e2u e3u

bv = e1v e2v e3v

bt = e1t e2t e3t

partial derivative notation : =


dv = e1 e2 e3 di dj dk is the volume element, with only e3 that depends on time. D
and S are the ocean domain volume and surface, respectively. No wetting/drying is allow
(i.e. S
t = 0) Let ks and kb be the ocean surface and bottom, resp. (i.e. s(ks ) = and
s(kb ) = H, where H is the bottom depth).
s
k=k
Z

dk =
e3 (k)

z(k) =

k=k

Zks

e3 dk

Continuity equation with the above notation :




1
1
t (e3t ) +
i [U ] + j [V ] + k [W ] = 0
e3t
bt
A quantity, Q is conserved when its domain averaged time change is zero, that is
when :
Z

t
Q dv = 0
D

Noting that the coordinate system used .... blah blah


Z
 Z
Z
t
Q dv =
t (e3 Q) e1 e2 di dj dk =
D

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

C.2. Continuous conservation

263

that is in a more compact form :


Z
t
D

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

that is in a more compact form :


 Z
Z
Z
1
1 2
1 2
Q dv =
Q t Q dv +
t
Q t e3 dv
2
2
e
D
D 3
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

Discrete Invariants of the Equations

advection term (flux form) :


Z
1
(v i e2 u j e1 ) (k Uh ) Uh dv = 0
e1 e2

(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)

where h = |k is the gradient along the s-surfaces.


blah blah....
The prognostic ocean dynamics equation can be summarized as follows :


VOR + KEG + ZAD
NXT =
+ HPG + SPG + LDF + ZDF
COR + ADV

Vector invariant form :

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)

C.2. Continuous conservation

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

Discrete Invariants of the Equations

introducing the hydrostatic balance k p = g e3 in the last term, it becomes :


Z
=

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

Discrete total energy conservation : vector invariant


form

C.3.1

Total energy conservation


The discrete form of the total energy conservation, (C.3), is given by :


2
X u2
v
t
bu +
bv + g zt bt = 0
2
2
i,j,k

which in vector invariant forms, it leads to :


X
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

Vorticity term (coriolis + vorticity part of the advection)


Let q, located at f -points, be either the relative (q = /e3f ), or the planetary (q =
f /e3f ), or the total potential vorticity (q = (+f )/e3f ). Two discretisation of the vorticity
term (ENE and EEN) allows the conservation of the kinetic energy.

C.3. Discrete total energy conservation : vector invariant form

267

Vorticity Term with ENE scheme (ln dynvor ene=.true.)


For the ENE scheme, the two components of the vorticity term are given by :

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.

Vorticity Term with EEN scheme (ln dynvor een=.true.)


With the EEN scheme, the vorticity terms are represented as :

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

Discrete Invariants of the Equations

This formulation does conserve the total kinetic energy. Indeed,


Z
Uh ( k Uh ) dv
D

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

Expending the summation on ip and kp , it becomes :

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

ij+1 Q1/2 Uj+1

+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

C.3. Discrete total energy conservation : vector invariant form

269

Gradient of Kinetic Energy / Vertical Advection


The change of Kinetic Energy (KE) due to the vertical advection is exactly balanced
by the change of KE due to the horizontal gradient of KE :
Z

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

, or at least that the time derivative of these


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

Discrete Invariants of the Equations

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

which is (over-)satified by defining the vertical scale factor as follows :


1
e e e i+1/2
e1u e2u 1t 2t 3t
1
e e e j+1/2
=
e1v e2v 1t 2t 3t

e3u =

(C.10)

e3v

(C.11)

Blah blah required on the the step representation of bottom topography.....

C.3.3

Pressure Gradient Term


When the equation of state is linear (i.e. when an advection-diffusion equation for
density can be derived from those of temperature and salinity) the change of KE due to
the work of pressure forces is balanced by the change of potential energy due to buoyancy
forces :
Z
Z
Z

p|z Uh dv =
( U) g z dv +
g t (z) dv
D

C.3. Discrete total energy conservation : vector invariant form

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

Discrete Invariants of the Equations


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

therefore, the balance to be satisfied is :



 X
X
pw t (bw )
pt t (bt )
i,j,k

i,j,k

which is a purely vertical balance :


 X

X
pt t (e3t )
pw t (e3w )
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

Discrete total energy conservation : flux form

C.4.1

Total energy conservation


The discrete form of the total energy conservation, (C.3), is given by :


2
X u2
v
t
bu +
bv + g zt bt = 0
2
2
i,j,k

which in flux form, it leads to :





X u (e3u u)
v (e3v v)
1 X u2 e3u
v 2 e3v
bu +
bv
bu +
bv
e3u
t
e3v
t
2
e3u t
e3v t
i,j,k
i,j,k
 X

X 1 e3t
zt
=
g zt bt
g
bt
e3 t t
t
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. Discrete total energy conservation : flux form

C.4.2

273

Coriolis and advection terms : flux form


Coriolis plus metric Term
In flux from the vorticity term reduces to a Coriolis term in which the Coriolis parameter has been modified to account for the metric term. This altered Coriolis parameter
is discretised at an f-point. It is given by :



1
e2
1  i+1/2
e1
f+
v
f+
u
v
i+1/2 [e2u ] u j+1/2 j+1/2 [e1u ]
e1 e2
i
j
e1f e2f
Either the ENE or EEN scheme is then applied to obtain the vorticity term in flux
form. It therefore conserves the total KE. The derivation is the same as for the vorticity
term in the vector invariant form (C.3.2).

Flux form advection


The flux form operator of the momentum advection is evaluated using a centered
second order finite difference scheme. Because of the flux form, the discrete operator
does not contribute to the global budget of linear momentum. Because of the centered
second order scheme, it conserves the horizontal kinetic energy, that is :


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
+

Discrete Invariants of the Equations


X1
i,j,k

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

which is the discrete form of 2 D u (U u) dv. (C.12) is thus satisfied.


When the UBS scheme is used to evaluate the flux form momentum advection, the
discrete operator does not contribute to the global budget of linear momentum (flux form).
The horizontal kinetic energy is not conserved, but forced to decay (i.e. the scheme is
diffusive).

C.5

Discrete enstrophy conservation


Vorticity Term with ENS scheme (ln dynvor ens=.true.)
In the ENS scheme, the vorticity term is descretized as follows :

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

C.5. Discrete enstrophy conservation

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

12 q 2 e1t e2t e3t

i+1/2,j+1/2

The later equality is obtain only when the flow is horizontally non-divergent, i.e. =0.

Vorticity Term with EEN scheme (ln dynvor een=.true.)


With the EEN scheme, the vorticity terms are represented as :

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

Discrete Invariants of the Equations

X
i,j,k

i+1/2, j+1/2
1 i +1/2 2
j Q+1/2
bt
2

C.6

Conservation Properties on Tracers


All the numerical schemes used in NEMO are written such that the tracer content is
conserved by the internal dynamics and physics (equations in flux form). For advection,
only the CEN2 scheme (i.e. 2nd order finite different scheme) conserves the global variance of tracer. Nevertheless the other schemes ensure that the global variance decreases
(i.e. they are at least slightly diffusive). For diffusion, all the schemes ensure the decrease
of the total tracer variance, except the iso-neutral operator. There is generally no strict
conservation of mass, as the equation of state is non linear with respect to T and S. In
practice, the mass is conserved to a very high accuracy.

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

C.7. Conservation Properties on Lateral Momentum Physics

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

which is the discrete form of

C.7

1
2

R
D

3
T 2 e13 e
t dv.

Conservation Properties on Lateral Momentum Physics


The discrete formulation of the horizontal diffusion of momentum ensures the conservation of potential vorticity and the horizontal divergence, and the dissipation of the square
of these quantities (i.e. enstrophy and the variance of the horizontal divergence) as well as
the dissipation of the horizontal kinetic energy. In particular, when the eddy coefficients
are horizontally uniform, it ensures a complete separation of vorticity and horizontal divergence fields, so that diffusion (dissipation) of vorticity (enstrophy) does not generate
horizontal divergence (variance of the horizontal divergence) and vice versa.
These properties of the horizontal diffusion operator are a direct consequence of properties (4.9) and (4.10). When the vertical curl of the horizontal diffusion of momentum
(discrete sense) is taken, the term associated with the horizontal gradient of the divergence
is locally zero.

C.7.1

Conservation of Potential Vorticity


The lateral momentum diffusion term conserves the potential vorticity :
Z
h 


i
1
k h A lm h A lm k dv = 0
e3
D

278
Z

Discrete Invariants of the Equations


h

i
1
lm
k h A k dv
e3

=
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

Using (4.11), it follows :

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

Dissipation of Horizontal Kinetic Energy


The lateral momentum diffusion term dissipates the horizontal kinetic energy :
Z
Uh [h



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

ATlm 2 e1t e2t e3t Aflm 2 e1f e2f e3f

C.7. Conservation Properties on Lateral Momentum Physics

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

Using (4.11), it follows :

A lm

(
X 
i,j,k

1
i [e3f ]
e1v e3v

2


bv +

2 )
1
j [e3f ] bu
e2u e3u

C.7.4

Conservation of Horizontal Divergence


When the horizontal divergence of the horizontal diffusion of momentum (discrete
sense) is taken, the term associated with the vertical curl of the vorticity is zero locally,
due to ( ! ! ! II.1.8 ! ! ! ! !). The resulting term conserves the and dissipates 2 when the
eddy coefficients are horizontally uniform.
Z

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

Using (4.11), it follows :

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

Discrete Invariants of the Equations

Dissipation of Horizontal Divergence Variance


Z

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

Using (4.11), it turns out to be :


(
2

2 )
X  1
1
A lm

[] bu +

[] bv
e1u i+1/2
e2v j+1/2
i,j,k

C.8

Conservation Properties on Vertical Momentum Physics


As for the lateral momentum physics, the continuous form of the vertical diffusion
of momentum satisfies several integral constraints. The first two are associated with the
conservation of momentum and the dissipation of horizontal kinetic energy :


Z
1 A vm Uh
dv
= ~0
e3 k
e3 k
D

and
Z
Uh

1
e3 k

A vm Uh
e3 k


dv

The first property is obvious. The second results from :


Z

1
Uh
e3 k

A vm Uh
e3 k


dv

 vm

 vm


X
Au
Av

u k

[u] e1u e2u + v k

[v] e1v e2v


e3uw k+1/2
e3vw k+1/2
i,j,k

C.8. Conservation Properties on Vertical Momentum Physics

281

since the horizontal scale factor does not depend on k, it follows :

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

The vorticity is also conserved. Indeed :


Z

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

This property is only satisfied in z-coordinates :




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

Discrete Invariants of the Equations


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

Similarly, the horizontal divergence is obviously conserved :

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

This property is only satisfied in the z-coordinate :




1
e3 k

A vm Uh
e3 k


dv

C.9. Conservation Properties on Tracer Physics

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

k+1/2 i+1/2 [e2u u] + j+1/2 [e1v v]

i

X 1

[] k+1/2 [e1t e2t ]


e3w k+1/2
i,j,k

A vm

X e1t e2t
i,j,k

C.9

e3w

2
k+1/2 []

Conservation Properties on Tracer Physics


The numerical schemes used for tracer subgridscale physics are written such that the
heat and salt contents are conserved (equations in flux form, second order centered finite
differences). Since a flux form is used to compute the temperature and salinity, the quadratic form of these quantities (i.e. their variance) globally tends to diminish. As for the
advection term, there is generally no strict conservation of mass, even if in practice the
mass is conserved to a very high accuracy.

284

C.9.1

Discrete Invariants of the Equations

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

Dissipation of Tracer Variance


constraint on the dissipation of tracer variance :
Z
T (A T ) dv
D

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

[T ] e1u e2u e3u


e1u i+1/2

2
1
lT
+ Av

[T ] e1v e2v e3v


e2v j+1/2
2


1
vT

[T ] e1w e2w e3w


+ Aw
e3w k+1/2

AulT

D Coding Rules

Contents
D.1
D.2
D.3
D.4

The program structure


Coding conventions . .
Naming Conventions . .
The program structure

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

.
.
.
.

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

The program structure


Each program begins with a set of headline comments containing :
- the program title
- the purpose of the routine
- the method and algorithms used
- the detail of input and output interfaces
- the external routines and functions used (if they exist)
- references (if they exist)
- the author name(s), the date of creation and any updates.
- Each program is split into several well separated sections and sub-sections with an
underlined title and specific labelled statements.
- A program has not more than 200 to 300 lines.
A template of a module style can be found on the NEMO depository in the following
file : NEMO/OPA SRC/module example.

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.

D.2. Coding conventions

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

character structure double


precision
c
s
d
but not
but not
but not
cp cd
sd sd
dp dd
cl cn
sl sn
dl dn

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. The program structure

D.4

The program structure


To be done....

289

E Griffiess iso-neutral diffusion

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

Griffiess formulation of iso-neutral diffusion

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

Griffiess iso-neutral diffusion

and in the k-direction resulting from the lateral tracer gradients


r1

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 standard discretization


The straightforward approach to discretize the lateral skew flux (E.1) from tracer cell
i, k to i + 1, k, introduced in 1995 into OPA, (5.10), is to calculate a mean vertical gradient at the u-point from the average of the four surrounding vertical tracer gradients,
and multiply this by a mean slope at the u-point, calculated from the averaged surrounding vertical density gradients. The total area-integrated skew-flux from tracer cell i, k to
i + 1, k, noting that the e3uk
in the area e3uk
e2uk
at the u-point cancels out with
i+1/2

the 1/e3uk

i+1/2

i+1/2

i+1/2

associated with the vertical tracer gradient, is then (5.10)




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

E.1. Griffiess formulation of iso-neutral diffusion

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

Expression of the skew-flux in terms of triad slopes


[Griffies et al. 1998] introduce a different discretization of the off-diagonal terms
that nicely solves the problem. They get the skew flux from the products of the vertical

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

Griffiess iso-neutral diffusion

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

E.1. Griffiess formulation of iso-neutral diffusion


s0i in (E.4) and (E.5) in this notation, we have e.g. s1 = s01 =

295
k R1/2 .
i 1/2

Each triad slope

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.g. in (E.4) a1 = ki Au 1/2 , and in (E.5) a01 = ki Aw 1/2 .

E.1.4

The full triad fluxes


A key property of isoneutral diffusion is that it should not affect the (locally referenced) density. In particular there should be no lateral or vertical density flux. The lateral
density flux disappears so long as the area-integrated lateral diffusive flux from tracer cell
i, k to i + 1, k coming from the 11 term of the diffusion tensor takes the form
 k



T
k
i+1/2
Fu11 i+ 1 = k+1
a1 + k+1
a2 + ki a3 + ki a4
,
(E.7)
i
i
k
2
e1u i+1/2
where the areas ai are as in (E.4). In this case, separating the total lateral flux, the sum of
(E.4) and (E.7), into triad components, a lateral tracer flux
!
i
i+ip [T k ]
kp
kp
k kp k+kp [T ]
k
kk
i R ip
(E.8)
i Fu ip (T ) = Ai i Au ip
k+k
e1u ki+ip
e3w i p
k+k

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

Fu ipp () = ik ki Fu ipp (T ) + ik ki Fu ipp (S) = 0


(E.9)
i
i
Thus the total flux Fu31 i,k+ 1 + Fu11 i,k+ 1 from tracer cell i, k to i + 1, k must also
2
2
vanish since it is a sum of four such triad fluxes.
The squared slope r12 in the expression (E.3) for the 33 component is also expressed
in terms of area-weighted squared triad slopes, so the area-integrated vertical flux from
tracer cell i, k to i, k + 1 resulting from the r12 term is


k+ 1
 i+1 
k+1 0 02
k 0 02
Fw33 i 2 = k+1
a01 s02
a2 s2 + ki a03 s02
, (E.10)
1 + i
3 + i a4 s4 k+ 1 T
i
2

where the areas a0

and slopes s0

are the same as in (E.5). Then, separating the total vertical


flux, the sum of (E.5) and (E.10), into triad components, a vertical flux
!
i]

2
k]
[T

[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

Griffiess iso-neutral diffusion


k

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

Ensuring the scheme cannot increase tracer variance


We now require that this operator cannot increase the globally-integrated tracer vak
k
riance. Each triad slope ki Ripp drives a lateral flux ki Fu ipp (T ) across the u-point i + ip , k
k

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

and ki Fw ipp (T ) with (E.8) and (E.11), it is


(
Aki

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)

E.1. Griffiess formulation of iso-neutral diffusion

297

the variance tendency reduces to the perfect square


k
Aki ki Vipp

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

and the gradient




k+k
T = i+ip [T k ]/e1u ki+ip , k+kp [T i ]/e3w i p

E.1.6

Triad volumes in Griffess scheme and in NEMO


k

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

e1w ki+1/2 e1v ki+1/2


e1u ki+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

Griffiess iso-neutral diffusion

Summary of the scheme


The divergence of the expression (E.13) for the fluxes gives the iso-neutral diffusion
tendency at each tracer point :
DlT =

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

The property is demonstrated in E.1.5 above. It is a key property for a diffusion


term. It means that it is also a dissipation term, i.e. it is a diffusion of the square
of the quantity on which it is applied. It therefore ensures that, when the diffusivity
coefficient is large enough, the field on which it is applied become free of grid-point
noise.

E.2. Eddy induced velocity and Skew flux formulation

299

self-adjoint operator The iso-neutral diffusion operator is self-adjoint, i.e.


X
X S

Dl T bT
S DlT bT =
i,j,k

(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

Eddy induced velocity and Skew flux formulation


When Gent and McWilliamss [1990] diffusion is used (key traldf eiv defined), an
additional advection term is added. The associated velocity is the so called eddy induced
velocity, the formulation of which depends on the slopes of iso- neutral surfaces. Contrary
to the case of iso-neutral mixing, the slopes used here are referenced to the geopotential
surfaces, i.e. (9.2) is used in z-coordinate, and the sum (9.2) + (9.3) in z or s-coordinates.
The eddy induced velocity is given by :
1
k (e2 Ae ri )
e2 e3
1
k (e1 Ae rj )
v =
e1 e3
1
w =
{i (e2 Ae ri ) + j (e1 Ae rj )}
e1 e2
u =

(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

Griffiess iso-neutral diffusion

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. Eddy induced velocity and Skew flux formulation

E.2.1

301

Discrete Invariants of the skew flux formulation


Demonstration for the conservation of the tracer variance in the (i,j) plane.
This have to be moved in an Appendix.
The continuous property to be demonstrated is :
Z
Feiv (T ) T dv 0
D

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

apply the adjoint of delta operator, it becomes


(

XX
k
e2u ki+ip +1/2 Ae ki+ip +1/2 ki+ip +1/2 Rip p

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

k+k +1/2 k+kp +1/2 kp


Ae i p
R ip
i

i+ip [T

k+kp +1/2


] k+1/2 [Ti ]

Expending the summation on ip and kp , it becomes :


Pn
1/2
+e2u ki+1 Ae ki+1 ki+1 R1/2 k1/2 [Ti+1 ] i+1/2 [T k ]
i,k

+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 ]

k+1/2 [Ti+1 ] i+1/2 [T k ]


k+1/2 [Ti

] i+1/2 [T k ]

i1/2 [T k+1 ] k+1/2 [Ti ]


i1/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

eel r5, 245


eel r6, 246
esopa, 234
floats, 201
gyre, 244, 245
iomput, 200
lim2, 131
lim3, 131
mpp mpi, 51, 140, 149
mpp rep, 233
netcdf4, 197, 198, 200
nosignedzero, 232
noslip accurate, 137
oasis3, 124
oasis4, 124
obc, 143
orca r025, 242
orca r05, 158, 228, 242
orca r1, 242
orca r2, 158, 228, 242
orca r4, 242
orca rX, 241, 242
pisces, 125

INDEX
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key
key

303

pomme r025, 246


subbasins.nc, 201
top, 125
Model parameters
trabbl, 81, 82, 166
cp cfg, 242
tradmp, 85
jp cfg, 242, 245
traldf c1d, 156, 157
jperio, 55, 57, 137
traldf c2d, 156158
jphgr mesh, 54, 55
traldf c3d, 156, 158
jpi,
140, 230
traldf eiv, 158, 163, 299
jpidta, 230
trddvor, 200
jpieob, 144
trddyn, 94, 200
jpiglo, 51, 140, 144, 230, 234, 242, 245
trdmld, 200
jpind, 144
trdmld trc, 201
jpinf, 144
trdtra, 66, 200
jpisd, 144
trdtrc, 201
jpisf, 144
trdvor, 94, 200
jpiwob, 144
vectopt loop, 233
jpizoom, 230, 240
vvl, 56, 57, 62, 67, 77, 96, 103
jpj, 140, 149, 230
106, 111, 127, 174, 204, 235
jpjdta, 230
key zdfcst, 166
jpjed, 144, 149
key zdfddm, 76, 180
jpjef, 144, 149
key zdfgls, 174, 176, 179
jpjglo, 51, 140, 144, 230, 234, 245
key zdfkpp, 176
jpjnob, 144
key zdfric, 167
jpjsob, 144
key zdftke, 167, 172, 179
jpjwd, 144
key zdftmx, 186
jpjwf, 144
jpjzoom, 230, 240
h90 file
jpk, 51, 56, 5860, 140, 145, 230, 245
domzgr substitute, 57
jpkdta, 230
ldfdyn antarctic, 158
jpkglo, 230
ldfdyn arctic, 158
jpni, 140, 142
ldfdyn substitute, 157
jpnij, 140, 142
ldftra substitute, 157
jpnj, 140, 142
par GYRE, 245
jpreci, 140
traldf c1d, 157
jpwd, 145
Input NetCDF files
jpwf, 145
bathy level.nc, 57
lk vvl, 86
bathy meter.nc, 57, 58
lp obc east, 144
bfr coef.nc, 183
lp obc west, 146
coordinates.nc, 54
pp to be computed, 60
ctlsurf idx.nc, 200
ppa0, 60
geothermal heating.nc, 81
ppa1, 60
mask itf.nc, 187
ppacr, 60
restart mld.nc, 200
ppacr=0, 58

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

dyn frs, 151


dynadv cen2, 101
dynadv ubs, 101, 159
dynhpg djc, 104
dynhpg hel, 104
dynhpg imp, 104, 105
dynhpg rot, 104
dynhpg sco, 104
dynhpg vec, 111
dynhpg wdj, 104
dynhpg zco, 103
dynhpg zps, 103
dynldf bilap, 102, 109, 159
dynldf hor, 108, 159
dynldf iso, 108
dynldf lap, 102, 108, 159
dynvor een, 97, 267, 275
dynvor ene, 97, 267
dynvor ens, 97, 274
dynvor mix, 97
ena, 209
flork4, 201
flx, 114, 122, 127, 128, 130
flxqsr, 78
grid global, 209
grid search lookup, 209
lc, 171
length lim, 176
lsurf, 171
nc4zip, 198
obc clim, 146
qsr 2bd, 79
qsr bio, 79
qsr rgb, 79
ref apr, 125
rnf, 114
rnf depth, 126
rnf sal, 126
rnf temp, 126
s3d, 209
sco, 57, 62, 159
ssr, 114
subbas, 201

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

Eiseman, P. R. and A. P. Stone, 1980 : Conservation lows of fluid dynamics a survey.


SIAM Review, 22, 1227.
Emile-Geay, J. and G. Madec, 2009 : Geothermal heating, diapycnal mixing and the abyssal circulation. Ocean Sc., 5, 281325.
Engerdahl, H., 1995 : Use of the flow relaxation scheme in a three-dimensional baroclinic
ocean model with realistic topography. Tellus, 47A, 365382.
Farge, M., 1987 : Dynamique non lineaire des ondes et des tourbillons dans les equations
de saint venant. Ph.D. thesis, Doctorat es Mathematiques, Paris VI University.
Farrow, D. E. and D. P. Stevens, 1995 : A new tracer advection scheme for bryancox type
ocean general circulation models. J. Phys. Oceanogr., 25, 17311741.
Flather, R., 1994 : A storm surge prediction model for the northern bay of bengal with
application to the cyclone disaster in april 1991. J. Phys. Oceanogr., 24, 172190.
Fujio, S. and N. Imasato, 1991 : Diagnostic calculation for circulation and water mass
movement in the deep pacific. J. Geophys. Res, 96, 759774.
Galperin, B., L. H. Kantha, S. Hassid, and A. Rosati, 1988 : A quasi-equilibrium turbulent
energy model for geophysical flows. J. Atmos. Sc., 45, 5562.
Gargett, A. E., 1984 : Vertical eddy diffusivity in the ocean interior. J. Mar. Res., 42.
Gaspar, P., Y. Gregoris, and J.-M. Lefevre, 1990 : A simple eddy kinetic energy model for
simulations of the oceanic vertical mixing Tests at station papa and long-term upper
ocean study site. J. Geophys. Res, 95 (C9).
Gent, P. R. and J. C. Mcwilliams, 1990 : Isopycnal mixing in ocean circulation models. J.
Phys. Oceanogr., 20 (1), 150155.
Gerdes, R., 1993a : A primitive equation ocean circulation model using a general vertical
coordinate transformation 1. description and testing of the model. J. Geophys. Res, 98.
, 1993b : A primitive equation ocean circulation model using a general vertical
coordinate transformation 2. application to an overflow problem. J. Geophys. Res, 98,
14 70314 726.
Gibson, J. K., 1986 : Standard software development and maintenance. Tech. rep., Operational Dep., ECMWF, Reading, UK.
Gill, A. E., 1982 : Atmosphere-Ocean Dynamics. International Geophysics Series, Academic Press, New-York.

314

BIBLIOGRAPHIE

Goosse, H., E. Deleersnijder, T. Fichefet, and M. England, 1999 : Sensitivity of a global


coupled ocean-sea ice model to the parameterization of vertical mixing. J. Geophys.
Res, 104, 13,68113,695.
Greatbatch, R. J., 1994 : A note on the representation of steric sea level in models that
conserve volume rather than mass. J. Geophys. Res, 99 (C6), 12,76712,771.
Griffies, S., 1998 : The gent-mcwilliams skew-flux. J. Phys. Oceanogr., 28, 831841.
, 2004 : Fundamentals of ocean climate models. Princeton University Press,
434pp.
Griffies, S., A. Biastoch, C. Boning, F. Bryan, G. Danabasoglu, E. P. Chassignet, M. H.
England, R. Gerdes, H. Haak, R. W. Hallberg, W. Hazeleger, J. Jungclaus, W. G. Large,
G. Madec, A. Pirani, B. L. Samuels, M. Scheinert, A. S. Gupta, C. A. Severijns, H. L.
Simmons, A.-M. Treguier, M. Winton, S. Yeager, and J. Yin, 2009 : Coordinated oceanice reference experiments (cores). Ocean Modelling, 26 (1-2), 146, doi :10.1016/j.
ocemod.2008.08.007, URL http://dx.doi.org/.
Griffies, S., A. Gnanadesikan, K. Dixon, J. Dunne, R. Gerdes, M. Harrison, A. Rosati,
J. Russell, B. Samuels, M. Spelman, M. Winton, and R. Zhang, 2005 : Formulation of
an ocean model for global climate simulations. Ocean Sc., 1, 4579.
Griffies, S., A. Gnanadesikan, R. Pacanowski, V. Larichev, J. Dukowicz, and R. Smith,
1998 : Isoneutral diffusion in a z-coordinate ocean model. J. Phys. Oceanogr., 28 (5),
805830.
Griffies, S., R. Pacanowski, M. Schmidt, and V. Balaji, 2001 : Tracer conservation with an
explicit free surface method for z-coordinate ocean models. Mon. Wea. Rev., 129 (5),
10811098.
Guilyardi, E., G. Madec, and L. Terray, 2001 : The role of lateral ocean physics in the
upper ocean thermal balance of a coupled ocean-atmosphere gcm. Clim. Dyn., 17 (8),
589599.
Haltiner, G. J. and R. T. Williams, 1980 : Numerical prediction and dynamic meteorology.
John Wiley & Sons Eds., second edition, 477pp pp.
Haney, R. L., 1991 : On the pressure gradient force over steep topography in sigma coordinate ocean models. J. Phys. Oceanogr., 21 (4), 610619.
Hazeleger, W. and S. S. Drijfhout, 1998 : Mode water variability in a model of the subtropical gyre : response to anomalous forcing. J. Phys. Oceanogr., 28, 266288.
, 1999 : Stochastically forced mode water variability. J. Phys. Oceanogr., 29,
17721786.

BIBLIOGRAPHIE

315

, 2000a : Eddy subduction in a model of the subtropical gyre. J. Phys. Oceanogr.,


30, 677695.
, 2000b : A model study on internally generated variability in subtropical mode
water formation. J. Geophys. Res, 105, 13,96513,979.
He, Y. and C. H. Q. Ding, 2001 : Using accurate arithmetics to improve numerical reproducibility and stability in parallel applications. J. Supercomputing., 18, 259277.
Hirt, C. W., A. A. Amsden, and J. L. Cook, 1974 : An arbitrary lagrangianeulerian computing method for all flow speeds. J. Comput. Phys., 14, 227253.
Hofmeister, R., H. Burchard, and J.-M. Beckers, 2009 : Non-uniform adaptive
vertical grids for 3d numerical ocean models. Ocean Modelling, 33, 7086,
doi :10.1016/j.ocemod.2009.12.003, URL http://dx.doi.org/10.1016/j.
ocemod.2009.12.003.
Huang, R., 1993 : Real freshwater flux as a natural boundary condition for the salinity
balance and thermohaline circulation forced by evaporation and precipitation. J. Phys.
Oceanogr., 23, 24282446.
Jackett, D. R. and T. J. McDougall, 1995 : Minimal adjustment of hydrographic data to
achieve static stability. J. Atmos. Ocean Tech., 12, 381389.
Jones, P. W., 1998 : A users guide for scrip : A spherical coordinate remapping and
interpolation package. version 1.4. Tech. rep., Los Alamos National Laboratory, URL
http://climate.lanl.gov/Software/SCRIP/SCRIPusers.pdf.
Kantha, L. and S. Carniel, 2005 : Comment on generic length-scale equation for geophysical turbulence models by l. umlauf and h. burchard. J. Mar. Sys., 61, 693702.
Kantha, L. H. and C. A. Clayson, 1994 : An improved mixed layer model for geophysical
applications. J. Geophys. Res, 99, 25,23525,266.
Kasahara, A., 1974 : Various vertical coordinate systems used for numerical weather prediction. Mon. Wea. Rev., 102, 509522.
Killworth, P., D. Stainforth, D. Webb, and S. Paterson, 1991 : The development of a freesurface bryan-cox-semtner ocean model. J. Phys. Oceanogr., 21 (9), 13331348.
Killworth, P. D., 1989 : On the parameterization of deep convection in ocean models. Parameterization of small-scale processes, winter workshop, H., Ed., University of Hawaii at Manoa.
, 1992 : An equivalent-barotropic mode in the fine resolution antarctic model. J.
Phys. Oceanogr., 22, 13791387.

316

BIBLIOGRAPHIE

Koch-Larrouy, A., M. Lengaigne, P. Terray, G. Madec, and S. Masson, 2010 : Tidal


mixing in the indonesian seas and its effect on the tropical climate system. Clim. Dyn.,
34 (6), 891904, doi :10.1007/s00382-009-0642-4, URL http://dx.doi.org/
10.1007/s00382-009-0642-4.
Koch-Larrouy, A., G. Madec, B. Blanke, and R. Molcard, 2008a : Water mass transformation along the indonesian throughflow in an ogcm. Ocean Dyn., 58 (3-4), 289
309, doi :10.1007/s10236-008-0155-4, URL http://dx.doi.org/10.1007/
s10236-008-0155-4.
Koch-Larrouy, A., G. Madec, P. Bouruet-Aubertot, T. Gerkema, L. Bessieres, and R. Molcard, 2007 : Tidal mixing in the indonesian seas and its effect on the tropical climate system. Geophys. Res. Let., 34, L04 604, doi :10.1029/2006GL028405, URL
http://dx.doi.org/10.1029/2006GL028405.
Koch-Larrouy, A., G. Madec, D. Iudicone, A. Atmadipoera, and R. Molcard, 2008b :
Physical processes contributing to the water mass transformation of the indonesian
throughflow. Ocean Dyn., 58 (3-4), 275288, doi :10.1007/s10236-008-0154-5, URL
http://dx.doi.org/10.1007/s10236-008-0154-5.
Kolmogorov, A. N., 1942 : The equation of turbulent motion in an incompressible fluid.
Izv. Akad. Nauk SSSR, Ser. Fiz., 6, 5658.
Large, W. G., J. C. McWilliams, and S. C. Doney, 1994 : Oceanic vertical mixing - a
review and a model with a nonlocal boundary layer parameterization. Reviews of Geophysics, 32, 363404, doi :10.1029/94RG01872, URL http://dx.doi.org/10.
1029/94RG01872.
Large, W. G. and S. Yeager, 2004 : Diurnal to decadal global forcing for ocean and seaice models : the data sets and flux climatologies. NCAR Technical Note, NCAR/TN460+STR, CGD Division of the National Center for Atmospheric Research.
Lazar, A., 1997 : La branche froide de la circulation thermohaline - sensibilite a` la diffusion turbulente dans un mod`ele de circulation generale idealisee. Ph.D. thesis, Universite Pierre et Marie Curie, Paris, France, 200pp.
Lazar, A., G. Madec, and P. Delecluse, 1999 : The deep interior downwelling, the veronis
effect, and mesoscale tracer transport parameterizations in an ogcm. J. Phys. Oceanogr.,
29 (11), 29452961.
Le Sommer, J., T. Penduff, S. Theetten, G. Madec, and B. Barnier, 2009 : How momentum advection schemes influence current-topography interactions at eddy permitting
resolution. Ocean Modelling, 29 (1), 114, doi :10.1016/j.ocemod.2008.11.007, URL
http://dx.doi.org/10.1016/j.ocemod.2008.11.007.
Leclair, M., 2010 : introduction dune coordonnee verticale arbitrairement lagrangienne
eulerienne dans le code nemo, 180pp. Ph.D. thesis, Universite Pierre and Marie Curie.

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

UNESCO, 1983 : Algorithms for computation of fundamental property of sea water.


Techn. Paper in Mar. Sci, 44, UNESCO.
Valcke, S., 2006 : Oasis3 user guide (prism 2-5). Tech. rep., PRISM Support Initiative
Report No 3, CERFACS, Toulouse, France.
Vancoppenolle, M., T. Fichefet, and H. Goosse, 2009a : Simulating the mass balance and
salinity of arctic and antarctic sea ice. 2. importance of sea ice salinity variations. Ocean
Modelling, 27, 5469.
Vancoppenolle, M., T. Fichefet, H. Goosse, S. Bouillon, G. Madec, and M. A. M.
Maqueda, 2009b : Simulating the mass balance and salinity of arctic and antarctic sea ice. 1. model description and validation. Ocean Modelling, 27, 3353,
doi :10.1016/j.ocemod.2008.10.005, URL http://dx.doi.org/10.1016/j.
ocemod.2008.10.005.
Warner, J. C., C. R. Sherwood, H. G. Arango, and R. P. Signell, 2005 : Performance of four
turbulence closure models implemented using a generic length scale method. Ocean
Modelling, 8, 81113, doi :10.1016/j.ocemod.2003.12.003, URL http://dx.doi.
org/j.ocemod.2003.12.003.
Weatherly, G. L., 1984 : An estimate of bottom frictional dissipation by gulf stream fluctuations. J. Mar. Res., 42 (2), 289301.
Weaver, A. J. and M. Eby, 1997 : On the numerical implementation of advection schemes
for use in conjuction with various mixing parameterizations in the gfdl ocean model. J.
Phys. Oceanogr., 27.
Webb, D. J., B. A. de Cuevas, and C. S. Richmond, 1998 : Improved advection schemes
for ocean models. J. Atmos. Ocean Tech., 15 (5), 11711187.
White, L., A. Adcroft, and R. Hallberg, 2009 : High-order regridding-remapping schemes
for continuous isopycnal and generalized coordinates in ocean models. J. Climate, 228,
86658692.
Wilcox, D. C., 1988 : Reassessment of the scale-determining equation for advanced turbulence models. AIAA journal, 26 (11), 12991310.
Willebrand, J., B. Barnier, C. Boning, C. Dieterich, P. D. Killworth, C. L. Provost,
Y. Jia, J.-M. Molines, and A. L. New, 2001 : Circulation characteristics in three eddypermitting models of the north atlantic. Prog. Oceangr., 48 (2), 123161.
Zalesak, S. T., 1979 : Fully multidimensional flux corrected transport algorithms for
fluids. J. Comput. Phys., 31.
Zhang, R.-H. and M. Endoh, 1992 : A free surface general circulation model for the
tropical pacific ocean. J. Geophys. Res, 97, 11,23711,255.

You might also like