New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
chap_misc.tex in NEMO/trunk/doc/latex/NEMO/subfiles – NEMO

source: NEMO/trunk/doc/latex/NEMO/subfiles/chap_misc.tex @ 11582

Last change on this file since 11582 was 11582, checked in by nicolasmartin, 5 years ago

New LaTeX commands \nam and \np to mention namelist content (step 2)
Finally convert \forcode{...} following \np{}{} into optional arg of the new command \np[]{}{}

File size: 22.5 KB
Line 
1\documentclass[../main/NEMO_manual]{subfiles}
2
3\onlyinsubfile{\makeindex}
4
5\begin{document}
6% ================================================================
7% Chapter --- Miscellaneous Topics
8% ================================================================
9\chapter{Miscellaneous Topics}
10\label{chap:MISC}
11
12\chaptertoc
13
14\newpage
15
16% ================================================================
17% Representation of Unresolved Straits
18% ================================================================
19\section{Representation of unresolved straits}
20\label{sec:MISC_strait}
21
22In climate modeling, it often occurs that a crucial connections between water masses is broken as
23the grid mesh is too coarse to resolve narrow straits.
24For example, coarse grid spacing typically closes off the Mediterranean from the Atlantic at
25the Strait of Gibraltar.
26In this case, it is important for climate models to include the effects of salty water entering the Atlantic from
27the Mediterranean.
28Likewise, it is important for the Mediterranean to replenish its supply of water from the Atlantic to
29balance the net evaporation occurring over the Mediterranean region.
30This problem occurs even in eddy permitting simulations.
31For example, in ORCA 1/4\deg\ several straits of the Indonesian archipelago (Ombai, Lombok...)
32are much narrow than even a single ocean grid-point.
33
34We describe briefly here the two methods that can be used in \NEMO\ to handle such
35improperly resolved straits. The methods consist of opening the strait while ensuring
36that the mass exchanges through the strait are not too large by either artificially
37reducing the cross-sectional area of the strait grid-cells or, locally increasing the
38lateral friction.
39
40% -------------------------------------------------------------------------------------------------------------
41%       Hand made geometry changes
42% -------------------------------------------------------------------------------------------------------------
43\subsection{Hand made geometry changes}
44\label{subsec:MISC_strait_hand}
45
46The first method involves reducing the scale factor in the cross-strait direction to a
47value in better agreement with the true mean width of the strait
48(\autoref{fig:MISC_strait_hand}).  This technique is sometime called "partially open face"
49or "partially closed cells".  The key issue here is only to reduce the faces of $T$-cell
50(\ie\ change the value of the horizontal scale factors at $u$- or $v$-point) but not the
51volume of the $T$-cell.  Indeed, reducing the volume of strait $T$-cell can easily produce
52a numerical instability at that grid point which would require a reduction of the model
53time step.  Thus to instigate a local change in the width of a Strait requires two steps:
54
55\begin{itemize}
56
57\item Add \texttt{e1e2u} and \texttt{e1e2v} arrays to the \np{cn_domcfg}{cn\_domcfg} file. These 2D
58arrays should contain the products of the unaltered values of: $\texttt{e1u}*\texttt{e2u}$
59and $\texttt{e1u}*\texttt{e2v}$ respectively. That is the original surface areas of $u$-
60and $v$- cells respectively.  These areas are usually defined by the corresponding product
61within the \NEMO\ code but the presence of \texttt{e1e2u} and \texttt{e1e2v} in the
62\np{cn_domcfg}{cn\_domcfg} file will suppress this calculation and use the supplied fields instead.
63If the model domain is provided by user-supplied code in \mdl{usrdef\_hgr}, then this
64routine should also return \texttt{e1e2u} and \texttt{e1e2v} and set the integer return
65argument \texttt{ie1e2u\_v} to a non-zero value. Values other than 0 for this argument
66will suppress the calculation of the areas.
67
68\item Change values of \texttt{e2u} or \texttt{e1v} (either in the \np{cn_domcfg}{cn\_domcfg} file or
69via code in  \mdl{usrdef\_hgr}), whereever a Strait reduction is required. The choice of
70whether to alter \texttt{e2u} or \texttt{e1v} depends. respectively,  on whether the
71Strait in question is North-South orientated (\eg\ Gibraltar) or East-West orientated (\eg
72Lombok).
73
74\end{itemize}
75
76The second method is to increase the viscous boundary layer thickness by a local increase
77of the fmask value at the coast. This method can also be effective in wider passages.  The
78concept is illustarted in the second part of  \autoref{fig:MISC_strait_hand} and changes
79to specific locations can be coded in \mdl{usrdef\_fmask}. The \forcode{usr_def_fmask}
80routine is always called after \texttt{fmask} has been defined according to the choice of
81lateral boundary condition as discussed in \autoref{sec:LBC_coast}. The default version of
82\mdl{usrdef\_fmask} contains settings specific to ORCA2 and ORCA1 configurations. These are
83meant as examples only; it is up to the user to verify settings and provide alternatives
84for their own configurations. The default \forcode{usr_def_fmask} makes no changes to
85\texttt{fmask} for any other configuration.
86
87%>>>>>>>>>>>>>>>>>>>>>>>>>>>>
88\begin{figure}[!tbp]
89  \centering
90  \includegraphics[width=0.66\textwidth]{Fig_Gibraltar}
91  \includegraphics[width=0.66\textwidth]{Fig_Gibraltar2}
92  \caption[Two methods to defined the Gibraltar strait]{
93    Example of the Gibraltar strait defined in a 1\deg\ $\times$ 1\deg\ mesh.
94    \textit{Top}: using partially open cells.
95    The meridional scale factor at $v$-point is reduced on both sides of the strait to
96    account for the real width of the strait (about 20 km).
97    Note that the scale factors of the strait $T$-point remains unchanged.
98    \textit{Bottom}: using viscous boundary layers.
99    The four fmask parameters along the strait coastlines are set to a value larger than 4,
100    \ie\ "strong" no-slip case (see \autoref{fig:LBC_shlat}) creating a large viscous boundary layer
101    that allows a reduced transport through the strait.}
102  \label{fig:MISC_strait_hand}
103\end{figure}
104%>>>>>>>>>>>>>>>>>>>>>>>>>>>>
105
106%>>>>>>>>>>>>>>>>>>>>>>>>>>>>
107\begin{figure}[!tbp]
108  \centering
109  \includegraphics[width=0.66\textwidth]{Fig_closea_mask_example}
110  \caption[Mask fields for the \protect\mdl{closea} module]{
111    Example of mask fields for the \protect\mdl{closea} module.
112    \textit{Left}: a closea\_mask field;
113    \textit{Right}: a closea\_mask\_rnf field.
114    In this example, if \protect\np{ln_closea}{ln\_closea} is set to \forcode{.true.},
115    the mean freshwater flux over each of the American Great Lakes will be set to zero,
116    and the total residual for all the lakes, if negative, will be put into
117    the St Laurence Seaway in the area shown.}
118  \label{fig:MISC_closea_mask_example}
119\end{figure}
120%>>>>>>>>>>>>>>>>>>>>>>>>>>>>
121
122% ================================================================
123% Closed seas
124% ================================================================
125\section[Closed seas (\textit{closea.F90})]{Closed seas (\protect\mdl{closea})}
126\label{sec:MISC_closea}
127
128Some configurations include inland seas and lakes as ocean
129points. This is particularly the case for configurations that are
130coupled to an atmosphere model where one might want to include inland
131seas and lakes as ocean model points in order to provide a better
132bottom boundary condition for the atmosphere. However there is no
133route for freshwater to run off from the lakes to the ocean and this
134can lead to large drifts in the sea surface height over the lakes. The
135closea module provides options to either fill in closed seas and lakes
136at run time, or to set the net surface freshwater flux for each lake
137to zero and put the residual flux into the ocean.
138
139Prior to \NEMO\ 4 the locations of inland seas and lakes was set via
140hardcoded indices for various ORCA configurations. From \NEMO\ 4 onwards
141the inland seas and lakes are defined using mask fields in the
142domain configuration file. The options are as follows.
143
144\begin{enumerate}
145\item{{\bfseries No ``closea\_mask'' field is included in domain configuration
146  file.} In this case the closea module does nothing.}
147
148\item{{\bfseries A field called closea\_mask is included in the domain
149configuration file and ln\_closea=.false. in namelist namcfg.} In this
150case the inland seas defined by the closea\_mask field are filled in
151(turned to land points) at run time. That is every point in
152closea\_mask that is nonzero is set to be a land point.}
153
154\item{{\bfseries A field called closea\_mask is included in the domain
155configuration file and ln\_closea=.true. in namelist namcfg.} Each
156inland sea or group of inland seas is set to a positive integer value
157in the closea\_mask field (see \autoref{fig:MISC_closea_mask_example}
158for an example). The net surface flux over each inland sea or group of
159inland seas is set to zero each timestep and the residual flux is
160distributed over the global ocean (ie. all ocean points where
161closea\_mask is zero).}
162
163\item{{\bfseries Fields called closea\_mask and closea\_mask\_rnf are
164included in the domain configuration file and ln\_closea=.true. in
165namelist namcfg.} This option works as for option 3, except that if
166the net surface flux over an inland sea is negative (net
167precipitation) it is put into the ocean at specified runoff points. A
168net positive surface flux (net evaporation) is still spread over the
169global ocean. The mapping from inland seas to runoff points is defined
170by the closea\_mask\_rnf field. Each mapping is defined by a positive
171integer value for the inland sea(s) and the corresponding runoff
172points. An example is given in
173\autoref{fig:MISC_closea_mask_example}. If no mapping is provided for a
174particular inland sea then the residual is spread over the global
175ocean.}
176
177\item{{\bfseries Fields called closea\_mask and closea\_mask\_emp are
178included in the domain configuration file and ln\_closea=.true. in
179namelist namcfg.} This option works the same as option 4 except that
180the nonzero net surface flux is sent to the ocean at the specified
181runoff points regardless of whether it is positive or negative. The
182mapping from inland seas to runoff points in this case is defined by
183the closea\_mask\_emp field.}
184\end{enumerate}
185
186There is a python routine to create the closea\_mask fields and append
187them to the domain configuration file in the utils/tools/DOMAINcfg directory.
188
189% ================================================================
190% Sub-Domain Functionality
191% ================================================================
192\section{Sub-domain functionality}
193\label{sec:MISC_zoom}
194
195\subsection{Simple subsetting of input files via NetCDF attributes}
196
197The extended grids for use with the under-shelf ice cavities will result in redundant rows
198around Antarctica if the ice cavities are not active.  A simple mechanism for subsetting
199input files associated with the extended domains has been implemented to avoid the need to
200maintain different sets of input fields for use with or without active ice cavities.  This
201subsetting operates for the j-direction only and works by optionally looking for and using
202a global file attribute (named: \np{open_ocean_jstart}{open\_ocean\_jstart}) to determine the starting j-row
203for input.  The use of this option is best explained with an example:
204\medskip
205
206\noindent Consider an ORCA1
207configuration using the extended grid domain configuration file: \ifile{eORCA1\_domcfg.nc}
208This file define a horizontal domain of 362x332.  The first row with
209open ocean wet points in the non-isf bathymetry for this set is row 42 (\fortran\ indexing)
210then the formally correct setting for \np{open_ocean_jstart}{open\_ocean\_jstart} is 41.  Using this value as
211the first row to be read will result in a 362x292 domain which is the same size as the
212original ORCA1 domain.  Thus the extended domain configuration file can be used with all
213the original input files for ORCA1 if the ice cavities are not active (\np{ln\_isfcav =
214.false.}).  Full instructions for achieving this are:
215
216\begin{itemize}
217\item  Add the new attribute to any input files requiring a j-row offset, i.e:
218\begin{cmds}
219ncatted  -a open_ocean_jstart,global,a,d,41 eORCA1_domcfg.nc
220\end{cmds}
221
222\item Add the logical switch \np{ln_use_jattr}{ln\_use\_jattr} to \nam{cfg}{cfg} in the configuration
223namelist (if it is not already there) and set \forcode{.true.}
224\end{itemize}
225
226\noindent Note that with this option, the j-size of the global domain is (extended
227j-size minus \np{open_ocean_jstart}{open\_ocean\_jstart} + 1 ) and this must match the \texttt{jpjglo} value
228for the configuration. This means an alternative version of \ifile{eORCA1\_domcfg.nc} must
229be created for when \np{ln_use_jattr}{ln\_use\_jattr} is active. The \texttt{ncap2} tool provides a
230convenient way of achieving this:
231
232\begin{cmds}
233ncap2 -s 'jpjglo=292' eORCA1_domcfg.nc nORCA1_domcfg.nc
234\end{cmds}
235
236The domain configuration file is unique in this respect since it also contains the value of \jp{jpjglo}
237that is read and used by the model.
238Any other global, 2D and 3D, netcdf, input field can be prepared for use in a reduced domain by adding the
239\texttt{open\_ocean\_jstart} attribute to the file's global attributes.
240In particular this is true for any field that is read by \NEMO\ using the following optional argument to
241the appropriate call to \np{iom_get}{iom\_get}.
242
243\begin{forlines}
244lrowattr=ln_use_jattr
245\end{forlines}
246
247Currently, only the domain configuration variables make use of this optional argument so
248this facility is of little practical use except for tests where no other external input
249files are needed or you wish to use an extended domain configuration with inputs from
250earlier, non-extended configurations. Alternatively, it should be possible to exclude
251empty rows for extended domain, forced ocean runs using interpolation on the fly, by
252adding the optional argument to \texttt{iom\_get} calls for the weights and initial
253conditions. Experimenting with this remains an exercise for the user.
254
255% ================================================================
256% Accuracy and Reproducibility
257% ================================================================
258\section[Accuracy and reproducibility (\textit{lib\_fortran.F90})]{Accuracy and reproducibility (\protect\mdl{lib\_fortran})}
259\label{sec:MISC_fortran}
260
261\subsection[Issues with intrinsinc SIGN function (\texttt{\textbf{key\_nosignedzero}})]{Issues with intrinsinc SIGN function (\protect\key{nosignedzero})}
262\label{subsec:MISC_sign}
263
264The SIGN(A, B) is the \fortran\ intrinsic function delivers the magnitude of A with the sign of B.
265For example, SIGN(-3.0,2.0) has the value 3.0.
266The problematic case is when the second argument is zero, because, on platforms that support IEEE arithmetic,
267zero is actually a signed number.
268There is a positive zero and a negative zero.
269
270In \fninety, the processor was required always to deliver a positive result for SIGN(A, B) if B was zero.
271Nevertheless, in \fninety, the processor is allowed to do the correct thing and deliver ABS(A) when
272B is a positive zero and -ABS(A) when B is a negative zero.
273This change in the specification becomes apparent only when B is of type real, and is zero,
274and the processor is capable of distinguishing between positive and negative zero,
275and B is negative real zero.
276Then SIGN delivers a negative result where, under \fninety\ rules, it used to return a positive result.
277This change may be especially sensitive for the ice model,
278so we overwrite the intrinsinc function with our own function simply performing :   \\
279\verb?   IF( B >= 0.e0 ) THEN   ;   SIGN(A,B) = ABS(A)  ?    \\
280\verb?   ELSE                   ;   SIGN(A,B) =-ABS(A)     ?  \\
281\verb?   ENDIF    ? \\
282This feature can be found in \mdl{lib\_fortran} module and is effective when \key{nosignedzero} is defined.
283We use a CPP key as the overwritting of a intrinsic function can present performance issues with
284some computers/compilers.
285
286
287\subsection{MPP reproducibility}
288\label{subsec:MISC_glosum}
289
290The numerical reproducibility of simulations on distributed memory parallel computers is a critical issue.
291In particular, within \NEMO\ global summation of distributed arrays is most susceptible to rounding errors,
292and their propagation and accumulation cause uncertainty in final simulation reproducibility on
293different numbers of processors.
294To avoid so, based on \citet{he.ding_JS01} review of different technics,
295we use a so called self-compensated summation method.
296The idea is to estimate the roundoff error, store it in a buffer, and then add it back in the next addition.
297
298Suppose we need to calculate $b = a_1 + a_2 + a_3$.
299The following algorithm will allow to split the sum in two
300($sum_1 = a_{1} + a_{2}$ and $b = sum_2 = sum_1 + a_3$) with exactly the same rounding errors as
301the sum performed all at once.
302\begin{align*}
303   sum_1 \ \  &= a_1 + a_2 \\
304   error_1     &= a_2 + ( a_1 - sum_1 ) \\
305   sum_2 \ \  &= sum_1 + a_3 + error_1 \\
306   error_2     &= a_3 + error_1 + ( sum_1 - sum_2 ) \\
307   b \qquad \ &= sum_2 \\
308\end{align*}
309An example of this feature can be found in \mdl{lib\_fortran} module.
310It is systematicallt used in glob\_sum function (summation over the entire basin excluding duplicated rows and
311columns due to cyclic or north fold boundary condition as well as overlap MPP areas).
312The self-compensated summation method should be used in all summation in i- and/or j-direction.
313See \mdl{closea} module for an example.
314Note also that this implementation may be sensitive to the optimization level.
315
316\subsection{MPP scalability}
317\label{subsec:MISC_mppsca}
318
319The default method of communicating values across the north-fold in distributed memory applications (\key{mpp\_mpi})
320uses a \textsc{MPI\_ALLGATHER} function to exchange values from each processing region in
321the northern row with every other processing region in the northern row.
322This enables a global width array containing the top 4 rows to be collated on every northern row processor and then
323folded with a simple algorithm.
324Although conceptually simple, this "All to All" communication will hamper performance scalability for
325large numbers of northern row processors.
326From version 3.4 onwards an alternative method is available which only performs direct "Peer to Peer" communications
327between each processor and its immediate "neighbours" across the fold line.
328This is achieved by using the default \textsc{MPI\_ALLGATHER} method during initialisation to
329help identify the "active" neighbours.
330Stored lists of these neighbours are then used in all subsequent north-fold exchanges to
331restrict exchanges to those between associated regions.
332The collated global width array for each region is thus only partially filled but is guaranteed to
333be set at all the locations actually required by each individual for the fold operation.
334This alternative method should give identical results to the default \textsc{ALLGATHER} method and
335is recommended for large values of \np{jpni}{jpni}.
336The new method is activated by setting \np{ln_nnogather}{ln\_nnogather} to be true (\nam{mpp}{mpp}).
337The reproducibility of results using the two methods should be confirmed for each new,
338non-reference configuration.
339
340% ================================================================
341% Model optimisation, Control Print and Benchmark
342% ================================================================
343\section{Model optimisation, control print and benchmark}
344\label{sec:MISC_opt}
345%--------------------------------------------namctl-------------------------------------------------------
346
347\begin{listing}
348  \nlst{namctl}
349  \caption{\forcode{&namctl}}
350  \label{lst:namctl}
351\end{listing}
352%--------------------------------------------------------------------------------------------------------------
353
354Options are defined through the  \nam{ctl}{ctl} namelist variables.
355
356\subsection{Vector optimisation}
357
358\key{vectopt\_loop} enables the internal loops to collapse.
359This is very a very efficient way to increase the length of vector calculations and thus
360to speed up the model on vector computers.
361
362% Add here also one word on NPROMA technique that has been found useless, since compiler have made significant progress during the last decade.
363
364% Add also one word on NEC specific optimisation (Novercheck option for example)
365
366\subsection{Control print}
367
368The \np{ln_ctl}{ln\_ctl} switch was originally used as a debugging option in two modes:
369
370\begin{enumerate}
371\item{\np{ln_ctl}{ln\_ctl}: compute and print the trends averaged over the interior domain in all TRA, DYN, LDF and
372ZDF modules.
373This option is very helpful when diagnosing the origin of an undesired change in model results. }
374
375\item{also \np{ln_ctl}{ln\_ctl} but using the nictl and njctl namelist parameters to check the source of differences between
376mono and multi processor runs.}
377\end{enumerate}
378
379However, in recent versions it has also been used to force all processors to assume the
380reporting role. Thus when \np{ln_ctl}{ln\_ctl} is true all processors produce their own versions
381of files such as: ocean.output, layout.dat, etc.  All such files, beyond the the normal
382reporting processor (narea == 1), are named with a \_XXXX extension to their name, where
383XXXX is a 4-digit area number (with leading zeros, if required). Other reporting files
384such as run.stat (and its netCDF counterpart: run.stat.nc) and tracer.stat contain global
385information and are only ever produced by the reporting master (narea == 1). For version
3864.0 a start has been made to return \np{ln_ctl}{ln\_ctl} to its original function by introducing
387a new control structure which allows finer control over which files are produced. This
388feature is still evolving but it does already allow the user to: select individually the
389production of run.stat and tracer.stat files and to toggle the production of other files
390on processors other than the reporting master. These other reporters can be a simple
391subset of processors as defined by a minimum, maximum and incremental processor number.
392
393Note, that production of the run.stat and tracer.stat files require global communications.
394For run.stat, these are global min and max operations to find metrics such as the gloabl
395maximum velocity. For tracer.stat these are global sums of tracer fields. To improve model
396performance these operations are disabled by default and, where necessary, any use of the
397global values have been replaced with local calculations. For example, checks on the CFL
398criterion are now done on the local domain and only reported if a breach is detected.
399
400Experienced users may wish to still monitor this information as a check on model progress.
401If so, the best compromise will be to activate the files with:
402
403\begin{verbatim}
404     sn_cfctl%l_config = .TRUE.
405       sn_cfctl%l_runstat = .TRUE.
406       sn_cfctl%l_trcstat = .TRUE.
407\end{verbatim}
408
409and to use the new time increment setting to ensure the values are collected and reported
410at a suitably long interval. For example:
411
412\begin{verbatim}
413       sn_cfctl%ptimincr  = 25
414\end{verbatim}
415
416will carry out the global communications and write the information every 25 timesteps. This
417increment also applies to the time.step file which is otherwise updated every timestep.
418
419% ================================================================
420\onlyinsubfile{\bibliography{../main/bibliography}}
421
422\onlyinsubfile{\printindex}
423
424\end{document}
Note: See TracBrowser for help on using the repository browser.