1 | MODULE step_oce |
---|
2 | !!====================================================================== |
---|
3 | !! *** MODULE step_oce *** |
---|
4 | !! Ocean time-stepping : module used in both initialisation phase and time stepping |
---|
5 | !!====================================================================== |
---|
6 | !! History : 3.3 ! 2010-08 (C. Ethe) Original code - reorganisation of the initial phase |
---|
7 | !!---------------------------------------------------------------------- |
---|
8 | USE oce ! ocean dynamics and tracers variables |
---|
9 | USE dom_oce ! ocean space and time domain variables |
---|
10 | USE zdf_oce ! ocean vertical physics variables |
---|
11 | USE ldftra_oce ! ocean tracer - trends |
---|
12 | USE ldfdyn_oce ! ocean dynamics - trends |
---|
13 | USE in_out_manager ! I/O manager |
---|
14 | USE iom ! |
---|
15 | USE lbclnk |
---|
16 | |
---|
17 | USE daymod ! calendar (day routine) |
---|
18 | |
---|
19 | USE sbcmod ! surface boundary condition (sbc routine) |
---|
20 | USE sbcrnf ! surface boundary condition: runoff variables |
---|
21 | USE sbccpl ! surface boundary condition: coupled formulation (call send at end of step) |
---|
22 | USE cpl_oasis3, ONLY : lk_cpl |
---|
23 | |
---|
24 | USE traqsr ! solar radiation penetration (tra_qsr routine) |
---|
25 | USE trasbc ! surface boundary condition (tra_sbc routine) |
---|
26 | USE trabbc ! bottom boundary condition (tra_bbc routine) |
---|
27 | USE trabbl ! bottom boundary layer (tra_bbl routine) |
---|
28 | USE tradmp ! internal damping (tra_dmp routine) |
---|
29 | USE traadv ! advection scheme control (tra_adv_ctl routine) |
---|
30 | USE traldf ! lateral mixing (tra_ldf routine) |
---|
31 | ! zdfkpp ! KPP non-local tracer fluxes (tra_kpp routine) |
---|
32 | USE trazdf ! vertical mixing (tra_zdf routine) |
---|
33 | USE tranxt ! time-stepping (tra_nxt routine) |
---|
34 | USE tranpc ! non-penetrative convection (tra_npc routine) |
---|
35 | |
---|
36 | USE eosbn2 ! equation of state (eos_bn2 routine) |
---|
37 | |
---|
38 | USE dynadv ! advection (dyn_adv routine) |
---|
39 | USE dynbfr ! Bottom friction terms (dyn_bfr routine) |
---|
40 | USE dynvor ! vorticity term (dyn_vor routine) |
---|
41 | USE dynhpg ! hydrostatic pressure grad. (dyn_hpg routine) |
---|
42 | USE dynldf ! lateral momentum diffusion (dyn_ldf routine) |
---|
43 | USE dynzdf ! vertical diffusion (dyn_zdf routine) |
---|
44 | USE dynspg_oce ! surface pressure gradient (dyn_spg routine) |
---|
45 | USE dynspg ! surface pressure gradient (dyn_spg routine) |
---|
46 | USE dynnxt ! time-stepping (dyn_nxt routine) |
---|
47 | |
---|
48 | USE obc_par ! open boundary condition variables |
---|
49 | USE obcdta ! open boundary condition data (obc_dta routine) |
---|
50 | USE obcrst ! open boundary cond. restart (obc_rst routine) |
---|
51 | USE obcrad ! open boundary cond. radiation (obc_rad routine) |
---|
52 | |
---|
53 | USE bdy_par ! unstructured open boundary data variables |
---|
54 | USE bdydta ! unstructured open boundary data (bdy_dta routine) |
---|
55 | |
---|
56 | USE sshwzv ! vertical velocity and ssh (ssh_wzv routine) |
---|
57 | |
---|
58 | USE ldfslp ! iso-neutral slopes (ldf_slp routine) |
---|
59 | USE ldfeiv ! eddy induced velocity coef. (ldf_eiv routine) |
---|
60 | |
---|
61 | USE zdftmx ! tide-induced vertical mixing (zdf_tmx routine) |
---|
62 | USE zdfbfr ! bottom friction (zdf_bfr routine) |
---|
63 | USE zdftke ! TKE vertical mixing (zdf_tke routine) |
---|
64 | USE zdfgls ! GLS vertical mixing (zdf_gls routine) |
---|
65 | USE zdfkpp ! KPP vertical mixing (zdf_kpp routine) |
---|
66 | USE zdfddm ! double diffusion mixing (zdf_ddm routine) |
---|
67 | USE zdfevd ! enhanced vertical diffusion (zdf_evd routine) |
---|
68 | USE zdfric ! Richardson vertical mixing (zdf_ric routine) |
---|
69 | USE zdfmxl ! Mixed-layer depth (zdf_mxl routine) |
---|
70 | |
---|
71 | USE zpshde ! partial step: hor. derivative (zps_hde routine) |
---|
72 | |
---|
73 | USE diawri ! Standard run outputs (dia_wri routine) |
---|
74 | USE trdicp ! Ocean momentum/tracers trends (trd_wri routine) |
---|
75 | USE trdmld ! mixed-layer trends (trd_mld routine) |
---|
76 | USE trdmld_rst ! restart for mixed-layer trends |
---|
77 | USE trdmod_oce ! ocean momentum/tracers trends |
---|
78 | USE trdmod ! momentum/tracers trends |
---|
79 | USE trdvor ! vorticity budget (trd_vor routine) |
---|
80 | USE diaptr ! poleward transports (dia_ptr routine) |
---|
81 | USE diaar5 ! AR5 diagnosics (dia_ar5 routine) |
---|
82 | USE diahth ! thermocline depth (dia_hth routine) |
---|
83 | USE diafwb ! freshwater budget (dia_fwb routine) |
---|
84 | USE diahsb ! heat, salt and volume budgets (dia_hsb routine) |
---|
85 | USE flo_oce ! floats variables |
---|
86 | USE floats ! floats computation (flo_stp routine) |
---|
87 | |
---|
88 | USE stpctl ! time stepping control (stp_ctl routine) |
---|
89 | USE restart ! ocean restart (rst_wri routine) |
---|
90 | USE prtctl ! Print control (prt_ctl routine) |
---|
91 | |
---|
92 | USE diaobs ! Observation operator |
---|
93 | |
---|
94 | #if defined key_agrif |
---|
95 | USE agrif_opa_sponge ! Momemtum and tracers sponges |
---|
96 | #endif |
---|
97 | !!---------------------------------------------------------------------- |
---|
98 | !! NEMO/OPA 3.3 , NEMO Consortium (2010) |
---|
99 | !! $Id$ |
---|
100 | !! Software governed by the CeCILL licence (NEMOGCM/NEMO_CeCILL.txt) |
---|
101 | !!====================================================================== |
---|
102 | END MODULE step_oce |
---|