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.
Changeset 11772 – NEMO

Changeset 11772


Ignore:
Timestamp:
2019-10-23T16:04:12+02:00 (5 years ago)
Author:
laurent
Message:

LB: solid updates+improvements of cool-skin/warm-layer capabilty of COARE and ECMWF bulk algorithms!

Location:
NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk
Files:
12 edited

Legend:

Unmodified
Added
Removed
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/cfgs/ORCA2_ICE_PISCES/EXPREF/file_def_nemo-oce.xml

    r9990 r11772  
    77=                                         put the variables you want...                                    = 
    88============================================================================================================ 
    9     --> 
    10     
    11     <file_definition type="one_file" name="@expname@_@freq@_@startdate@_@enddate@" sync_freq="1mo" min_digits="4"> 
    12      
    13       <file_group id="5d" output_freq="5d"  output_level="10" enabled=".TRUE.">  <!-- 5d files -->    
    14         <file id="file11" name_suffix="_grid_T" description="ocean T grid variables" > 
    15           <field field_ref="e3t"      /> 
    16           <field field_ref="toce"         name="thetao"                                                                      operation="instant" freq_op="5d" > @toce_e3t / @e3t </field> 
    17           <field field_ref="soce"         name="so"                                                                          operation="instant" freq_op="5d" > @soce_e3t / @e3t </field> 
    18           <field field_ref="sst"          name="tos"   /> 
    19           <field field_ref="sss"          name="sos"   /> 
    20           <field field_ref="ssh"          name="zos"   /> 
    21           <field field_ref="sst"          name="tosstd"       long_name="sea surface temperature standard deviation"         operation="instant" freq_op="5d" > sqrt( @sst2 - @sst * @sst ) </field> 
    22           <field field_ref="ssh"          name="zosstd"       long_name="sea surface height above geoid standard deviation"  operation="instant" freq_op="5d" > sqrt( @ssh2 - @ssh * @ssh ) </field> 
    23           <field field_ref="sst"          name="sstdcy"       long_name="amplitude of sst diurnal cycle"                     operation="average" freq_op="1d" > @sstmax - @sstmin </field> 
    24           <field field_ref="mldkz5"   /> 
    25           <field field_ref="mldr10_1" /> 
    26           <field field_ref="mldr10_1"     name="mldr10_1dcy"  long_name="amplitude of mldr10_1 diurnal cycle"                operation="average" freq_op="1d" > @mldr10_1max - @mldr10_1min </field> 
    27           <field field_ref="sbt"      /> 
    28           <field field_ref="heatc"        name="heatc" /> 
    29           <field field_ref="saltc"        name="saltc" /> 
     9--> 
    3010 
    31      <field field_ref="empmr"        name="wfo"      /> 
    32      <field field_ref="qsr_oce"      name="qsr_oce"  /> 
    33      <field field_ref="qns_oce"      name="qns_oce"  /> 
    34      <field field_ref="qt_oce"       name="qt_oce"   /> 
    35      <field field_ref="saltflx"      name="sfx"      /> 
    36      <field field_ref="taum"         name="taum"     /> 
    37      <field field_ref="wspd"         name="windsp"   /> 
    38      <field field_ref="precip"       name="precip"   /> 
    39      <field field_ref="berg_melt_qlat"  name="berg_melt_qlat" /> 
    40      <!-- ice and snow --> 
    41      <field field_ref="snowpre" /> 
    42    </file> 
     11<file_definition type="one_file" name="@expname@_@freq@_@startdate@_@enddate@" sync_freq="1mo" min_digits="4"> 
    4312 
    44    <file id="file12" name_suffix="_grid_U" description="ocean U grid variables" > 
    45      <field field_ref="e3u" /> 
    46      <field field_ref="ssu"          name="uos"      /> 
    47      <field field_ref="uoce"         name="uo"       operation="instant" freq_op="5d" > @uoce_e3u / @e3u </field> 
    48      <field field_ref="utau"         name="tauuo"    /> 
    49           <field field_ref="uocetr_eff"   name="uocetr_eff"  /> 
    50           <!-- available with diaar5 --> 
    51      <field field_ref="u_masstr"     name="vozomatr" /> 
    52      <field field_ref="u_heattr"     name="sozohetr" /> 
    53      <field field_ref="u_salttr"     name="sozosatr" /> 
    54    </file> 
    55     
    56    <file id="file13" name_suffix="_grid_V" description="ocean V grid variables" > 
    57      <field field_ref="e3v" /> 
    58      <field field_ref="ssv"          name="vos"      /> 
    59      <field field_ref="voce"         name="vo"       operation="instant" freq_op="5d" > @voce_e3v / @e3v </field> 
    60      <field field_ref="vtau"         name="tauvo"    /> 
    61           <field field_ref="vocetr_eff"   name="vocetr_eff"  /> 
    62           <!-- available with diaar5 --> 
    63      <field field_ref="v_masstr"     name="vomematr" /> 
    64      <field field_ref="v_heattr"     name="somehetr" /> 
    65           <field field_ref="v_salttr"     name="somesatr" /> 
    66    </file> 
    67     
    68    <file id="file14" name_suffix="_grid_W" description="ocean W grid variables" > 
    69      <field field_ref="e3w" /> 
    70      <field field_ref="woce"         name="wo"       /> 
    71      <field field_ref="avt"          name="difvho"   /> 
    72      <field field_ref="w_masstr"     name="vovematr" /> 
    73          <!-- variables available with ln_zdfiwm =T --> 
    74           <field field_ref="av_wave"      name="av_wave"    /> 
    75           <field field_ref="bn2"          name="bn2"        /> 
    76           <field field_ref="bflx_iwm"     name="bflx_iwm"   /> 
    77           <field field_ref="pcmap_iwm"    name="pcmap_iwm"  /> 
    78           <field field_ref="emix_iwm"     name="emix_iwm"   /> 
    79           <field field_ref="av_ratio"     name="av_ratio"   /> 
    80    </file> 
     13<file_group id="5d" output_freq="5d"  output_level="10" enabled=".TRUE.">  <!-- 5d files --> 
     14  <file id="file11" name_suffix="_grid_T" description="ocean T grid variables" > 
     15    <field field_ref="e3t"      /> 
     16    <field field_ref="toce"         name="thetao"                                                                      operation="instant" freq_op="5d" > @toce_e3t / @e3t </field> 
     17    <field field_ref="soce"         name="so"                                                                          operation="instant" freq_op="5d" > @soce_e3t / @e3t </field> 
     18    <field field_ref="sst"          name="tos"   /> 
     19    <field field_ref="sss"          name="sos"   /> 
     20    <field field_ref="ssh"          name="zos"   /> 
     21    <field field_ref="t_skin"       name="t_skin" /> 
     22    <field field_ref="dt_skin"      name="dt_skin"  /> 
     23    <field field_ref="sst"          name="tosstd"       long_name="sea surface temperature standard deviation"         operation="instant" freq_op="5d" > sqrt( @sst2 - @sst * @sst ) </field> 
     24    <field field_ref="ssh"          name="zosstd"       long_name="sea surface height above geoid standard deviation"  operation="instant" freq_op="5d" > sqrt( @ssh2 - @ssh * @ssh ) </field> 
     25    <field field_ref="sst"          name="sstdcy"       long_name="amplitude of sst diurnal cycle"                     operation="average" freq_op="1d" > @sstmax - @sstmin </field> 
     26    <field field_ref="mldkz5"   /> 
     27    <field field_ref="mldr10_1" /> 
     28    <field field_ref="mldr10_1"     name="mldr10_1dcy"  long_name="amplitude of mldr10_1 diurnal cycle"                operation="average" freq_op="1d" > @mldr10_1max - @mldr10_1min </field> 
     29    <field field_ref="sbt"      /> 
     30    <field field_ref="heatc"        name="heatc" /> 
     31    <field field_ref="saltc"        name="saltc" /> 
    8132 
    82         <file id="file15" name_suffix="_scalar" description="scalar variables" > 
    83           <!-- global drifts (conservation checks) --> 
    84           <field field_ref="bgtemper"     grid_ref="grid_1point"   name="bgtemper"    /> 
    85           <field field_ref="bgsaline"     grid_ref="grid_1point"   name="bgsaline"    /> 
    86           <field field_ref="bgheatco"     grid_ref="grid_1point"   name="bgheatco"    /> 
    87           <field field_ref="bgheatfx"     grid_ref="grid_1point"   name="bgheatfx"    /> 
    88           <field field_ref="bgsaltco"     grid_ref="grid_1point"   name="bgsaltco"    /> 
    89           <field field_ref="bgvolssh"     grid_ref="grid_1point"   name="bgvolssh"    /> 
    90           <field field_ref="bgvole3t"     grid_ref="grid_1point"   name="bgvole3t"    /> 
     33    <field field_ref="empmr"        name="wfo"      /> 
     34    <field field_ref="qsr_oce"      name="qsr_oce"  /> 
     35    <field field_ref="qns_oce"      name="qns_oce"  /> 
     36    <field field_ref="qt_oce"       name="qt_oce"   /> 
     37    <field field_ref="saltflx"      name="sfx"      /> 
     38    <field field_ref="taum"         name="taum"     /> 
     39    <field field_ref="wspd"         name="windsp"   /> 
     40    <field field_ref="precip"       name="precip"   /> 
     41    <field field_ref="berg_melt_qlat"  name="berg_melt_qlat" /> 
     42    <!-- ice and snow --> 
     43    <field field_ref="snowpre" /> 
     44  </file> 
    9145 
    92           <!-- global surface forcings  --> 
    93           <field field_ref="bgfrcvol"     grid_ref="grid_1point"   name="bgfrcvol"    /> 
    94           <field field_ref="bgfrctem"     grid_ref="grid_1point"   name="bgfrctem"    /> 
    95           <field field_ref="bgfrchfx"     grid_ref="grid_1point"   name="bgfrchfx"    /> 
    96           <field field_ref="bgfrcsal"     grid_ref="grid_1point"   name="bgfrcsal"    /> 
    97         </file> 
     46  <file id="file12" name_suffix="_grid_U" description="ocean U grid variables" > 
     47    <field field_ref="e3u" /> 
     48    <field field_ref="ssu"          name="uos"      /> 
     49    <field field_ref="uoce"         name="uo"       operation="instant" freq_op="5d" > @uoce_e3u / @e3u </field> 
     50    <field field_ref="utau"         name="tauuo"    /> 
     51    <field field_ref="uocetr_eff"   name="uocetr_eff"  /> 
     52    <!-- available with diaar5 --> 
     53    <field field_ref="u_masstr"     name="vozomatr" /> 
     54    <field field_ref="u_heattr"     name="sozohetr" /> 
     55    <field field_ref="u_salttr"     name="sozosatr" /> 
     56  </file> 
    9857 
    99       </file_group>  
     58  <file id="file13" name_suffix="_grid_V" description="ocean V grid variables" > 
     59    <field field_ref="e3v" /> 
     60    <field field_ref="ssv"          name="vos"      /> 
     61    <field field_ref="voce"         name="vo"       operation="instant" freq_op="5d" > @voce_e3v / @e3v </field> 
     62    <field field_ref="vtau"         name="tauvo"    /> 
     63    <field field_ref="vocetr_eff"   name="vocetr_eff"  /> 
     64    <!-- available with diaar5 --> 
     65    <field field_ref="v_masstr"     name="vomematr" /> 
     66    <field field_ref="v_heattr"     name="somehetr" /> 
     67    <field field_ref="v_salttr"     name="somesatr" /> 
     68  </file> 
     69 
     70  <file id="file14" name_suffix="_grid_W" description="ocean W grid variables" > 
     71    <field field_ref="e3w" /> 
     72    <field field_ref="woce"         name="wo"       /> 
     73    <field field_ref="avt"          name="difvho"   /> 
     74    <field field_ref="w_masstr"     name="vovematr" /> 
     75    <!-- variables available with ln_zdfiwm =T --> 
     76    <field field_ref="av_wave"      name="av_wave"    /> 
     77    <field field_ref="bn2"          name="bn2"        /> 
     78    <field field_ref="bflx_iwm"     name="bflx_iwm"   /> 
     79    <field field_ref="pcmap_iwm"    name="pcmap_iwm"  /> 
     80    <field field_ref="emix_iwm"     name="emix_iwm"   /> 
     81    <field field_ref="av_ratio"     name="av_ratio"   /> 
     82  </file> 
     83 
     84  <file id="file15" name_suffix="_scalar" description="scalar variables" > 
     85    <!-- global drifts (conservation checks) --> 
     86    <field field_ref="bgtemper"     grid_ref="grid_1point"   name="bgtemper"    /> 
     87    <field field_ref="bgsaline"     grid_ref="grid_1point"   name="bgsaline"    /> 
     88    <field field_ref="bgheatco"     grid_ref="grid_1point"   name="bgheatco"    /> 
     89    <field field_ref="bgheatfx"     grid_ref="grid_1point"   name="bgheatfx"    /> 
     90    <field field_ref="bgsaltco"     grid_ref="grid_1point"   name="bgsaltco"    /> 
     91    <field field_ref="bgvolssh"     grid_ref="grid_1point"   name="bgvolssh"    /> 
     92    <field field_ref="bgvole3t"     grid_ref="grid_1point"   name="bgvole3t"    /> 
     93 
     94    <!-- global surface forcings  --> 
     95    <field field_ref="bgfrcvol"     grid_ref="grid_1point"   name="bgfrcvol"    /> 
     96    <field field_ref="bgfrctem"     grid_ref="grid_1point"   name="bgfrctem"    /> 
     97    <field field_ref="bgfrchfx"     grid_ref="grid_1point"   name="bgfrchfx"    /> 
     98    <field field_ref="bgfrcsal"     grid_ref="grid_1point"   name="bgfrcsal"    /> 
     99  </file> 
     100 
     101</file_group> 
    100102 
    101103 
    102       <file_group id="1m" output_freq="1mo" output_level="10" enabled=".TRUE."> <!-- real monthly files --> 
    103       </file_group> 
     104<file_group id="1m" output_freq="1mo" output_level="10" enabled=".TRUE."> <!-- real monthly files --> 
     105</file_group> 
    104106 
    105       <file_group id="1y"  output_freq="1y" output_level="10" enabled=".TRUE."> <!-- real yearly files --> 
    106       </file_group> 
    107     
    108        
    109       <file_group id="1ts" output_freq="1ts" output_level="10" enabled=".TRUE."/> <!-- 1 time step files --> 
    110       <file_group id="2h"  output_freq="2h"  output_level="10" enabled=".TRUE."/> <!-- 2h files --> 
    111       <file_group id="3h"  output_freq="3h"  output_level="10" enabled=".TRUE."/> <!-- 3h files -->      
    112       <file_group id="4h"  output_freq="4h"  output_level="10" enabled=".TRUE."/> <!-- 4h files --> 
    113       <file_group id="6h"  output_freq="6h"  output_level="10" enabled=".TRUE."/> <!-- 6h files -->      
    114       <file_group id="2m"  output_freq="2mo" output_level="10" enabled=".TRUE."/> <!-- real 2m files --> 
    115       <file_group id="3m"  output_freq="3mo" output_level="10" enabled=".TRUE."/> <!-- real 3m files --> 
    116       <file_group id="4m"  output_freq="4mo" output_level="10" enabled=".TRUE."/> <!-- real 4m files --> 
    117       <file_group id="6m"  output_freq="6mo" output_level="10" enabled=".TRUE."/> <!-- real 6m files --> 
    118       <file_group id="2y"  output_freq="2y"  output_level="10" enabled=".TRUE."/> <!-- real 2y files --> 
    119       <file_group id="5y"  output_freq="5y"  output_level="10" enabled=".TRUE."/> <!-- real 5y files --> 
    120       <file_group id="10y" output_freq="10y" output_level="10" enabled=".TRUE."/> <!-- real 10y files --> 
    121  
    122    </file_definition> 
    123      
     107<file_group id="1y"  output_freq="1y" output_level="10" enabled=".TRUE."> <!-- real yearly files --> 
     108</file_group> 
    124109 
    125110 
     111<file_group id="1ts" output_freq="1ts" output_level="10" enabled=".TRUE."/> <!-- 1 time step files --> 
     112<file_group id="2h"  output_freq="2h"  output_level="10" enabled=".TRUE."/> <!-- 2h files --> 
     113<file_group id="3h"  output_freq="3h"  output_level="10" enabled=".TRUE."/> <!-- 3h files --> 
     114<file_group id="4h"  output_freq="4h"  output_level="10" enabled=".TRUE."/> <!-- 4h files --> 
     115<file_group id="6h"  output_freq="6h"  output_level="10" enabled=".TRUE."/> <!-- 6h files --> 
     116<file_group id="2m"  output_freq="2mo" output_level="10" enabled=".TRUE."/> <!-- real 2m files --> 
     117<file_group id="3m"  output_freq="3mo" output_level="10" enabled=".TRUE."/> <!-- real 3m files --> 
     118<file_group id="4m"  output_freq="4mo" output_level="10" enabled=".TRUE."/> <!-- real 4m files --> 
     119<file_group id="6m"  output_freq="6mo" output_level="10" enabled=".TRUE."/> <!-- real 6m files --> 
     120<file_group id="2y"  output_freq="2y"  output_level="10" enabled=".TRUE."/> <!-- real 2y files --> 
     121<file_group id="5y"  output_freq="5y"  output_level="10" enabled=".TRUE."/> <!-- real 5y files --> 
     122<file_group id="10y" output_freq="10y" output_level="10" enabled=".TRUE."/> <!-- real 10y files --> 
    126123 
     124</file_definition> 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/cfgs/ORCA2_ICE_PISCES/EXPREF/namelist_cfg

    r10190 r11772  
    7575&namsbc        !   Surface Boundary Condition manager                   (default: NO selection) 
    7676!----------------------------------------------------------------------- 
    77    nn_fsbc     = 3         !  frequency of SBC module call 
     77   nn_fsbc     = 1         !!LOLO!  frequency of SBC module call 
    7878                           !     (also = the frequency of sea-ice & iceberg model call) 
    7979                     ! Type of air-sea fluxes  
     
    8585   ln_traqsr   = .true.    !  Light penetration in the ocean            (T => fill namtra_qsr) 
    8686   ln_ssr      = .true.    !  Sea Surface Restoring on T and/or S       (T => fill namsbc_ssr) 
     87   ln_dm2dc    = .true.    !  daily mean to diurnal cycle on short wave 
    8788   ln_rnf      = .true.    !  runoffs                                   (T => fill namsbc_rnf) 
    8889   nn_fwb      = 2         !  FreshWater Budget:  
     
    103104!----------------------------------------------------------------------- 
    104105   !                    !  bulk algorithm : 
    105    ln_NCAR    = .true.     ! "NCAR"      algorithm   (Large and Yeager 2008) 
    106  
    107    cn_dir = './'  !  root directory for the bulk data location 
     106   ln_NCAR      = .false.   ! "NCAR"      algorithm   (Large and Yeager 2008) 
     107   ln_COARE_3p0 = .false.   ! "COARE 3.0" algorithm   (Fairall et al. 2003) 
     108   ln_COARE_3p6 = .false.   ! "COARE 3.6" algorithm   (Edson et al. 2013) 
     109   ln_ECMWF     = .true.    ! "ECMWF"     algorithm   (IFS cycle 31) 
     110      rn_zqt      =  2.     !  Air temperature & humidity reference height (m) 
     111      rn_zu       = 10.     !  Wind vector reference height (m) 
     112      ! 
     113      ! Skin is ONLY available in ECMWF and COARE algorithms: 
     114      ln_skin_cs = .true.   !  use the cool-skin parameterization => set nn_fsbc=1 and ln_dm2dc=.true.! 
     115      ln_skin_wl = .true.   !  use the warm-layer        "        => set nn_fsbc=1 and ln_dm2dc=.true.! 
     116      ! 
     117      ln_humi_sph = .false. !  humidity specified below in "sn_humi" is specific humidity     [kg/kg] if .true. 
     118      ln_humi_dpt = .true.  !  humidity specified below in "sn_humi" is dew-point temperature   [K]   if .true. 
     119      ln_humi_rlh = .false. !  humidity specified below in "sn_humi" is relative humidity       [%]   if .true. 
     120   ! 
     121   cn_dir = './FATM/'  !  root directory for the bulk data location 
    108122   !___________!_________________________!___________________!___________!_____________!________!___________!______________________________________!__________!_______________! 
    109    !           !  file name              ! frequency (hours) ! variable  ! time interp.!  clim  ! 'yearly'/ !          weights filename            ! rotation ! land/sea mask ! 
    110    !           !                         !  (if <0  months)  !   name    !   (logical) !  (T/F) ! 'monthly' !                                      ! pairing  !    filename   ! 
    111    sn_wndi     = 'u_10.15JUNE2009_fill'       ,    6         , 'U_10_MOD',   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bicubic_noc.nc'  , 'Uwnd'   , '' 
    112    sn_wndj     = 'v_10.15JUNE2009_fill'       ,    6         , 'V_10_MOD',   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bicubic_noc.nc'  , 'Vwnd'   , '' 
    113    sn_qsr      = 'ncar_rad.15JUNE2009_fill'   ,   24         , 'SWDN_MOD',   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bilinear_noc.nc' , ''       , '' 
    114    sn_qlw      = 'ncar_rad.15JUNE2009_fill'   ,   24         , 'LWDN_MOD',   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bilinear_noc.nc' , ''       , '' 
    115    sn_tair     = 't_10.15JUNE2009_fill'       ,    6         , 'T_10_MOD',   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bilinear_noc.nc' , ''       , '' 
    116    sn_humi     = 'q_10.15JUNE2009_fill'       ,    6         , 'Q_10_MOD',   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bilinear_noc.nc' , ''       , '' 
    117    sn_prec     = 'ncar_precip.15JUNE2009_fill',   -1         , 'PRC_MOD1',   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bilinear_noc.nc' , ''       , '' 
    118    sn_snow     = 'ncar_precip.15JUNE2009_fill',   -1         , 'SNOW'    ,   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bilinear_noc.nc' , ''       , '' 
    119    sn_slp      = 'slp.15JUNE2009_fill'        ,    6         , 'SLP'     ,   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bilinear_noc.nc' , ''       , '' 
    120    sn_tdif     = 'taudif_core'                ,   24         , 'taudif'  ,   .false.   , .true. , 'yearly'  , 'weights_core_orca2_bilinear_noc.nc' , ''       , '' 
     123   !           !  file name              ! frequency (hours) ! variable  ! time interp.!  clim  ! 'yearly'/ ! weights filename ! rotation ! land/sea mask ! 
     124   !           !                         !  (if <0  months)  !   name    !   (logical) !  (T/F) ! 'monthly' !                  ! pairing  !    filename   ! 
     125   sn_wndi     = 'u10_ERAi_512x256-ORCA2_gridT',   3         ,   'u10'   ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     126   sn_wndj     = 'v10_ERAi_512x256-ORCA2_gridT',   3         ,   'v10'   ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     127   sn_qsr      = 'radsw_ERAi_512x256-ORCA2'   ,   24         ,  'radsw'  ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     128   sn_qlw      = 'radlw_ERAi_512x256-ORCA2'   ,   24         ,  'radlw'  ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     129   sn_tair     = 't2_ERAi_512x256-ORCA2'      ,    3         ,    't2'   ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     130   sn_humi     = 'd2_ERAi_512x256-ORCA2'      ,    3         ,    'd2'   ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     131   sn_prec     = 'precip_ERAi_512x256-ORCA2'  ,   24         ,  'precip' ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     132   sn_snow     = 'snow_ERAi_512x256-ORCA2'    ,   24         ,   'snow'  ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     133   sn_slp      = 'msl_ERAi_512x256-ORCA2'     ,    3         ,   'msl'   ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
     134   sn_tdif     = 'taudif_core'                ,   24         , 'taudif'  ,   .false.   , .false. , 'yearly'  ,       ''        , ''       , '' 
    121135/ 
    122136!----------------------------------------------------------------------- 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/cfgs/SHARED/field_def_nemo-oce.xml

    r10824 r11772  
    1 <?xml version="1.0"?>  
    2     <!-- $id$ --> 
    3      
    4     <!--  
     1<?xml version="1.0"?> 
     2<!-- $id$ --> 
     3 
     4<!-- 
    55============================================================================================================ 
    66=                                  definition of all existing variables                                    = 
    77=                                            DO NOT CHANGE                                                 = 
    88============================================================================================================ 
    9     --> 
    10     <field_definition level="1" prec="4" operation="average" enabled=".TRUE." default_value="1.e20" > <!-- time step automaticaly defined --> 
    11  
    12     <!--  
    13 ============================================================================================================ 
    14                                   Physical ocean model variables 
    15 ============================================================================================================ 
    16     --> 
    17  
    18       <!-- T grid --> 
    19        
    20       <field_group id="grid_T" grid_ref="grid_T_2D" > 
    21         <field id="e3t"          long_name="T-cell thickness"                    standard_name="cell_thickness"     unit="m"   grid_ref="grid_T_3D" /> 
    22         <field id="e3t_surf"     long_name="T-cell thickness"   field_ref="e3t"  standard_name="cell_thickness"     unit="m"   grid_ref="grid_T_SFC"/> 
    23         <field id="e3t_0"        long_name="Initial T-cell thickness"            standard_name="ref_cell_thickness" unit="m"   grid_ref="grid_T_3D" /> 
    24  
    25         <field id="toce"         long_name="temperature"                         standard_name="sea_water_potential_temperature"   unit="degC"     grid_ref="grid_T_3D"/> 
    26         <field id="toce_e3t"     long_name="temperature (thickness weighted)"                                                      unit="degC"     grid_ref="grid_T_3D" > toce * e3t </field > 
    27         <field id="soce"         long_name="salinity"                            standard_name="sea_water_practical_salinity"      unit="1e-3"     grid_ref="grid_T_3D"/> 
    28         <field id="soce_e3t"     long_name="salinity    (thickness weighted)"                                                      unit="1e-3"     grid_ref="grid_T_3D" > soce * e3t </field > 
    29  
    30         <!-- t-eddy viscosity coefficients (ldfdyn) --> 
    31    <field id="ahmt_2d"      long_name=" surface t-eddy viscosity coefficient"   unit="m2/s or m4/s"                      /> 
    32    <field id="ahmt_3d"      long_name=" 3D      t-eddy viscosity coefficient"   unit="m2/s or m4/s"  grid_ref="grid_T_3D"/> 
    33  
    34         <field id="sst"          long_name="sea surface temperature"                            standard_name="sea_surface_temperature"             unit="degC"     /> 
    35         <field id="sst2"         long_name="square of sea surface temperature"                  standard_name="square_of_sea_surface_temperature"   unit="degC2"     > sst * sst </field > 
    36         <field id="sstmax"       long_name="max of sea surface temperature"   field_ref="sst"   operation="maximum"                                                 /> 
    37         <field id="sstmin"       long_name="min of sea surface temperature"   field_ref="sst"   operation="minimum"                                                 /> 
    38         <field id="sstgrad"      long_name="module of sst gradient"                                                                                 unit="degC/m"   /> 
    39         <field id="sstgrad2"     long_name="square of module of sst gradient"                                                                       unit="degC2/m2" /> 
    40         <field id="sbt"          long_name="sea bottom temperature"                                                                                 unit="degC"     /> 
    41         <field id="tosmint"      long_name="vertical integral of temperature times density"     standard_name="integral_wrt_depth_of_product_of_density_and_potential_temperature"  unit="(kg m2) degree_C" /> 
    42         <field id="sst_wl"       long_name="Delta SST of warm layer"                                                                                unit="degC"     /> 
    43         <field id="sst_cs"       long_name="Delta SST of cool skin"                                                                                 unit="degC"     /> 
    44    <field id="temp_3m"      long_name="temperature at 3m"                                                                                      unit="degC"     /> 
    45          
    46         <field id="sss"          long_name="sea surface salinity"                               standard_name="sea_surface_salinity"                unit="1e-3"     /> 
    47         <field id="sss2"         long_name="square of sea surface salinity"                                                                         unit="1e-6"      > sss * sss </field > 
    48         <field id="sssmax"       long_name="max of sea surface salinity"      field_ref="sss"   operation="maximum"                                                 /> 
    49         <field id="sssmin"       long_name="min of sea surface salinity"      field_ref="sss"   operation="minimum"                                                 /> 
    50         <field id="sbs"          long_name="sea bottom salinity"                                                                                    unit="0.001"    /> 
    51         <field id="somint"       long_name="vertical integral of salinity times density"        standard_name="integral_wrt_depth_of_product_of_density_and_salinity"  unit="(kg m2) x (1e-3)" />  
    52  
    53         <field id="taubot"       long_name="bottom stress module"                                                                                   unit="N/m2"     />  
    54  
    55         <field id="ssh"          long_name="sea surface height"                                 standard_name="sea_surface_height_above_geoid"             unit="m" /> 
    56         <field id="ssh2"         long_name="square of sea surface height"                       standard_name="square_of_sea_surface_height_above_geoid"   unit="m2" > ssh * ssh </field > 
    57         <field id="wetdep"       long_name="wet depth"                                          standard_name="wet_depth"                                  unit="m" /> 
    58         <field id="sshmax"       long_name="max of sea surface height"        field_ref="ssh"   operation="maximum"                                                 /> 
    59  
    60         <field id="mldkz5"       long_name="Turbocline depth (Kz = 5e-4)"                       standard_name="ocean_mixed_layer_thickness_defined_by_vertical_tracer_diffusivity"                unit="m"          /> 
    61         <field id="mldr10_1"     long_name="Mixed Layer Depth (dsigma = 0.01 wrt 10m)"          standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"          /> 
    62         <field id="mldr10_1max"  long_name="Max of Mixed Layer Depth (dsigma = 0.01 wrt 10m)"   field_ref="mldr10_1"   operation="maximum"                                                                          /> 
    63         <field id="mldr10_1min"  long_name="Min of Mixed Layer Depth (dsigma = 0.01 wrt 10m)"   field_ref="mldr10_1"   operation="minimum"                                                                          /> 
    64         <field id="heatc"        long_name="Heat content vertically integrated"                 standard_name="integral_of_sea_water_potential_temperature_wrt_depth_expressed_as_heat_content"   unit="J/m2"       /> 
    65         <field id="saltc"        long_name="Salt content vertically integrated"                                                                                                                   unit="1e-3*kg/m2" /> 
    66  
    67         <!-- EOS --> 
    68         <field id="alpha"        long_name="thermal expansion"                                                         unit="degC-1" grid_ref="grid_T_3D" /> 
    69         <field id="beta"         long_name="haline contraction"                                                        unit="1e3"    grid_ref="grid_T_3D" /> 
    70         <field id="bn2"          long_name="squared Brunt-Vaisala frequency"                                           unit="s-1"    grid_ref="grid_T_3D" /> 
    71         <field id="rhop"         long_name="potential density (sigma0)"        standard_name="sea_water_sigma_theta"   unit="kg/m3"  grid_ref="grid_T_3D" /> 
    72  
    73         <!-- Energy - horizontal divergence --> 
    74         <field id="eken"         long_name="kinetic energy"          standard_name="specific_kinetic_energy_of_sea_water"   unit="m2/s2"  grid_ref="grid_T_3D" /> 
    75         <field id="hdiv"         long_name="horizontal divergence"                                                          unit="s-1"    grid_ref="grid_T_3D" /> 
    76  
    77         <!-- variables available with MLE --> 
    78         <field id="Lf_NHpf"      long_name="MLE: Lf = N H / f"   unit="m" /> 
    79  
    80         <!-- next variables available with ln_zad_Aimp=.true. --> 
    81         <field id="Courant"      long_name="Courant number"                                                                 unit="#"   grid_ref="grid_T_3D" /> 
    82         <field id="wimp"         long_name="Implicit vertical velocity"                                                     unit="m/s" grid_ref="grid_T_3D" /> 
    83         <field id="wexp"         long_name="Explicit vertical velocity"                                                     unit="m/s" grid_ref="grid_T_3D" /> 
    84         <field id="wi_cff"       long_name="Fraction of implicit vertical velocity"                                         unit="#"   grid_ref="grid_T_3D" /> 
    85  
    86         <!-- next variables available with key_diahth --> 
    87         <field id="mlddzt"       long_name="Thermocline Depth (depth of max dT/dz)"         standard_name="depth_at_maximum_upward_derivative_of_sea_water_potential_temperature"             unit="m"                         /> 
    88         <field id="mldr10_3"     long_name="Mixed Layer Depth (dsigma = 0.03 wrt 10m)"      standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"                         /> 
    89         <field id="mldr0_1"      long_name="Mixed Layer Depth (dsigma = 0.01 wrt sfc)"      standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"                         /> 
    90         <field id="mldr0_3"      long_name="Mixed Layer Depth (dsigma = 0.03 wrt sfc)"      standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"                         /> 
    91         <field id="mld_dt02"     long_name="Mixed Layer Depth (|dT| = 0.2 wrt 10m)"         standard_name="ocean_mixed_layer_thickness_defined_by_temperature"                                unit="m"                         /> 
    92         <field id="topthdep"     long_name="Top of Thermocline Depth (dT = -0.2 wrt 10m)"   standard_name="ocean_mixed_layer_thickness_defined_by_temperature"                                unit="m"                         /> 
    93         <field id="pycndep"      long_name="Pycnocline Depth (dsigma[dT=-0.2] wrt 10m)"     standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"                         /> 
    94         <field id="BLT"          long_name="Barrier Layer Thickness"                                                                                                                          unit="m"                          > topthdep - pycndep </field> 
    95         <field id="tinv"         long_name="Max of vertical invertion of temperature"                                                                                                         unit="degC"                      /> 
    96         <field id="depti"        long_name="Depth of max. vert. inv. of temperature"                                                                                                          unit="m"                         /> 
    97         <field id="20d"          long_name="Depth of 20C isotherm"                          standard_name="depth_of_isosurface_of_sea_water_potential_temperature"                            unit="m"      axis_ref="iax_20C" /> 
    98         <field id="28d"          long_name="Depth of 28C isotherm"                          standard_name="depth_of_isosurface_of_sea_water_potential_temperature"                            unit="m"      axis_ref="iax_28C" /> 
    99         <field id="hc300"        long_name="Heat content 0-300m"                            standard_name="integral_of_sea_water_potential_temperature_wrt_depth_expressed_as_heat_content"   unit="J/m2"                      /> 
    100  
    101         <!-- variables available with diaar5 --> 
    102         <field id="botpres"      long_name="Sea Water Pressure at Sea Floor"          standard_name="sea_water_pressure_at_sea_floor"                    unit="dbar" /> 
    103         <field id="sshdyn"       long_name="dynamic sea surface height"               standard_name="dynamic_sea_surface_height_above_geoid"             unit="m"    /> 
    104         <field id="sshdyn2"      long_name="square of dynamic sea surface height"     standard_name="dynamic_sea_surface_height_above_geoid_squared"     unit="m2"    > sshdyn * sshdyn </field> 
    105         <field id="tnpeo"      long_name="Tendency of ocean potential energy content"                                                                    unit="W/m2" /> 
    106  
    107         <!-- variables available ln_linssh=.FALSE. --> 
    108         <field id="tpt_dep"      long_name="T-point depth"                  standard_name="depth_below_geoid"   unit="m"   grid_ref="grid_T_3D" /> 
    109         <field id="e3tdef"       long_name="T-cell thickness deformation"                                       unit="%"   grid_ref="grid_T_3D" /> 
    110  
    111         <!-- variables available with ln_diacfl=.true. --> 
    112         <field id="cfl_cu"       long_name="u-courant number"   unit="#" /> 
    113         <field id="cfl_cv"       long_name="v-courant number"   unit="#" /> 
    114         <field id="cfl_cw"       long_name="w-courant number"   unit="#" /> 
    115  
    116       </field_group> <!-- grid_T --> 
    117  
    118       <!-- Tides --> 
    119  
    120       <field_group id="Tides_T" grid_ref="grid_T_2D" operation="once" > 
    121         <!-- tidal composante --> 
    122         <field id="M2x"          long_name="M2 Elevation harmonic real part "                             unit="m"        /> 
    123         <field id="M2y"          long_name="M2 Elevation harmonic imaginary part"                         unit="m"        /> 
    124         <field id="S2x"          long_name="S2 Elevation harmonic real part "                             unit="m"        /> 
    125         <field id="S2y"          long_name="S2 Elevation harmonic imaginary part"                         unit="m"        /> 
    126         <field id="N2x"          long_name="N2 Elevation harmonic real part "                             unit="m"        /> 
    127         <field id="N2y"          long_name="N2 Elevation harmonic imaginary part"                         unit="m"        /> 
    128         <field id="K1x"          long_name="K1 Elevation harmonic real part "                             unit="m"        /> 
    129         <field id="K1y"          long_name="K1 Elevation harmonic imaginary part"                         unit="m"        /> 
    130         <field id="O1x"          long_name="O1 Elevation harmonic real part "                             unit="m"        /> 
    131         <field id="O1y"          long_name="O1 Elevation harmonic imaginary part"                         unit="m"        /> 
    132         <field id="Q1x"          long_name="Q1 Elevation harmonic real part "                             unit="m"        /> 
    133         <field id="Q1y"          long_name="Q1 Elevation harmonic imaginary part"                         unit="m"        /> 
    134         <field id="M4x"          long_name="M4 Elevation harmonic real part "                             unit="m"        /> 
    135         <field id="M4y"          long_name="M4 Elevation harmonic imaginary part"                         unit="m"        /> 
    136         <field id="K2x"          long_name="K2 Elevation harmonic real part "                             unit="m"        /> 
    137         <field id="K2y"          long_name="K2 Elevation harmonic imaginary part"                         unit="m"        /> 
    138         <field id="P1x"          long_name="P1 Elevation harmonic real part "                             unit="m"        /> 
    139         <field id="P1y"          long_name="P1 Elevation harmonic imaginary part"                         unit="m"        /> 
    140         <field id="Mfx"          long_name="Mf Elevation harmonic real part "                             unit="m"        /> 
    141         <field id="Mfy"          long_name="Mf Elevation harmonic imaginary part"                         unit="m"        /> 
    142         <field id="Mmx"          long_name="Mm Elevation harmonic real part "                             unit="m"        /> 
    143         <field id="Mmy"          long_name="Mm Elevation harmonic imaginary part"                         unit="m"        /> 
    144       </field_group> 
    145      
    146       <field_group id="Tides_U" grid_ref="grid_U_2D" operation="once" > 
    147         <field id="M2x_u"        long_name="M2 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    148         <field id="M2y_u"        long_name="M2 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    149         <field id="S2x_u"        long_name="S2 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    150         <field id="S2y_u"        long_name="S2 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    151         <field id="N2x_u"        long_name="N2 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    152         <field id="N2y_u"        long_name="N2 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    153         <field id="K1x_u"        long_name="K1 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    154         <field id="K1y_u"        long_name="K1 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    155         <field id="O1x_u"        long_name="O1 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    156         <field id="O1y_u"        long_name="O1 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    157         <field id="Q1x_u"        long_name="Q1 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    158         <field id="Q1y_u"        long_name="Q1 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    159         <field id="M4x_u"        long_name="M4 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    160         <field id="M4y_u"        long_name="M4 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    161         <field id="K2x_u"        long_name="K2 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    162         <field id="K2y_u"        long_name="K2 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    163         <field id="P1x_u"        long_name="P1 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    164         <field id="P1y_u"        long_name="P1 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    165         <field id="Mfx_u"        long_name="Mf current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    166         <field id="Mfy_u"        long_name="Mf current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    167         <field id="Mmx_u"        long_name="Mm current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
    168         <field id="Mmy_u"        long_name="Mm current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
    169       </field_group> 
    170      
    171       <field_group id="Tides_V" grid_ref="grid_V_2D" operation="once" > 
    172         <field id="M2x_v"        long_name="M2 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    173         <field id="M2y_v"        long_name="M2 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    174         <field id="S2x_v"        long_name="S2 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    175         <field id="S2y_v"        long_name="S2 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    176         <field id="N2x_v"        long_name="N2 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    177         <field id="N2y_v"        long_name="N2 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    178         <field id="K1x_v"        long_name="K1 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    179         <field id="K1y_v"        long_name="K1 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    180         <field id="O1x_v"        long_name="O1 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    181         <field id="O1y_v"        long_name="O1 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    182         <field id="Q1x_v"        long_name="Q1 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    183         <field id="Q1y_v"        long_name="Q1 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    184         <field id="M4x_v"        long_name="M4 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    185         <field id="M4y_v"        long_name="M4 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    186         <field id="K2x_v"        long_name="K2 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    187         <field id="K2y_v"        long_name="K2 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    188         <field id="P1x_v"        long_name="P1 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    189         <field id="P1y_v"        long_name="P1 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    190         <field id="Mfx_v"        long_name="Mf current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    191         <field id="Mfy_v"        long_name="Mf current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
    192         <field id="Mmx_v"        long_name="Mm current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
    193         <field id="Mmy_v"        long_name="Mm current barotrope along j-axis harmonic imaginary part "   unit="m/s"      />    
    194       </field_group> 
    195  
    196       <!-- OSMOSIS variables (available with ln_zdfosm=.true.) --> 
    197  
    198       <field_group id="OSMOSIS_T" grid_ref="grid_T_2D"> 
    199         <field id="zwth0"               long_name="surface non-local temperature flux"       unit="deg m/s" /> 
    200         <field id="zws0"                long_name="surface non-local salinity flux"          unit="psu m/s" /> 
    201         <field id="hbl"                 long_name="boundary layer depth"                     unit="m"       /> 
    202         <field id="hbli"                long_name="initial boundary layer depth"             unit="m"       /> 
    203         <field id="dstokes"             long_name="stokes drift  depth scale"                unit="m"       /> 
    204         <field id="zustke"              long_name="magnitude of stokes drift  at T-points"   unit="m/s"     /> 
    205         <field id="zwstrc"              long_name="convective velocity scale"                unit="m/s"     /> 
    206         <field id="zwstrl"              long_name="langmuir velocity scale"                  unit="m/s"     /> 
    207         <field id="zustar"              long_name="friction velocity"                        unit="m/s"     /> 
    208         <field id="zhbl"                long_name="boundary layer depth"                     unit="m"       /> 
    209         <field id="zhml"                long_name="mixed layer depth"                        unit="m"       /> 
    210         <field id="wind_wave_abs_power" long_name="\rho |U_s| x u*^2"                        unit="mW"      /> 
    211         <field id="wind_wave_power"     long_name="U_s \dot  tau"                            unit="mW"      /> 
    212         <field id="wind_power"          long_name="\rho  u*^3"                               unit="mW"      /> 
    213  
    214         <!-- extra OSMOSIS diagnostics --> 
    215         <field id="zwthav"              long_name="av turb flux of T in ml"                  unit="deg m/s" /> 
    216         <field id="zt_ml"               long_name="av T in ml"                               unit="deg"     /> 
    217         <field id="zwth_ent"            long_name="entrainment turb flux of T"               unit="deg m/s" /> 
    218         <field id="zhol"                long_name="Hoenekker number"                         unit="#"       /> 
    219         <field id="zdh"                 long_name="Pycnocline  depth - grid"                 unit=" m"      /> 
    220       </field_group> 
    221  
    222       <field_group id="OSMOSIS_W" grid_ref="grid_W_3D" operation="instant" > 
    223         <field id="ghamt"       long_name="non-local temperature flux"                       unit="deg m/s" /> 
    224         <field id="ghams"       long_name="non-local salinity flux"                          unit="psu m/s" /> 
    225         <field id="zdtdz_pyc"   long_name="Pycnocline temperature gradient"                  unit=" deg/m"  /> 
    226       </field_group> 
    227  
    228       <field_group id="OSMOSIS_U" grid_ref="grid_U_2D" > 
    229         <field id="ghamu"       long_name="non-local u-momentum flux"   grid_ref="grid_U_3D" unit="m^2/s^2" /> 
    230         <field id="us_x"        long_name="i component of Stokes drift"                      unit="m/s"     /> 
    231       </field_group> 
    232  
    233       <field_group id="OSMOSIS_V" grid_ref="grid_V_2D" > 
    234         <field id="ghamv"       long_name="non-local v-momentum flux"   grid_ref="grid_V_3D" unit="m^2/s^2" /> 
    235         <field id="us_y"        long_name="j component of Stokes drift"                      unit="m/s"     /> 
    236       </field_group> 
    237        
    238       <!-- SBC --> 
    239       <field_group id="SBC" > <!-- time step automaticaly defined based on nn_fsbc --> 
    240  
    241         <field_group id="SBC_2D" grid_ref="grid_T_2D" > 
    242  
    243           <field id="empmr"        long_name="Net Upward Water Flux"                standard_name="water_flux_out_of_sea_ice_and_sea_water"                              unit="kg/m2/s"   /> 
    244           <field id="empbmr"       long_name="Net Upward Water Flux at pre. tstep"  standard_name="water_flux_out_of_sea_ice_and_sea_water"                              unit="kg/m2/s"   /> 
    245           <field id="emp_oce"      long_name="Evap minus Precip over ocean"         standard_name="evap_minus_precip_over_sea_water"                                     unit="kg/m2/s"   /> 
    246           <field id="emp_ice"      long_name="Evap minus Precip over ice"           standard_name="evap_minus_precip_over_sea_ice"                                       unit="kg/m2/s"   /> 
    247           <field id="saltflx"      long_name="Downward salt flux"                                                                                                        unit="1e-3/m2/s" /> 
    248           <field id="fmmflx"       long_name="Water flux due to freezing/melting"                                                                                        unit="kg/m2/s"   /> 
    249           <field id="snowpre"      long_name="Snow precipitation"                   standard_name="snowfall_flux"                                                        unit="kg/m2/s"   /> 
    250           <field id="runoffs"      long_name="River Runoffs"                        standard_name="water_flux_into_sea_water_from_rivers"                                unit="kg/m2/s"   /> 
    251           <field id="precip"       long_name="Total precipitation"                  standard_name="precipitation_flux"                                                   unit="kg/m2/s"   /> 
    252       
    253           <field id="qt"           long_name="Net Downward Heat Flux"                standard_name="surface_downward_heat_flux_in_sea_water"                              unit="W/m2"                           /> 
    254           <field id="qns"          long_name="non solar Downward Heat Flux"                                                                                               unit="W/m2"                           /> 
    255           <field id="qsr"          long_name="Shortwave Radiation"                   standard_name="net_downward_shortwave_flux_at_sea_water_surface"                     unit="W/m2"                           /> 
    256           <field id="qsr3d"        long_name="Shortwave Radiation 3D distribution"   standard_name="downwelling_shortwave_flux_in_sea_water"                              unit="W/m2"      grid_ref="grid_T_3D" /> 
    257           <field id="qrp"          long_name="Surface Heat Flux: Damping"            standard_name="heat_flux_into_sea_water_due_to_newtonian_relaxation"                 unit="W/m2"                           /> 
    258           <field id="erp"          long_name="Surface Water Flux: Damping"           standard_name="water_flux_out_of_sea_water_due_to_newtonian_relaxation"              unit="kg/m2/s"                        /> 
    259           <field id="taum"         long_name="wind stress module"                    standard_name="magnitude_of_surface_downward_stress"                                 unit="N/m2"                           /> 
    260           <field id="wspd"         long_name="wind speed module"                     standard_name="wind_speed"                                                           unit="m/s"                            /> 
    261            
    262           <!-- * variable relative to atmospheric pressure forcing : available with ln_apr_dyn --> 
    263           <field id="ssh_ib"       long_name="Inverse barometer sea surface height"  standard_name="sea_surface_height_correction_due_to_air_pressure_at_low_frequency"   unit="m"        /> 
    264  
    265           <!-- * variable related to ice shelf forcing * --> 
    266           <field id="fwfisf"       long_name="Ice shelf melting"                             unit="kg/m2/s"  /> 
    267           <field id="fwfisf3d"     long_name="Ice shelf melting"                             unit="kg/m2/s"  grid_ref="grid_T_3D" /> 
    268           <field id="qlatisf"      long_name="Ice shelf latent heat flux"                    unit="W/m2"     /> 
    269           <field id="qlatisf3d"    long_name="Ice shelf latent heat flux"                    unit="W/m2"     grid_ref="grid_T_3D" /> 
    270           <field id="qhcisf"       long_name="Ice shelf heat content flux"                   unit="W/m2"     /> 
    271           <field id="qhcisf3d"     long_name="Ice shelf heat content flux"                   unit="W/m2"     grid_ref="grid_T_3D" /> 
    272           <field id="isfgammat"    long_name="transfert coefficient for isf (temperature) "  unit="m/s"      /> 
    273           <field id="isfgammas"    long_name="transfert coefficient for isf (salinity)    "  unit="m/s"      /> 
    274           <field id="stbl"         long_name="salinity in the Losh tbl                    "  unit="PSU"      /> 
    275           <field id="ttbl"         long_name="temperature in the Losh tbl                 "  unit="C"        /> 
    276           <field id="utbl"         long_name="zonal current in the Losh tbl at T point    "  unit="m/s"      /> 
    277           <field id="vtbl"         long_name="merid current in the Losh tbl at T point    "  unit="m/s"      /> 
    278           <field id="thermald"     long_name="thermal driving of ice shelf melting        "  unit="C"        /> 
    279           <field id="tfrz"         long_name="top freezing point (used to compute melt)   "  unit="C"        /> 
    280           <field id="tinsitu"      long_name="top insitu temperature (used to cmpt melt)  "  unit="C"        /> 
    281           <field id="ustar"        long_name="ustar at T point used in ice shelf melting  "  unit="m/s"      /> 
    282  
    283           <!-- *_oce variables available with ln_blk_clio or ln_blk_core --> 
    284           <field id="qlw_oce"      long_name="Longwave Downward Heat Flux over open ocean"  standard_name="surface_net_downward_longwave_flux"                 unit="W/m2"  /> 
    285           <field id="qsb_oce"      long_name="Sensible Downward Heat Flux over open ocean"  standard_name="surface_downward_sensible_heat_flux"                unit="W/m2"  /> 
    286           <field id="qla_oce"      long_name="Latent Downward Heat Flux over open ocean"    standard_name="surface_downward_latent_heat_flux"                  unit="W/m2"  /> 
    287           <field id="qt_oce"       long_name="total flux at ocean surface"                  standard_name="surface_downward_heat_flux_in_sea_water"            unit="W/m2"  /> 
    288           <field id="qsr_oce"      long_name="solar heat flux at ocean surface"             standard_name="net_downward_shortwave_flux_at_sea_water_surface"   unit="W/m2"  /> 
    289           <field id="qns_oce"      long_name="non-solar heat flux at ocean surface (including E-P)"                                                            unit="W/m2"  /> 
    290           <field id="qemp_oce"     long_name="Downward Heat Flux from E-P over open ocean"                                                                     unit="W/m2"  /> 
    291           <field id="taum_oce"     long_name="wind stress module over open ocean"           standard_name="magnitude_of_surface_downward_stress"               unit="N/m2"  /> 
    292  
    293           <!-- available key_oasis3 --> 
    294           <field id="snow_ao_cea"  long_name="Snow over ice-free ocean (cell average)"   standard_name="snowfall_flux"                             unit="kg/m2/s"  /> 
    295           <field id="snow_ai_cea"  long_name="Snow over sea-ice (cell average)"          standard_name="snowfall_flux"                             unit="kg/m2/s"  /> 
    296           <field id="subl_ai_cea"  long_name="Sublimation over sea-ice (cell average)"   standard_name="surface_snow_and_ice_sublimation_flux"     unit="kg/m2/s"  /> 
    297           <field id="icealb_cea"   long_name="Ice albedo (cell average)"                 standard_name="sea_ice_albedo"                            unit="1"        /> 
    298           <field id="calving_cea"  long_name="Calving"                                   standard_name="water_flux_into_sea_water_from_icebergs"   unit="kg/m2/s"  /> 
    299           <field id="iceberg_cea"  long_name="Iceberg"                                   standard_name="water_flux_into_sea_water_from_icebergs"   unit="kg/m2/s"  /> 
    300           <field id="iceshelf_cea" long_name="Iceshelf"                                  standard_name="water_flux_into_sea_water_from_iceshelf"   unit="kg/m2/s"  /> 
    301  
    302  
    303           <!-- available if key_oasis3 + conservative method --> 
    304           <field id="rain"          long_name="Liquid precipitation"                                     standard_name="rainfall_flux"                                                                 unit="kg/m2/s"  /> 
    305           <field id="evap_ao_cea"   long_name="Evaporation over ice-free ocean (cell average)"           standard_name="water_evaporation_flux"                                                        unit="kg/m2/s"  /> 
    306           <field id="isnwmlt_cea"   long_name="Snow over Ice melting (cell average)"                     standard_name="surface_snow_melt_flux"                                                        unit="kg/m2/s"  /> 
    307           <field id="fsal_virt_cea" long_name="Virtual salt flux due to ice formation (cell average)"    standard_name="virtual_salt_flux_into_sea_water_due_to_sea_ice_thermodynamics"                unit="kg/m2/s"  /> 
    308           <field id="fsal_real_cea" long_name="Real salt flux due to ice formation (cell average)"       standard_name="downward_sea_ice_basal_salt_flux"                                              unit="kg/m2/s"  /> 
    309           <field id="hflx_rain_cea" long_name="heat flux due to rainfall"                                standard_name="temperature_flux_due_to_rainfall_expressed_as_heat_flux_into_sea_water"        unit="W/m2"     /> 
    310           <field id="hflx_evap_cea" long_name="heat flux due to evaporation"                             standard_name="temperature_flux_due_to_evaporation_expressed_as_heat_flux_out_of_sea_water"   unit="W/m2"     /> 
    311           <field id="hflx_snow_cea" long_name="heat flux due to snow falling"                            standard_name="heat_flux_onto_ocean_and_ice_due_to_snow_thermodynamics"                       unit="W/m2"     /> 
    312           <field id="hflx_snow_ai_cea" long_name="heat flux due to snow falling over ice"                standard_name="heat_flux_onto_ice_due_to_snow_thermodynamics"                                 unit="W/m2"     /> 
    313           <field id="hflx_snow_ao_cea" long_name="heat flux due to snow falling over ice-free ocean"     standard_name="heat_flux_onto_sea_water_due_to_snow_thermodynamics"                           unit="W/m2"     /> 
    314           <field id="hflx_ice_cea"  long_name="heat flux due to ice thermodynamics"                      standard_name="heat_flux_into_sea_water_due_to_sea_ice_thermodynamics"                        unit="W/m2"     /> 
    315           <field id="hflx_rnf_cea"  long_name="heat flux due to runoffs"                                 standard_name="temperature_flux_due_to_runoff_expressed_as_heat_flux_into_sea_water"          unit="W/m2"     /> 
    316           <field id="hflx_cal_cea"  long_name="heat flux due to calving"                                 standard_name="heat_flux_into_sea_water_due_to_calving"                                       unit="W/m2"     /> 
    317           <field id="hflx_icb_cea"  long_name="heat flux due to iceberg"                                 standard_name="heat_flux_into_sea_water_due_to_icebergs"                                      unit="W/m2"     /> 
    318           <field id="hflx_isf_cea"  long_name="heat flux due to iceshelf"                                standard_name="heat_flux_into_sea_water_due_to_iceshelf"                                      unit="W/m2"     /> 
    319           <field id="bicemel_cea"   long_name="Rate of Melt at Sea Ice Base (cell average)"              standard_name="tendency_of_sea_ice_amount_due_to_basal_melting"                               unit="kg/m2/s"  /> 
    320           <field id="licepro_cea"   long_name="Lateral Sea Ice Growth Rate (cell average)"               standard_name="tendency_of_sea_ice_amount_due_to_lateral_growth_of_ice_floes"                 unit="kg/m2/s"  /> 
    321           <field id="snowmel_cea"   long_name="Snow Melt Rate (cell average)"                            standard_name="surface_snow_melt_flux"                                                        unit="kg/m2/s"  /> 
    322           <field id="sntoice_cea"   long_name="Snow-Ice Formation Rate (cell average)"                   standard_name="tendency_of_sea_ice_amount_due_to_snow_conversion"                             unit="kg/m2/s"  /> 
    323           <field id="ticemel_cea"   long_name="Rate of Melt at Upper Surface of Sea Ice (cell average)"  standard_name="tendency_of_sea_ice_amount_due_to_surface_melting"                             unit="kg/m2/s"  /> 
    324  
    325           <!-- ice field (nn_ice=1)  --> 
    326           <field id="ice_cover"    long_name="Ice fraction"                                                 standard_name="sea_ice_area_fraction"                              unit="1"            /> 
    327            
    328           <!-- dilution --> 
    329           <field id="emp_x_sst"    long_name="Concentration/Dilution term on SST"                                                                                              unit="kg*degC/m2/s" /> 
    330           <field id="emp_x_sss"    long_name="Concentration/Dilution term on SSS"                                                                                              unit="kg*1e-3/m2/s" />         
    331           <field id="rnf_x_sst"    long_name="Runoff term on SST"                                                                                                              unit="kg*degC/m2/s" /> 
    332           <field id="rnf_x_sss"    long_name="Runoff term on SSS"                                                                                                              unit="kg*1e-3/m2/s" /> 
    333       
    334      <!-- sbcssm variables --> 
    335           <field id="sst_m"    unit="degC" /> 
    336           <field id="sss_m"    unit="psu"  /> 
    337           <field id="ssu_m"    unit="m/s"  /> 
    338           <field id="ssv_m"    unit="m/s"  /> 
    339           <field id="ssh_m"    unit="m"    /> 
    340           <field id="e3t_m"    unit="m"    /> 
    341           <field id="frq_m"    unit="-"    /> 
    342  
    343    </field_group> 
    344     
    345    <!-- scalar variables --> 
    346    <field_group id="SBC_0D"  grid_ref="grid_1point" > 
    347    </field_group> 
    348  
    349       </field_group> <!-- SBC --> 
    350  
    351       <!-- U grid --> 
    352        
    353       <field_group id="grid_U"   grid_ref="grid_U_2D"> 
    354         <field id="e3u"          long_name="U-cell thickness"                                       standard_name="cell_thickness"              unit="m"          grid_ref="grid_U_3D" /> 
    355         <field id="e3u_0"        long_name="Initial U-cell thickness"                               standard_name="ref_cell_thickness"          unit="m"          grid_ref="grid_U_3D"/> 
    356         <field id="utau"         long_name="Wind Stress along i-axis"                               standard_name="surface_downward_x_stress"   unit="N/m2"                            /> 
    357         <field id="uoce"         long_name="ocean current along i-axis"                             standard_name="sea_water_x_velocity"        unit="m/s"        grid_ref="grid_U_3D" /> 
    358         <field id="uoce_e3u"     long_name="ocean current along i-axis  (thickness weighted)"                                                   unit="m/s"        grid_ref="grid_U_3D"  > uoce * e3u </field> 
    359         <field id="ssu"          long_name="ocean surface current along i-axis"                                                                 unit="m/s"                             /> 
    360         <field id="sbu"          long_name="ocean bottom current along i-axis"                                                                  unit="m/s"                             /> 
    361         <field id="ubar"         long_name="ocean barotropic current along i-axis"                                                              unit="m/s"                             /> 
    362         <field id="uocetr_eff"   long_name="Effective ocean transport along i-axis"                 standard_name="ocean_volume_x_transport"    unit="m3/s"       grid_ref="grid_U_3D" /> 
    363         <field id="uocet"        long_name="ocean transport along i-axis times temperature (CRS)"                                               unit="degC*m/s"   grid_ref="grid_U_3D" /> 
    364         <field id="uoces"        long_name="ocean transport along i-axis times salinity (CRS)"                                                  unit="1e-3*m/s"   grid_ref="grid_U_3D" /> 
    365  
    366         <!-- u-eddy diffusivity coefficients (available if ln_traldf_OFF=F) --> 
    367         <field id="ahtu_2d"      long_name=" surface u-eddy diffusivity coefficient"   unit="m2/s or m4/s" /> 
    368         <field id="ahtu_3d"      long_name=" 3D u-EIV coefficient"                     unit="m2/s or m4/s"      grid_ref="grid_U_3D"/> 
    369         <!-- u-eiv diffusivity coefficients (available if ln_ldfeiv=F) --> 
    370         <field id="aeiu_2d"      long_name=" surface u-EIV coefficient"                unit="m2/s" /> 
    371         <field id="aeiu_3d"      long_name=" 3D u-EIV coefficient"                     unit="m2/s"              grid_ref="grid_U_3D"/> 
    372  
    373         <!-- variables available with MLE (ln_mle=T) --> 
    374         <field id="psiu_mle"     long_name="MLE streamfunction along i-axis"   unit="m3/s"   grid_ref="grid_U_3D" /> 
    375  
    376         <!-- uoce_eiv: available EIV (ln_ldfeiv=T and ln_ldfeiv_dia=T) --> 
    377         <field id="uoce_eiv"     long_name="EIV ocean current along i-axis"   standard_name="bolus_sea_water_x_velocity"   unit="m/s"   grid_ref="grid_U_3D" /> 
    378  
    379         <!-- uoce_bbl: available with ln_trabbl=T and nn_bbl_adv=1 --> 
    380         <field id="uoce_bbl"     long_name="BBL ocean current along i-axis"    unit="m/s"  /> 
    381         <!-- ahu_bbl : available with ln_trabbl=T and nn_bbl_ldf=1 --> 
    382         <field id="ahu_bbl"      long_name="BBL diffusive flux along i-axis"   unit="m3/s" /> 
    383  
    384         <!-- variables available with WAVE (ln_wave=T) --> 
    385         <field id="ustokes"      long_name="Stokes Drift Velocity i-axis"      standard_name="StokesDrift_x_velocity"      unit="m/s"        grid_ref="grid_U_3D" /> 
    386         <field id="ustokes_e3u"  long_name="Stokes Drift Velocity i-axis  (thickness weighted)"                            unit="m/s"        grid_ref="grid_U_3D"  > ustokes * e3u </field> 
    387  
    388         <!-- variable for ice shelves --> 
    389         <field id="utbl"         long_name="zonal current in the Losh tbl"     unit="m/s" /> 
    390  
    391         <field id="u_masstr"      long_name="Ocean Mass X Transport"                                          standard_name="ocean_mass_x_transport"                         unit="kg/s" grid_ref="grid_U_3D" /> 
    392         <field id="u_masstr_vint" long_name="vertical integral of ocean eulerian mass transport along i-axis" standard_name="vertical_integral_of_ocean_mass_x_transport"    unit="kg/s"                      /> 
    393         <field id="u_heattr"      long_name="ocean eulerian heat transport along i-axis"                      standard_name="ocean_heat_x_transport"                         unit="W"                         /> 
    394         <field id="u_salttr"      long_name="ocean eulerian salt transport along i-axis"                      standard_name="ocean_salt_x_transport"                         unit="1e-3*kg/s"                 /> 
    395         <field id="uadv_heattr"   long_name="ocean advective heat transport along i-axis"                     standard_name="advectice_ocean_heat_x_transport"               unit="W"                         /> 
    396         <field id="uadv_salttr"   long_name="ocean advective salt transport along i-axis"                     standard_name="advectice_ocean_salt_x_transport"               unit="1e-3*kg/s"                 /> 
    397         <field id="ueiv_heattr"   long_name="ocean bolus heat transport along i-axis"                         standard_name="ocean_heat_x_transport_due_to_bolus_advection"  unit="W"                         /> 
    398         <field id="ueiv_salttr"   long_name="ocean bolus salt transport along i-axis"                         standard_name="ocean_salt_x_transport_due_to_bolus_advection"  unit="Kg"                        /> 
    399         <field id="ueiv_heattr3d" long_name="ocean bolus heat transport along i-axis"                         standard_name="ocean_heat_x_transport_due_to_bolus_advection"  unit="W"    grid_ref="grid_U_3D" /> 
    400         <field id="ueiv_salttr3d" long_name="ocean bolus salt transport along i-axis"                         standard_name="ocean_salt_x_transport_due_to_bolus_advection"  unit="kg"   grid_ref="grid_U_3D" /> 
    401         <field id="udiff_heattr"  long_name="ocean diffusion heat transport along i-axis"                     standard_name="ocean_heat_x_transport_due_to_diffusion"        unit="W"                         /> 
    402         <field id="udiff_salttr"  long_name="ocean diffusion salt transport along i-axis"                     standard_name="ocean_salt_x_transport_due_to_diffusion"        unit="1e-3*kg/s"                 /> 
    403       </field_group> 
    404        
    405       <!-- V grid --> 
    406        
    407       <field_group id="grid_V"   grid_ref="grid_V_2D"> 
    408         <field id="e3v"          long_name="V-cell thickness"                                       standard_name="cell_thickness"              unit="m"          grid_ref="grid_V_3D" /> 
    409         <field id="e3v_0"        long_name="Initial V-cell thickness"                               standard_name="ref_cell_thickness"          unit="m"          grid_ref="grid_V_3D" /> 
    410         <field id="vtau"         long_name="Wind Stress along j-axis"                               standard_name="surface_downward_y_stress"   unit="N/m2"                            /> 
    411         <field id="voce"         long_name="ocean current along j-axis"                             standard_name="sea_water_y_velocity"        unit="m/s"        grid_ref="grid_V_3D" /> 
    412         <field id="voce_e3v"     long_name="ocean current along j-axis  (thickness weighted)"                                                   unit="m/s"        grid_ref="grid_V_3D"  > voce * e3v </field> 
    413         <field id="ssv"          long_name="ocean surface current along j-axis"                                                                 unit="m/s"                             /> 
    414         <field id="sbv"          long_name="ocean bottom current along j-axis"                                                                  unit="m/s"                             /> 
    415         <field id="vbar"         long_name="ocean barotropic current along j-axis"                                                              unit="m/s"                             /> 
    416         <field id="vocetr_eff"   long_name="Effective ocean transport along j-axis"                 standard_name="ocean_volume_y_transport"    unit="m3/s"       grid_ref="grid_V_3D" /> 
    417         <field id="vocet"        long_name="ocean transport along j-axis times temperature (CRS)"                                               unit="degC*m/s"   grid_ref="grid_V_3D" /> 
    418         <field id="voces"        long_name="ocean transport along j-axis times salinity (CRS)"                                                  unit="1e-3*m/s"   grid_ref="grid_V_3D" /> 
    419  
    420         <!-- v-eddy diffusivity coefficients (available if ln_traldf_OFF=F) --> 
    421         <field id="ahtv_2d"      long_name=" surface v-eddy diffusivity coefficient"     unit="m2/s or (m4/s)^1/2" /> 
    422         <field id="ahtv_3d"      long_name=" 3D v-eddy diffusivity coefficient"          unit="m2/s or (m4/s)^1/2"           grid_ref="grid_V_3D"/> 
    423         <!-- v-eiv diffusivity coefficients (available if ln_ldfeiv=F) --> 
    424         <field id="aeiv_2d"      long_name=" surface v-EIV coefficient"                  unit="m2/s" /> 
    425         <field id="aeiv_3d"      long_name=" 3D v-EIV coefficient"                       unit="m2/s"                         grid_ref="grid_V_3D" /> 
    426  
    427         <!-- variables available with MLE (ln_mle=T) --> 
    428         <field id="psiv_mle"     long_name="MLE streamfunction along j-axis"   unit="m3/s"   grid_ref="grid_V_3D" /> 
    429  
    430         <!-- voce_eiv: available EIV (ln_ldfeiv=T and ln_ldfeiv_dia=T)  --> 
    431         <field id="voce_eiv"     long_name="EIV ocean current along j-axis"   standard_name="bolus_sea_water_y_velocity"   unit="m/s"   grid_ref="grid_V_3D" /> 
    432  
    433         <!-- voce_bbl: available with ln_trabbl=T and nn_bbl_adv=1 --> 
    434         <field id="voce_bbl"     long_name="BBL ocean current along j-axis"    unit="m/s"  /> 
    435         <!-- ahu_bbl : available with ln_trabbl=T and nn_bbl_ldf=1 --> 
    436         <field id="ahv_bbl"      long_name="BBL diffusive flux along j-axis"   unit="m3/s" /> 
    437  
    438         <!-- variables available with WAVE (ln_wave=T) --> 
    439         <field id="vstokes"      long_name="Stokes Drift Velocity j-axis"      standard_name="StokesDrift_y_velocity"      unit="m/s"        grid_ref="grid_V_3D" /> 
    440         <field id="vstokes_e3v"  long_name="Stokes Drift Velocity j-axis  (thickness weighted)"                            unit="m/s"        grid_ref="grid_V_3D"  > vstokes * e3v </field> 
    441  
    442         <!-- variable for ice shelves --> 
    443         <field id="vtbl"         long_name="meridional current in the Losh tbl"   unit="m/s" /> 
    444  
    445         <!-- variables available with diaar5 --> 
    446         <field id="v_masstr"      long_name="ocean eulerian mass transport along j-axis"    standard_name="ocean_mass_y_transport"                          unit="kg/s" grid_ref="grid_V_3D" /> 
    447         <field id="v_heattr"      long_name="ocean eulerian heat transport along j-axis"    standard_name="ocean_heat_y_transport"                          unit="W"                         /> 
    448         <field id="v_salttr"      long_name="ocean eulerian salt transport along i-axis"    standard_name="ocean_salt_y_transport"                          unit="1e-3*kg/s"                 /> 
    449         <field id="vadv_heattr"   long_name="ocean advective heat transport along j-axis"   standard_name="advectice_ocean_heat_y_transport"                unit="W"                         /> 
    450         <field id="vadv_salttr"   long_name="ocean advective salt transport along j-axis"   standard_name="advectice_ocean_salt_y_transport"                unit="1e-3*kg/s"                 /> 
    451         <field id="veiv_heattr"   long_name="ocean bolus heat transport along j-axis"       standard_name="ocean_heat_y_transport_due_to_bolus_advection"   unit="W"                         /> 
    452         <field id="veiv_salttr"   long_name="ocean bolus salt transport along j-axis"       standard_name="ocean_salt_x_transport_due_to_bolus_advection"   unit="Kg"                        /> 
    453         <field id="veiv_heattr3d" long_name="ocean bolus heat transport along j-axis"       standard_name="ocean_heat_y_transport_due_to_bolus_advection"   unit="W"    grid_ref="grid_V_3D" /> 
    454         <field id="veiv_salttr3d" long_name="ocean bolus salt transport along j-axis"       standard_name="ocean_salt_y_transport_due_to_bolus_advection"   unit="kg"   grid_ref="grid_V_3D" /> 
    455         <field id="vdiff_heattr"  long_name="ocean diffusion heat transport along j-axis"   standard_name="ocean_heat_y_transport_due_to_diffusion"         unit="W"                         /> 
    456         <field id="vdiff_salttr"  long_name="ocean diffusion salt transport along j-axis"   standard_name="ocean_salt_y_transport_due_to_diffusion"         unit="1e-3*kg/s"                 /> 
    457       </field_group> 
    458        
    459       <!-- W grid --> 
    460        
    461       <field_group id="grid_W" grid_ref="grid_W_3D"> 
    462         <field id="e3w"          long_name="W-cell thickness"                              standard_name="cell_thickness"                         unit="m"    /> 
    463         <field id="woce"         long_name="ocean vertical velocity"                       standard_name="upward_sea_water_velocity"              unit="m/s"  /> 
    464         <field id="wocetr_eff"   long_name="effective ocean vertical transport"                                                                   unit="m3/s" /> 
    465  
    466         <!-- woce_eiv: available with EIV  (ln_ldfeiv=T and ln_ldfeiv_dia=T)  --> 
    467         <field id="woce_eiv"     long_name="EIV ocean vertical velocity"                    standard_name="bolus_upward_sea_water_velocity"       unit="m/s"  /> 
    468  
    469         <field id="avt"          long_name="vertical eddy diffusivity"                      standard_name="ocean_vertical_heat_diffusivity"       unit="m2/s" /> 
    470         <field id="logavt"       long_name="logarithm of vertical eddy diffusivity"         standard_name="ocean_vertical_heat_diffusivity"       unit="m2/s" /> 
    471         <field id="avm"          long_name="vertical eddy viscosity"                        standard_name="ocean_vertical_momentum_diffusivity"   unit="m2/s" /> 
    472  
    473         <!-- avs: /= avt with ln_zdfddm=T --> 
    474         <field id="avs"          long_name="salt vertical eddy diffusivity"                 standard_name="ocean_vertical_salt_diffusivity"       unit="m2/s" /> 
    475         <field id="logavs"       long_name="logarithm of salt vertical eddy diffusivity"    standard_name="ocean_vertical_heat_diffusivity"       unit="m2/s" /> 
    476  
    477         <!-- avt_evd and avm_evd: available with ln_zdfevd --> 
    478         <field id="avt_evd"      long_name="convective enhancement of vertical diffusivity" standard_name="ocean_vertical_tracer_diffusivity_due_to_convection"     unit="m2/s" /> 
    479         <field id="avm_evd"      long_name="convective enhancement of vertical viscosity"   standard_name="ocean_vertical_momentum_diffusivity_due_to_convection"   unit="m2/s" /> 
    480  
    481         <!-- avt_tide: available with ln_zdfiwm=T --> 
    482         <field id="av_ratio"     long_name="S over T diffusivity ratio"                     standard_name="salinity_over_temperature_diffusivity_ratio"                     unit="1"    /> 
    483         <field id="av_wave"      long_name="internal wave-induced vertical diffusivity"     standard_name="ocean_vertical_tracer_diffusivity_due_to_internal_waves"         unit="m2/s" /> 
    484         <field id="bflx_iwm"     long_name="internal wave-induced buoyancy flux"            standard_name="buoyancy_flux_due_to_internal_waves"                             unit="W/kg" /> 
    485         <field id="pcmap_iwm"    long_name="power consumed by wave-driven mixing"           standard_name="vertically_integrated_power_consumption_by_wave_driven_mixing"   unit="W/m2"      grid_ref="grid_W_2D" /> 
    486         <field id="emix_iwm"     long_name="power density available for mixing"             standard_name="power_available_for_mixing_from_breaking_internal_waves"         unit="W/kg" /> 
    487  
    488         <!-- variables available with WAVE (ln_wave=T) --> 
    489         <field id="wstokes"      long_name="Stokes Drift vertical velocity"                 standard_name="upward_StokesDrift_velocity"   unit="m/s" /> 
    490  
    491         <!-- variables available with diaar5 -->    
    492         <field id="w_masstr"     long_name="vertical mass transport"                        standard_name="upward_ocean_mass_transport"             unit="kg/s"   /> 
    493         <field id="w_masstr2"    long_name="square of vertical mass transport"              standard_name="square_of_upward_ocean_mass_transport"   unit="kg2/s2" /> 
    494  
    495       </field_group> 
    496        
    497       <!-- F grid --> 
    498       <!-- f-eddy viscosity coefficients (ldfdyn) --> 
    499       <field id="ahmf_2d"      long_name=" surface f-eddy viscosity coefficient"   unit="m2/s or m4/s" /> 
    500       <field id="ahmf_3d"      long_name=" 3D      f-eddy viscosity coefficient"   unit="m2/s or m4/s"  grid_ref="grid_T_3D"/> 
    501  
    502       <field_group id="scalar"  grid_ref="grid_T_2D"  > 
    503          <!-- Need to have a salinity reference climatological file : sali_ref_clim_monthly --> 
    504         <field id="voltot"     long_name="global total volume"                          standard_name="sea_water_volume"                               unit="m3"   /> 
    505         <field id="sshtot"     long_name="global mean ssh"                              standard_name="global_average_sea_level_change"                unit="m"    /> 
    506         <field id="sshsteric"  long_name="global mean ssh steric"                       standard_name="global_average_steric_sea_level_change"         unit="m"    /> 
    507         <field id="sshthster"  long_name="global mean ssh thermosteric"                 standard_name="global_average_thermosteric_sea_level_change"   unit="m"    /> 
    508         <field id="masstot"    long_name="global total mass"                            standard_name="sea_water_mass"                                 unit="kg"   /> 
    509         <field id="temptot"    long_name="global mean temperature"                      standard_name="sea_water_potential_temperature"                unit="degC" /> 
    510         <field id="saltot"     long_name="global mean salinity"                         standard_name="sea_water_salinity"                             unit="1e-3" /> 
    511         <field id="fram_trans" long_name="Sea Ice Mass Transport Through Fram Strait"   standard_name="sea_ice_transport_across_line"                  unit="kg/s" /> 
    512  
    513          <!-- available with ln_diahsb --> 
    514         <field id="bgtemper"     long_name="drift in global mean temperature wrt timestep 1"                 standard_name="change_over_time_in_sea_water_potential_temperature"   unit="degC"     /> 
    515         <field id="bgsaline"     long_name="drift in global mean salinity wrt timestep 1"                    standard_name="change_over_time_in_sea_water_practical_salinity"      unit="1e-3"     /> 
    516         <field id="bgheatco"     long_name="drift in global mean heat content wrt timestep 1"                                                                                      unit="1.e20J"   /> 
    517         <field id="bgheatfx"     long_name="drift in global mean heat flux    wrt timestep 1"                                                                                      unit="W/m2"     /> 
    518         <field id="bgsaltco"     long_name="drift in global mean salt content wrt timestep 1"                                                                                      unit="1e-3*km3" /> 
    519         <field id="bgvolssh"     long_name="drift in global mean ssh volume wrt timestep 1"                                                                                        unit="km3"      /> 
    520         <field id="bgvole3t"     long_name="drift in global mean volume variation (e3t) wrt timestep 1"                                                                            unit="km3"      /> 
    521         <field id="bgfrcvol"     long_name="global mean volume from forcing"                                                                                                       unit="km3"      /> 
    522         <field id="bgfrctem"     long_name="global mean heat content from forcing"                                                                                                 unit="1.e20J"   /> 
    523         <field id="bgfrchfx"     long_name="global mean heat flux from forcing"                                                                                                    unit="W/m2"     /> 
    524         <field id="bgfrcsal"     long_name="global mean salt content from forcing"                                                                                                 unit="1e-3*km3" /> 
    525         <field id="bgmistem"     long_name="global mean temperature error due to free surface (linssh true)"                                                                       unit="degC"     /> 
    526         <field id="bgmissal"     long_name="global mean salinity error due to free surface (linssh true)"                                                                          unit="1e-3"     /> 
    527       </field_group> 
    528        
    529       <!-- variables available with key_float --> 
    530  
    531       <field_group id="floatvar" grid_ref="grid_T_nfloat"  operation="instant" > 
    532         <field id="traj_lon"      long_name="floats longitude"                                                           unit="degrees_east"  /> 
    533         <field id="traj_lat"      long_name="floats latitude"                                                            unit="degrees_north" /> 
    534         <field id="traj_dep"      long_name="floats depth"                                                               unit="m"             /> 
    535         <field id="traj_temp"     long_name="floats temperature"       standard_name="sea_water_potential_temperature"   unit="degC"          /> 
    536         <field id="traj_salt"     long_name="floats salinity"          standard_name="sea_water_practical_salinity"      unit="1e-3"          /> 
    537         <field id="traj_dens"     long_name="floats in-situ density"   standard_name="sea_water_density"                 unit="kg/m3"         /> 
    538         <field id="traj_group"    long_name="floats group"                                                               unit="1"             /> 
    539       </field_group> 
    540  
    541       <!-- variables available with iceberg trajectories --> 
    542  
    543       <field_group id="icbvar" domain_ref="grid_T"  >  
    544         <field id="berg_melt"          long_name="icb melt rate of icebergs"                       unit="kg/m2/s"                    /> 
    545         <field id="berg_melt_hcflx"    long_name="icb heat flux to ocean due to melting heat content"   unit="J/m2/s"                /> 
    546         <field id="berg_melt_qlat"     long_name="icb heat flux to ocean due to melting latent heat"    unit="J/m2/s"                /> 
    547         <field id="berg_buoy_melt"     long_name="icb buoyancy component of iceberg melt rate"     unit="kg/m2/s"                    /> 
    548         <field id="berg_eros_melt"     long_name="icb erosion component of iceberg melt rate"      unit="kg/m2/s"                    /> 
    549         <field id="berg_conv_melt"     long_name="icb convective component of iceberg melt rate"   unit="kg/m2/s"                    /> 
    550         <field id="berg_virtual_area"  long_name="icb virtual coverage by icebergs"                unit="m2"                         /> 
    551         <field id="bits_src"           long_name="icb mass source of bergy bits"                   unit="kg/m2/s"                    /> 
    552         <field id="bits_melt"          long_name="icb melt rate of bergy bits"                     unit="kg/m2/s"                    /> 
    553         <field id="bits_mass"          long_name="icb bergy bit density field"                     unit="kg/m2"                      /> 
    554         <field id="berg_mass"          long_name="icb iceberg density field"                       unit="kg/m2"                      /> 
    555         <field id="calving"            long_name="icb calving mass input"                          unit="kg/s"                       /> 
    556         <field id="berg_floating_melt" long_name="icb melt rate of icebergs + bits"                unit="kg/m2/s"                    /> 
    557         <field id="berg_real_calving"  long_name="icb calving into iceberg class"                  unit="kg/s"     axis_ref="icbcla" /> 
    558         <field id="berg_stored_ice"    long_name="icb accumulated ice mass by class"               unit="kg"       axis_ref="icbcla" /> 
    559       </field_group> 
    560  
    561       <!-- Poleward transport : ptr -->      
    562       <field_group id="diaptr" >   
    563         <field id="zomsfglo"          long_name="Meridional Stream-Function: Global"           unit="Sv"        grid_ref="gznl_W_3D" /> 
    564         <field id="zomsfatl"          long_name="Meridional Stream-Function: Atlantic"         unit="Sv"        grid_ref="gznl_W_3D" /> 
    565         <field id="zomsfpac"          long_name="Meridional Stream-Function: Pacific"          unit="Sv"        grid_ref="gznl_W_3D" /> 
    566         <field id="zomsfind"          long_name="Meridional Stream-Function: Indian"           unit="Sv"        grid_ref="gznl_W_3D" /> 
    567         <field id="zomsfipc"          long_name="Meridional Stream-Function: Pacific+Indian"   unit="Sv"        grid_ref="gznl_W_3D" /> 
    568         <field id="zotemglo"          long_name="Zonal Mean Temperature : Global"              unit="degree_C"  grid_ref="gznl_T_3D" /> 
    569         <field id="zotematl"          long_name="Zonal Mean Temperature : Atlantic"            unit="degree_C"  grid_ref="gznl_T_3D" /> 
    570         <field id="zotempac"          long_name="Zonal Mean Temperature : Pacific"             unit="degree_C"  grid_ref="gznl_T_3D" /> 
    571         <field id="zotemind"          long_name="Zonal Mean Temperature : Indian"              unit="degree_C"  grid_ref="gznl_T_3D" /> 
    572         <field id="zotemipc"          long_name="Zonal Mean Temperature : Pacific+Indian"      unit="degree_C"  grid_ref="gznl_T_3D" /> 
    573         <field id="zosalglo"          long_name="Zonal Mean Salinity : Global"                 unit="0.001"     grid_ref="gznl_T_3D" /> 
    574         <field id="zosalatl"          long_name="Zonal Mean Salinity : Atlantic"               unit="0.001"     grid_ref="gznl_T_3D" /> 
    575         <field id="zosalpac"          long_name="Zonal Mean Salinity : Pacific"                unit="0.001"     grid_ref="gznl_T_3D" /> 
    576         <field id="zosalind"          long_name="Zonal Mean Salinity : Indian"                 unit="0.001"     grid_ref="gznl_T_3D" /> 
    577         <field id="zosalipc"          long_name="Zonal Mean Salinity : Pacific+Indian"         unit="0.001"     grid_ref="gznl_T_3D" /> 
    578         <field id="zosrfglo"          long_name="Zonal Mean Surface"                           unit="m2"        grid_ref="gznl_T_3D" /> 
    579         <field id="zosrfatl"          long_name="Zonal Mean Surface : Atlantic"                unit="m2"        grid_ref="gznl_T_3D" /> 
    580         <field id="zosrfpac"          long_name="Zonal Mean Surface : Pacific"                 unit="m2"        grid_ref="gznl_T_3D" /> 
    581         <field id="zosrfind"          long_name="Zonal Mean Surface : Indian"                  unit="m2"        grid_ref="gznl_T_3D" /> 
    582         <field id="zosrfipc"          long_name="Zonal Mean Surface : Pacific+Indian"          unit="m2"        grid_ref="gznl_T_3D" /> 
    583         <field id="sophtadv"          long_name="Advective Heat Transport"                     unit="PW"        grid_ref="gznl_T_2D" /> 
    584         <field id="sophtadv_atl"      long_name="Advective Heat Transport: Atlantic"           unit="PW"        grid_ref="gznl_T_2D" /> 
    585         <field id="sophtadv_pac"      long_name="Advective Heat Transport: Pacific"            unit="PW"        grid_ref="gznl_T_2D" /> 
    586         <field id="sophtadv_ind"      long_name="Advective Heat Transport: Indian"             unit="PW"        grid_ref="gznl_T_2D" /> 
    587         <field id="sophtadv_ipc"      long_name="Advective Heat Transport: Pacific+Indian"     unit="PW"        grid_ref="gznl_T_2D" /> 
    588         <field id="sophtldf"          long_name="Diffusive Heat Transport"                     unit="PW"        grid_ref="gznl_T_2D" /> 
    589         <field id="sophtldf_atl"      long_name="Diffusive Heat Transport: Atlantic"           unit="PW"        grid_ref="gznl_T_2D" /> 
    590         <field id="sophtldf_pac"      long_name="Diffusive Heat Transport: Pacific"            unit="PW"        grid_ref="gznl_T_2D" /> 
    591         <field id="sophtldf_ind"      long_name="Diffusive Heat Transport: Indian"             unit="PW"        grid_ref="gznl_T_2D" /> 
    592         <field id="sophtldf_ipc"      long_name="Diffusive Heat Transport: Pacific+Indian"     unit="PW"        grid_ref="gznl_T_2D" /> 
    593         <field id="sophtove"          long_name="Overturning Heat Transport"                   unit="PW"        grid_ref="gznl_T_2D" /> 
    594         <field id="sophtove_atl"      long_name="Overturning Heat Transport: Atlantic"         unit="PW"        grid_ref="gznl_T_2D" /> 
    595         <field id="sophtove_pac"      long_name="Overturning Heat Transport: Pacific"          unit="PW"        grid_ref="gznl_T_2D" /> 
    596         <field id="sophtove_ind"      long_name="Overturning Heat Transport: Indian"           unit="PW"        grid_ref="gznl_T_2D" /> 
    597         <field id="sophtove_ipc"      long_name="Overturning Heat Transport: Pacific+Indian"   unit="PW"        grid_ref="gznl_T_2D" /> 
    598         <field id="sophtbtr"          long_name="Barotropic Heat Transport"                    unit="PW"        grid_ref="gznl_T_2D" /> 
    599         <field id="sophtbtr_atl"      long_name="Barotropic Heat Transport: Atlantic"          unit="PW"        grid_ref="gznl_T_2D" /> 
    600         <field id="sophtbtr_pac"      long_name="Barotropic Heat Transport: Pacific"           unit="PW"        grid_ref="gznl_T_2D" /> 
    601         <field id="sophtbtr_ind"      long_name="Barotropic Heat Transport: Indian"            unit="PW"        grid_ref="gznl_T_2D" /> 
    602         <field id="sophtbtr_ipc"      long_name="Barotropic Heat Transport: Pacific+Indian"    unit="PW"        grid_ref="gznl_T_2D" /> 
    603         <field id="sophteiv"          long_name="Heat Transport from mesoscale eddy advection"                     unit="PW"       grid_ref="gznl_T_2D" /> 
    604         <field id="sophteiv_atl"      long_name="Heat Transport from mesoscale eddy advection: Atlantic"           unit="PW"       grid_ref="gznl_T_2D" /> 
    605         <field id="sophteiv_pac"      long_name="Heat Transport from mesoscale eddy advection: Pacific"            unit="PW"       grid_ref="gznl_T_2D" /> 
    606         <field id="sophteiv_ind"      long_name="Heat Transport from mesoscale eddy advection: Indian"             unit="PW"       grid_ref="gznl_T_2D" /> 
    607         <field id="sophteiv_ipc"      long_name="Heat Transport from mesoscale eddy advection: Pacific+Indian"     unit="PW"       grid_ref="gznl_T_2D" /> 
    608         <field id="sopstadv"          long_name="Advective Salt Transport"                     unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    609         <field id="sopstadv_atl"      long_name="Advective Salt Transport: Atlantic"           unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    610         <field id="sopstadv_pac"      long_name="Advective Salt Transport: Pacific"            unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    611         <field id="sopstadv_ind"      long_name="Advective Salt Transport: Indian"             unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    612         <field id="sopstadv_ipc"      long_name="Advective Salt Transport: Pacific+Indian"     unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    613         <field id="sopstove"          long_name="Overturning Salt Transport"                   unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    614         <field id="sopstove_atl"      long_name="Overturning Salt Transport: Atlantic"         unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    615         <field id="sopstove_pac"      long_name="Overturning Salt Transport: Pacific"          unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    616         <field id="sopstove_ind"      long_name="Overturning Salt Transport: Indian"           unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    617         <field id="sopstove_ipc"      long_name="Overturning Salt Transport: Pacific+Indian"   unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    618         <field id="sopstbtr"          long_name="Barotropic Salt Transport"                    unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    619         <field id="sopstbtr_atl"      long_name="Barotropic Salt Transport: Atlantic"          unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    620         <field id="sopstbtr_pac"      long_name="Barotropic Salt Transport: Pacific"           unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    621         <field id="sopstbtr_ind"      long_name="Barotropic Salt Transport: Indian"            unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    622         <field id="sopstbtr_ipc"      long_name="Barotropic Salt Transport: Pacific+Indian"    unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    623         <field id="sopstldf"          long_name="Diffusive Salt Transport"                     unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    624         <field id="sopstldf_atl"      long_name="Diffusive Salt Transport: Atlantic"           unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    625         <field id="sopstldf_pac"      long_name="Diffusive Salt Transport: Pacific"            unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    626         <field id="sopstldf_ind"      long_name="Diffusive Salt Transport: Indian"             unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    627         <field id="sopstldf_ipc"      long_name="Diffusive Salt Transport: Pacific+Indian"     unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
    628         <field id="sopsteiv"          long_name="Salt Transport from mesoscale eddy advection"                     unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
    629         <field id="sopsteiv_atl"      long_name="Salt Transport from mesoscale eddy advection: Atlantic"           unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
    630         <field id="sopsteiv_pac"      long_name="Salt Transport from mesoscale eddy advection: Pacific"            unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
    631         <field id="sopsteiv_ind"      long_name="Salt Transport from mesoscale eddy advection: Indian"             unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
    632         <field id="sopsteiv_ipc"      long_name="Salt Transport from mesoscale eddy advection: Pacific+Indian"     unit="Giga g/s"       grid_ref="gznl_T_2D" />        
    633       </field_group> 
    634  
    635     <!--  
    636 ============================================================================================================ 
    637                   Physical ocean model trend diagnostics : temperature, KE, PE, momentum 
    638 ============================================================================================================ 
    639     --> 
    640  
    641    <!-- variables available with ln_tra_trd --> 
    642    <!-- Asselin trends  calculated on odd time steps--> 
    643    <field_group id="trendT_odd"  grid_ref="grid_T_3D"> 
    644      <field id="ttrd_atf"      long_name="temperature-trend: asselin time filter"       unit="degree_C/s" /> 
    645      <field id="strd_atf"      long_name="salinity   -trend: asselin time filter"       unit="0.001/s" /> 
    646      <!-- Thickness weighted versions: --> 
    647      <field id="ttrd_atf_e3t"      unit="degC/s * m"  >  ttrd_atf * e3t </field> 
    648      <field id="strd_atf_e3t"      unit="1e-3/s * m"  >  strd_atf * e3t </field> 
    649      <!-- OMIP  layer-integrated trends --> 
    650      <field id="ttrd_atf_li"      long_name="layer integrated heat-trend: asselin time filter "       unit="W/m^2" > ttrd_atf_e3t * 1026.0 * 3991.86795711963  </field> 
    651      <field id="strd_atf_li"      long_name="layer integrated salt   -trend: asselin time filter "       unit="kg/(m^2 s)" > strd_atf_e3t * 1026.0 * 0.001 </field> 
    652    </field_group> 
    653  
    654    <!-- Other trends  calculated on even time steps--> 
    655    <field_group id="trendT_even" grid_ref="grid_T_3D"> 
    656      <field id="ttrd_xad"      long_name="temperature-trend: i-advection"                                                                                          unit="degC/s"                        /> 
    657      <field id="strd_xad"      long_name="salinity   -trend: i-advection"                                                                                          unit="1e-3/s"                        /> 
    658      <field id="ttrd_yad"      long_name="temperature-trend: j-advection"                                                                                          unit="degC/s"                        /> 
    659      <field id="strd_yad"      long_name="salinity   -trend: j-advection"                                                                                          unit="1e-3/s"                        /> 
    660      <field id="ttrd_zad"      long_name="temperature-trend: k-advection"                                                                                          unit="degC/s"                        /> 
    661      <field id="strd_zad"      long_name="salinity   -trend: k-advection"                                                                                          unit="1e-3/s"                        /> 
    662      <field id="ttrd_ad"       long_name="temperature-trend: advection"               standard_name="tendency_of_sea_water_temperature_due_to_advection"           unit="degC/s"                         > sqrt( ttrd_xad^2 + ttrd_yad^2 + ttrd_zad^2 ) </field> 
    663      <field id="strd_ad"       long_name="salinity   -trend: advection"               standard_name="tendency_of_sea_water_salinity_due_to_advection"              unit="1e-3/s"                         > sqrt( strd_xad^2 + strd_yad^2 + strd_zad^2 ) </field> 
    664      <field id="ttrd_totad"    long_name="temperature-trend: total advection"         standard_name="tendency_of_sea_water_salinity_due_to_advection"              unit="degC/s"                        /> 
    665      <field id="strd_totad"    long_name="salinity   -trend: total advection"         standard_name="tendency_of_sea_water_salinity_due_to_advection"              unit="1e-3/s"                        /> 
    666      <field id="ttrd_sad"      long_name="temperature-trend: surface adv. (linssh true)"                                                                                unit="degC/s"   grid_ref="grid_T_2D" /> 
    667      <field id="strd_sad"      long_name="salinity   -trend: surface adv. (linssh true)"                                                                                unit="1e-3/s"   grid_ref="grid_T_2D" /> 
    668      <field id="ttrd_ldf"      long_name="temperature-trend: lateral  diffusion"      standard_name="tendency_of_sea_water_temperature_due_to_horizontal_mixing"   unit="degC/s"                        /> 
    669      <field id="strd_ldf"      long_name="salinity   -trend: lateral  diffusion"      standard_name="tendency_of_sea_water_salinity_due_to_horizontal_mixing"      unit="1e-3/s"                        /> 
    670      <field id="ttrd_zdf"      long_name="temperature-trend: vertical diffusion"      standard_name="tendency_of_sea_water_temperature_due_to_vertical_mixing"     unit="degC/s"                        /> 
    671      <field id="strd_zdf"      long_name="salinity   -trend: vertical diffusion"      standard_name="tendency_of_sea_water_salinity_due_to_vertical_mixing"        unit="1e-3/s"                        /> 
    672      <field id="ttrd_evd"      long_name="temperature-trend: EVD convection"                                                                                       unit="degC/s"                        /> 
    673      <field id="strd_evd"      long_name="salinity   -trend: EVD convection"                                                                                       unit="1e-3/s"                        /> 
    674  
    675      <!-- ln_traldf_iso=T only (iso-neutral diffusion) --> 
    676      <field id="ttrd_iso"      long_name="temperature-trend: isopycnal diffusion"                             unit="degC/s" > ttrd_ldf + ttrd_zdf - ttrd_zdfp </field> 
    677      <field id="strd_iso"      long_name="salinity   -trend: isopycnal diffusion"                             unit="1e-3/s" > strd_ldf + strd_zdf - strd_zdfp </field> 
    678      <field id="ttrd_zdfp"     long_name="temperature-trend: pure vert. diffusion"   unit="degC/s" /> 
    679      <field id="strd_zdfp"     long_name="salinity   -trend: pure vert. diffusion"   unit="1e-3/s" /> 
    680  
    681      <!-- --> 
    682      <field id="ttrd_dmp"      long_name="temperature-trend: interior restoring"        unit="degC/s" /> 
    683      <field id="strd_dmp"      long_name="salinity   -trend: interior restoring"        unit="1e-3/s" /> 
    684      <field id="ttrd_bbl"      long_name="temperature-trend: bottom boundary layer"     unit="degC/s" /> 
    685      <field id="strd_bbl"      long_name="salinity   -trend: bottom boundary layer"     unit="1e-3/s" /> 
    686      <field id="ttrd_npc"      long_name="temperature-trend: non-penetrative conv."     unit="degC/s" /> 
    687      <field id="strd_npc"      long_name="salinity   -trend: non-penetrative conv."     unit="1e-3/s" /> 
    688      <field id="ttrd_qns"      long_name="temperature-trend: non-solar flux + runoff"   unit="degC/s" grid_ref="grid_T_2D" /> 
    689      <field id="strd_cdt"      long_name="salinity   -trend: C/D term       + runoff"   unit="degC/s" grid_ref="grid_T_2D" /> 
    690      <field id="ttrd_qsr"      long_name="temperature-trend: solar penetr. heating"     unit="degC/s" /> 
    691      <field id="ttrd_bbc"      long_name="temperature-trend: geothermal heating"        unit="degC/s" /> 
    692  
    693      <!-- Thickness weighted versions: --> 
    694      <field id="ttrd_xad_e3t"      unit="degC/s * m" >  ttrd_xad * e3t </field> 
    695      <field id="strd_xad_e3t"      unit="1e-3/s * m" >  strd_xad * e3t </field> 
    696      <field id="ttrd_yad_e3t"      unit="degC/s * m" >  ttrd_yad * e3t </field> 
    697      <field id="strd_yad_e3t"      unit="1e-3/s * m" >  strd_yad * e3t </field> 
    698      <field id="ttrd_zad_e3t"      unit="degC/s * m" >  ttrd_zad * e3t </field> 
    699      <field id="strd_zad_e3t"      unit="1e-3/s * m" >  strd_zad * e3t </field> 
    700      <field id="ttrd_ad_e3t"       unit="degC/s * m" >  ttrd_ad  * e3t </field> 
    701      <field id="strd_ad_e3t"       unit="1e-3/s * m" >  strd_ad  * e3t </field> 
    702      <field id="ttrd_totad_e3t"    unit="degC/s * m" >  ttrd_totad  * e3t </field> 
    703      <field id="strd_totad_e3t"    unit="1e-3/s * m" >  strd_totad  * e3t </field> 
    704      <field id="ttrd_ldf_e3t"      unit="degC/s * m" >  ttrd_ldf * e3t </field> 
    705      <field id="strd_ldf_e3t"      unit="1e-3/s * m" >  strd_ldf * e3t </field> 
    706      <field id="ttrd_zdf_e3t"      unit="degC/s * m" >  ttrd_zdf * e3t </field> 
    707      <field id="strd_zdf_e3t"      unit="1e-3/s * m" >  strd_zdf * e3t </field> 
    708      <field id="ttrd_evd_e3t"      unit="degC/s * m" >  ttrd_evd * e3t </field> 
    709      <field id="strd_evd_e3t"      unit="1e-3/s * m" >  strd_evd * e3t </field> 
    710  
    711      <!-- ln_traldf_iso=T only (iso-neutral diffusion) --> 
    712      <field id="ttrd_iso_e3t"      unit="degC/s * m"  >  ttrd_iso * e3t </field> 
    713      <field id="strd_iso_e3t"      unit="1e-3/s * m"  >  strd_iso * e3t </field> 
    714      <field id="ttrd_zdfp_e3t"     unit="degC/s * m"  >  ttrd_zdfp * e3t </field> 
    715      <field id="strd_zdfp_e3t"     unit="1e-3/s * m"  >  strd_zdfp * e3t </field> 
    716  
    717      <!-- --> 
    718      <field id="ttrd_dmp_e3t"      unit="degC/s * m"  >  ttrd_dmp * e3t </field> 
    719      <field id="strd_dmp_e3t"      unit="1e-3/s * m"  >  strd_dmp * e3t </field> 
    720      <field id="ttrd_bbl_e3t"      unit="degC/s * m"  >  ttrd_bbl * e3t </field> 
    721      <field id="strd_bbl_e3t"      unit="1e-3/s * m"  >  strd_bbl * e3t </field> 
    722      <field id="ttrd_npc_e3t"      unit="degC/s * m"  >  ttrd_npc * e3t </field> 
    723      <field id="strd_npc_e3t"      unit="1e-3/s * m"  >  strd_npc * e3t </field> 
    724      <field id="ttrd_qns_e3t"      unit="degC/s * m"  >  ttrd_qns * e3t_surf </field> 
    725      <field id="strd_cdt_e3t"      unit="degC/s * m"  >  strd_cdt * e3t_surf </field> 
    726      <field id="ttrd_qsr_e3t"      unit="degC/s * m"  >  ttrd_qsr * e3t </field> 
    727      <field id="ttrd_bbc_e3t"      unit="degC/s * m"  >  ttrd_bbc * e3t </field> 
    728  
    729      <!-- OMIP  layer-integrated trends --> 
    730      <field id="ttrd_totad_li"    long_name="layer integrated heat-trend: total advection"         unit="W/m^2"     > ttrd_totad_e3t * 1026.0 * 3991.86795711963 </field> 
    731      <field id="strd_totad_li"    long_name="layer integrated salt-trend: total advection"         unit="kg/(m^2 s)"    > strd_totad_e3t * 1026.0 * 0.001  </field> 
    732      <field id="ttrd_evd_li"      long_name="layer integrated heat-trend: EVD convection"          unit="W/m^2"    > ttrd_evd_e3t * 1026.0 * 3991.86795711963 </field> 
    733      <field id="strd_evd_li"      long_name="layer integrated salt-trend: EVD convection"          unit="kg/(m^2 s)"  > strd_evd_e3t * 1026.0 * 0.001  </field> 
    734      <field id="ttrd_iso_li"      long_name="layer integrated heat-trend: isopycnal diffusion"     unit="W/m^2" > ttrd_iso_e3t * 1026.0 * 3991.86795711963 </field> 
    735      <field id="strd_iso_li"      long_name="layer integrated salt-trend: isopycnal diffusion"     unit="kg/(m^2 s)" > strd_iso_e3t * 1026.0 * 0.001  </field> 
    736      <field id="ttrd_zdfp_li"     long_name="layer integrated heat-trend: pure vert. diffusion"    unit="W/m^2" > ttrd_zdfp_e3t * 1026.0 * 3991.86795711963 </field> 
    737      <field id="strd_zdfp_li"     long_name="layer integrated salt-trend: pure vert. diffusion"    unit="kg/(m^2 s)" > strd_zdfp_e3t * 1026.0 * 0.001  </field> 
    738      <field id="ttrd_qns_li"      long_name="layer integrated heat-trend: non-solar flux + runoff" unit="W/m^2" grid_ref="grid_T_2D"> ttrd_qns_e3t * 1026.0 * 3991.86795711963 </field> 
    739      <field id="ttrd_qsr_li"      long_name="layer integrated heat-trend: solar flux"              unit="W/m^2"  grid_ref="grid_T_3D"> ttrd_qsr_e3t * 1026.0 * 3991.86795711963 </field> 
    740      <field id="ttrd_bbl_li"      long_name="layer integrated heat-trend: bottom boundary layer "  unit="W/m^2" > ttrd_bbl_e3t * 1026.0 * 3991.86795711963 </field> 
    741      <field id="strd_bbl_li"      long_name="layer integrated salt-trend: bottom boundary layer "  unit="kg/(m^2 s)" > strd_bbl_e3t * 1026.0 * 0.001  </field> 
    742      <field id="ttrd_evd_li"      long_name="layer integrated heat-trend: evd convection "         unit="W/m^2" >ttrd_evd_e3t * 1026.0 * 3991.86795711963  </field> 
    743      <field id="strd_evd_li"      long_name="layer integrated salt-trend: evd convection "         unit="kg/(m^2 s)" > strd_evd_e3t * 1026.0 * 0.001  </field> 
    744  
    745    </field_group> 
    746  
    747    <!--  Total trends calculated every time step--> 
    748    <field_group id="trendT" grid_ref="grid_T_3D"> 
    749      <field id="ttrd_tot"      long_name="temperature-trend: total model trend"         unit="degC/s" /> 
    750      <field id="strd_tot"      long_name="salinity   -trend: total model trend"         unit="1e-3/s" /> 
    751      <!-- Thickness weighted versions: --> 
    752      <field id="ttrd_tot_e3t"      unit="degC/s * m"  >  ttrd_tot * e3t </field> 
    753      <field id="strd_tot_e3t"      unit="1e-3/s * m"  >  strd_tot * e3t </field> 
    754      <!-- OMIP  layer-integrated total trends --> 
    755      <field id="ttrd_tot_li"      long_name="layer integrated heat-trend: total model trend :"         unit="W/m^2" > ttrd_tot_e3t * 1026.0 * 3991.86795711963 </field> 
    756      <field id="strd_tot_li"      long_name="layer integrated salt-trend: total model trend :"         unit="kg/(m^2 s)" > strd_tot_e3t * 1026.0 * 0.001  </field> 
    757  
    758      <!-- **** these trends have not been apportioned to all/even/odd ts yet **** --> 
    759      <!-- variables available with ln_KE_trd --> 
    760      <field id="ketrd_hpg"     long_name="ke-trend: hydrostatic pressure gradient"          unit="W/s^3"                        /> 
    761      <field id="ketrd_spg"     long_name="ke-trend: surface     pressure gradient"          unit="W/s^3"                        /> 
    762      <field id="ketrd_spgexp"  long_name="ke-trend: surface pressure gradient (explicit)"   unit="W/s^3"                        /> 
    763      <field id="ketrd_spgflt"  long_name="ke-trend: surface pressure gradient (filter)"     unit="W/s^3"                        /> 
    764      <field id="ssh_flt"       long_name="filtered contribution to ssh (dynspg_flt)"        unit="m"       grid_ref="grid_T_2D" /> 
    765      <field id="w0"            long_name="surface vertical velocity"                        unit="m/s"     grid_ref="grid_T_2D" /> 
    766      <field id="pw0_exp"       long_name="surface pressure flux due to ssh"                 unit="W/s^2"   grid_ref="grid_T_2D" /> 
    767      <field id="pw0_flt"       long_name="surface pressure flux due to filtered ssh"        unit="W/s^2"   grid_ref="grid_T_2D" /> 
    768      <field id="ketrd_keg"     long_name="ke-trend: KE gradient         or hor. adv."       unit="W/s^3"                        /> 
    769      <field id="ketrd_rvo"     long_name="ke-trend: relative  vorticity or metric term"     unit="W/s^3"                        /> 
    770      <field id="ketrd_pvo"     long_name="ke-trend: planetary vorticity"                    unit="W/s^3"                        /> 
    771      <field id="ketrd_zad"     long_name="ke-trend: vertical  advection"                    unit="W/s^3"                        /> 
    772      <field id="ketrd_udx"     long_name="ke-trend: U.dx[U]"                                unit="W/s^3"                        /> 
    773      <field id="ketrd_ldf"     long_name="ke-trend: lateral   diffusion"                    unit="W/s^3"                        /> 
    774      <field id="ketrd_zdf"     long_name="ke-trend: vertical  diffusion"                    unit="W/s^3"                        /> 
    775      <field id="ketrd_tau"     long_name="ke-trend: wind stress "                           unit="W/s^3"   grid_ref="grid_T_2D" /> 
    776      <field id="ketrd_bfr"     long_name="ke-trend: bottom friction (explicit)"             unit="W/s^3"                        />    
    777      <field id="ketrd_bfri"    long_name="ke-trend: bottom friction (implicit)"             unit="W/s^3"                        />    
    778      <field id="ketrd_atf"     long_name="ke-trend: asselin time filter trend"              unit="W/s^3"                        />   
    779      <field id="ketrd_convP2K" long_name="ke-trend: conversion (potential to kinetic)"      unit="W/s^3"                        /> 
    780      <field id="KE"            long_name="kinetic energy: u(n)*u(n+1)/2"                    unit="W/s^2"                        />    
    781  
    782      <!-- variables available when explicit lateral mixing is used (ln_dynldf_OFF=F) --> 
    783      <field id="dispkexyfo"    long_name="KE-trend: lateral  mixing induced dissipation"   standard_name="ocean_kinetic_energy_dissipation_per_unit_area_due_to_xy_friction"                   unit="W/m^2" grid_ref="grid_T_2D" />    
    784      <field id="dispkevfo"     long_name="KE-trend: vertical mixing induced dissipation"   standard_name="ocean_kinetic_energy_dissipation_per_unit_area_due_to_vertical_friction"             unit="W/m^2" grid_ref="grid_T_2D" />    
    785      <!-- variables available with ln_traadv_eiv=T and ln_diaeiv=T --> 
    786      <field id="eketrd_eiv"    long_name="EKE-trend due to parameterized eddy advection"   standard_name="tendency_of_ocean_eddy_kinetic_energy_content_due_to_parameterized_eddy_advection"   unit="W/m^2" grid_ref="grid_T_2D" />    
    787  
    788      <!-- variables available with ln_PE_trd --> 
    789      <field id="petrd_xad"     long_name="pe-trend: i-advection"                unit="W/m^3"                        /> 
    790      <field id="petrd_yad"     long_name="pe-trend: j-advection"                unit="W/m^3"                        /> 
    791      <field id="petrd_zad"     long_name="pe-trend: k-advection"                unit="W/m^3"                        /> 
    792      <field id="petrd_sad"     long_name="pe-trend: surface adv. (linssh true)" unit="W/m^3"   grid_ref="grid_T_2D" /> 
    793      <field id="petrd_ldf"     long_name="pe-trend: lateral  diffusion"         unit="W/m^3"                        /> 
    794      <field id="petrd_zdf"     long_name="pe-trend: vertical diffusion"         unit="W/m^3"                        /> 
    795      <field id="petrd_zdfp"    long_name="pe-trend: pure vert. diffusion"       unit="W/m^3"                        /> 
    796      <field id="petrd_dmp"     long_name="pe-trend: interior restoring"         unit="W/m^3"                        /> 
    797      <field id="petrd_bbl"     long_name="pe-trend: bottom boundary layer"      unit="W/m^3"                        /> 
    798      <field id="petrd_npc"     long_name="pe-trend: non-penetrative conv."      unit="W/m^3"                        /> 
    799      <field id="petrd_nsr"     long_name="pe-trend: surface forcing + runoff"   unit="W/m^3"                        /> 
    800      <field id="petrd_qsr"     long_name="pe-trend: solar penetr. heating"      unit="W/m^3"                        /> 
    801      <field id="petrd_bbc"     long_name="pe-trend: geothermal heating"         unit="W/m^3"                        /> 
    802      <field id="petrd_atf"     long_name="pe-trend: asselin time filter"        unit="W/m^3"                        /> 
    803      <field id="PEanom"        long_name="potential energy anomaly"             unit="1"                            />    
    804      <field id="alphaPE"       long_name="partial deriv. of PEanom wrt T"       unit="degC-1"                       />    
    805      <field id="betaPE"        long_name="partial deriv. of PEanom wrt S"       unit="1e3"                          />    
    806    </field_group> 
    807  
    808    <field_group id="trendU" grid_ref="grid_U_3D"> 
    809      <!-- variables available with ln_dyn_trd --> 
    810      <field id="utrd_hpg"       long_name="i-trend: hydrostatic pressure gradient"          unit="m/s^2"                        /> 
    811      <field id="utrd_spg"       long_name="i-trend: surface     pressure gradient"          unit="m/s^2"                        /> 
    812      <field id="utrd_spgexp"    long_name="i-trend: surface pressure gradient (explicit)"   unit="m/s^2"                        /> 
    813      <field id="utrd_spgflt"    long_name="i-trend: surface pressure gradient (filtered)"   unit="m/s^2"                        /> 
    814      <field id="utrd_keg"       long_name="i-trend: KE gradient         or hor. adv."       unit="m/s^2"                        /> 
    815      <field id="utrd_rvo"       long_name="i-trend: relative  vorticity or metric term"     unit="m/s^2"                        /> 
    816      <field id="utrd_pvo"       long_name="i-trend: planetary vorticity"                    unit="m/s^2"                        /> 
    817      <field id="utrd_zad"       long_name="i-trend: vertical  advection"                    unit="m/s^2"                        /> 
    818      <field id="utrd_udx"       long_name="i-trend: U.dx[U]"                                unit="m/s^2"                        /> 
    819      <field id="utrd_ldf"       long_name="i-trend: lateral   diffusion"                    unit="m/s^2"                        /> 
    820      <field id="utrd_zdf"       long_name="i-trend: vertical  diffusion"                    unit="m/s^2"                        /> 
    821      <field id="utrd_tau"       long_name="i-trend: wind stress "                           unit="m/s^2"   grid_ref="grid_U_2D" /> 
    822      <field id="utrd_bfr"       long_name="i-trend: bottom friction (explicit)"             unit="m/s^2"                        />    
    823      <field id="utrd_bfri"      long_name="i-trend: bottom friction (implicit)"             unit="m/s^2"                        />    
    824      <field id="utrd_tot"       long_name="i-trend: total momentum trend before atf"        unit="m/s^2"                        />    
    825      <field id="utrd_atf"       long_name="i-trend: asselin time filter trend"              unit="m/s^2"                        />    
    826    </field_group> 
    827  
    828    <field_group id="trendV" grid_ref="grid_V_3D"> 
    829      <!-- variables available with ln_dyn_trd --> 
    830      <field id="vtrd_hpg"       long_name="j-trend: hydrostatic pressure gradient"          unit="m/s^2"                        /> 
    831      <field id="vtrd_spg"       long_name="j-trend: surface     pressure gradient"          unit="m/s^2"                        /> 
    832      <field id="vtrd_spgexp"    long_name="j-trend: surface pressure gradient (explicit)"   unit="m/s^2"                        /> 
    833      <field id="vtrd_spgflt"    long_name="j-trend: surface pressure gradient (filtered)"   unit="m/s^2"                        /> 
    834      <field id="vtrd_keg"       long_name="j-trend: KE gradient         or hor. adv."       unit="m/s^2"                        /> 
    835      <field id="vtrd_rvo"       long_name="j-trend: relative  vorticity or metric term"     unit="m/s^2"                        /> 
    836      <field id="vtrd_pvo"       long_name="j-trend: planetary vorticity"                    unit="m/s^2"                        /> 
    837      <field id="vtrd_zad"       long_name="j-trend: vertical  advection"                    unit="m/s^2"                        /> 
    838      <field id="vtrd_vdy"       long_name="i-trend: V.dx[V]"                                unit="m/s^2"                        /> 
    839      <field id="vtrd_ldf"       long_name="j-trend: lateral   diffusion"                    unit="m/s^2"                        /> 
    840      <field id="vtrd_zdf"       long_name="j-trend: vertical  diffusion"                    unit="m/s^2"                        /> 
    841      <field id="vtrd_tau"       long_name="j-trend: wind stress "                           unit="m/s^2"   grid_ref="grid_V_2D" /> 
    842      <field id="vtrd_bfr"       long_name="j-trend: bottom friction (explicit)"             unit="m/s^2"                        />    
    843      <field id="vtrd_bfri"      long_name="j-trend: bottom friction (implicit)"             unit="m/s^2"                        />    
    844      <field id="vtrd_tot"       long_name="j-trend: total momentum trend before atf"        unit="m/s^2"                        />    
    845      <field id="vtrd_atf"       long_name="j-trend: asselin time filter trend"              unit="m/s^2"                        />    
    846    </field_group> 
    847  
    848  
    849     <!--  
    850 ============================================================================================================ 
    851                                         Definitions for iodef_demo.xml 
    852 ============================================================================================================ 
    853     --> 
    854  
    855     <field_group id="TRD" > 
    856       <field field_ref="ttrd_totad_li"   name="opottempadvect"  /> 
    857       <field field_ref="ttrd_iso_li"     name="opottemppmdiff"  /> 
    858       <field field_ref="ttrd_zdfp_li"    name="opottempdiff"  /> 
    859       <field field_ref="ttrd_evd_li"     name="opottempevd" /> 
    860       <field field_ref="strd_evd_li"     name="osaltevd" /> 
    861       <field field_ref="ttrd_qns_li"     name="opottempqns"  /> 
    862       <field field_ref="ttrd_qsr_li"     name="rsdoabsorb" operation="accumulate" /> 
    863       <field field_ref="strd_totad_li"   name="osaltadvect" /> 
    864       <field field_ref="strd_iso_li"     name="osaltpmdiff"  /> 
    865       <field field_ref="strd_zdfp_li"    name="osaltdiff" /> 
     9--> 
     10<field_definition level="1" prec="4" operation="average" enabled=".TRUE." default_value="1.e20" > <!-- time step automaticaly defined --> 
     11 
     12  <!-- 
     13      ============================================================================================================ 
     14      Physical ocean model variables 
     15      ============================================================================================================ 
     16  --> 
     17 
     18  <!-- T grid --> 
     19 
     20  <field_group id="grid_T" grid_ref="grid_T_2D" > 
     21    <field id="e3t"          long_name="T-cell thickness"                    standard_name="cell_thickness"     unit="m"   grid_ref="grid_T_3D" /> 
     22    <field id="e3t_surf"     long_name="T-cell thickness"   field_ref="e3t"  standard_name="cell_thickness"     unit="m"   grid_ref="grid_T_SFC"/> 
     23    <field id="e3t_0"        long_name="Initial T-cell thickness"            standard_name="ref_cell_thickness" unit="m"   grid_ref="grid_T_3D" /> 
     24 
     25    <field id="toce"         long_name="temperature"                         standard_name="sea_water_potential_temperature"   unit="degC"     grid_ref="grid_T_3D"/> 
     26    <field id="toce_e3t"     long_name="temperature (thickness weighted)"                                                      unit="degC"     grid_ref="grid_T_3D" > toce * e3t </field > 
     27    <field id="soce"         long_name="salinity"                            standard_name="sea_water_practical_salinity"      unit="1e-3"     grid_ref="grid_T_3D"/> 
     28    <field id="soce_e3t"     long_name="salinity    (thickness weighted)"                                                      unit="1e-3"     grid_ref="grid_T_3D" > soce * e3t </field > 
     29 
     30    <!-- t-eddy viscosity coefficients (ldfdyn) --> 
     31    <field id="ahmt_2d"      long_name=" surface t-eddy viscosity coefficient"   unit="m2/s or m4/s"                      /> 
     32    <field id="ahmt_3d"      long_name=" 3D      t-eddy viscosity coefficient"   unit="m2/s or m4/s"  grid_ref="grid_T_3D"/> 
     33 
     34    <field id="sst"          long_name="Bulk sea surface temperature"                       standard_name="bulk_sea_surface_temperature"        unit="degC"     /> 
     35    <field id="t_skin"       long_name="Skin temperature aka SSST"                          standard_name="skin_temperature"                    unit="degC"     /> 
     36    <field id="sst2"         long_name="square of sea surface temperature"                  standard_name="square_of_sea_surface_temperature"   unit="degC2"     > sst * sst </field > 
     37    <field id="sstmax"       long_name="max of sea surface temperature"   field_ref="sst"   operation="maximum"                                                 /> 
     38    <field id="sstmin"       long_name="min of sea surface temperature"   field_ref="sst"   operation="minimum"                                                 /> 
     39    <field id="sstgrad"      long_name="module of sst gradient"                                                                                 unit="degC/m"   /> 
     40    <field id="sstgrad2"     long_name="square of module of sst gradient"                                                                       unit="degC2/m2" /> 
     41    <field id="sbt"          long_name="sea bottom temperature"                                                                                 unit="degC"     /> 
     42    <field id="tosmint"      long_name="vertical integral of temperature times density"     standard_name="integral_wrt_depth_of_product_of_density_and_potential_temperature"  unit="(kg m2) degree_C" /> 
     43    <field id="sst_wl"       long_name="Delta SST of warm layer"                                                                                unit="degC"     /> 
     44    <field id="sst_cs"       long_name="Delta SST of cool skin"                                                                                 unit="degC"     /> 
     45    <field id="temp_3m"      long_name="temperature at 3m"                                                                                      unit="degC"     /> 
     46 
     47    <field id="sss"          long_name="sea surface salinity"                               standard_name="sea_surface_salinity"                unit="1e-3"     /> 
     48    <field id="sss2"         long_name="square of sea surface salinity"                                                                         unit="1e-6"      > sss * sss </field > 
     49    <field id="sssmax"       long_name="max of sea surface salinity"      field_ref="sss"   operation="maximum"                                                 /> 
     50    <field id="sssmin"       long_name="min of sea surface salinity"      field_ref="sss"   operation="minimum"                                                 /> 
     51    <field id="sbs"          long_name="sea bottom salinity"                                                                                    unit="0.001"    /> 
     52    <field id="somint"       long_name="vertical integral of salinity times density"        standard_name="integral_wrt_depth_of_product_of_density_and_salinity"  unit="(kg m2) x (1e-3)" /> 
     53 
     54    <field id="taubot"       long_name="bottom stress module"                                                                                   unit="N/m2"     /> 
     55 
     56    <field id="ssh"          long_name="sea surface height"                                 standard_name="sea_surface_height_above_geoid"             unit="m" /> 
     57    <field id="ssh2"         long_name="square of sea surface height"                       standard_name="square_of_sea_surface_height_above_geoid"   unit="m2" > ssh * ssh </field > 
     58    <field id="wetdep"       long_name="wet depth"                                          standard_name="wet_depth"                                  unit="m" /> 
     59    <field id="sshmax"       long_name="max of sea surface height"        field_ref="ssh"   operation="maximum"                                                 /> 
     60 
     61    <field id="mldkz5"       long_name="Turbocline depth (Kz = 5e-4)"                       standard_name="ocean_mixed_layer_thickness_defined_by_vertical_tracer_diffusivity"                unit="m"          /> 
     62    <field id="mldr10_1"     long_name="Mixed Layer Depth (dsigma = 0.01 wrt 10m)"          standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"          /> 
     63    <field id="mldr10_1max"  long_name="Max of Mixed Layer Depth (dsigma = 0.01 wrt 10m)"   field_ref="mldr10_1"   operation="maximum"                                                                          /> 
     64    <field id="mldr10_1min"  long_name="Min of Mixed Layer Depth (dsigma = 0.01 wrt 10m)"   field_ref="mldr10_1"   operation="minimum"                                                                          /> 
     65    <field id="heatc"        long_name="Heat content vertically integrated"                 standard_name="integral_of_sea_water_potential_temperature_wrt_depth_expressed_as_heat_content"   unit="J/m2"       /> 
     66    <field id="saltc"        long_name="Salt content vertically integrated"                                                                                                                   unit="1e-3*kg/m2" /> 
     67 
     68    <!-- EOS --> 
     69    <field id="alpha"        long_name="thermal expansion"                                                         unit="degC-1" grid_ref="grid_T_3D" /> 
     70    <field id="beta"         long_name="haline contraction"                                                        unit="1e3"    grid_ref="grid_T_3D" /> 
     71    <field id="bn2"          long_name="squared Brunt-Vaisala frequency"                                           unit="s-1"    grid_ref="grid_T_3D" /> 
     72    <field id="rhop"         long_name="potential density (sigma0)"        standard_name="sea_water_sigma_theta"   unit="kg/m3"  grid_ref="grid_T_3D" /> 
     73 
     74    <!-- Energy - horizontal divergence --> 
     75    <field id="eken"         long_name="kinetic energy"          standard_name="specific_kinetic_energy_of_sea_water"   unit="m2/s2"  grid_ref="grid_T_3D" /> 
     76    <field id="hdiv"         long_name="horizontal divergence"                                                          unit="s-1"    grid_ref="grid_T_3D" /> 
     77 
     78    <!-- variables available with MLE --> 
     79    <field id="Lf_NHpf"      long_name="MLE: Lf = N H / f"   unit="m" /> 
     80 
     81    <!-- next variables available with ln_zad_Aimp=.true. --> 
     82    <field id="Courant"      long_name="Courant number"                                                                 unit="#"   grid_ref="grid_T_3D" /> 
     83    <field id="wimp"         long_name="Implicit vertical velocity"                                                     unit="m/s" grid_ref="grid_T_3D" /> 
     84    <field id="wexp"         long_name="Explicit vertical velocity"                                                     unit="m/s" grid_ref="grid_T_3D" /> 
     85    <field id="wi_cff"       long_name="Fraction of implicit vertical velocity"                                         unit="#"   grid_ref="grid_T_3D" /> 
     86 
     87    <!-- next variables available with key_diahth --> 
     88    <field id="mlddzt"       long_name="Thermocline Depth (depth of max dT/dz)"         standard_name="depth_at_maximum_upward_derivative_of_sea_water_potential_temperature"             unit="m"                         /> 
     89    <field id="mldr10_3"     long_name="Mixed Layer Depth (dsigma = 0.03 wrt 10m)"      standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"                         /> 
     90    <field id="mldr0_1"      long_name="Mixed Layer Depth (dsigma = 0.01 wrt sfc)"      standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"                         /> 
     91    <field id="mldr0_3"      long_name="Mixed Layer Depth (dsigma = 0.03 wrt sfc)"      standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"                         /> 
     92    <field id="mld_dt02"     long_name="Mixed Layer Depth (|dT| = 0.2 wrt 10m)"         standard_name="ocean_mixed_layer_thickness_defined_by_temperature"                                unit="m"                         /> 
     93    <field id="topthdep"     long_name="Top of Thermocline Depth (dT = -0.2 wrt 10m)"   standard_name="ocean_mixed_layer_thickness_defined_by_temperature"                                unit="m"                         /> 
     94    <field id="pycndep"      long_name="Pycnocline Depth (dsigma[dT=-0.2] wrt 10m)"     standard_name="ocean_mixed_layer_thickness_defined_by_sigma_theta"                                unit="m"                         /> 
     95    <field id="BLT"          long_name="Barrier Layer Thickness"                                                                                                                          unit="m"                          > topthdep - pycndep </field> 
     96    <field id="tinv"         long_name="Max of vertical invertion of temperature"                                                                                                         unit="degC"                      /> 
     97    <field id="depti"        long_name="Depth of max. vert. inv. of temperature"                                                                                                          unit="m"                         /> 
     98    <field id="20d"          long_name="Depth of 20C isotherm"                          standard_name="depth_of_isosurface_of_sea_water_potential_temperature"                            unit="m"      axis_ref="iax_20C" /> 
     99    <field id="28d"          long_name="Depth of 28C isotherm"                          standard_name="depth_of_isosurface_of_sea_water_potential_temperature"                            unit="m"      axis_ref="iax_28C" /> 
     100    <field id="hc300"        long_name="Heat content 0-300m"                            standard_name="integral_of_sea_water_potential_temperature_wrt_depth_expressed_as_heat_content"   unit="J/m2"                      /> 
     101 
     102    <!-- variables available with diaar5 --> 
     103    <field id="botpres"      long_name="Sea Water Pressure at Sea Floor"          standard_name="sea_water_pressure_at_sea_floor"                    unit="dbar" /> 
     104    <field id="sshdyn"       long_name="dynamic sea surface height"               standard_name="dynamic_sea_surface_height_above_geoid"             unit="m"    /> 
     105    <field id="sshdyn2"      long_name="square of dynamic sea surface height"     standard_name="dynamic_sea_surface_height_above_geoid_squared"     unit="m2"    > sshdyn * sshdyn </field> 
     106    <field id="tnpeo"      long_name="Tendency of ocean potential energy content"                                                                    unit="W/m2" /> 
     107 
     108    <!-- variables available ln_linssh=.FALSE. --> 
     109    <field id="tpt_dep"      long_name="T-point depth"                  standard_name="depth_below_geoid"   unit="m"   grid_ref="grid_T_3D" /> 
     110    <field id="e3tdef"       long_name="T-cell thickness deformation"                                       unit="%"   grid_ref="grid_T_3D" /> 
     111 
     112    <!-- variables available with ln_diacfl=.true. --> 
     113    <field id="cfl_cu"       long_name="u-courant number"   unit="#" /> 
     114    <field id="cfl_cv"       long_name="v-courant number"   unit="#" /> 
     115    <field id="cfl_cw"       long_name="w-courant number"   unit="#" /> 
     116 
     117  </field_group> <!-- grid_T --> 
     118 
     119  <!-- Tides --> 
     120 
     121  <field_group id="Tides_T" grid_ref="grid_T_2D" operation="once" > 
     122    <!-- tidal composante --> 
     123    <field id="M2x"          long_name="M2 Elevation harmonic real part "                             unit="m"        /> 
     124    <field id="M2y"          long_name="M2 Elevation harmonic imaginary part"                         unit="m"        /> 
     125    <field id="S2x"          long_name="S2 Elevation harmonic real part "                             unit="m"        /> 
     126    <field id="S2y"          long_name="S2 Elevation harmonic imaginary part"                         unit="m"        /> 
     127    <field id="N2x"          long_name="N2 Elevation harmonic real part "                             unit="m"        /> 
     128    <field id="N2y"          long_name="N2 Elevation harmonic imaginary part"                         unit="m"        /> 
     129    <field id="K1x"          long_name="K1 Elevation harmonic real part "                             unit="m"        /> 
     130    <field id="K1y"          long_name="K1 Elevation harmonic imaginary part"                         unit="m"        /> 
     131    <field id="O1x"          long_name="O1 Elevation harmonic real part "                             unit="m"        /> 
     132    <field id="O1y"          long_name="O1 Elevation harmonic imaginary part"                         unit="m"        /> 
     133    <field id="Q1x"          long_name="Q1 Elevation harmonic real part "                             unit="m"        /> 
     134    <field id="Q1y"          long_name="Q1 Elevation harmonic imaginary part"                         unit="m"        /> 
     135    <field id="M4x"          long_name="M4 Elevation harmonic real part "                             unit="m"        /> 
     136    <field id="M4y"          long_name="M4 Elevation harmonic imaginary part"                         unit="m"        /> 
     137    <field id="K2x"          long_name="K2 Elevation harmonic real part "                             unit="m"        /> 
     138    <field id="K2y"          long_name="K2 Elevation harmonic imaginary part"                         unit="m"        /> 
     139    <field id="P1x"          long_name="P1 Elevation harmonic real part "                             unit="m"        /> 
     140    <field id="P1y"          long_name="P1 Elevation harmonic imaginary part"                         unit="m"        /> 
     141    <field id="Mfx"          long_name="Mf Elevation harmonic real part "                             unit="m"        /> 
     142    <field id="Mfy"          long_name="Mf Elevation harmonic imaginary part"                         unit="m"        /> 
     143    <field id="Mmx"          long_name="Mm Elevation harmonic real part "                             unit="m"        /> 
     144    <field id="Mmy"          long_name="Mm Elevation harmonic imaginary part"                         unit="m"        /> 
     145  </field_group> 
     146 
     147  <field_group id="Tides_U" grid_ref="grid_U_2D" operation="once" > 
     148    <field id="M2x_u"        long_name="M2 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     149    <field id="M2y_u"        long_name="M2 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     150    <field id="S2x_u"        long_name="S2 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     151    <field id="S2y_u"        long_name="S2 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     152    <field id="N2x_u"        long_name="N2 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     153    <field id="N2y_u"        long_name="N2 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     154    <field id="K1x_u"        long_name="K1 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     155    <field id="K1y_u"        long_name="K1 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     156    <field id="O1x_u"        long_name="O1 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     157    <field id="O1y_u"        long_name="O1 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     158    <field id="Q1x_u"        long_name="Q1 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     159    <field id="Q1y_u"        long_name="Q1 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     160    <field id="M4x_u"        long_name="M4 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     161    <field id="M4y_u"        long_name="M4 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     162    <field id="K2x_u"        long_name="K2 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     163    <field id="K2y_u"        long_name="K2 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     164    <field id="P1x_u"        long_name="P1 current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     165    <field id="P1y_u"        long_name="P1 current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     166    <field id="Mfx_u"        long_name="Mf current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     167    <field id="Mfy_u"        long_name="Mf current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     168    <field id="Mmx_u"        long_name="Mm current barotrope along i-axis harmonic real part "        unit="m/s"      /> 
     169    <field id="Mmy_u"        long_name="Mm current barotrope along i-axis harmonic imaginary part "   unit="m/s"      /> 
     170  </field_group> 
     171 
     172  <field_group id="Tides_V" grid_ref="grid_V_2D" operation="once" > 
     173    <field id="M2x_v"        long_name="M2 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     174    <field id="M2y_v"        long_name="M2 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     175    <field id="S2x_v"        long_name="S2 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     176    <field id="S2y_v"        long_name="S2 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     177    <field id="N2x_v"        long_name="N2 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     178    <field id="N2y_v"        long_name="N2 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     179    <field id="K1x_v"        long_name="K1 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     180    <field id="K1y_v"        long_name="K1 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     181    <field id="O1x_v"        long_name="O1 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     182    <field id="O1y_v"        long_name="O1 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     183    <field id="Q1x_v"        long_name="Q1 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     184    <field id="Q1y_v"        long_name="Q1 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     185    <field id="M4x_v"        long_name="M4 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     186    <field id="M4y_v"        long_name="M4 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     187    <field id="K2x_v"        long_name="K2 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     188    <field id="K2y_v"        long_name="K2 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     189    <field id="P1x_v"        long_name="P1 current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     190    <field id="P1y_v"        long_name="P1 current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     191    <field id="Mfx_v"        long_name="Mf current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     192    <field id="Mfy_v"        long_name="Mf current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     193    <field id="Mmx_v"        long_name="Mm current barotrope along j-axis harmonic real part "        unit="m/s"      /> 
     194    <field id="Mmy_v"        long_name="Mm current barotrope along j-axis harmonic imaginary part "   unit="m/s"      /> 
     195  </field_group> 
     196 
     197  <!-- OSMOSIS variables (available with ln_zdfosm=.true.) --> 
     198 
     199  <field_group id="OSMOSIS_T" grid_ref="grid_T_2D"> 
     200    <field id="zwth0"               long_name="surface non-local temperature flux"       unit="deg m/s" /> 
     201    <field id="zws0"                long_name="surface non-local salinity flux"          unit="psu m/s" /> 
     202    <field id="hbl"                 long_name="boundary layer depth"                     unit="m"       /> 
     203    <field id="hbli"                long_name="initial boundary layer depth"             unit="m"       /> 
     204    <field id="dstokes"             long_name="stokes drift  depth scale"                unit="m"       /> 
     205    <field id="zustke"              long_name="magnitude of stokes drift  at T-points"   unit="m/s"     /> 
     206    <field id="zwstrc"              long_name="convective velocity scale"                unit="m/s"     /> 
     207    <field id="zwstrl"              long_name="langmuir velocity scale"                  unit="m/s"     /> 
     208    <field id="zustar"              long_name="friction velocity"                        unit="m/s"     /> 
     209    <field id="zhbl"                long_name="boundary layer depth"                     unit="m"       /> 
     210    <field id="zhml"                long_name="mixed layer depth"                        unit="m"       /> 
     211    <field id="wind_wave_abs_power" long_name="\rho |U_s| x u*^2"                        unit="mW"      /> 
     212    <field id="wind_wave_power"     long_name="U_s \dot  tau"                            unit="mW"      /> 
     213    <field id="wind_power"          long_name="\rho  u*^3"                               unit="mW"      /> 
     214 
     215    <!-- extra OSMOSIS diagnostics --> 
     216    <field id="zwthav"              long_name="av turb flux of T in ml"                  unit="deg m/s" /> 
     217    <field id="zt_ml"               long_name="av T in ml"                               unit="deg"     /> 
     218    <field id="zwth_ent"            long_name="entrainment turb flux of T"               unit="deg m/s" /> 
     219    <field id="zhol"                long_name="Hoenekker number"                         unit="#"       /> 
     220    <field id="zdh"                 long_name="Pycnocline  depth - grid"                 unit=" m"      /> 
     221  </field_group> 
     222 
     223  <field_group id="OSMOSIS_W" grid_ref="grid_W_3D" operation="instant" > 
     224    <field id="ghamt"       long_name="non-local temperature flux"                       unit="deg m/s" /> 
     225    <field id="ghams"       long_name="non-local salinity flux"                          unit="psu m/s" /> 
     226    <field id="zdtdz_pyc"   long_name="Pycnocline temperature gradient"                  unit=" deg/m"  /> 
     227  </field_group> 
     228 
     229  <field_group id="OSMOSIS_U" grid_ref="grid_U_2D" > 
     230    <field id="ghamu"       long_name="non-local u-momentum flux"   grid_ref="grid_U_3D" unit="m^2/s^2" /> 
     231    <field id="us_x"        long_name="i component of Stokes drift"                      unit="m/s"     /> 
     232  </field_group> 
     233 
     234  <field_group id="OSMOSIS_V" grid_ref="grid_V_2D" > 
     235    <field id="ghamv"       long_name="non-local v-momentum flux"   grid_ref="grid_V_3D" unit="m^2/s^2" /> 
     236    <field id="us_y"        long_name="j component of Stokes drift"                      unit="m/s"     /> 
     237  </field_group> 
     238 
     239  <!-- SBC --> 
     240  <field_group id="SBC" > <!-- time step automaticaly defined based on nn_fsbc --> 
     241 
     242    <field_group id="SBC_2D" grid_ref="grid_T_2D" > 
     243 
     244      <field id="empmr"        long_name="Net Upward Water Flux"                standard_name="water_flux_out_of_sea_ice_and_sea_water"                              unit="kg/m2/s"   /> 
     245      <field id="empbmr"       long_name="Net Upward Water Flux at pre. tstep"  standard_name="water_flux_out_of_sea_ice_and_sea_water"                              unit="kg/m2/s"   /> 
     246      <field id="emp_oce"      long_name="Evap minus Precip over ocean"         standard_name="evap_minus_precip_over_sea_water"                                     unit="kg/m2/s"   /> 
     247      <field id="emp_ice"      long_name="Evap minus Precip over ice"           standard_name="evap_minus_precip_over_sea_ice"                                       unit="kg/m2/s"   /> 
     248      <field id="saltflx"      long_name="Downward salt flux"                                                                                                        unit="1e-3/m2/s" /> 
     249      <field id="fmmflx"       long_name="Water flux due to freezing/melting"                                                                                        unit="kg/m2/s"   /> 
     250      <field id="snowpre"      long_name="Snow precipitation"                   standard_name="snowfall_flux"                                                        unit="kg/m2/s"   /> 
     251      <field id="runoffs"      long_name="River Runoffs"                        standard_name="water_flux_into_sea_water_from_rivers"                                unit="kg/m2/s"   /> 
     252      <field id="precip"       long_name="Total precipitation"                  standard_name="precipitation_flux"                                                   unit="kg/m2/s"   /> 
     253 
     254      <field id="qt"           long_name="Net Downward Heat Flux"                standard_name="surface_downward_heat_flux_in_sea_water"                              unit="W/m2"                           /> 
     255      <field id="qns"          long_name="non solar Downward Heat Flux"                                                                                               unit="W/m2"                           /> 
     256      <field id="qsr"          long_name="Shortwave Radiation"                   standard_name="net_downward_shortwave_flux_at_sea_water_surface"                     unit="W/m2"                           /> 
     257      <field id="qsr3d"        long_name="Shortwave Radiation 3D distribution"   standard_name="downwelling_shortwave_flux_in_sea_water"                              unit="W/m2"      grid_ref="grid_T_3D" /> 
     258      <field id="qrp"          long_name="Surface Heat Flux: Damping"            standard_name="heat_flux_into_sea_water_due_to_newtonian_relaxation"                 unit="W/m2"                           /> 
     259      <field id="erp"          long_name="Surface Water Flux: Damping"           standard_name="water_flux_out_of_sea_water_due_to_newtonian_relaxation"              unit="kg/m2/s"                        /> 
     260      <field id="taum"         long_name="wind stress module"                    standard_name="magnitude_of_surface_downward_stress"                                 unit="N/m2"                           /> 
     261      <field id="wspd"         long_name="wind speed module"                     standard_name="wind_speed"                                                           unit="m/s"                            /> 
     262 
     263      <!-- * variable relative to atmospheric pressure forcing : available with ln_apr_dyn --> 
     264      <field id="ssh_ib"       long_name="Inverse barometer sea surface height"  standard_name="sea_surface_height_correction_due_to_air_pressure_at_low_frequency"   unit="m"        /> 
     265 
     266      <!-- * variable related to ice shelf forcing * --> 
     267      <field id="fwfisf"       long_name="Ice shelf melting"                             unit="kg/m2/s"  /> 
     268      <field id="fwfisf3d"     long_name="Ice shelf melting"                             unit="kg/m2/s"  grid_ref="grid_T_3D" /> 
     269      <field id="qlatisf"      long_name="Ice shelf latent heat flux"                    unit="W/m2"     /> 
     270      <field id="qlatisf3d"    long_name="Ice shelf latent heat flux"                    unit="W/m2"     grid_ref="grid_T_3D" /> 
     271      <field id="qhcisf"       long_name="Ice shelf heat content flux"                   unit="W/m2"     /> 
     272      <field id="qhcisf3d"     long_name="Ice shelf heat content flux"                   unit="W/m2"     grid_ref="grid_T_3D" /> 
     273      <field id="isfgammat"    long_name="transfert coefficient for isf (temperature) "  unit="m/s"      /> 
     274      <field id="isfgammas"    long_name="transfert coefficient for isf (salinity)    "  unit="m/s"      /> 
     275      <field id="stbl"         long_name="salinity in the Losh tbl                    "  unit="PSU"      /> 
     276      <field id="ttbl"         long_name="temperature in the Losh tbl                 "  unit="C"        /> 
     277      <field id="utbl"         long_name="zonal current in the Losh tbl at T point    "  unit="m/s"      /> 
     278      <field id="vtbl"         long_name="merid current in the Losh tbl at T point    "  unit="m/s"      /> 
     279      <field id="thermald"     long_name="thermal driving of ice shelf melting        "  unit="C"        /> 
     280      <field id="tfrz"         long_name="top freezing point (used to compute melt)   "  unit="C"        /> 
     281      <field id="tinsitu"      long_name="top insitu temperature (used to cmpt melt)  "  unit="C"        /> 
     282      <field id="ustar"        long_name="ustar at T point used in ice shelf melting  "  unit="m/s"      /> 
     283 
     284      <!-- *_oce variables available with ln_blk_clio or ln_blk_core --> 
     285      <field id="rho_air"      long_name="Air density at 10m above sea surface"         standard_name="rho_air_10m"                                        unit="kg/m3" /> 
     286      <field id="dt_skin"      long_name="SSST-SST temperature difference"              standard_name="SSST-SST"                                             unit="K"   /> 
     287      <field id="qlw_oce"      long_name="Longwave Downward Heat Flux over open ocean"  standard_name="surface_net_downward_longwave_flux"                 unit="W/m2"  /> 
     288      <field id="qsb_oce"      long_name="Sensible Downward Heat Flux over open ocean"  standard_name="surface_downward_sensible_heat_flux"                unit="W/m2"  /> 
     289      <field id="qla_oce"      long_name="Latent Downward Heat Flux over open ocean"    standard_name="surface_downward_latent_heat_flux"                  unit="W/m2"  /> 
     290      <field id="evap_oce"     long_name="Evaporation over open ocean"                  standard_name="evaporation"                                        unit="kg/m2/s" /> 
     291      <field id="qt_oce"       long_name="total flux at ocean surface"                  standard_name="surface_downward_heat_flux_in_sea_water"            unit="W/m2"  /> 
     292      <field id="qsr_oce"      long_name="solar heat flux at ocean surface"             standard_name="net_downward_shortwave_flux_at_sea_water_surface"   unit="W/m2"  /> 
     293      <field id="qns_oce"      long_name="non-solar heat flux at ocean surface (including E-P)"                                                            unit="W/m2"  /> 
     294      <field id="qemp_oce"     long_name="Downward Heat Flux from E-P over open ocean"                                                                     unit="W/m2"  /> 
     295      <field id="taum_oce"     long_name="wind stress module over open ocean"           standard_name="magnitude_of_surface_downward_stress"               unit="N/m2"  /> 
     296 
     297      <!-- available key_oasis3 --> 
     298      <field id="snow_ao_cea"  long_name="Snow over ice-free ocean (cell average)"   standard_name="snowfall_flux"                             unit="kg/m2/s"  /> 
     299      <field id="snow_ai_cea"  long_name="Snow over sea-ice (cell average)"          standard_name="snowfall_flux"                             unit="kg/m2/s"  /> 
     300      <field id="subl_ai_cea"  long_name="Sublimation over sea-ice (cell average)"   standard_name="surface_snow_and_ice_sublimation_flux"     unit="kg/m2/s"  /> 
     301      <field id="icealb_cea"   long_name="Ice albedo (cell average)"                 standard_name="sea_ice_albedo"                            unit="1"        /> 
     302      <field id="calving_cea"  long_name="Calving"                                   standard_name="water_flux_into_sea_water_from_icebergs"   unit="kg/m2/s"  /> 
     303      <field id="iceberg_cea"  long_name="Iceberg"                                   standard_name="water_flux_into_sea_water_from_icebergs"   unit="kg/m2/s"  /> 
     304      <field id="iceshelf_cea" long_name="Iceshelf"                                  standard_name="water_flux_into_sea_water_from_iceshelf"   unit="kg/m2/s"  /> 
     305 
     306 
     307      <!-- available if key_oasis3 + conservative method --> 
     308      <field id="rain"          long_name="Liquid precipitation"                                     standard_name="rainfall_flux"                                                                 unit="kg/m2/s"  /> 
     309      <field id="evap_ao_cea"   long_name="Evaporation over ice-free ocean (cell average)"           standard_name="water_evaporation_flux"                                                        unit="kg/m2/s"  /> 
     310      <field id="isnwmlt_cea"   long_name="Snow over Ice melting (cell average)"                     standard_name="surface_snow_melt_flux"                                                        unit="kg/m2/s"  /> 
     311      <field id="fsal_virt_cea" long_name="Virtual salt flux due to ice formation (cell average)"    standard_name="virtual_salt_flux_into_sea_water_due_to_sea_ice_thermodynamics"                unit="kg/m2/s"  /> 
     312      <field id="fsal_real_cea" long_name="Real salt flux due to ice formation (cell average)"       standard_name="downward_sea_ice_basal_salt_flux"                                              unit="kg/m2/s"  /> 
     313      <field id="hflx_rain_cea" long_name="heat flux due to rainfall"                                standard_name="temperature_flux_due_to_rainfall_expressed_as_heat_flux_into_sea_water"        unit="W/m2"     /> 
     314      <field id="hflx_evap_cea" long_name="heat flux due to evaporation"                             standard_name="temperature_flux_due_to_evaporation_expressed_as_heat_flux_out_of_sea_water"   unit="W/m2"     /> 
     315      <field id="hflx_snow_cea" long_name="heat flux due to snow falling"                            standard_name="heat_flux_onto_ocean_and_ice_due_to_snow_thermodynamics"                       unit="W/m2"     /> 
     316      <field id="hflx_snow_ai_cea" long_name="heat flux due to snow falling over ice"                standard_name="heat_flux_onto_ice_due_to_snow_thermodynamics"                                 unit="W/m2"     /> 
     317      <field id="hflx_snow_ao_cea" long_name="heat flux due to snow falling over ice-free ocean"     standard_name="heat_flux_onto_sea_water_due_to_snow_thermodynamics"                           unit="W/m2"     /> 
     318      <field id="hflx_ice_cea"  long_name="heat flux due to ice thermodynamics"                      standard_name="heat_flux_into_sea_water_due_to_sea_ice_thermodynamics"                        unit="W/m2"     /> 
     319      <field id="hflx_rnf_cea"  long_name="heat flux due to runoffs"                                 standard_name="temperature_flux_due_to_runoff_expressed_as_heat_flux_into_sea_water"          unit="W/m2"     /> 
     320      <field id="hflx_cal_cea"  long_name="heat flux due to calving"                                 standard_name="heat_flux_into_sea_water_due_to_calving"                                       unit="W/m2"     /> 
     321      <field id="hflx_icb_cea"  long_name="heat flux due to iceberg"                                 standard_name="heat_flux_into_sea_water_due_to_icebergs"                                      unit="W/m2"     /> 
     322      <field id="hflx_isf_cea"  long_name="heat flux due to iceshelf"                                standard_name="heat_flux_into_sea_water_due_to_iceshelf"                                      unit="W/m2"     /> 
     323      <field id="bicemel_cea"   long_name="Rate of Melt at Sea Ice Base (cell average)"              standard_name="tendency_of_sea_ice_amount_due_to_basal_melting"                               unit="kg/m2/s"  /> 
     324      <field id="licepro_cea"   long_name="Lateral Sea Ice Growth Rate (cell average)"               standard_name="tendency_of_sea_ice_amount_due_to_lateral_growth_of_ice_floes"                 unit="kg/m2/s"  /> 
     325      <field id="snowmel_cea"   long_name="Snow Melt Rate (cell average)"                            standard_name="surface_snow_melt_flux"                                                        unit="kg/m2/s"  /> 
     326      <field id="sntoice_cea"   long_name="Snow-Ice Formation Rate (cell average)"                   standard_name="tendency_of_sea_ice_amount_due_to_snow_conversion"                             unit="kg/m2/s"  /> 
     327      <field id="ticemel_cea"   long_name="Rate of Melt at Upper Surface of Sea Ice (cell average)"  standard_name="tendency_of_sea_ice_amount_due_to_surface_melting"                             unit="kg/m2/s"  /> 
     328 
     329      <!-- ice field (nn_ice=1)  --> 
     330      <field id="ice_cover"    long_name="Ice fraction"                                                 standard_name="sea_ice_area_fraction"                              unit="1"            /> 
     331 
     332      <!-- dilution --> 
     333      <field id="emp_x_sst"    long_name="Concentration/Dilution term on SST"                                                                                              unit="kg*degC/m2/s" /> 
     334      <field id="emp_x_sss"    long_name="Concentration/Dilution term on SSS"                                                                                              unit="kg*1e-3/m2/s" /> 
     335      <field id="rnf_x_sst"    long_name="Runoff term on SST"                                                                                                              unit="kg*degC/m2/s" /> 
     336      <field id="rnf_x_sss"    long_name="Runoff term on SSS"                                                                                                              unit="kg*1e-3/m2/s" /> 
     337 
     338      <!-- sbcssm variables --> 
     339      <field id="sst_m" long_name="Bulk sea surface temperature"  standard_name="bulk_sea_surface_temperature" unit="degC" /> 
     340      <field id="sss_m" long_name="sea surface salinity"          standard_name="sea_surface_salinity"         unit="psu"  /> 
     341      <field id="ssu_m" long_name="ocean surface current along i-axis"                                         unit="m/s"  /> 
     342      <field id="ssv_m" long_name="ocean surface current along j-axis"                                         unit="m/s"  /> 
     343      <field id="ssh_m"    unit="m"    /> 
     344      <field id="e3t_m"    unit="m"    /> 
     345      <field id="frq_m"    unit="-"    /> 
     346 
    866347    </field_group> 
    867      
    868     <field_group id="mooring" > 
    869       <field field_ref="toce"         name="thetao"   long_name="sea_water_potential_temperature"      /> 
    870       <field field_ref="soce"         name="so"       long_name="sea_water_salinity"                   /> 
    871       <field field_ref="uoce"         name="uo"       long_name="sea_water_x_velocity"                 /> 
    872       <field field_ref="voce"         name="vo"       long_name="sea_water_y_velocity"                 /> 
    873       <field field_ref="woce"         name="wo"       long_name="sea_water_z_velocity"                 /> 
    874       <field field_ref="avt"          name="difvho"   long_name="ocean_vertical_heat_diffusivity"      /> 
    875       <field field_ref="avm"          name="difvmo"   long_name="ocean_vertical_momentum_diffusivity"  /> 
    876        
    877       <field field_ref="sst"          name="tos"      long_name="sea_surface_temperature"                       /> 
    878       <field field_ref="sst2"         name="tossq"    long_name="square_of_sea_surface_temperature"             /> 
    879       <field field_ref="sstgrad"      name="tosgrad"  long_name="module_of_sea_surface_temperature_gradient"    /> 
    880       <field field_ref="sss"          name="sos"      long_name="sea_surface_salinity"                          /> 
    881       <field field_ref="ssh"          name="zos"      long_name="sea_surface_height_above_geoid"                /> 
    882       <field field_ref="empmr"        name="wfo"      long_name="water_flux_into_sea_water"                     /> 
    883       <field field_ref="qsr"          name="rsntds"   long_name="surface_net_downward_shortwave_flux"           /> 
    884       <field field_ref="qt"           name="tohfls"   long_name="surface_net_downward_total_heat_flux"          /> 
    885       <field field_ref="taum"                                                                                   /> 
    886       <field field_ref="20d"                                                                                    /> 
    887       <field field_ref="mldkz5"                                                                                 /> 
    888       <field field_ref="mldr10_1"                                                                               /> 
    889       <field field_ref="mldr10_3"                                                                               /> 
    890       <field field_ref="mldr0_1"                                                                                /> 
    891       <field field_ref="mldr0_3"                                                                                /> 
    892       <field field_ref="mld_dt02"                                                                               /> 
    893       <field field_ref="topthdep"                                                                               /> 
    894       <field field_ref="pycndep"                                                                                /> 
    895       <field field_ref="tinv"                                                                                   /> 
    896       <field field_ref="depti"                                                                                  /> 
    897       <field field_ref="BLT"          name="blt"      long_name="barrier_layer_thickness"                       /> 
    898       <field field_ref="utau"         name="tauuo"    long_name="surface_downward_x_stress"                     /> 
    899       <field field_ref="vtau"         name="tauvo"    long_name="surface_downward_y_stress"                     /> 
     348 
     349    <!-- scalar variables --> 
     350    <field_group id="SBC_0D"  grid_ref="grid_1point" > 
    900351    </field_group> 
    901352 
    902     <field_group id="groupT" > 
    903       <field field_ref="toce"         name="thetao"   long_name="sea_water_potential_temperature"               /> 
    904       <field field_ref="soce"         name="so"       long_name="sea_water_salinity"                            /> 
    905       <field field_ref="sst"          name="tos"      long_name="sea_surface_temperature"                       /> 
    906       <field field_ref="sst2"         name="tossq"    long_name="square_of_sea_surface_temperature"             /> 
    907       <field field_ref="sss"          name="sos"      long_name="sea_surface_salinity"                          /> 
    908       <field field_ref="ssh"          name="zos"      long_name="sea_surface_height_above_geoid"                /> 
    909       <field field_ref="empmr"        name="wfo"      long_name="water_flux_into_sea_water"                     /> 
    910       <field field_ref="qsr"          name="rsntds"   long_name="surface_net_downward_shortwave_flux"           /> 
    911       <field field_ref="qt"           name="tohfls"   long_name="surface_net_downward_total_heat_flux"          /> 
    912       <field field_ref="taum"                                                                                   /> 
    913       <field field_ref="20d"                                                                                    /> 
    914       <field field_ref="mldkz5"                                                                                 /> 
    915       <field field_ref="mldr10_1"                                                                               /> 
    916       <field field_ref="mldr10_3"                                                                               /> 
    917       <field field_ref="mld_dt02"                                                                               /> 
    918       <field field_ref="topthdep"                                                                               /> 
    919       <field field_ref="pycndep"                                                                                /> 
    920       <field field_ref="tinv"                                                                                   /> 
    921       <field field_ref="depti"                                                                                  /> 
    922       <field field_ref="BLT"          name="blt"      long_name="Barrier Layer Thickness"                       /> 
    923     </field_group> 
    924      
    925     <field_group id="groupU" > 
    926       <field field_ref="uoce"         name="uo"      long_name="sea_water_x_velocity"      /> 
    927       <field field_ref="ssu"          name="uos"     long_name="sea_surface_x_velocity"    /> 
    928       <field field_ref="utau"         name="tauuo"   long_name="surface_downward_x_stress" /> 
    929     </field_group> 
    930      
    931     <field_group id="groupV" > 
    932       <field field_ref="voce"         name="vo"      long_name="sea_water_y_velocity"      /> 
    933       <field field_ref="ssv"          name="vos"     long_name="sea_surface_y_velocity"    /> 
    934       <field field_ref="vtau"         name="tauvo"   long_name="surface_downward_y_stress" /> 
    935     </field_group> 
    936      
    937     <field_group id="groupW" > 
    938       <field field_ref="woce"         name="wo"       long_name="ocean vertical velocity"  /> 
    939     </field_group> 
    940  
    941     <!-- TMB diagnostic output --> 
    942     <field_group  id="1h_grid_T_tmb" grid_ref="grid_T_2D" operation="instant"> 
    943       <field id="top_temp"           name="votemper_top"  unit="degC"  /> 
    944       <field id="mid_temp"           name="votemper_mid"  unit="degC"  /> 
    945       <field id="bot_temp"           name="votemper_bot"  unit="degC"  /> 
    946       <field id="top_sal"            name="vosaline_top"  unit="psu"   /> 
    947       <field id="mid_sal"            name="vosaline_mid"  unit="psu"   /> 
    948       <field id="bot_sal"            name="vosaline_bot"  unit="psu"   /> 
    949       <field id="sshnmasked"         name="sossheig"      unit="m"     />  
    950     </field_group> 
    951  
    952     <field_group  id="1h_grid_U_tmb" grid_ref="grid_U_2D" operation="instant"> 
    953       <field id="top_u"           name="vozocrtx_top"  unit="m/s"  /> 
    954       <field id="mid_u"           name="vozocrtx_mid"  unit="m/s"  /> 
    955       <field id="bot_u"           name="vozocrtx_bot"  unit="m/s"  /> 
    956       <field id="baro_u"          name="vobtcrtx"      unit="m/s"  /> 
    957     </field_group> 
    958  
    959     <field_group  id="1h_grid_V_tmb" grid_ref="grid_V_2D" operation="instant"> 
    960       <field id="top_v"           name="vomecrty_top"  unit="m/s"  /> 
    961       <field id="mid_v"           name="vomecrty_mid"  unit="m/s"  /> 
    962       <field id="bot_v"           name="vomecrty_bot"  unit="m/s"  /> 
    963       <field id="baro_v"          name="vobtcrty"      unit="m/s"  /> 
    964     </field_group> 
    965  
    966     <!-- 25h diagnostic output --> 
    967     <field_group id="25h_grid_T" grid_ref="grid_T_3D" operation="instant"> 
    968       <field id="temper25h"         name="potential temperature 25h mean"    unit="degC" /> 
    969       <field id="tempis25h"         name="insitu temperature 25h mean"    unit="degC" /> 
    970       <field id="salin25h"          name="salinity 25h mean"                 unit="psu"  /> 
    971       <field id="ssh25h"            name="sea surface height 25h mean"  grid_ref="grid_T_2D"      unit="m"    /> 
    972     </field_group> 
    973  
    974     <field_group id="25h_grid_U" grid_ref="grid_U_3D" operation="instant" > 
    975       <field id="vozocrtx25h"         name="i current 25h mean"    unit="m/s"   /> 
    976     </field_group> 
    977  
    978     <field_group id="25h_grid_V" grid_ref="grid_V_3D" operation="instant"> 
    979       <field id="vomecrty25h"         name="j current 25h mean"    unit="m/s"    /> 
    980     </field_group> 
    981  
    982     <field_group id="25h_grid_W" grid_ref="grid_W_3D" operation="instant"> 
    983       <field id="vovecrtz25h"         name="k current 25h mean"                 unit="m/s"      /> 
    984       <field id="avt25h"              name="vertical diffusivity25h mean"       unit="m2/s" /> 
    985       <field id="avm25h"              name="vertical viscosity 25h mean"        unit="m2/s" /> 
    986       <field id="tke25h"              name="turbulent kinetic energy 25h mean" /> 
    987       <field id="mxln25h"             name="mixing length 25h mean"             unit="m" /> 
    988     </field_group> 
    989  
    990     <!--  
    991 ============================================================================================================ 
    992     --> 
    993     <!-- output variables for my configuration (example) -->  
    994      
    995     <field_group id="myvarOCE" > 
    996       <!-- grid T -->  
    997       <field field_ref="e3t"          name="e3t"      long_name="vertical scale factor"           /> 
    998       <field field_ref="sst"          name="tos"      long_name="sea_surface_temperature"         /> 
    999       <field field_ref="sss"          name="sos"      long_name="sea_surface_salinity"            /> 
    1000       <field field_ref="ssh"          name="zos"      long_name="sea_surface_height_above_geoid"  /> 
    1001        
    1002       <!-- grid U -->  
    1003       <field field_ref="e3u"          name="e3u"     long_name="vertical scale factor"            /> 
    1004       <field field_ref="ssu"          name="uos"     long_name="sea_surface_x_velocity"           /> 
    1005        
    1006       <!-- grid V -->  
    1007       <field field_ref="e3v"          name="e3v"     long_name="vertical scale factor"            /> 
    1008       <field field_ref="ssv"          name="vos"     long_name="sea_surface_y_velocity"           />      
    1009     </field_group>     
    1010  
    1011    </field_definition> 
     353  </field_group> <!-- SBC --> 
     354 
     355  <!-- U grid --> 
     356 
     357  <field_group id="grid_U"   grid_ref="grid_U_2D"> 
     358    <field id="e3u"          long_name="U-cell thickness"                                       standard_name="cell_thickness"              unit="m"          grid_ref="grid_U_3D" /> 
     359    <field id="e3u_0"        long_name="Initial U-cell thickness"                               standard_name="ref_cell_thickness"          unit="m"          grid_ref="grid_U_3D"/> 
     360    <field id="utau"         long_name="Wind Stress along i-axis"                               standard_name="surface_downward_x_stress"   unit="N/m2"                            /> 
     361    <field id="uoce"         long_name="ocean current along i-axis"                             standard_name="sea_water_x_velocity"        unit="m/s"        grid_ref="grid_U_3D" /> 
     362    <field id="uoce_e3u"     long_name="ocean current along i-axis  (thickness weighted)"                                                   unit="m/s"        grid_ref="grid_U_3D"  > uoce * e3u </field> 
     363    <field id="ssu"          long_name="ocean surface current along i-axis"                                                                 unit="m/s"                             /> 
     364    <field id="sbu"          long_name="ocean bottom current along i-axis"                                                                  unit="m/s"                             /> 
     365    <field id="ubar"         long_name="ocean barotropic current along i-axis"                                                              unit="m/s"                             /> 
     366    <field id="uocetr_eff"   long_name="Effective ocean transport along i-axis"                 standard_name="ocean_volume_x_transport"    unit="m3/s"       grid_ref="grid_U_3D" /> 
     367    <field id="uocet"        long_name="ocean transport along i-axis times temperature (CRS)"                                               unit="degC*m/s"   grid_ref="grid_U_3D" /> 
     368    <field id="uoces"        long_name="ocean transport along i-axis times salinity (CRS)"                                                  unit="1e-3*m/s"   grid_ref="grid_U_3D" /> 
     369 
     370    <!-- u-eddy diffusivity coefficients (available if ln_traldf_OFF=F) --> 
     371    <field id="ahtu_2d"      long_name=" surface u-eddy diffusivity coefficient"   unit="m2/s or m4/s" /> 
     372    <field id="ahtu_3d"      long_name=" 3D u-EIV coefficient"                     unit="m2/s or m4/s"      grid_ref="grid_U_3D"/> 
     373    <!-- u-eiv diffusivity coefficients (available if ln_ldfeiv=F) --> 
     374    <field id="aeiu_2d"      long_name=" surface u-EIV coefficient"                unit="m2/s" /> 
     375    <field id="aeiu_3d"      long_name=" 3D u-EIV coefficient"                     unit="m2/s"              grid_ref="grid_U_3D"/> 
     376 
     377    <!-- variables available with MLE (ln_mle=T) --> 
     378    <field id="psiu_mle"     long_name="MLE streamfunction along i-axis"   unit="m3/s"   grid_ref="grid_U_3D" /> 
     379 
     380    <!-- uoce_eiv: available EIV (ln_ldfeiv=T and ln_ldfeiv_dia=T) --> 
     381    <field id="uoce_eiv"     long_name="EIV ocean current along i-axis"   standard_name="bolus_sea_water_x_velocity"   unit="m/s"   grid_ref="grid_U_3D" /> 
     382 
     383    <!-- uoce_bbl: available with ln_trabbl=T and nn_bbl_adv=1 --> 
     384    <field id="uoce_bbl"     long_name="BBL ocean current along i-axis"    unit="m/s"  /> 
     385    <!-- ahu_bbl : available with ln_trabbl=T and nn_bbl_ldf=1 --> 
     386    <field id="ahu_bbl"      long_name="BBL diffusive flux along i-axis"   unit="m3/s" /> 
     387 
     388    <!-- variables available with WAVE (ln_wave=T) --> 
     389    <field id="ustokes"      long_name="Stokes Drift Velocity i-axis"      standard_name="StokesDrift_x_velocity"      unit="m/s"        grid_ref="grid_U_3D" /> 
     390    <field id="ustokes_e3u"  long_name="Stokes Drift Velocity i-axis  (thickness weighted)"                            unit="m/s"        grid_ref="grid_U_3D"  > ustokes * e3u </field> 
     391 
     392    <!-- variable for ice shelves --> 
     393    <field id="utbl"         long_name="zonal current in the Losh tbl"     unit="m/s" /> 
     394 
     395    <field id="u_masstr"      long_name="Ocean Mass X Transport"                                          standard_name="ocean_mass_x_transport"                         unit="kg/s" grid_ref="grid_U_3D" /> 
     396    <field id="u_masstr_vint" long_name="vertical integral of ocean eulerian mass transport along i-axis" standard_name="vertical_integral_of_ocean_mass_x_transport"    unit="kg/s"                      /> 
     397    <field id="u_heattr"      long_name="ocean eulerian heat transport along i-axis"                      standard_name="ocean_heat_x_transport"                         unit="W"                         /> 
     398    <field id="u_salttr"      long_name="ocean eulerian salt transport along i-axis"                      standard_name="ocean_salt_x_transport"                         unit="1e-3*kg/s"                 /> 
     399    <field id="uadv_heattr"   long_name="ocean advective heat transport along i-axis"                     standard_name="advectice_ocean_heat_x_transport"               unit="W"                         /> 
     400    <field id="uadv_salttr"   long_name="ocean advective salt transport along i-axis"                     standard_name="advectice_ocean_salt_x_transport"               unit="1e-3*kg/s"                 /> 
     401    <field id="ueiv_heattr"   long_name="ocean bolus heat transport along i-axis"                         standard_name="ocean_heat_x_transport_due_to_bolus_advection"  unit="W"                         /> 
     402    <field id="ueiv_salttr"   long_name="ocean bolus salt transport along i-axis"                         standard_name="ocean_salt_x_transport_due_to_bolus_advection"  unit="Kg"                        /> 
     403    <field id="ueiv_heattr3d" long_name="ocean bolus heat transport along i-axis"                         standard_name="ocean_heat_x_transport_due_to_bolus_advection"  unit="W"    grid_ref="grid_U_3D" /> 
     404    <field id="ueiv_salttr3d" long_name="ocean bolus salt transport along i-axis"                         standard_name="ocean_salt_x_transport_due_to_bolus_advection"  unit="kg"   grid_ref="grid_U_3D" /> 
     405    <field id="udiff_heattr"  long_name="ocean diffusion heat transport along i-axis"                     standard_name="ocean_heat_x_transport_due_to_diffusion"        unit="W"                         /> 
     406    <field id="udiff_salttr"  long_name="ocean diffusion salt transport along i-axis"                     standard_name="ocean_salt_x_transport_due_to_diffusion"        unit="1e-3*kg/s"                 /> 
     407  </field_group> 
     408 
     409  <!-- V grid --> 
     410 
     411  <field_group id="grid_V"   grid_ref="grid_V_2D"> 
     412    <field id="e3v"          long_name="V-cell thickness"                                       standard_name="cell_thickness"              unit="m"          grid_ref="grid_V_3D" /> 
     413    <field id="e3v_0"        long_name="Initial V-cell thickness"                               standard_name="ref_cell_thickness"          unit="m"          grid_ref="grid_V_3D" /> 
     414    <field id="vtau"         long_name="Wind Stress along j-axis"                               standard_name="surface_downward_y_stress"   unit="N/m2"                            /> 
     415    <field id="voce"         long_name="ocean current along j-axis"                             standard_name="sea_water_y_velocity"        unit="m/s"        grid_ref="grid_V_3D" /> 
     416    <field id="voce_e3v"     long_name="ocean current along j-axis  (thickness weighted)"                                                   unit="m/s"        grid_ref="grid_V_3D"  > voce * e3v </field> 
     417    <field id="ssv"          long_name="ocean surface current along j-axis"                                                                 unit="m/s"                             /> 
     418    <field id="sbv"          long_name="ocean bottom current along j-axis"                                                                  unit="m/s"                             /> 
     419    <field id="vbar"         long_name="ocean barotropic current along j-axis"                                                              unit="m/s"                             /> 
     420    <field id="vocetr_eff"   long_name="Effective ocean transport along j-axis"                 standard_name="ocean_volume_y_transport"    unit="m3/s"       grid_ref="grid_V_3D" /> 
     421    <field id="vocet"        long_name="ocean transport along j-axis times temperature (CRS)"                                               unit="degC*m/s"   grid_ref="grid_V_3D" /> 
     422    <field id="voces"        long_name="ocean transport along j-axis times salinity (CRS)"                                                  unit="1e-3*m/s"   grid_ref="grid_V_3D" /> 
     423 
     424    <!-- v-eddy diffusivity coefficients (available if ln_traldf_OFF=F) --> 
     425    <field id="ahtv_2d"      long_name=" surface v-eddy diffusivity coefficient"     unit="m2/s or (m4/s)^1/2" /> 
     426    <field id="ahtv_3d"      long_name=" 3D v-eddy diffusivity coefficient"          unit="m2/s or (m4/s)^1/2"           grid_ref="grid_V_3D"/> 
     427    <!-- v-eiv diffusivity coefficients (available if ln_ldfeiv=F) --> 
     428    <field id="aeiv_2d"      long_name=" surface v-EIV coefficient"                  unit="m2/s" /> 
     429    <field id="aeiv_3d"      long_name=" 3D v-EIV coefficient"                       unit="m2/s"                         grid_ref="grid_V_3D" /> 
     430 
     431    <!-- variables available with MLE (ln_mle=T) --> 
     432    <field id="psiv_mle"     long_name="MLE streamfunction along j-axis"   unit="m3/s"   grid_ref="grid_V_3D" /> 
     433 
     434    <!-- voce_eiv: available EIV (ln_ldfeiv=T and ln_ldfeiv_dia=T)  --> 
     435    <field id="voce_eiv"     long_name="EIV ocean current along j-axis"   standard_name="bolus_sea_water_y_velocity"   unit="m/s"   grid_ref="grid_V_3D" /> 
     436 
     437    <!-- voce_bbl: available with ln_trabbl=T and nn_bbl_adv=1 --> 
     438    <field id="voce_bbl"     long_name="BBL ocean current along j-axis"    unit="m/s"  /> 
     439    <!-- ahu_bbl : available with ln_trabbl=T and nn_bbl_ldf=1 --> 
     440    <field id="ahv_bbl"      long_name="BBL diffusive flux along j-axis"   unit="m3/s" /> 
     441 
     442    <!-- variables available with WAVE (ln_wave=T) --> 
     443    <field id="vstokes"      long_name="Stokes Drift Velocity j-axis"      standard_name="StokesDrift_y_velocity"      unit="m/s"        grid_ref="grid_V_3D" /> 
     444    <field id="vstokes_e3v"  long_name="Stokes Drift Velocity j-axis  (thickness weighted)"                            unit="m/s"        grid_ref="grid_V_3D"  > vstokes * e3v </field> 
     445 
     446    <!-- variable for ice shelves --> 
     447    <field id="vtbl"         long_name="meridional current in the Losh tbl"   unit="m/s" /> 
     448 
     449    <!-- variables available with diaar5 --> 
     450    <field id="v_masstr"      long_name="ocean eulerian mass transport along j-axis"    standard_name="ocean_mass_y_transport"                          unit="kg/s" grid_ref="grid_V_3D" /> 
     451    <field id="v_heattr"      long_name="ocean eulerian heat transport along j-axis"    standard_name="ocean_heat_y_transport"                          unit="W"                         /> 
     452    <field id="v_salttr"      long_name="ocean eulerian salt transport along i-axis"    standard_name="ocean_salt_y_transport"                          unit="1e-3*kg/s"                 /> 
     453    <field id="vadv_heattr"   long_name="ocean advective heat transport along j-axis"   standard_name="advectice_ocean_heat_y_transport"                unit="W"                         /> 
     454    <field id="vadv_salttr"   long_name="ocean advective salt transport along j-axis"   standard_name="advectice_ocean_salt_y_transport"                unit="1e-3*kg/s"                 /> 
     455    <field id="veiv_heattr"   long_name="ocean bolus heat transport along j-axis"       standard_name="ocean_heat_y_transport_due_to_bolus_advection"   unit="W"                         /> 
     456    <field id="veiv_salttr"   long_name="ocean bolus salt transport along j-axis"       standard_name="ocean_salt_x_transport_due_to_bolus_advection"   unit="Kg"                        /> 
     457    <field id="veiv_heattr3d" long_name="ocean bolus heat transport along j-axis"       standard_name="ocean_heat_y_transport_due_to_bolus_advection"   unit="W"    grid_ref="grid_V_3D" /> 
     458    <field id="veiv_salttr3d" long_name="ocean bolus salt transport along j-axis"       standard_name="ocean_salt_y_transport_due_to_bolus_advection"   unit="kg"   grid_ref="grid_V_3D" /> 
     459    <field id="vdiff_heattr"  long_name="ocean diffusion heat transport along j-axis"   standard_name="ocean_heat_y_transport_due_to_diffusion"         unit="W"                         /> 
     460    <field id="vdiff_salttr"  long_name="ocean diffusion salt transport along j-axis"   standard_name="ocean_salt_y_transport_due_to_diffusion"         unit="1e-3*kg/s"                 /> 
     461  </field_group> 
     462 
     463  <!-- W grid --> 
     464 
     465  <field_group id="grid_W" grid_ref="grid_W_3D"> 
     466    <field id="e3w"          long_name="W-cell thickness"                              standard_name="cell_thickness"                         unit="m"    /> 
     467    <field id="woce"         long_name="ocean vertical velocity"                       standard_name="upward_sea_water_velocity"              unit="m/s"  /> 
     468    <field id="wocetr_eff"   long_name="effective ocean vertical transport"                                                                   unit="m3/s" /> 
     469 
     470    <!-- woce_eiv: available with EIV  (ln_ldfeiv=T and ln_ldfeiv_dia=T)  --> 
     471    <field id="woce_eiv"     long_name="EIV ocean vertical velocity"                    standard_name="bolus_upward_sea_water_velocity"       unit="m/s"  /> 
     472 
     473    <field id="avt"          long_name="vertical eddy diffusivity"                      standard_name="ocean_vertical_heat_diffusivity"       unit="m2/s" /> 
     474    <field id="logavt"       long_name="logarithm of vertical eddy diffusivity"         standard_name="ocean_vertical_heat_diffusivity"       unit="m2/s" /> 
     475    <field id="avm"          long_name="vertical eddy viscosity"                        standard_name="ocean_vertical_momentum_diffusivity"   unit="m2/s" /> 
     476 
     477    <!-- avs: /= avt with ln_zdfddm=T --> 
     478    <field id="avs"          long_name="salt vertical eddy diffusivity"                 standard_name="ocean_vertical_salt_diffusivity"       unit="m2/s" /> 
     479    <field id="logavs"       long_name="logarithm of salt vertical eddy diffusivity"    standard_name="ocean_vertical_heat_diffusivity"       unit="m2/s" /> 
     480 
     481    <!-- avt_evd and avm_evd: available with ln_zdfevd --> 
     482    <field id="avt_evd"      long_name="convective enhancement of vertical diffusivity" standard_name="ocean_vertical_tracer_diffusivity_due_to_convection"     unit="m2/s" /> 
     483    <field id="avm_evd"      long_name="convective enhancement of vertical viscosity"   standard_name="ocean_vertical_momentum_diffusivity_due_to_convection"   unit="m2/s" /> 
     484 
     485    <!-- avt_tide: available with ln_zdfiwm=T --> 
     486    <field id="av_ratio"     long_name="S over T diffusivity ratio"                     standard_name="salinity_over_temperature_diffusivity_ratio"                     unit="1"    /> 
     487    <field id="av_wave"      long_name="internal wave-induced vertical diffusivity"     standard_name="ocean_vertical_tracer_diffusivity_due_to_internal_waves"         unit="m2/s" /> 
     488    <field id="bflx_iwm"     long_name="internal wave-induced buoyancy flux"            standard_name="buoyancy_flux_due_to_internal_waves"                             unit="W/kg" /> 
     489    <field id="pcmap_iwm"    long_name="power consumed by wave-driven mixing"           standard_name="vertically_integrated_power_consumption_by_wave_driven_mixing"   unit="W/m2"      grid_ref="grid_W_2D" /> 
     490    <field id="emix_iwm"     long_name="power density available for mixing"             standard_name="power_available_for_mixing_from_breaking_internal_waves"         unit="W/kg" /> 
     491 
     492    <!-- variables available with WAVE (ln_wave=T) --> 
     493    <field id="wstokes"      long_name="Stokes Drift vertical velocity"                 standard_name="upward_StokesDrift_velocity"   unit="m/s" /> 
     494 
     495    <!-- variables available with diaar5 --> 
     496    <field id="w_masstr"     long_name="vertical mass transport"                        standard_name="upward_ocean_mass_transport"             unit="kg/s"   /> 
     497    <field id="w_masstr2"    long_name="square of vertical mass transport"              standard_name="square_of_upward_ocean_mass_transport"   unit="kg2/s2" /> 
     498 
     499  </field_group> 
     500 
     501  <!-- F grid --> 
     502  <!-- f-eddy viscosity coefficients (ldfdyn) --> 
     503  <field id="ahmf_2d"      long_name=" surface f-eddy viscosity coefficient"   unit="m2/s or m4/s" /> 
     504  <field id="ahmf_3d"      long_name=" 3D      f-eddy viscosity coefficient"   unit="m2/s or m4/s"  grid_ref="grid_T_3D"/> 
     505 
     506  <field_group id="scalar"  grid_ref="grid_T_2D"  > 
     507    <!-- Need to have a salinity reference climatological file : sali_ref_clim_monthly --> 
     508    <field id="voltot"     long_name="global total volume"                          standard_name="sea_water_volume"                               unit="m3"   /> 
     509    <field id="sshtot"     long_name="global mean ssh"                              standard_name="global_average_sea_level_change"                unit="m"    /> 
     510    <field id="sshsteric"  long_name="global mean ssh steric"                       standard_name="global_average_steric_sea_level_change"         unit="m"    /> 
     511    <field id="sshthster"  long_name="global mean ssh thermosteric"                 standard_name="global_average_thermosteric_sea_level_change"   unit="m"    /> 
     512    <field id="masstot"    long_name="global total mass"                            standard_name="sea_water_mass"                                 unit="kg"   /> 
     513    <field id="temptot"    long_name="global mean temperature"                      standard_name="sea_water_potential_temperature"                unit="degC" /> 
     514    <field id="saltot"     long_name="global mean salinity"                         standard_name="sea_water_salinity"                             unit="1e-3" /> 
     515    <field id="fram_trans" long_name="Sea Ice Mass Transport Through Fram Strait"   standard_name="sea_ice_transport_across_line"                  unit="kg/s" /> 
     516 
     517    <!-- available with ln_diahsb --> 
     518    <field id="bgtemper"     long_name="drift in global mean temperature wrt timestep 1"                 standard_name="change_over_time_in_sea_water_potential_temperature"   unit="degC"     /> 
     519    <field id="bgsaline"     long_name="drift in global mean salinity wrt timestep 1"                    standard_name="change_over_time_in_sea_water_practical_salinity"      unit="1e-3"     /> 
     520    <field id="bgheatco"     long_name="drift in global mean heat content wrt timestep 1"                                                                                      unit="1.e20J"   /> 
     521    <field id="bgheatfx"     long_name="drift in global mean heat flux    wrt timestep 1"                                                                                      unit="W/m2"     /> 
     522    <field id="bgsaltco"     long_name="drift in global mean salt content wrt timestep 1"                                                                                      unit="1e-3*km3" /> 
     523    <field id="bgvolssh"     long_name="drift in global mean ssh volume wrt timestep 1"                                                                                        unit="km3"      /> 
     524    <field id="bgvole3t"     long_name="drift in global mean volume variation (e3t) wrt timestep 1"                                                                            unit="km3"      /> 
     525    <field id="bgfrcvol"     long_name="global mean volume from forcing"                                                                                                       unit="km3"      /> 
     526    <field id="bgfrctem"     long_name="global mean heat content from forcing"                                                                                                 unit="1.e20J"   /> 
     527    <field id="bgfrchfx"     long_name="global mean heat flux from forcing"                                                                                                    unit="W/m2"     /> 
     528    <field id="bgfrcsal"     long_name="global mean salt content from forcing"                                                                                                 unit="1e-3*km3" /> 
     529    <field id="bgmistem"     long_name="global mean temperature error due to free surface (linssh true)"                                                                       unit="degC"     /> 
     530    <field id="bgmissal"     long_name="global mean salinity error due to free surface (linssh true)"                                                                          unit="1e-3"     /> 
     531  </field_group> 
     532 
     533  <!-- variables available with key_float --> 
     534 
     535  <field_group id="floatvar" grid_ref="grid_T_nfloat"  operation="instant" > 
     536    <field id="traj_lon"      long_name="floats longitude"                                                           unit="degrees_east"  /> 
     537    <field id="traj_lat"      long_name="floats latitude"                                                            unit="degrees_north" /> 
     538    <field id="traj_dep"      long_name="floats depth"                                                               unit="m"             /> 
     539    <field id="traj_temp"     long_name="floats temperature"       standard_name="sea_water_potential_temperature"   unit="degC"          /> 
     540    <field id="traj_salt"     long_name="floats salinity"          standard_name="sea_water_practical_salinity"      unit="1e-3"          /> 
     541    <field id="traj_dens"     long_name="floats in-situ density"   standard_name="sea_water_density"                 unit="kg/m3"         /> 
     542    <field id="traj_group"    long_name="floats group"                                                               unit="1"             /> 
     543  </field_group> 
     544 
     545  <!-- variables available with iceberg trajectories --> 
     546 
     547  <field_group id="icbvar" domain_ref="grid_T"  > 
     548    <field id="berg_melt"          long_name="icb melt rate of icebergs"                       unit="kg/m2/s"                    /> 
     549    <field id="berg_melt_hcflx"    long_name="icb heat flux to ocean due to melting heat content"   unit="J/m2/s"                /> 
     550    <field id="berg_melt_qlat"     long_name="icb heat flux to ocean due to melting latent heat"    unit="J/m2/s"                /> 
     551    <field id="berg_buoy_melt"     long_name="icb buoyancy component of iceberg melt rate"     unit="kg/m2/s"                    /> 
     552    <field id="berg_eros_melt"     long_name="icb erosion component of iceberg melt rate"      unit="kg/m2/s"                    /> 
     553    <field id="berg_conv_melt"     long_name="icb convective component of iceberg melt rate"   unit="kg/m2/s"                    /> 
     554    <field id="berg_virtual_area"  long_name="icb virtual coverage by icebergs"                unit="m2"                         /> 
     555    <field id="bits_src"           long_name="icb mass source of bergy bits"                   unit="kg/m2/s"                    /> 
     556    <field id="bits_melt"          long_name="icb melt rate of bergy bits"                     unit="kg/m2/s"                    /> 
     557    <field id="bits_mass"          long_name="icb bergy bit density field"                     unit="kg/m2"                      /> 
     558    <field id="berg_mass"          long_name="icb iceberg density field"                       unit="kg/m2"                      /> 
     559    <field id="calving"            long_name="icb calving mass input"                          unit="kg/s"                       /> 
     560    <field id="berg_floating_melt" long_name="icb melt rate of icebergs + bits"                unit="kg/m2/s"                    /> 
     561    <field id="berg_real_calving"  long_name="icb calving into iceberg class"                  unit="kg/s"     axis_ref="icbcla" /> 
     562    <field id="berg_stored_ice"    long_name="icb accumulated ice mass by class"               unit="kg"       axis_ref="icbcla" /> 
     563  </field_group> 
     564 
     565  <!-- Poleward transport : ptr --> 
     566  <field_group id="diaptr" > 
     567    <field id="zomsfglo"          long_name="Meridional Stream-Function: Global"           unit="Sv"        grid_ref="gznl_W_3D" /> 
     568    <field id="zomsfatl"          long_name="Meridional Stream-Function: Atlantic"         unit="Sv"        grid_ref="gznl_W_3D" /> 
     569    <field id="zomsfpac"          long_name="Meridional Stream-Function: Pacific"          unit="Sv"        grid_ref="gznl_W_3D" /> 
     570    <field id="zomsfind"          long_name="Meridional Stream-Function: Indian"           unit="Sv"        grid_ref="gznl_W_3D" /> 
     571    <field id="zomsfipc"          long_name="Meridional Stream-Function: Pacific+Indian"   unit="Sv"        grid_ref="gznl_W_3D" /> 
     572    <field id="zotemglo"          long_name="Zonal Mean Temperature : Global"              unit="degree_C"  grid_ref="gznl_T_3D" /> 
     573    <field id="zotematl"          long_name="Zonal Mean Temperature : Atlantic"            unit="degree_C"  grid_ref="gznl_T_3D" /> 
     574    <field id="zotempac"          long_name="Zonal Mean Temperature : Pacific"             unit="degree_C"  grid_ref="gznl_T_3D" /> 
     575    <field id="zotemind"          long_name="Zonal Mean Temperature : Indian"              unit="degree_C"  grid_ref="gznl_T_3D" /> 
     576    <field id="zotemipc"          long_name="Zonal Mean Temperature : Pacific+Indian"      unit="degree_C"  grid_ref="gznl_T_3D" /> 
     577    <field id="zosalglo"          long_name="Zonal Mean Salinity : Global"                 unit="0.001"     grid_ref="gznl_T_3D" /> 
     578    <field id="zosalatl"          long_name="Zonal Mean Salinity : Atlantic"               unit="0.001"     grid_ref="gznl_T_3D" /> 
     579    <field id="zosalpac"          long_name="Zonal Mean Salinity : Pacific"                unit="0.001"     grid_ref="gznl_T_3D" /> 
     580    <field id="zosalind"          long_name="Zonal Mean Salinity : Indian"                 unit="0.001"     grid_ref="gznl_T_3D" /> 
     581    <field id="zosalipc"          long_name="Zonal Mean Salinity : Pacific+Indian"         unit="0.001"     grid_ref="gznl_T_3D" /> 
     582    <field id="zosrfglo"          long_name="Zonal Mean Surface"                           unit="m2"        grid_ref="gznl_T_3D" /> 
     583    <field id="zosrfatl"          long_name="Zonal Mean Surface : Atlantic"                unit="m2"        grid_ref="gznl_T_3D" /> 
     584    <field id="zosrfpac"          long_name="Zonal Mean Surface : Pacific"                 unit="m2"        grid_ref="gznl_T_3D" /> 
     585    <field id="zosrfind"          long_name="Zonal Mean Surface : Indian"                  unit="m2"        grid_ref="gznl_T_3D" /> 
     586    <field id="zosrfipc"          long_name="Zonal Mean Surface : Pacific+Indian"          unit="m2"        grid_ref="gznl_T_3D" /> 
     587    <field id="sophtadv"          long_name="Advective Heat Transport"                     unit="PW"        grid_ref="gznl_T_2D" /> 
     588    <field id="sophtadv_atl"      long_name="Advective Heat Transport: Atlantic"           unit="PW"        grid_ref="gznl_T_2D" /> 
     589    <field id="sophtadv_pac"      long_name="Advective Heat Transport: Pacific"            unit="PW"        grid_ref="gznl_T_2D" /> 
     590    <field id="sophtadv_ind"      long_name="Advective Heat Transport: Indian"             unit="PW"        grid_ref="gznl_T_2D" /> 
     591    <field id="sophtadv_ipc"      long_name="Advective Heat Transport: Pacific+Indian"     unit="PW"        grid_ref="gznl_T_2D" /> 
     592    <field id="sophtldf"          long_name="Diffusive Heat Transport"                     unit="PW"        grid_ref="gznl_T_2D" /> 
     593    <field id="sophtldf_atl"      long_name="Diffusive Heat Transport: Atlantic"           unit="PW"        grid_ref="gznl_T_2D" /> 
     594    <field id="sophtldf_pac"      long_name="Diffusive Heat Transport: Pacific"            unit="PW"        grid_ref="gznl_T_2D" /> 
     595    <field id="sophtldf_ind"      long_name="Diffusive Heat Transport: Indian"             unit="PW"        grid_ref="gznl_T_2D" /> 
     596    <field id="sophtldf_ipc"      long_name="Diffusive Heat Transport: Pacific+Indian"     unit="PW"        grid_ref="gznl_T_2D" /> 
     597    <field id="sophtove"          long_name="Overturning Heat Transport"                   unit="PW"        grid_ref="gznl_T_2D" /> 
     598    <field id="sophtove_atl"      long_name="Overturning Heat Transport: Atlantic"         unit="PW"        grid_ref="gznl_T_2D" /> 
     599    <field id="sophtove_pac"      long_name="Overturning Heat Transport: Pacific"          unit="PW"        grid_ref="gznl_T_2D" /> 
     600    <field id="sophtove_ind"      long_name="Overturning Heat Transport: Indian"           unit="PW"        grid_ref="gznl_T_2D" /> 
     601    <field id="sophtove_ipc"      long_name="Overturning Heat Transport: Pacific+Indian"   unit="PW"        grid_ref="gznl_T_2D" /> 
     602    <field id="sophtbtr"          long_name="Barotropic Heat Transport"                    unit="PW"        grid_ref="gznl_T_2D" /> 
     603    <field id="sophtbtr_atl"      long_name="Barotropic Heat Transport: Atlantic"          unit="PW"        grid_ref="gznl_T_2D" /> 
     604    <field id="sophtbtr_pac"      long_name="Barotropic Heat Transport: Pacific"           unit="PW"        grid_ref="gznl_T_2D" /> 
     605    <field id="sophtbtr_ind"      long_name="Barotropic Heat Transport: Indian"            unit="PW"        grid_ref="gznl_T_2D" /> 
     606    <field id="sophtbtr_ipc"      long_name="Barotropic Heat Transport: Pacific+Indian"    unit="PW"        grid_ref="gznl_T_2D" /> 
     607    <field id="sophteiv"          long_name="Heat Transport from mesoscale eddy advection"                     unit="PW"       grid_ref="gznl_T_2D" /> 
     608    <field id="sophteiv_atl"      long_name="Heat Transport from mesoscale eddy advection: Atlantic"           unit="PW"       grid_ref="gznl_T_2D" /> 
     609    <field id="sophteiv_pac"      long_name="Heat Transport from mesoscale eddy advection: Pacific"            unit="PW"       grid_ref="gznl_T_2D" /> 
     610    <field id="sophteiv_ind"      long_name="Heat Transport from mesoscale eddy advection: Indian"             unit="PW"       grid_ref="gznl_T_2D" /> 
     611    <field id="sophteiv_ipc"      long_name="Heat Transport from mesoscale eddy advection: Pacific+Indian"     unit="PW"       grid_ref="gznl_T_2D" /> 
     612    <field id="sopstadv"          long_name="Advective Salt Transport"                     unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     613    <field id="sopstadv_atl"      long_name="Advective Salt Transport: Atlantic"           unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     614    <field id="sopstadv_pac"      long_name="Advective Salt Transport: Pacific"            unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     615    <field id="sopstadv_ind"      long_name="Advective Salt Transport: Indian"             unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     616    <field id="sopstadv_ipc"      long_name="Advective Salt Transport: Pacific+Indian"     unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     617    <field id="sopstove"          long_name="Overturning Salt Transport"                   unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     618    <field id="sopstove_atl"      long_name="Overturning Salt Transport: Atlantic"         unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     619    <field id="sopstove_pac"      long_name="Overturning Salt Transport: Pacific"          unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     620    <field id="sopstove_ind"      long_name="Overturning Salt Transport: Indian"           unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     621    <field id="sopstove_ipc"      long_name="Overturning Salt Transport: Pacific+Indian"   unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     622    <field id="sopstbtr"          long_name="Barotropic Salt Transport"                    unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     623    <field id="sopstbtr_atl"      long_name="Barotropic Salt Transport: Atlantic"          unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     624    <field id="sopstbtr_pac"      long_name="Barotropic Salt Transport: Pacific"           unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     625    <field id="sopstbtr_ind"      long_name="Barotropic Salt Transport: Indian"            unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     626    <field id="sopstbtr_ipc"      long_name="Barotropic Salt Transport: Pacific+Indian"    unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     627    <field id="sopstldf"          long_name="Diffusive Salt Transport"                     unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     628    <field id="sopstldf_atl"      long_name="Diffusive Salt Transport: Atlantic"           unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     629    <field id="sopstldf_pac"      long_name="Diffusive Salt Transport: Pacific"            unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     630    <field id="sopstldf_ind"      long_name="Diffusive Salt Transport: Indian"             unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     631    <field id="sopstldf_ipc"      long_name="Diffusive Salt Transport: Pacific+Indian"     unit="Giga g/s"  grid_ref="gznl_T_2D" /> 
     632    <field id="sopsteiv"          long_name="Salt Transport from mesoscale eddy advection"                     unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
     633    <field id="sopsteiv_atl"      long_name="Salt Transport from mesoscale eddy advection: Atlantic"           unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
     634    <field id="sopsteiv_pac"      long_name="Salt Transport from mesoscale eddy advection: Pacific"            unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
     635    <field id="sopsteiv_ind"      long_name="Salt Transport from mesoscale eddy advection: Indian"             unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
     636    <field id="sopsteiv_ipc"      long_name="Salt Transport from mesoscale eddy advection: Pacific+Indian"     unit="Giga g/s"       grid_ref="gznl_T_2D" /> 
     637  </field_group> 
     638 
     639  <!-- 
     640      ============================================================================================================ 
     641      Physical ocean model trend diagnostics : temperature, KE, PE, momentum 
     642      ============================================================================================================ 
     643  --> 
     644 
     645  <!-- variables available with ln_tra_trd --> 
     646  <!-- Asselin trends  calculated on odd time steps--> 
     647  <field_group id="trendT_odd"  grid_ref="grid_T_3D"> 
     648    <field id="ttrd_atf"      long_name="temperature-trend: asselin time filter"       unit="degree_C/s" /> 
     649    <field id="strd_atf"      long_name="salinity   -trend: asselin time filter"       unit="0.001/s" /> 
     650    <!-- Thickness weighted versions: --> 
     651    <field id="ttrd_atf_e3t"      unit="degC/s * m"  >  ttrd_atf * e3t </field> 
     652    <field id="strd_atf_e3t"      unit="1e-3/s * m"  >  strd_atf * e3t </field> 
     653    <!-- OMIP  layer-integrated trends --> 
     654    <field id="ttrd_atf_li"      long_name="layer integrated heat-trend: asselin time filter "       unit="W/m^2" > ttrd_atf_e3t * 1026.0 * 3991.86795711963  </field> 
     655    <field id="strd_atf_li"      long_name="layer integrated salt   -trend: asselin time filter "       unit="kg/(m^2 s)" > strd_atf_e3t * 1026.0 * 0.001 </field> 
     656  </field_group> 
     657 
     658  <!-- Other trends  calculated on even time steps--> 
     659  <field_group id="trendT_even" grid_ref="grid_T_3D"> 
     660    <field id="ttrd_xad"      long_name="temperature-trend: i-advection"                                                                                          unit="degC/s"                        /> 
     661    <field id="strd_xad"      long_name="salinity   -trend: i-advection"                                                                                          unit="1e-3/s"                        /> 
     662    <field id="ttrd_yad"      long_name="temperature-trend: j-advection"                                                                                          unit="degC/s"                        /> 
     663    <field id="strd_yad"      long_name="salinity   -trend: j-advection"                                                                                          unit="1e-3/s"                        /> 
     664    <field id="ttrd_zad"      long_name="temperature-trend: k-advection"                                                                                          unit="degC/s"                        /> 
     665    <field id="strd_zad"      long_name="salinity   -trend: k-advection"                                                                                          unit="1e-3/s"                        /> 
     666    <field id="ttrd_ad"       long_name="temperature-trend: advection"               standard_name="tendency_of_sea_water_temperature_due_to_advection"           unit="degC/s"                         > sqrt( ttrd_xad^2 + ttrd_yad^2 + ttrd_zad^2 ) </field> 
     667    <field id="strd_ad"       long_name="salinity   -trend: advection"               standard_name="tendency_of_sea_water_salinity_due_to_advection"              unit="1e-3/s"                         > sqrt( strd_xad^2 + strd_yad^2 + strd_zad^2 ) </field> 
     668    <field id="ttrd_totad"    long_name="temperature-trend: total advection"         standard_name="tendency_of_sea_water_salinity_due_to_advection"              unit="degC/s"                        /> 
     669    <field id="strd_totad"    long_name="salinity   -trend: total advection"         standard_name="tendency_of_sea_water_salinity_due_to_advection"              unit="1e-3/s"                        /> 
     670    <field id="ttrd_sad"      long_name="temperature-trend: surface adv. (linssh true)"                                                                                unit="degC/s"   grid_ref="grid_T_2D" /> 
     671    <field id="strd_sad"      long_name="salinity   -trend: surface adv. (linssh true)"                                                                                unit="1e-3/s"   grid_ref="grid_T_2D" /> 
     672    <field id="ttrd_ldf"      long_name="temperature-trend: lateral  diffusion"      standard_name="tendency_of_sea_water_temperature_due_to_horizontal_mixing"   unit="degC/s"                        /> 
     673    <field id="strd_ldf"      long_name="salinity   -trend: lateral  diffusion"      standard_name="tendency_of_sea_water_salinity_due_to_horizontal_mixing"      unit="1e-3/s"                        /> 
     674    <field id="ttrd_zdf"      long_name="temperature-trend: vertical diffusion"      standard_name="tendency_of_sea_water_temperature_due_to_vertical_mixing"     unit="degC/s"                        /> 
     675    <field id="strd_zdf"      long_name="salinity   -trend: vertical diffusion"      standard_name="tendency_of_sea_water_salinity_due_to_vertical_mixing"        unit="1e-3/s"                        /> 
     676    <field id="ttrd_evd"      long_name="temperature-trend: EVD convection"                                                                                       unit="degC/s"                        /> 
     677    <field id="strd_evd"      long_name="salinity   -trend: EVD convection"                                                                                       unit="1e-3/s"                        /> 
     678 
     679    <!-- ln_traldf_iso=T only (iso-neutral diffusion) --> 
     680    <field id="ttrd_iso"      long_name="temperature-trend: isopycnal diffusion"                             unit="degC/s" > ttrd_ldf + ttrd_zdf - ttrd_zdfp </field> 
     681    <field id="strd_iso"      long_name="salinity   -trend: isopycnal diffusion"                             unit="1e-3/s" > strd_ldf + strd_zdf - strd_zdfp </field> 
     682    <field id="ttrd_zdfp"     long_name="temperature-trend: pure vert. diffusion"   unit="degC/s" /> 
     683    <field id="strd_zdfp"     long_name="salinity   -trend: pure vert. diffusion"   unit="1e-3/s" /> 
     684 
     685    <!-- --> 
     686    <field id="ttrd_dmp"      long_name="temperature-trend: interior restoring"        unit="degC/s" /> 
     687    <field id="strd_dmp"      long_name="salinity   -trend: interior restoring"        unit="1e-3/s" /> 
     688    <field id="ttrd_bbl"      long_name="temperature-trend: bottom boundary layer"     unit="degC/s" /> 
     689    <field id="strd_bbl"      long_name="salinity   -trend: bottom boundary layer"     unit="1e-3/s" /> 
     690    <field id="ttrd_npc"      long_name="temperature-trend: non-penetrative conv."     unit="degC/s" /> 
     691    <field id="strd_npc"      long_name="salinity   -trend: non-penetrative conv."     unit="1e-3/s" /> 
     692    <field id="ttrd_qns"      long_name="temperature-trend: non-solar flux + runoff"   unit="degC/s" grid_ref="grid_T_2D" /> 
     693    <field id="strd_cdt"      long_name="salinity   -trend: C/D term       + runoff"   unit="degC/s" grid_ref="grid_T_2D" /> 
     694    <field id="ttrd_qsr"      long_name="temperature-trend: solar penetr. heating"     unit="degC/s" /> 
     695    <field id="ttrd_bbc"      long_name="temperature-trend: geothermal heating"        unit="degC/s" /> 
     696 
     697    <!-- Thickness weighted versions: --> 
     698    <field id="ttrd_xad_e3t"      unit="degC/s * m" >  ttrd_xad * e3t </field> 
     699    <field id="strd_xad_e3t"      unit="1e-3/s * m" >  strd_xad * e3t </field> 
     700    <field id="ttrd_yad_e3t"      unit="degC/s * m" >  ttrd_yad * e3t </field> 
     701    <field id="strd_yad_e3t"      unit="1e-3/s * m" >  strd_yad * e3t </field> 
     702    <field id="ttrd_zad_e3t"      unit="degC/s * m" >  ttrd_zad * e3t </field> 
     703    <field id="strd_zad_e3t"      unit="1e-3/s * m" >  strd_zad * e3t </field> 
     704    <field id="ttrd_ad_e3t"       unit="degC/s * m" >  ttrd_ad  * e3t </field> 
     705    <field id="strd_ad_e3t"       unit="1e-3/s * m" >  strd_ad  * e3t </field> 
     706    <field id="ttrd_totad_e3t"    unit="degC/s * m" >  ttrd_totad  * e3t </field> 
     707    <field id="strd_totad_e3t"    unit="1e-3/s * m" >  strd_totad  * e3t </field> 
     708    <field id="ttrd_ldf_e3t"      unit="degC/s * m" >  ttrd_ldf * e3t </field> 
     709    <field id="strd_ldf_e3t"      unit="1e-3/s * m" >  strd_ldf * e3t </field> 
     710    <field id="ttrd_zdf_e3t"      unit="degC/s * m" >  ttrd_zdf * e3t </field> 
     711    <field id="strd_zdf_e3t"      unit="1e-3/s * m" >  strd_zdf * e3t </field> 
     712    <field id="ttrd_evd_e3t"      unit="degC/s * m" >  ttrd_evd * e3t </field> 
     713    <field id="strd_evd_e3t"      unit="1e-3/s * m" >  strd_evd * e3t </field> 
     714 
     715    <!-- ln_traldf_iso=T only (iso-neutral diffusion) --> 
     716    <field id="ttrd_iso_e3t"      unit="degC/s * m"  >  ttrd_iso * e3t </field> 
     717    <field id="strd_iso_e3t"      unit="1e-3/s * m"  >  strd_iso * e3t </field> 
     718    <field id="ttrd_zdfp_e3t"     unit="degC/s * m"  >  ttrd_zdfp * e3t </field> 
     719    <field id="strd_zdfp_e3t"     unit="1e-3/s * m"  >  strd_zdfp * e3t </field> 
     720 
     721    <!-- --> 
     722    <field id="ttrd_dmp_e3t"      unit="degC/s * m"  >  ttrd_dmp * e3t </field> 
     723    <field id="strd_dmp_e3t"      unit="1e-3/s * m"  >  strd_dmp * e3t </field> 
     724    <field id="ttrd_bbl_e3t"      unit="degC/s * m"  >  ttrd_bbl * e3t </field> 
     725    <field id="strd_bbl_e3t"      unit="1e-3/s * m"  >  strd_bbl * e3t </field> 
     726    <field id="ttrd_npc_e3t"      unit="degC/s * m"  >  ttrd_npc * e3t </field> 
     727    <field id="strd_npc_e3t"      unit="1e-3/s * m"  >  strd_npc * e3t </field> 
     728    <field id="ttrd_qns_e3t"      unit="degC/s * m"  >  ttrd_qns * e3t_surf </field> 
     729    <field id="strd_cdt_e3t"      unit="degC/s * m"  >  strd_cdt * e3t_surf </field> 
     730    <field id="ttrd_qsr_e3t"      unit="degC/s * m"  >  ttrd_qsr * e3t </field> 
     731    <field id="ttrd_bbc_e3t"      unit="degC/s * m"  >  ttrd_bbc * e3t </field> 
     732 
     733    <!-- OMIP  layer-integrated trends --> 
     734    <field id="ttrd_totad_li"    long_name="layer integrated heat-trend: total advection"         unit="W/m^2"     > ttrd_totad_e3t * 1026.0 * 3991.86795711963 </field> 
     735    <field id="strd_totad_li"    long_name="layer integrated salt-trend: total advection"         unit="kg/(m^2 s)"    > strd_totad_e3t * 1026.0 * 0.001  </field> 
     736    <field id="ttrd_evd_li"      long_name="layer integrated heat-trend: EVD convection"          unit="W/m^2"    > ttrd_evd_e3t * 1026.0 * 3991.86795711963 </field> 
     737    <field id="strd_evd_li"      long_name="layer integrated salt-trend: EVD convection"          unit="kg/(m^2 s)"  > strd_evd_e3t * 1026.0 * 0.001  </field> 
     738    <field id="ttrd_iso_li"      long_name="layer integrated heat-trend: isopycnal diffusion"     unit="W/m^2" > ttrd_iso_e3t * 1026.0 * 3991.86795711963 </field> 
     739    <field id="strd_iso_li"      long_name="layer integrated salt-trend: isopycnal diffusion"     unit="kg/(m^2 s)" > strd_iso_e3t * 1026.0 * 0.001  </field> 
     740    <field id="ttrd_zdfp_li"     long_name="layer integrated heat-trend: pure vert. diffusion"    unit="W/m^2" > ttrd_zdfp_e3t * 1026.0 * 3991.86795711963 </field> 
     741    <field id="strd_zdfp_li"     long_name="layer integrated salt-trend: pure vert. diffusion"    unit="kg/(m^2 s)" > strd_zdfp_e3t * 1026.0 * 0.001  </field> 
     742    <field id="ttrd_qns_li"      long_name="layer integrated heat-trend: non-solar flux + runoff" unit="W/m^2" grid_ref="grid_T_2D"> ttrd_qns_e3t * 1026.0 * 3991.86795711963 </field> 
     743    <field id="ttrd_qsr_li"      long_name="layer integrated heat-trend: solar flux"              unit="W/m^2"  grid_ref="grid_T_3D"> ttrd_qsr_e3t * 1026.0 * 3991.86795711963 </field> 
     744    <field id="ttrd_bbl_li"      long_name="layer integrated heat-trend: bottom boundary layer "  unit="W/m^2" > ttrd_bbl_e3t * 1026.0 * 3991.86795711963 </field> 
     745    <field id="strd_bbl_li"      long_name="layer integrated salt-trend: bottom boundary layer "  unit="kg/(m^2 s)" > strd_bbl_e3t * 1026.0 * 0.001  </field> 
     746    <field id="ttrd_evd_li"      long_name="layer integrated heat-trend: evd convection "         unit="W/m^2" >ttrd_evd_e3t * 1026.0 * 3991.86795711963  </field> 
     747    <field id="strd_evd_li"      long_name="layer integrated salt-trend: evd convection "         unit="kg/(m^2 s)" > strd_evd_e3t * 1026.0 * 0.001  </field> 
     748 
     749  </field_group> 
     750 
     751  <!--  Total trends calculated every time step--> 
     752  <field_group id="trendT" grid_ref="grid_T_3D"> 
     753    <field id="ttrd_tot"      long_name="temperature-trend: total model trend"         unit="degC/s" /> 
     754    <field id="strd_tot"      long_name="salinity   -trend: total model trend"         unit="1e-3/s" /> 
     755    <!-- Thickness weighted versions: --> 
     756    <field id="ttrd_tot_e3t"      unit="degC/s * m"  >  ttrd_tot * e3t </field> 
     757    <field id="strd_tot_e3t"      unit="1e-3/s * m"  >  strd_tot * e3t </field> 
     758    <!-- OMIP  layer-integrated total trends --> 
     759    <field id="ttrd_tot_li"      long_name="layer integrated heat-trend: total model trend :"         unit="W/m^2" > ttrd_tot_e3t * 1026.0 * 3991.86795711963 </field> 
     760    <field id="strd_tot_li"      long_name="layer integrated salt-trend: total model trend :"         unit="kg/(m^2 s)" > strd_tot_e3t * 1026.0 * 0.001  </field> 
     761 
     762    <!-- **** these trends have not been apportioned to all/even/odd ts yet **** --> 
     763    <!-- variables available with ln_KE_trd --> 
     764    <field id="ketrd_hpg"     long_name="ke-trend: hydrostatic pressure gradient"          unit="W/s^3"                        /> 
     765    <field id="ketrd_spg"     long_name="ke-trend: surface     pressure gradient"          unit="W/s^3"                        /> 
     766    <field id="ketrd_spgexp"  long_name="ke-trend: surface pressure gradient (explicit)"   unit="W/s^3"                        /> 
     767    <field id="ketrd_spgflt"  long_name="ke-trend: surface pressure gradient (filter)"     unit="W/s^3"                        /> 
     768    <field id="ssh_flt"       long_name="filtered contribution to ssh (dynspg_flt)"        unit="m"       grid_ref="grid_T_2D" /> 
     769    <field id="w0"            long_name="surface vertical velocity"                        unit="m/s"     grid_ref="grid_T_2D" /> 
     770    <field id="pw0_exp"       long_name="surface pressure flux due to ssh"                 unit="W/s^2"   grid_ref="grid_T_2D" /> 
     771    <field id="pw0_flt"       long_name="surface pressure flux due to filtered ssh"        unit="W/s^2"   grid_ref="grid_T_2D" /> 
     772    <field id="ketrd_keg"     long_name="ke-trend: KE gradient         or hor. adv."       unit="W/s^3"                        /> 
     773    <field id="ketrd_rvo"     long_name="ke-trend: relative  vorticity or metric term"     unit="W/s^3"                        /> 
     774    <field id="ketrd_pvo"     long_name="ke-trend: planetary vorticity"                    unit="W/s^3"                        /> 
     775    <field id="ketrd_zad"     long_name="ke-trend: vertical  advection"                    unit="W/s^3"                        /> 
     776    <field id="ketrd_udx"     long_name="ke-trend: U.dx[U]"                                unit="W/s^3"                        /> 
     777    <field id="ketrd_ldf"     long_name="ke-trend: lateral   diffusion"                    unit="W/s^3"                        /> 
     778    <field id="ketrd_zdf"     long_name="ke-trend: vertical  diffusion"                    unit="W/s^3"                        /> 
     779    <field id="ketrd_tau"     long_name="ke-trend: wind stress "                           unit="W/s^3"   grid_ref="grid_T_2D" /> 
     780    <field id="ketrd_bfr"     long_name="ke-trend: bottom friction (explicit)"             unit="W/s^3"                        /> 
     781    <field id="ketrd_bfri"    long_name="ke-trend: bottom friction (implicit)"             unit="W/s^3"                        /> 
     782    <field id="ketrd_atf"     long_name="ke-trend: asselin time filter trend"              unit="W/s^3"                        /> 
     783    <field id="ketrd_convP2K" long_name="ke-trend: conversion (potential to kinetic)"      unit="W/s^3"                        /> 
     784    <field id="KE"            long_name="kinetic energy: u(n)*u(n+1)/2"                    unit="W/s^2"                        /> 
     785 
     786    <!-- variables available when explicit lateral mixing is used (ln_dynldf_OFF=F) --> 
     787    <field id="dispkexyfo"    long_name="KE-trend: lateral  mixing induced dissipation"   standard_name="ocean_kinetic_energy_dissipation_per_unit_area_due_to_xy_friction"                   unit="W/m^2" grid_ref="grid_T_2D" /> 
     788    <field id="dispkevfo"     long_name="KE-trend: vertical mixing induced dissipation"   standard_name="ocean_kinetic_energy_dissipation_per_unit_area_due_to_vertical_friction"             unit="W/m^2" grid_ref="grid_T_2D" /> 
     789    <!-- variables available with ln_traadv_eiv=T and ln_diaeiv=T --> 
     790    <field id="eketrd_eiv"    long_name="EKE-trend due to parameterized eddy advection"   standard_name="tendency_of_ocean_eddy_kinetic_energy_content_due_to_parameterized_eddy_advection"   unit="W/m^2" grid_ref="grid_T_2D" /> 
     791 
     792    <!-- variables available with ln_PE_trd --> 
     793    <field id="petrd_xad"     long_name="pe-trend: i-advection"                unit="W/m^3"                        /> 
     794    <field id="petrd_yad"     long_name="pe-trend: j-advection"                unit="W/m^3"                        /> 
     795    <field id="petrd_zad"     long_name="pe-trend: k-advection"                unit="W/m^3"                        /> 
     796    <field id="petrd_sad"     long_name="pe-trend: surface adv. (linssh true)" unit="W/m^3"   grid_ref="grid_T_2D" /> 
     797    <field id="petrd_ldf"     long_name="pe-trend: lateral  diffusion"         unit="W/m^3"                        /> 
     798    <field id="petrd_zdf"     long_name="pe-trend: vertical diffusion"         unit="W/m^3"                        /> 
     799    <field id="petrd_zdfp"    long_name="pe-trend: pure vert. diffusion"       unit="W/m^3"                        /> 
     800    <field id="petrd_dmp"     long_name="pe-trend: interior restoring"         unit="W/m^3"                        /> 
     801    <field id="petrd_bbl"     long_name="pe-trend: bottom boundary layer"      unit="W/m^3"                        /> 
     802    <field id="petrd_npc"     long_name="pe-trend: non-penetrative conv."      unit="W/m^3"                        /> 
     803    <field id="petrd_nsr"     long_name="pe-trend: surface forcing + runoff"   unit="W/m^3"                        /> 
     804    <field id="petrd_qsr"     long_name="pe-trend: solar penetr. heating"      unit="W/m^3"                        /> 
     805    <field id="petrd_bbc"     long_name="pe-trend: geothermal heating"         unit="W/m^3"                        /> 
     806    <field id="petrd_atf"     long_name="pe-trend: asselin time filter"        unit="W/m^3"                        /> 
     807    <field id="PEanom"        long_name="potential energy anomaly"             unit="1"                            /> 
     808    <field id="alphaPE"       long_name="partial deriv. of PEanom wrt T"       unit="degC-1"                       /> 
     809    <field id="betaPE"        long_name="partial deriv. of PEanom wrt S"       unit="1e3"                          /> 
     810  </field_group> 
     811 
     812  <field_group id="trendU" grid_ref="grid_U_3D"> 
     813    <!-- variables available with ln_dyn_trd --> 
     814    <field id="utrd_hpg"       long_name="i-trend: hydrostatic pressure gradient"          unit="m/s^2"                        /> 
     815    <field id="utrd_spg"       long_name="i-trend: surface     pressure gradient"          unit="m/s^2"                        /> 
     816    <field id="utrd_spgexp"    long_name="i-trend: surface pressure gradient (explicit)"   unit="m/s^2"                        /> 
     817    <field id="utrd_spgflt"    long_name="i-trend: surface pressure gradient (filtered)"   unit="m/s^2"                        /> 
     818    <field id="utrd_keg"       long_name="i-trend: KE gradient         or hor. adv."       unit="m/s^2"                        /> 
     819    <field id="utrd_rvo"       long_name="i-trend: relative  vorticity or metric term"     unit="m/s^2"                        /> 
     820    <field id="utrd_pvo"       long_name="i-trend: planetary vorticity"                    unit="m/s^2"                        /> 
     821    <field id="utrd_zad"       long_name="i-trend: vertical  advection"                    unit="m/s^2"                        /> 
     822    <field id="utrd_udx"       long_name="i-trend: U.dx[U]"                                unit="m/s^2"                        /> 
     823    <field id="utrd_ldf"       long_name="i-trend: lateral   diffusion"                    unit="m/s^2"                        /> 
     824    <field id="utrd_zdf"       long_name="i-trend: vertical  diffusion"                    unit="m/s^2"                        /> 
     825    <field id="utrd_tau"       long_name="i-trend: wind stress "                           unit="m/s^2"   grid_ref="grid_U_2D" /> 
     826    <field id="utrd_bfr"       long_name="i-trend: bottom friction (explicit)"             unit="m/s^2"                        /> 
     827    <field id="utrd_bfri"      long_name="i-trend: bottom friction (implicit)"             unit="m/s^2"                        /> 
     828    <field id="utrd_tot"       long_name="i-trend: total momentum trend before atf"        unit="m/s^2"                        /> 
     829    <field id="utrd_atf"       long_name="i-trend: asselin time filter trend"              unit="m/s^2"                        /> 
     830  </field_group> 
     831 
     832  <field_group id="trendV" grid_ref="grid_V_3D"> 
     833    <!-- variables available with ln_dyn_trd --> 
     834    <field id="vtrd_hpg"       long_name="j-trend: hydrostatic pressure gradient"          unit="m/s^2"                        /> 
     835    <field id="vtrd_spg"       long_name="j-trend: surface     pressure gradient"          unit="m/s^2"                        /> 
     836    <field id="vtrd_spgexp"    long_name="j-trend: surface pressure gradient (explicit)"   unit="m/s^2"                        /> 
     837    <field id="vtrd_spgflt"    long_name="j-trend: surface pressure gradient (filtered)"   unit="m/s^2"                        /> 
     838    <field id="vtrd_keg"       long_name="j-trend: KE gradient         or hor. adv."       unit="m/s^2"                        /> 
     839    <field id="vtrd_rvo"       long_name="j-trend: relative  vorticity or metric term"     unit="m/s^2"                        /> 
     840    <field id="vtrd_pvo"       long_name="j-trend: planetary vorticity"                    unit="m/s^2"                        /> 
     841    <field id="vtrd_zad"       long_name="j-trend: vertical  advection"                    unit="m/s^2"                        /> 
     842    <field id="vtrd_vdy"       long_name="i-trend: V.dx[V]"                                unit="m/s^2"                        /> 
     843    <field id="vtrd_ldf"       long_name="j-trend: lateral   diffusion"                    unit="m/s^2"                        /> 
     844    <field id="vtrd_zdf"       long_name="j-trend: vertical  diffusion"                    unit="m/s^2"                        /> 
     845    <field id="vtrd_tau"       long_name="j-trend: wind stress "                           unit="m/s^2"   grid_ref="grid_V_2D" /> 
     846    <field id="vtrd_bfr"       long_name="j-trend: bottom friction (explicit)"             unit="m/s^2"                        /> 
     847    <field id="vtrd_bfri"      long_name="j-trend: bottom friction (implicit)"             unit="m/s^2"                        /> 
     848    <field id="vtrd_tot"       long_name="j-trend: total momentum trend before atf"        unit="m/s^2"                        /> 
     849    <field id="vtrd_atf"       long_name="j-trend: asselin time filter trend"              unit="m/s^2"                        /> 
     850  </field_group> 
     851 
     852 
     853  <!-- 
     854      ============================================================================================================ 
     855      Definitions for iodef_demo.xml 
     856      ============================================================================================================ 
     857  --> 
     858 
     859  <field_group id="TRD" > 
     860    <field field_ref="ttrd_totad_li"   name="opottempadvect"  /> 
     861    <field field_ref="ttrd_iso_li"     name="opottemppmdiff"  /> 
     862    <field field_ref="ttrd_zdfp_li"    name="opottempdiff"  /> 
     863    <field field_ref="ttrd_evd_li"     name="opottempevd" /> 
     864    <field field_ref="strd_evd_li"     name="osaltevd" /> 
     865    <field field_ref="ttrd_qns_li"     name="opottempqns"  /> 
     866    <field field_ref="ttrd_qsr_li"     name="rsdoabsorb" operation="accumulate" /> 
     867    <field field_ref="strd_totad_li"   name="osaltadvect" /> 
     868    <field field_ref="strd_iso_li"     name="osaltpmdiff"  /> 
     869    <field field_ref="strd_zdfp_li"    name="osaltdiff" /> 
     870  </field_group> 
     871 
     872  <field_group id="mooring" > 
     873    <field field_ref="toce"         name="thetao"   long_name="sea_water_potential_temperature"      /> 
     874    <field field_ref="soce"         name="so"       long_name="sea_water_salinity"                   /> 
     875    <field field_ref="uoce"         name="uo"       long_name="sea_water_x_velocity"                 /> 
     876    <field field_ref="voce"         name="vo"       long_name="sea_water_y_velocity"                 /> 
     877    <field field_ref="woce"         name="wo"       long_name="sea_water_z_velocity"                 /> 
     878    <field field_ref="avt"          name="difvho"   long_name="ocean_vertical_heat_diffusivity"      /> 
     879    <field field_ref="avm"          name="difvmo"   long_name="ocean_vertical_momentum_diffusivity"  /> 
     880 
     881    <field field_ref="sst"          name="tos"      long_name="sea_surface_temperature"                       /> 
     882    <field field_ref="sst2"         name="tossq"    long_name="square_of_sea_surface_temperature"             /> 
     883    <field field_ref="sstgrad"      name="tosgrad"  long_name="module_of_sea_surface_temperature_gradient"    /> 
     884    <field field_ref="sss"          name="sos"      long_name="sea_surface_salinity"                          /> 
     885    <field field_ref="ssh"          name="zos"      long_name="sea_surface_height_above_geoid"                /> 
     886    <field field_ref="empmr"        name="wfo"      long_name="water_flux_into_sea_water"                     /> 
     887    <field field_ref="qsr"          name="rsntds"   long_name="surface_net_downward_shortwave_flux"           /> 
     888    <field field_ref="qt"           name="tohfls"   long_name="surface_net_downward_total_heat_flux"          /> 
     889    <field field_ref="taum"                                                                                   /> 
     890    <field field_ref="20d"                                                                                    /> 
     891    <field field_ref="mldkz5"                                                                                 /> 
     892    <field field_ref="mldr10_1"                                                                               /> 
     893    <field field_ref="mldr10_3"                                                                               /> 
     894    <field field_ref="mldr0_1"                                                                                /> 
     895    <field field_ref="mldr0_3"                                                                                /> 
     896    <field field_ref="mld_dt02"                                                                               /> 
     897    <field field_ref="topthdep"                                                                               /> 
     898    <field field_ref="pycndep"                                                                                /> 
     899    <field field_ref="tinv"                                                                                   /> 
     900    <field field_ref="depti"                                                                                  /> 
     901    <field field_ref="BLT"          name="blt"      long_name="barrier_layer_thickness"                       /> 
     902    <field field_ref="utau"         name="tauuo"    long_name="surface_downward_x_stress"                     /> 
     903    <field field_ref="vtau"         name="tauvo"    long_name="surface_downward_y_stress"                     /> 
     904  </field_group> 
     905 
     906  <field_group id="groupT" > 
     907    <field field_ref="toce"         name="thetao"   long_name="sea_water_potential_temperature"               /> 
     908    <field field_ref="soce"         name="so"       long_name="sea_water_salinity"                            /> 
     909    <field field_ref="sst"          name="tos"      long_name="sea_surface_temperature"                       /> 
     910    <field field_ref="sst2"         name="tossq"    long_name="square_of_sea_surface_temperature"             /> 
     911    <field field_ref="sss"          name="sos"      long_name="sea_surface_salinity"                          /> 
     912    <field field_ref="ssh"          name="zos"      long_name="sea_surface_height_above_geoid"                /> 
     913    <field field_ref="empmr"        name="wfo"      long_name="water_flux_into_sea_water"                     /> 
     914    <field field_ref="qsr"          name="rsntds"   long_name="surface_net_downward_shortwave_flux"           /> 
     915    <field field_ref="qt"           name="tohfls"   long_name="surface_net_downward_total_heat_flux"          /> 
     916    <field field_ref="taum"                                                                                   /> 
     917    <field field_ref="20d"                                                                                    /> 
     918    <field field_ref="mldkz5"                                                                                 /> 
     919    <field field_ref="mldr10_1"                                                                               /> 
     920    <field field_ref="mldr10_3"                                                                               /> 
     921    <field field_ref="mld_dt02"                                                                               /> 
     922    <field field_ref="topthdep"                                                                               /> 
     923    <field field_ref="pycndep"                                                                                /> 
     924    <field field_ref="tinv"                                                                                   /> 
     925    <field field_ref="depti"                                                                                  /> 
     926    <field field_ref="BLT"          name="blt"      long_name="Barrier Layer Thickness"                       /> 
     927  </field_group> 
     928 
     929  <field_group id="groupU" > 
     930    <field field_ref="uoce"         name="uo"      long_name="sea_water_x_velocity"      /> 
     931    <field field_ref="ssu"          name="uos"     long_name="sea_surface_x_velocity"    /> 
     932    <field field_ref="utau"         name="tauuo"   long_name="surface_downward_x_stress" /> 
     933  </field_group> 
     934 
     935  <field_group id="groupV" > 
     936    <field field_ref="voce"         name="vo"      long_name="sea_water_y_velocity"      /> 
     937    <field field_ref="ssv"          name="vos"     long_name="sea_surface_y_velocity"    /> 
     938    <field field_ref="vtau"         name="tauvo"   long_name="surface_downward_y_stress" /> 
     939  </field_group> 
     940 
     941  <field_group id="groupW" > 
     942    <field field_ref="woce"         name="wo"       long_name="ocean vertical velocity"  /> 
     943  </field_group> 
     944 
     945  <!-- TMB diagnostic output --> 
     946  <field_group  id="1h_grid_T_tmb" grid_ref="grid_T_2D" operation="instant"> 
     947    <field id="top_temp"           name="votemper_top"  unit="degC"  /> 
     948    <field id="mid_temp"           name="votemper_mid"  unit="degC"  /> 
     949    <field id="bot_temp"           name="votemper_bot"  unit="degC"  /> 
     950    <field id="top_sal"            name="vosaline_top"  unit="psu"   /> 
     951    <field id="mid_sal"            name="vosaline_mid"  unit="psu"   /> 
     952    <field id="bot_sal"            name="vosaline_bot"  unit="psu"   /> 
     953    <field id="sshnmasked"         name="sossheig"      unit="m"     /> 
     954  </field_group> 
     955 
     956  <field_group  id="1h_grid_U_tmb" grid_ref="grid_U_2D" operation="instant"> 
     957    <field id="top_u"           name="vozocrtx_top"  unit="m/s"  /> 
     958    <field id="mid_u"           name="vozocrtx_mid"  unit="m/s"  /> 
     959    <field id="bot_u"           name="vozocrtx_bot"  unit="m/s"  /> 
     960    <field id="baro_u"          name="vobtcrtx"      unit="m/s"  /> 
     961  </field_group> 
     962 
     963  <field_group  id="1h_grid_V_tmb" grid_ref="grid_V_2D" operation="instant"> 
     964    <field id="top_v"           name="vomecrty_top"  unit="m/s"  /> 
     965    <field id="mid_v"           name="vomecrty_mid"  unit="m/s"  /> 
     966    <field id="bot_v"           name="vomecrty_bot"  unit="m/s"  /> 
     967    <field id="baro_v"          name="vobtcrty"      unit="m/s"  /> 
     968  </field_group> 
     969 
     970  <!-- 25h diagnostic output --> 
     971  <field_group id="25h_grid_T" grid_ref="grid_T_3D" operation="instant"> 
     972    <field id="temper25h"         name="potential temperature 25h mean"    unit="degC" /> 
     973    <field id="tempis25h"         name="insitu temperature 25h mean"    unit="degC" /> 
     974    <field id="salin25h"          name="salinity 25h mean"                 unit="psu"  /> 
     975    <field id="ssh25h"            name="sea surface height 25h mean"  grid_ref="grid_T_2D"      unit="m"    /> 
     976  </field_group> 
     977 
     978  <field_group id="25h_grid_U" grid_ref="grid_U_3D" operation="instant" > 
     979    <field id="vozocrtx25h"         name="i current 25h mean"    unit="m/s"   /> 
     980  </field_group> 
     981 
     982  <field_group id="25h_grid_V" grid_ref="grid_V_3D" operation="instant"> 
     983    <field id="vomecrty25h"         name="j current 25h mean"    unit="m/s"    /> 
     984  </field_group> 
     985 
     986  <field_group id="25h_grid_W" grid_ref="grid_W_3D" operation="instant"> 
     987    <field id="vovecrtz25h"         name="k current 25h mean"                 unit="m/s"      /> 
     988    <field id="avt25h"              name="vertical diffusivity25h mean"       unit="m2/s" /> 
     989    <field id="avm25h"              name="vertical viscosity 25h mean"        unit="m2/s" /> 
     990    <field id="tke25h"              name="turbulent kinetic energy 25h mean" /> 
     991    <field id="mxln25h"             name="mixing length 25h mean"             unit="m" /> 
     992  </field_group> 
     993 
     994  <!-- 
     995      ============================================================================================================ 
     996  --> 
     997  <!-- output variables for my configuration (example) --> 
     998 
     999  <field_group id="myvarOCE" > 
     1000    <!-- grid T --> 
     1001    <field field_ref="e3t"          name="e3t"      long_name="vertical scale factor"           /> 
     1002    <field field_ref="sst"          name="tos"      long_name="sea_surface_temperature"         /> 
     1003    <field field_ref="sss"          name="sos"      long_name="sea_surface_salinity"            /> 
     1004    <field field_ref="ssh"          name="zos"      long_name="sea_surface_height_above_geoid"  /> 
     1005 
     1006    <!-- grid U --> 
     1007    <field field_ref="e3u"          name="e3u"     long_name="vertical scale factor"            /> 
     1008    <field field_ref="ssu"          name="uos"     long_name="sea_surface_x_velocity"           /> 
     1009 
     1010    <!-- grid V --> 
     1011    <field field_ref="e3v"          name="e3v"     long_name="vertical scale factor"            /> 
     1012    <field field_ref="ssv"          name="vos"     long_name="sea_surface_y_velocity"           /> 
     1013  </field_group> 
     1014 
     1015</field_definition> 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/cfgs/SHARED/namelist_ref

    r10808 r11772  
    249249!----------------------------------------------------------------------- 
    250250   !                    !  bulk algorithm : 
    251    ln_NCAR     = .false.   ! "NCAR"      algorithm   (Large and Yeager 2008) 
     251   ln_NCAR      = .false.   ! "NCAR"      algorithm   (Large and Yeager 2008) 
    252252   ln_COARE_3p0 = .false.   ! "COARE 3.0" algorithm   (Fairall et al. 2003) 
    253    ln_COARE_3p5 = .false.   ! "COARE 3.5" algorithm   (Edson et al. 2013) 
    254    ln_ECMWF    = .false.   ! "ECMWF"     algorithm   (IFS cycle 31) 
     253   ln_COARE_3p6 = .false.   ! "COARE 3.6" algorithm   (Edson et al. 2013) 
     254   ln_ECMWF     = .false.   ! "ECMWF"     algorithm   (IFS cycle 31) 
    255255      ! 
    256256      rn_zqt      = 10.       !  Air temperature & humidity reference height (m) 
     
    263263      rn_vfac     = 0.        !  multiplicative factor for ocean & ice velocity used to 
    264264      !                       !  calculate the wind stress (0.=absolute or 1.=relative winds) 
    265  
     265      ln_skin_cs = .FALSE.  !  use the cool-skin parameterization (only available in ECMWF and COARE algorithms) !LB 
     266      ln_skin_wl = .FALSE.  !  use the warm-layer        "               "                    " 
     267      ! 
     268      ln_humi_sph = .true.     !  humidity specified below in "sn_humi" is specific humidity     [kg/kg] if .true. 
     269      ln_humi_dpt = .false.    !  humidity specified below in "sn_humi" is dew-point temperature   [K]   if .true. 
     270      ln_humi_rlh = .false.    !  humidity specified below in "sn_humi" is relative humidity       [%]   if .true. 
     271   ! 
    266272   cn_dir      = './'      !  root directory for the bulk data location 
    267273   !___________!_________________________!___________________!___________!_____________!________!___________!______________________________________!__________!_______________! 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/src/OCE/DOM/phycst.F90

    r11615 r11772  
    8282   REAL(wp), PARAMETER, PUBLIC :: rho0_a  = 1.2_wp      !: Approx. of density of air                       [kg/m^3] 
    8383   REAL(wp), PARAMETER, PUBLIC :: rho0_w  = 1025._wp    !: Density of sea-water  (ECMWF->1025)             [kg/m^3] 
    84    REAL(wp), PARAMETER, PUBLIC :: roadrw = rho0_a/rho0_w !: Density ratio 
     84   REAL(wp), PARAMETER, PUBLIC :: radrw = rho0_a/rho0_w !: Density ratio 
     85   REAL(wp), PARAMETER, PUBLIC :: sq_radrw = SQRT(rho0_a/rho0_w) 
    8586   REAL(wp), PARAMETER, PUBLIC :: rCp0_w  = 4190._wp    !: Specific heat capacity of seawater (ECMWF 4190) [J/K/kg] 
    8687   REAL(wp), PARAMETER, PUBLIC :: rnu0_w  = 1.e-6_wp    !: kinetic viscosity of water                      [m^2/s] 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/src/OCE/SBC/sbcblk.F90

    r11672 r11772  
    542542         CASE( np_ECMWF     ) 
    543543            IF (lwp) WRITE(numout,*) ' *** blk_oce => calling "turb_ecmwf" WITH CSWL options!!!, gdept_1d(1)=', gdept_1d(1) !LBrm 
    544             CALL turb_ecmwf   ( rn_zqt, rn_zu, zst, ztpot, zsq, zqair, wndm, ln_skin_cs, ln_skin_wl,    &  ! ECMWF 
     544            CALL turb_ecmwf   ( kt, rn_zqt, rn_zu, zst, ztpot, zsq, zqair, wndm, ln_skin_cs, ln_skin_wl,    &  ! ECMWF 
    545545               &                Cd_atm, Ch_atm, Ce_atm, t_zu, q_zu, zU_zu, cdn_oce, chn_oce, cen_oce,   & 
    546546               &                Qsw=qsr(:,:), rad_lw=sf(jp_qlw)%fnow(:,:,1), slp=sf(jp_slp)%fnow(:,:,1) ) 
     
    585585         CASE( np_ECMWF     ) 
    586586            IF (lwp) WRITE(numout,*) ' *** blk_oce => calling "turb_ecmwf" WITHOUT CSWL optional arrays!!!' !LBrm 
    587             CALL turb_ecmwf   ( rn_zqt, rn_zu, zst, ztpot, zsq, zqair, wndm, ln_skin_cs, ln_skin_wl,    &  ! ECMWF 
     587            CALL turb_ecmwf   ( kt, rn_zqt, rn_zu, zst, ztpot, zsq, zqair, wndm, ln_skin_cs, ln_skin_wl,    &  ! ECMWF 
    588588               &                Cd_atm, Ch_atm, Ce_atm, t_zu, q_zu, zU_zu, cdn_oce, chn_oce, cen_oce ) 
    589589 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/src/OCE/SBC/sbcblk_algo_coare3p0.F90

    r11672 r11772  
    4949   REAL(wp), PARAMETER ::   Beta0   =   1.25_wp   ! gustiness parameter 
    5050 
    51    INTEGER , PARAMETER ::   nb_itt = 5             ! number of itterations 
     51   INTEGER , PARAMETER ::   nb_itt = 10             ! number of itterations 
    5252 
    5353   !!---------------------------------------------------------------------- 
     
    7070      IF ( l_use_wl ) THEN 
    7171         ierr = 0 
    72          ALLOCATE ( Tau_ac(jpi,jpj) , Qnt_ac(jpi,jpj), H_wl(jpi,jpj), STAT=ierr ) 
     72         ALLOCATE ( Tau_ac(jpi,jpj) , Qnt_ac(jpi,jpj), Hz_wl(jpi,jpj), dT_wl(jpi,jpj), STAT=ierr ) 
    7373         !IF( ierr > 0 ) STOP ' COARE3P0_INIT => allocation of Tau_ac and Qnt_ac failed!' 
    7474         Tau_ac(:,:) = 0._wp 
    75          Qnt_ac(:,:)   = 0._wp 
    76          H_wl(:,:)    = H_wl_max 
     75         Qnt_ac(:,:) = 0._wp 
     76         Hz_wl(:,:)  = Hwl_max 
     77         dT_wl(:,:)  = 0._wp 
    7778      END IF 
    7879      !! 
    7980      IF ( l_use_cs ) THEN 
    8081         ierr = 0 
    81          ALLOCATE ( delta_vl(jpi,jpj), STAT=ierr ) 
    82          !IF( ierr > 0 ) STOP ' COARE3P0_INIT => allocation of delta_vl and Qnt_ac failed!' 
    83          delta_vl(:,:) = 0.001_wp      ! First guess of zdelta [m] 
     82         ALLOCATE ( dT_cs(jpi,jpj), STAT=ierr ) 
     83         !IF( ierr > 0 ) STOP ' COARE3P0_INIT => allocation of dT_cs and Qnt_ac failed!' 
     84         dT_cs(:,:) = -0.25_wp  ! First guess of skin correction 
    8485      END IF 
    8586   END SUBROUTINE coare3p0_init 
     
    9192      &                      Cdn, Chn, Cen,                                              & 
    9293      &                      Qsw, rad_lw, slp, pdT_cs,                                   & ! optionals for cool-skin (and warm-layer) 
    93       &                      pdT_wl, Hwl )                                                 ! optionals for warm-layer only 
     94      &                      pdT_wl, pHz_wl )                                                 ! optionals for warm-layer only 
    9495      !!---------------------------------------------------------------------- 
    9596      !!                      ***  ROUTINE  turb_coare3p0  *** 
     
    133134      !!    * pdT_cs  : SST increment "dT" for cool-skin correction           [K] 
    134135      !!    * pdT_wl  : SST increment "dT" for warm-layer correction          [K] 
    135       !!    * Hwl     : depth of warm layer                                   [m] 
     136      !!    * pHz_wl  : thickness of warm-layer                               [m] 
    136137      !! 
    137138      !! OUTPUT : 
     
    171172      ! 
    172173      REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   pdT_wl   !             [K] 
    173       REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   Hwl      !             [m] 
     174      REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   pHz_wl   !             [m] 
    174175      ! 
    175176      INTEGER :: j_itt 
     
    190191         &                pdTw,   &  ! SST increment "dT" for warm layer correction          [K] 
    191192         &                zHwl       ! depth of warm-layer [m] 
     193      CHARACTER(len=40), PARAMETER :: crtnm = 'turb_coare3p0@sbcblk_algo_coare3p0' 
    192194      !!---------------------------------------------------------------------------------- 
    193195 
    194       IF ( kt == 1 ) CALL COARE3P0_INIT(l_use_cs, l_use_wl) ! allocation of accumulation arrays 
     196      IF ( kt == nit000 ) CALL COARE3P0_INIT(l_use_cs, l_use_wl) 
    195197 
    196198      l_zt_equal_zu = .FALSE. 
     
    199201 
    200202      !! Initializations for cool skin and warm layer: 
     203      IF ( l_use_cs ) THEN 
     204         IF( .NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp)) ) THEN 
     205            PRINT *, ' * PROBLEM ('//TRIM(crtnm)//'): you need to provide Qsw, rad_lw & slp to use cool-skin param!'; STOP 
     206         END IF 
     207      END IF 
     208 
     209      IF ( l_use_wl ) THEN 
     210         IF(.NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp) )) THEN 
     211            PRINT *, ' * PROBLEM ('//TRIM(crtnm)//'): you need to provide Qsw, rad_lw & slp to use warm-layer param!'; STOP 
     212         END IF 
     213      END IF 
     214 
    201215      IF ( l_use_cs .OR. l_use_wl ) THEN 
    202          IF( .NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp)) ) & 
    203             & CALL ctl_stop( 'turb_coare3p0 => provide Qsw, rad_lw & slp to ', 'use cool-skin and/or warm-layer param' ) 
    204216         ALLOCATE ( zsst(jpi,jpj) ) 
    205217         zsst = T_s ! backing up the bulk SST 
    206          IF( l_use_cs ) T_s = T_s - 0.25   ! First guess of correction 
     218         IF( l_use_cs ) T_s = T_s - 0.25_wp   ! First guess of correction 
    207219         q_s    = rdct_qsat_salt*q_sat(MAX(T_s, 200._wp), slp) ! First guess of q_s !LOLO WL too!!! 
    208       END IF 
    209       IF ( l_use_cs ) THEN 
    210          ALLOCATE ( pdTc(jpi,jpj) ) 
    211          pdTc(:,:) = -0.25_wp  ! First guess of skin correction 
    212       END IF 
    213       IF ( l_use_wl ) THEN 
    214          ALLOCATE ( pdTw(jpi,jpj) ) 
    215          IF (PRESENT(Hwl)) ALLOCATE ( zHwl(jpi,jpj) ) 
    216220      END IF 
    217221 
     
    323327            !! Cool-skin contribution 
    324328 
    325             CALL UPDATE_QNSOL_TAU( T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_blk, slp, rad_lw, & 
     329            CALL UPDATE_QNSOL_TAU( zu, T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_zu, U_blk, slp, rad_lw, & 
    326330               &                   ztmp1, zeta_u,  Qlat=ztmp2)  ! Qnsol -> ztmp1 / Tau -> zeta_u 
    327331 
    328             CALL CS_COARE( Qsw, ztmp1, u_star, zsst, ztmp2,  pdTc )  ! ! Qnsol -> ztmp1 / Qlat -> ztmp2 
    329  
    330             T_s(:,:) = zsst(:,:) + pdTc(:,:)*tmask(:,:,1) 
    331             IF( l_use_wl ) T_s(:,:) = T_s(:,:) + pdTw(:,:)*tmask(:,:,1) 
     332            CALL CS_COARE( Qsw, ztmp1, u_star, zsst, ztmp2 )  ! ! Qnsol -> ztmp1 / Qlat -> ztmp2 
     333 
     334            T_s(:,:) = zsst(:,:) + dT_cs(:,:)*tmask(:,:,1) 
     335            IF( l_use_wl ) T_s(:,:) = T_s(:,:) + dT_wl(:,:)*tmask(:,:,1) 
    332336            q_s(:,:) = rdct_qsat_salt*q_sat(MAX(T_s(:,:), 200._wp), slp(:,:)) 
    333337 
     
    336340         IF( l_use_wl ) THEN 
    337341            !! Warm-layer contribution 
    338             CALL UPDATE_QNSOL_TAU( T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_blk, slp, rad_lw, & 
     342            CALL UPDATE_QNSOL_TAU( zu, T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_zu, U_blk, slp, rad_lw, & 
    339343               &                   ztmp1, zeta_u)  ! Qnsol -> ztmp1 / Tau -> zeta_u 
    340344            !! In WL_COARE or , Tau_ac and Qnt_ac must be updated at the final itteration step => add a flag to do this! 
    341             IF (PRESENT(Hwl)) THEN 
    342                CALL WL_COARE( Qsw, ztmp1, zeta_u, zsst, MOD(nb_itt,j_itt),  pdTw,  Hwl=zHwl ) 
    343             ELSE 
    344                CALL WL_COARE( Qsw, ztmp1, zeta_u, zsst, MOD(nb_itt,j_itt),  pdTw ) 
    345             END IF 
     345            CALL WL_COARE( Qsw, ztmp1, zeta_u, zsst, MOD(nb_itt,j_itt) ) 
     346 
    346347            !! Updating T_s and q_s !!! 
    347             T_s(:,:) = zsst(:,:) + pdTw(:,:)*tmask(:,:,1) 
    348             IF( l_use_cs ) T_s(:,:) = T_s(:,:) + pdTc(:,:)*tmask(:,:,1) 
     348            T_s(:,:) = zsst(:,:) + dT_wl(:,:)*tmask(:,:,1) 
     349            IF( l_use_cs ) T_s(:,:) = T_s(:,:) + dT_cs(:,:)*tmask(:,:,1) 
    349350            q_s(:,:) = rdct_qsat_salt*q_sat(MAX(T_s(:,:), 200._wp), slp(:,:)) 
    350             !LOLO: 
    351             !IF ( j_itt == nb_itt) THEN 
    352             !   WRITE(cf_tmp,'("Qnt_ac_k",i5.5,"_p",i4.4,".nc")') kt, narea 
    353             !   CALL DUMP_FIELD(REAL( Qnt_ac*tmask(:,:,1) , 4), TRIM(cf_tmp), 'Qnt_ac') 
    354             !   WRITE(cf_tmp,  '("pdTw_k",i5.5,"_p",i4.4,".nc")') kt, narea 
    355             !   CALL DUMP_FIELD(REAL( pdTw*tmask(:,:,1) , 4), TRIM(cf_tmp), 'pdTw') 
    356             !END IF 
    357             !LOLO. 
    358          END IF 
    359  
     351         END IF 
    360352 
    361353         IF( l_use_cs .OR. l_use_wl .OR. (.NOT. l_zt_equal_zu) ) THEN 
     
    379371      IF( .NOT. l_zt_equal_zu ) DEALLOCATE( zeta_t ) 
    380372 
    381       IF ( l_use_cs .AND. PRESENT(pdT_cs) ) pdT_cs = pdTc*tmask(:,:,1) 
    382       IF ( l_use_wl .AND. PRESENT(pdT_wl) ) pdT_wl = pdTw*tmask(:,:,1) 
     373      IF ( l_use_cs .AND. PRESENT(pdT_cs) ) pdT_cs = dT_cs 
     374      IF ( l_use_wl .AND. PRESENT(pdT_wl) ) pdT_wl = dT_wl 
     375      IF ( l_use_wl .AND. PRESENT(pHz_wl) ) pHz_wl = Hz_wl 
    383376 
    384377      IF ( l_use_cs .OR. l_use_wl ) DEALLOCATE ( zsst ) 
    385       IF (          l_use_cs      ) DEALLOCATE ( pdTc ) 
    386       IF (          l_use_wl      ) THEN 
    387          DEALLOCATE ( pdTw ) 
    388          IF (PRESENT(Hwl)) DEALLOCATE ( zHwl ) 
    389       END IF 
    390378 
    391379   END SUBROUTINE turb_coare3p0 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/src/OCE/SBC/sbcblk_algo_coare3p6.F90

    r11672 r11772  
    4545   PUBLIC :: COARE3P6_INIT, TURB_COARE3P6 
    4646 
    47    !                                              !! COARE own values for given constants: 
    48    REAL(wp), PARAMETER ::   zi0     = 600._wp     ! scale height of the atmospheric boundary layer... 
    49    REAL(wp), PARAMETER ::   Beta0   =   1.2_wp   ! gustiness parameter 
    50  
    51    INTEGER , PARAMETER ::   nb_itt = 5             ! number of itterations 
     47   !! COARE own values for given constants: 
     48   REAL(wp), PARAMETER :: zi0   = 600._wp     ! scale height of the atmospheric boundary layer... 
     49   REAL(wp), PARAMETER :: Beta0 =  1.2_wp     ! gustiness parameter 
     50 
     51   INTEGER , PARAMETER ::   nb_itt = 10             ! number of itterations 
    5252 
    5353   !!---------------------------------------------------------------------- 
     
    7070      IF ( l_use_wl ) THEN 
    7171         ierr = 0 
    72          ALLOCATE ( Tau_ac(jpi,jpj) , Qnt_ac(jpi,jpj), H_wl(jpi,jpj), STAT=ierr ) 
    73          !IF( ierr > 0 ) STOP ' COARE3P6_INIT => allocation of Tau_ac and Qnt_ac failed!' 
     72         ALLOCATE ( Tau_ac(jpi,jpj) , Qnt_ac(jpi,jpj), Hz_wl(jpi,jpj), dT_wl(jpi,jpj), STAT=ierr ) 
     73         !IF( ierr > 0 ) STOP ' COARE3P6_INIT => allocation of Tau_ac, Qnt_ac, dT_wl & Hz_wl failed!' 
    7474         Tau_ac(:,:) = 0._wp 
    75          Qnt_ac(:,:)   = 0._wp 
    76          H_wl(:,:)    = H_wl_max 
     75         Qnt_ac(:,:) = 0._wp 
     76         dT_wl(:,:)  = 0._wp 
     77         Hz_wl(:,:)  = Hwl_max 
    7778      END IF 
    7879      !! 
    7980      IF ( l_use_cs ) THEN 
    8081         ierr = 0 
    81          ALLOCATE ( delta_vl(jpi,jpj), STAT=ierr ) 
    82          !IF( ierr > 0 ) STOP ' COARE3P6_INIT => allocation of delta_vl and Qnt_ac failed!' 
    83          delta_vl(:,:) = 0.001_wp      ! First guess of zdelta [m] 
     82         ALLOCATE ( dT_cs(jpi,jpj), STAT=ierr ) 
     83         !IF( ierr > 0 ) STOP ' COARE3P6_INIT => allocation of dT_cs failed!' 
     84         dT_cs(:,:) = -0.25_wp  ! First guess of skin correction 
    8485      END IF 
    8586   END SUBROUTINE coare3p6_init 
     
    9192      &                      Cdn, Chn, Cen,                                              & 
    9293      &                      Qsw, rad_lw, slp, pdT_cs,                                   & ! optionals for cool-skin (and warm-layer) 
    93       &                      pdT_wl, Hwl )                                                 ! optionals for warm-layer only 
     94      &                      pdT_wl, pHz_wl )                                                 ! optionals for warm-layer only 
    9495      !!---------------------------------------------------------------------- 
    9596      !!                      ***  ROUTINE  turb_coare3p6  *** 
     
    131132      !!    *  rad_lw : downwelling longwave radiation at the surface  (>0)   [W/m^2] 
    132133      !!    *  slp    : sea-level pressure                                    [Pa] 
     134      !! 
     135      !! OPTIONAL OUTPUT: 
     136      !! ---------------- 
    133137      !!    * pdT_cs  : SST increment "dT" for cool-skin correction           [K] 
    134138      !!    * pdT_wl  : SST increment "dT" for warm-layer correction          [K] 
    135       !!    * Hwl     : depth of warm layer                                   [m] 
     139      !!    * pHz_wl  : thickness of warm-layer                               [m] 
    136140      !! 
    137141      !! OUTPUT : 
     
    169173      REAL(wp), INTENT(in   ), OPTIONAL, DIMENSION(jpi,jpj) ::   slp      !             [Pa] 
    170174      REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   pdT_cs 
    171       ! 
    172175      REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   pdT_wl   !             [K] 
    173       REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   Hwl      !             [m] 
     176      REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   pHz_wl   !             [m] 
    174177      ! 
    175178      INTEGER :: j_itt 
     
    190193         &                pdTw,   &  ! SST increment "dT" for warm layer correction          [K] 
    191194         &                zHwl       ! depth of warm-layer [m] 
     195      CHARACTER(len=40), PARAMETER :: crtnm = 'turb_coare3p6@sbcblk_algo_coare3p6' 
    192196      !!---------------------------------------------------------------------------------- 
    193197 
    194       IF ( kt == 1 ) CALL COARE3P6_INIT(l_use_cs, l_use_wl) ! allocation of accumulation arrays 
     198      IF ( kt == nit000 ) CALL COARE3P6_INIT(l_use_cs, l_use_wl) 
    195199 
    196200      l_zt_equal_zu = .FALSE. 
     
    199203 
    200204      !! Initializations for cool skin and warm layer: 
     205      IF ( l_use_cs ) THEN 
     206         IF( .NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp)) ) THEN 
     207            PRINT *, ' * PROBLEM ('//TRIM(crtnm)//'): you need to provide Qsw, rad_lw & slp to use cool-skin param!'; STOP 
     208         END IF 
     209      END IF 
     210 
     211      IF ( l_use_wl ) THEN 
     212         IF( .NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp)) ) THEN 
     213            PRINT *, ' * PROBLEM ('//TRIM(crtnm)//'): you need to provide Qsw, rad_lw & slp to use warm-layer param!'; STOP 
     214         END IF 
     215      END IF 
     216 
    201217      IF ( l_use_cs .OR. l_use_wl ) THEN 
    202          IF( .NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp)) ) & 
    203             & CALL ctl_stop( 'turb_coare3p6 => provide Qsw, rad_lw & slp to ', 'use cool-skin and/or warm-layer param' ) 
    204218         ALLOCATE ( zsst(jpi,jpj) ) 
    205219         zsst = T_s ! backing up the bulk SST 
    206          IF( l_use_cs ) T_s = T_s - 0.25   ! First guess of correction 
     220         IF( l_use_cs ) T_s = T_s - 0.25_wp   ! First guess of correction 
    207221         q_s    = rdct_qsat_salt*q_sat(MAX(T_s, 200._wp), slp) ! First guess of q_s !LOLO WL too!!! 
    208       END IF 
    209       IF ( l_use_cs ) THEN 
    210          ALLOCATE ( pdTc(jpi,jpj) ) 
    211          pdTc(:,:) = -0.25_wp  ! First guess of skin correction 
    212       END IF 
    213       IF ( l_use_wl ) THEN 
    214          ALLOCATE ( pdTw(jpi,jpj) ) 
    215          IF (PRESENT(Hwl)) ALLOCATE ( zHwl(jpi,jpj) ) 
    216222      END IF 
    217223 
     
    323329            !! Cool-skin contribution 
    324330 
    325             CALL UPDATE_QNSOL_TAU( T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_blk, slp, rad_lw, & 
     331            CALL UPDATE_QNSOL_TAU( zu, T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_zu, U_blk, slp, rad_lw, & 
    326332               &                   ztmp1, zeta_u,  Qlat=ztmp2)  ! Qnsol -> ztmp1 / Tau -> zeta_u 
    327333 
    328             CALL CS_COARE( Qsw, ztmp1, u_star, zsst, ztmp2,  pdTc )  ! ! Qnsol -> ztmp1 / Qlat -> ztmp2 
    329  
    330             T_s(:,:) = zsst(:,:) + pdTc(:,:)*tmask(:,:,1) 
    331             IF( l_use_wl ) T_s(:,:) = T_s(:,:) + pdTw(:,:)*tmask(:,:,1) 
     334            CALL CS_COARE( Qsw, ztmp1, u_star, zsst, ztmp2 )  ! ! Qnsol -> ztmp1 / Qlat -> ztmp2 
     335 
     336            T_s(:,:) = zsst(:,:) + dT_cs(:,:)*tmask(:,:,1) 
     337            IF( l_use_wl ) T_s(:,:) = T_s(:,:) + dT_wl(:,:)*tmask(:,:,1) 
    332338            q_s(:,:) = rdct_qsat_salt*q_sat(MAX(T_s(:,:), 200._wp), slp(:,:)) 
    333339 
     
    336342         IF( l_use_wl ) THEN 
    337343            !! Warm-layer contribution 
    338             CALL UPDATE_QNSOL_TAU( T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_blk, slp, rad_lw, & 
     344            CALL UPDATE_QNSOL_TAU( zu, T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_zu, U_blk, slp, rad_lw, & 
    339345               &                   ztmp1, zeta_u)  ! Qnsol -> ztmp1 / Tau -> zeta_u 
    340346            !! In WL_COARE or , Tau_ac and Qnt_ac must be updated at the final itteration step => add a flag to do this! 
    341             IF (PRESENT(Hwl)) THEN 
    342                CALL WL_COARE( Qsw, ztmp1, zeta_u, zsst, MOD(nb_itt,j_itt),  pdTw,  Hwl=zHwl ) 
    343             ELSE 
    344                CALL WL_COARE( Qsw, ztmp1, zeta_u, zsst, MOD(nb_itt,j_itt),  pdTw ) 
    345             END IF 
     347            CALL WL_COARE( Qsw, ztmp1, zeta_u, zsst, MOD(nb_itt,j_itt) ) 
     348 
    346349            !! Updating T_s and q_s !!! 
    347             T_s(:,:) = zsst(:,:) + pdTw(:,:)*tmask(:,:,1) 
    348             IF( l_use_cs ) T_s(:,:) = T_s(:,:) + pdTc(:,:)*tmask(:,:,1) 
     350            T_s(:,:) = zsst(:,:) + dT_wl(:,:)*tmask(:,:,1) 
     351            IF( l_use_cs ) T_s(:,:) = T_s(:,:) + dT_cs(:,:)*tmask(:,:,1) 
    349352            q_s(:,:) = rdct_qsat_salt*q_sat(MAX(T_s(:,:), 200._wp), slp(:,:)) 
    350             !LOLO: 
    351             !IF ( j_itt == nb_itt) THEN 
    352             !   WRITE(cf_tmp,'("Qnt_ac_k",i5.5,"_p",i4.4,".nc")') kt, narea 
    353             !   CALL DUMP_FIELD(REAL( Qnt_ac*tmask(:,:,1) , 4), TRIM(cf_tmp), 'Qnt_ac') 
    354             !   WRITE(cf_tmp,  '("pdTw_k",i5.5,"_p",i4.4,".nc")') kt, narea 
    355             !   CALL DUMP_FIELD(REAL( pdTw*tmask(:,:,1) , 4), TRIM(cf_tmp), 'pdTw') 
    356             !END IF 
    357             !LOLO. 
    358          END IF 
    359  
     353         END IF 
    360354 
    361355         IF( l_use_cs .OR. l_use_wl .OR. (.NOT. l_zt_equal_zu) ) THEN 
     
    379373      IF( .NOT. l_zt_equal_zu ) DEALLOCATE( zeta_t ) 
    380374 
    381       IF ( l_use_cs .AND. PRESENT(pdT_cs) ) pdT_cs = pdTc*tmask(:,:,1) 
    382       IF ( l_use_wl .AND. PRESENT(pdT_wl) ) pdT_wl = pdTw*tmask(:,:,1) 
     375      IF ( l_use_cs .AND. PRESENT(pdT_cs) ) pdT_cs = dT_cs 
     376      IF ( l_use_wl .AND. PRESENT(pdT_wl) ) pdT_wl = dT_wl 
     377      IF ( l_use_wl .AND. PRESENT(pHz_wl) ) pHz_wl = Hz_wl 
    383378 
    384379      IF ( l_use_cs .OR. l_use_wl ) DEALLOCATE ( zsst ) 
    385       IF (          l_use_cs      ) DEALLOCATE ( pdTc ) 
    386       IF (          l_use_wl      ) THEN 
    387          DEALLOCATE ( pdTw ) 
    388          IF (PRESENT(Hwl)) DEALLOCATE ( zHwl ) 
    389       END IF 
    390380 
    391381   END SUBROUTINE turb_coare3p6 
     
    395385      !!------------------------------------------------------------------- 
    396386      !! Computes the Charnock parameter as a function of the Neutral wind speed at 10m 
    397       !! 
     387      !!  "wind speed dependent formulation" 
    398388      !!  (Eq. 13 in Edson et al., 2013) 
    399389      !! 
     
    405395      REAL(wp), PARAMETER :: charn0_max = 0.028  !: value above which the Charnock parameter levels off for winds > 18 m/s 
    406396      !!------------------------------------------------------------------- 
    407       ! 
    408397      alfa_charn_3p6 = MAX( MIN( 0.0017_wp*pwnd - 0.005_wp , charn0_max) , 0._wp ) 
    409       ! 
     398      !! 
    410399   END FUNCTION alfa_charn_3p6 
     400 
     401   FUNCTION alfa_charn_3p6_wave( pus, pwsh, pwps ) 
     402      !!------------------------------------------------------------------- 
     403      !! Computes the Charnock parameter as a function of wave information and u* 
     404      !! 
     405      !!  (COARE 3.6, Fairall et al., 2018) 
     406      !! 
     407      !! Author: L. Brodeau, October 2019 / AeroBulk  (https://github.com/brodeau/aerobulk/) 
     408      !!------------------------------------------------------------------- 
     409      REAL(wp), DIMENSION(jpi,jpj) :: alfa_charn_3p6_wave 
     410      REAL(wp), DIMENSION(jpi,jpj), INTENT(in) :: pus   ! friction velocity             [m/s] 
     411      REAL(wp), DIMENSION(jpi,jpj), INTENT(in) :: pwsh  ! significant wave height       [m] 
     412      REAL(wp), DIMENSION(jpi,jpj), INTENT(in) :: pwps  ! phase speed of dominant waves [m/s] 
     413      !!------------------------------------------------------------------- 
     414      alfa_charn_3p6_wave = ( pwsh*0.2_wp*(pus/pwps)**2.2_wp ) * grav/(pus*pus) 
     415      !! 
     416   END FUNCTION alfa_charn_3p6_wave 
     417 
    411418 
    412419   FUNCTION psi_m_coare( pzeta ) 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/src/OCE/SBC/sbcblk_algo_ecmwf.F90

    r11631 r11772  
    4444   PRIVATE 
    4545 
    46    PUBLIC :: TURB_ECMWF   ! called by sbcblk.F90 
     46   PUBLIC :: ECMWF_INIT, TURB_ECMWF 
    4747 
    4848   !                   !! ECMWF own values for given constants, taken form IFS documentation... 
     
    5555   REAL(wp), PARAMETER ::   alpha_Q = 0.62    ! 
    5656 
    57    INTEGER , PARAMETER ::   nb_itt = 5        ! number of itterations 
     57   INTEGER , PARAMETER ::   nb_itt = 10             ! number of itterations 
    5858 
    5959   !!---------------------------------------------------------------------- 
    6060CONTAINS 
    6161 
    62    SUBROUTINE turb_ecmwf( zt, zu, T_s, t_zt, q_s, q_zt, U_zu, l_use_cs, l_use_wl, & 
    63       &                      Cd, Ch, Ce, t_zu, q_zu, U_blk,      & 
    64       &                      Cdn, Chn, Cen,                      & 
    65       &                      Qsw, rad_lw, slp, pdT_cs,           & ! optionals for cool-skin (and warm-layer) 
    66       &                      pdT_wl )                              ! optionals for warm-layer only 
     62 
     63   SUBROUTINE ecmwf_init(l_use_cs, l_use_wl) 
     64      !!--------------------------------------------------------------------- 
     65      !!                  ***  FUNCTION ecmwf_init  *** 
     66      !! 
     67      !! INPUT : 
     68      !! ------- 
     69      !!    * l_use_cs : use the cool-skin parameterization 
     70      !!    * l_use_wl : use the warm-layer parameterization 
     71      !!--------------------------------------------------------------------- 
     72      LOGICAL , INTENT(in) ::   l_use_cs ! use the cool-skin parameterization 
     73      LOGICAL , INTENT(in) ::   l_use_wl ! use the warm-layer parameterization 
     74      INTEGER :: ierr 
     75      !!--------------------------------------------------------------------- 
     76      IF ( l_use_wl ) THEN 
     77         ierr = 0 
     78         ALLOCATE ( dT_wl(jpi,jpj), Hz_wl(jpi,jpj), STAT=ierr ) 
     79         !IF( ierr > 0 ) STOP ' ECMWF_INIT => allocation of dT_wl & Hz_wl failed!' 
     80         dT_wl(:,:)  = 0._wp 
     81         Hz_wl(:,:)  = rd0 ! (rd0, constant, = 3m is default for Zeng & Beljaars) 
     82      END IF 
     83      !! 
     84      IF ( l_use_cs ) THEN 
     85         ierr = 0 
     86         ALLOCATE ( dT_cs(jpi,jpj), STAT=ierr ) 
     87         !IF( ierr > 0 ) STOP ' ECMWF_INIT => allocation of dT_cs failed!' 
     88         dT_cs(:,:) = -0.25_wp  ! First guess of skin correction 
     89      END IF 
     90   END SUBROUTINE ecmwf_init 
     91 
     92 
     93 
     94   SUBROUTINE turb_ecmwf( kt, zt, zu, T_s, t_zt, q_s, q_zt, U_zu, l_use_cs, l_use_wl, & 
     95      &                      Cd, Ch, Ce, t_zu, q_zu, U_blk,                           & 
     96      &                      Cdn, Chn, Cen,                                           & 
     97      &                      Qsw, rad_lw, slp, pdT_cs,                                & ! optionals for cool-skin (and warm-layer) 
     98      &                      pdT_wl, pHz_wl )                                                 ! optionals for warm-layer only 
    6799      !!---------------------------------------------------------------------- 
    68100      !!                      ***  ROUTINE  turb_ecmwf  *** 
     
    80112      !! INPUT : 
    81113      !! ------- 
     114      !!    *  kt   : current time step (starts at 1) 
    82115      !!    *  zt   : height for temperature and spec. hum. of air            [m] 
    83116      !!    *  zu   : height for wind speed (usually 10m)                     [m] 
     
    95128      !! 
    96129      !!    *  q_s  : SSQ aka saturation specific humidity at temp. T_s       [kg/kg] 
    97       !!              -> doesn't need to be given a value if skin temp computed (in case l_use_skin=True) 
    98       !!              -> MUST be given the correct value if not computing skint temp. (in case l_use_skin=False) 
     130      !!              -> doesn't need to be given a value if skin temp computed (in case l_use_cs=True or l_use_wl=True) 
     131      !!              -> MUST be given the correct value if not computing skint temp. (in case l_use_cs=False or l_use_wl=False) 
    99132      !! 
    100133      !! OPTIONAL INPUT: 
     
    103136      !!    *  rad_lw : downwelling longwave radiation at the surface  (>0)   [W/m^2] 
    104137      !!    *  slp    : sea-level pressure                                    [Pa] 
     138      !! 
     139      !! OPTIONAL OUTPUT: 
     140      !! ---------------- 
    105141      !!    * pdT_cs  : SST increment "dT" for cool-skin correction           [K] 
    106142      !!    * pdT_wl  : SST increment "dT" for warm-layer correction          [K] 
     143      !!    * pHz_wl  : thickness of warm-layer                               [m] 
    107144      !! 
    108145      !! OUTPUT : 
     
    118155      !! ** Author: L. Brodeau, June 2019 / AeroBulk (https://github.com/brodeau/aerobulk/) 
    119156      !!---------------------------------------------------------------------------------- 
     157      INTEGER,  INTENT(in   )                     ::   kt       ! current time step 
    120158      REAL(wp), INTENT(in   )                     ::   zt       ! height for t_zt and q_zt                    [m] 
    121159      REAL(wp), INTENT(in   )                     ::   zu       ! height for U_zu                             [m] 
     
    139177      REAL(wp), INTENT(in   ), OPTIONAL, DIMENSION(jpi,jpj) ::   slp      !             [Pa] 
    140178      REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   pdT_cs 
    141       ! 
    142179      REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   pdT_wl   !             [K] 
     180      REAL(wp), INTENT(  out), OPTIONAL, DIMENSION(jpi,jpj) ::   pHz_wl   !             [m] 
    143181      ! 
    144182      INTEGER :: j_itt 
     
    162200      !!---------------------------------------------------------------------------------- 
    163201 
     202      IF ( kt == nit000 ) CALL ECMWF_INIT(l_use_cs, l_use_wl) 
     203 
    164204      l_zt_equal_zu = .FALSE. 
    165205      IF( ABS(zu - zt) < 0.01_wp )   l_zt_equal_zu = .TRUE.    ! testing "zu == zt" is risky with double precision 
     
    168208      IF ( l_use_cs ) THEN 
    169209         IF( .NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp)) ) THEN 
    170             PRINT *, ' * PROBLEM ('//trim(crtnm)//'): you need to provide Qsw, rad_lw & slp to use cool-skin param!' 
    171             STOP 
    172          END IF 
    173          ALLOCATE ( pdTc(jpi,jpj) ) 
    174          pdTc(:,:) = -0.25_wp  ! First guess of skin correction 
     210            PRINT *, ' * PROBLEM ('//TRIM(crtnm)//'): you need to provide Qsw, rad_lw & slp to use cool-skin param!'; STOP 
     211         END IF 
    175212      END IF 
    176213 
    177214      IF ( l_use_wl ) THEN 
    178          IF(.NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp))) THEN 
    179             PRINT *, ' * PROBLEM ('//trim(crtnm)//'): you need to provide Qsw, rad_lw & slp to use warm-layer param!' 
    180             STOP 
    181          END IF 
    182          ALLOCATE ( pdTw(jpi,jpj) ) 
    183          pdTw(:,:) = 0._wp 
     215         IF( .NOT.(PRESENT(Qsw) .AND. PRESENT(rad_lw) .AND. PRESENT(slp))) THEN 
     216            PRINT *, ' * PROBLEM ('//TRIM(crtnm)//'): you need to provide Qsw, rad_lw & slp to use warm-layer param!'; STOP 
     217         END IF 
    184218      END IF 
    185219 
     
    322356            !! Cool-skin contribution 
    323357 
    324             CALL UPDATE_QNSOL_TAU( T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_blk, slp, rad_lw, & 
     358            CALL UPDATE_QNSOL_TAU( zu, T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_zu, U_blk, slp, rad_lw, & 
    325359               &                   ztmp1, ztmp0,  Qlat=ztmp2)  ! Qnsol -> ztmp1 / Tau -> ztmp0 
    326360 
    327             CALL CS_ECMWF( Qsw, ztmp1, u_star, zsst, pdTc )  ! Qnsol -> ztmp1 
    328  
    329             T_s(:,:) = zsst(:,:) + pdTc(:,:) 
    330             IF( l_use_wl ) T_s(:,:) = T_s(:,:) + pdTw(:,:) 
     361            CALL CS_ECMWF( Qsw, ztmp1, u_star, zsst )  ! Qnsol -> ztmp1 
     362 
     363            T_s(:,:) = zsst(:,:) + dT_cs(:,:)*tmask(:,:,1) 
     364            IF( l_use_wl ) T_s(:,:) = T_s(:,:) + dT_wl(:,:)*tmask(:,:,1) 
    331365            q_s(:,:) = rdct_qsat_salt*q_sat(MAX(T_s(:,:), 200._wp), slp(:,:)) 
    332366 
     
    335369         IF( l_use_wl ) THEN 
    336370            !! Warm-layer contribution 
    337             CALL UPDATE_QNSOL_TAU( T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_blk, slp, rad_lw, & 
     371            CALL UPDATE_QNSOL_TAU( zu, T_s, q_s, t_zu, q_zu, u_star, t_star, q_star, U_zu, U_blk, slp, rad_lw, & 
    338372               &                   ztmp1, ztmp2)  ! Qnsol -> ztmp1 / Tau -> ztmp2 
    339             CALL WL_ECMWF( Qsw, ztmp1, u_star, zsst, pdTw ) 
     373            CALL WL_ECMWF( Qsw, ztmp1, u_star, zsst ) 
    340374            !! Updating T_s and q_s !!! 
    341             T_s(:,:) = zsst(:,:) + pdTw(:,:) 
    342             IF( l_use_cs ) T_s(:,:) = T_s(:,:) + pdTc(:,:) 
     375            T_s(:,:) = zsst(:,:) + dT_wl(:,:)*tmask(:,:,1) 
     376            IF( l_use_cs ) T_s(:,:) = T_s(:,:) + dT_cs(:,:)*tmask(:,:,1) 
    343377            q_s(:,:) = rdct_qsat_salt*q_sat(MAX(T_s(:,:), 200._wp), slp(:,:)) 
    344378         END IF 
    345  
    346379 
    347380         IF( l_use_cs .OR. l_use_wl .OR. (.NOT. l_zt_equal_zu) ) THEN 
     
    361394      Cen = vkarmn*vkarmn / (log(zu/z0q)*log(zu/z0q)) 
    362395 
    363       IF ( l_use_cs .AND. PRESENT(pdT_cs) ) pdT_cs = pdTc 
    364       IF ( l_use_wl .AND. PRESENT(pdT_wl) ) pdT_wl = pdTw 
     396      IF ( l_use_cs .AND. PRESENT(pdT_cs) ) pdT_cs = dT_cs 
     397      IF ( l_use_wl .AND. PRESENT(pdT_wl) ) pdT_wl = dT_wl 
     398      IF ( l_use_wl .AND. PRESENT(pHz_wl) ) pHz_wl = Hz_wl 
    365399 
    366400      IF ( l_use_cs .OR. l_use_wl ) DEALLOCATE ( zsst ) 
    367       IF (          l_use_cs      ) DEALLOCATE ( pdTc ) 
    368       IF (          l_use_wl      ) DEALLOCATE ( pdTw ) 
    369401 
    370402   END SUBROUTINE turb_ecmwf 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/src/OCE/SBC/sbcblk_phy.F90

    r11638 r11772  
    4545   END INTERFACE cp_air 
    4646 
    47       INTERFACE alpha_sw 
     47   INTERFACE alpha_sw 
    4848      MODULE PROCEDURE alpha_sw_vctr, alpha_sw_sclr 
    4949   END INTERFACE alpha_sw 
     50 
     51   INTERFACE turb_fluxes 
     52      MODULE PROCEDURE turb_fluxes_vctr, turb_fluxes_sclr 
     53   END INTERFACE turb_fluxes 
    5054 
    5155 
     
    6468   PUBLIC update_qnsol_tau 
    6569   PUBLIC alpha_sw 
     70   PUBLIC turb_fluxes 
    6671 
    6772   !!---------------------------------------------------------------------- 
     
    128133      rho_air_sclr = MAX( pslp / (R_dry*ptak * ( 1._wp + rctv0*pqa )) , 0.8_wp ) 
    129134   END FUNCTION rho_air_sclr 
    130     
     135 
    131136 
    132137 
     
    464469 
    465470 
    466    SUBROUTINE UPDATE_QNSOL_TAU( pTs, pqs, pTa, pqa, pust, ptst, pqst, pUb, pslp, prlw, & 
     471   SUBROUTINE UPDATE_QNSOL_TAU( pzu, pTs, pqs, pTa, pqa, pust, ptst, pqst, pwnd, pUb, pslp, prlw, & 
    467472      &                         pQns, pTau,  & 
    468473      &                         Qlat) 
     
    472477      !! ** Author: L. Brodeau, Sept. 2019 / AeroBulk (https://github.com/brodeau/aerobulk/) 
    473478      !!---------------------------------------------------------------------------------- 
     479      REAL(wp),                     INTENT(in)  :: pzu  ! height above the sea-level where all this takes place (normally 10m) 
    474480      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pTs  ! water temperature at the air-sea interface [K] 
    475481      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pqs  ! satur. spec. hum. at T=pTs   [kg/kg] 
    476       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pTa  ! air temperature at z=zu [K] 
    477       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pqa  ! specific humidity at z=zu [kg/kg] 
     482      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pTa  ! potential air temperature at z=pzu [K] 
     483      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pqa  ! specific humidity at z=pzu [kg/kg] 
    478484      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pust ! u* 
    479485      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: ptst ! t* 
    480486      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pqst ! q* 
    481       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pUb  ! bulk wind speed at z=zu [m/s] 
     487      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pwnd ! wind speed module at z=pzu [m/s] 
     488      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pUb  ! bulk wind speed at z=pzu (inc. pot. effect of gustiness etc) [m/s] 
    482489      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pslp ! sea-level atmospheric pressure [Pa] 
    483490      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: prlw ! downwelling longwave radiative flux [W/m^2] 
     
    491498         &        zQlat, zQsen, zQlw 
    492499      INTEGER  ::   ji, jj     ! dummy loop indices 
    493       !!----------------------------------------------------------------------------------      
     500      !!---------------------------------------------------------------------------------- 
    494501      DO jj = 1, jpj 
    495502         DO ji = 1, jpi 
     
    502509            zCe = zz0*pqst(ji,jj)/zdq 
    503510 
    504             zUrho = pUb(ji,jj)*MAX(rho_air(pTa(ji,jj), pqa(ji,jj), pslp(ji,jj)), 1._wp)     ! rho*U10 
     511            !zUrho = pUb(ji,jj)*MAX(rho_air(pTa(ji,jj), pqa(ji,jj), pslp(ji,jj)), 1._wp)     ! rho*U10 
    505512            zTs2  = pTs(ji,jj)*pTs(ji,jj) 
    506513 
     514            CALL TURB_FLUXES( pzu, pTs(ji,jj), pqs(ji,jj), pTa(ji,jj), pqa(ji,jj), zCd, zCh, zCe, & 
     515               &              pwnd(ji,jj), pUb(ji,jj), pslp(ji,jj), & 
     516               &              pTau(ji,jj), zQsen, zQlat ) 
     517 
     518 
    507519            ! Wind stress module: 
    508             pTau(ji,jj) = zCd*zUrho*pUb(ji,jj) ! lolo? 
     520            !pTau(ji,jj) = zCd*zUrho*pUb(ji,jj) ! lolo? 
    509521 
    510522            ! Non-Solar heat flux to the ocean: 
    511             zQlat = MIN ( zUrho*zCe*L_vap( pTs(ji,jj)) * zdq , 0._wp )  ! we do not want a Qlat > 0 ! 
    512             zQsen = zUrho*zCh*cp_air(pqa(ji,jj)) * zdt 
     523            !zQlat = MIN ( zUrho*zCe*L_vap( pTs(ji,jj)) * zdq , 0._wp )  ! we do not want a Qlat > 0 ! 
     524            !zQsen = zUrho*zCh*cp_air(pqa(ji,jj)) * zdt 
    513525            zQlw  = emiss_w*(prlw(ji,jj) - stefan*zTs2*zTs2) ! Net longwave flux 
    514526 
    515527            pQns(ji,jj) = zQlat + zQsen + zQlw 
    516              
    517             IF ( PRESENT(Qlat) ) Qlat(ji,jj) = zQlat             
     528 
     529            IF ( PRESENT(Qlat) ) Qlat(ji,jj) = zQlat 
    518530         END DO 
    519531      END DO 
    520532   END SUBROUTINE UPDATE_QNSOL_TAU 
     533 
     534 
     535 
     536 
     537 
     538   SUBROUTINE TURB_FLUXES_VCTR( pzu, pTs, pqs, pTa, pqa, pCd, pCh, pCe, pwnd, pUb, pslp, & 
     539      &                                 pTau, pQsen, pQlat,  pEvap ) 
     540      !!---------------------------------------------------------------------------------- 
     541      REAL(wp),                     INTENT(in)  :: pzu  ! height above the sea-level where all this takes place (normally 10m) 
     542      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pTs  ! water temperature at the air-sea interface [K] 
     543      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pqs  ! satur. spec. hum. at T=pTs   [kg/kg] 
     544      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pTa  ! potential air temperature at z=pzu [K] 
     545      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pqa  ! specific humidity at z=pzu [kg/kg] 
     546      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pCd 
     547      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pCh 
     548      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pCe 
     549      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pwnd ! wind speed module at z=pzu [m/s] 
     550      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pUb  ! bulk wind speed at z=pzu (inc. pot. effect of gustiness etc) [m/s] 
     551      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pslp ! sea-level atmospheric pressure [Pa] 
     552      !! 
     553      REAL(wp), DIMENSION(jpi,jpj), INTENT(out) :: pTau  ! module of the wind stress [N/m^2] 
     554      REAL(wp), DIMENSION(jpi,jpj), INTENT(out) :: pQsen !  [W/m^2] 
     555      REAL(wp), DIMENSION(jpi,jpj), INTENT(out) :: pQlat !  [W/m^2] 
     556      !! 
     557      REAL(wp), DIMENSION(jpi,jpj), INTENT(out), OPTIONAL :: pEvap !  [kg/m^2/s] 
     558      !! 
     559      REAL(wp) :: ztaa, zgamma, zrho, zUrho, zevap 
     560      INTEGER  :: ji, jj, jq     ! dummy loop indices 
     561      !!---------------------------------------------------------------------------------- 
     562      DO jj = 1, jpj 
     563         DO ji = 1, jpi 
     564 
     565            !! Need ztaa, absolute temperature at pzu (formula to estimate rho_air needs absolute temperature, not the potential temperature "pTa") 
     566            ztaa = pTa(ji,jj) ! first guess... 
     567            DO jq = 1, 4 
     568               zgamma = gamma_moist( 0.5*(ztaa+pTs(ji,jj)) , pqa(ji,jj) ) 
     569               ztaa = pTa(ji,jj) - zgamma*pzu   ! Absolute temp. is slightly colder... 
     570            END DO 
     571            zrho = rho_air(ztaa, pqa(ji,jj), pslp(ji,jj)) 
     572            zrho = rho_air(ztaa, pqa(ji,jj), pslp(ji,jj)-zrho*grav*pzu) ! taking into account that we are pzu m above the sea level where SLP is given! 
     573 
     574            zUrho = pUb(ji,jj)*MAX(zrho, 1._wp)     ! rho*U10 
     575 
     576            pTau(ji,jj) = zUrho * pCd(ji,jj) * pwnd(ji,jj) ! Wind stress module 
     577 
     578            zevap        = MIN( zUrho * pCe(ji,jj) * (pqa(ji,jj) - pqs(ji,jj)) , 0._wp )   ! we do not want condensation & Qlat > 0 ! 
     579            pQsen(ji,jj) =      zUrho * pCh(ji,jj) * (pTa(ji,jj) - pTs(ji,jj)) * cp_air(pqa(ji,jj)) 
     580            pQlat(ji,jj) =  L_vap(pTs(ji,jj)) * zevap 
     581 
     582            IF ( PRESENT(pEvap) ) pEvap(ji,jj) = - zevap 
     583 
     584         END DO 
     585      END DO 
     586   END SUBROUTINE TURB_FLUXES_VCTR 
     587 
     588 
     589   SUBROUTINE TURB_FLUXES_SCLR( pzu, pTs, pqs, pTa, pqa, pCd, pCh, pCe, pwnd, pUb, pslp, & 
     590      &                                 pTau, pQsen, pQlat,  pEvap ) 
     591      !!---------------------------------------------------------------------------------- 
     592      REAL(wp),                     INTENT(in)  :: pzu  ! height above the sea-level where all this takes place (normally 10m) 
     593      REAL(wp), INTENT(in)  :: pTs  ! water temperature at the air-sea interface [K] 
     594      REAL(wp), INTENT(in)  :: pqs  ! satur. spec. hum. at T=pTs   [kg/kg] 
     595      REAL(wp), INTENT(in)  :: pTa  ! potential air temperature at z=pzu [K] 
     596      REAL(wp), INTENT(in)  :: pqa  ! specific humidity at z=pzu [kg/kg] 
     597      REAL(wp), INTENT(in)  :: pCd 
     598      REAL(wp), INTENT(in)  :: pCh 
     599      REAL(wp), INTENT(in)  :: pCe 
     600      REAL(wp), INTENT(in)  :: pwnd ! wind speed module at z=pzu [m/s] 
     601      REAL(wp), INTENT(in)  :: pUb  ! bulk wind speed at z=pzu (inc. pot. effect of gustiness etc) [m/s] 
     602      REAL(wp), INTENT(in)  :: pslp ! sea-level atmospheric pressure [Pa] 
     603      !! 
     604      REAL(wp), INTENT(out) :: pTau  ! module of the wind stress [N/m^2] 
     605      REAL(wp), INTENT(out) :: pQsen !  [W/m^2] 
     606      REAL(wp), INTENT(out) :: pQlat !  [W/m^2] 
     607      !! 
     608      REAL(wp), INTENT(out), OPTIONAL :: pEvap !  [kg/m^2/s] 
     609      !! 
     610      REAL(wp) :: ztaa, zgamma, zrho, zUrho, zevap 
     611      INTEGER  :: jq 
     612      !!---------------------------------------------------------------------------------- 
     613 
     614      !! Need ztaa, absolute temperature at pzu (formula to estimate rho_air needs absolute temperature, not the potential temperature "pTa") 
     615      ztaa = pTa ! first guess... 
     616      DO jq = 1, 4 
     617         zgamma = gamma_moist( 0.5*(ztaa+pTs) , pqa ) 
     618         ztaa = pTa - zgamma*pzu   ! Absolute temp. is slightly colder... 
     619      END DO 
     620      zrho = rho_air(ztaa, pqa, pslp) 
     621      zrho = rho_air(ztaa, pqa, pslp-zrho*grav*pzu) ! taking into account that we are pzu m above the sea level where SLP is given! 
     622 
     623      zUrho = pUb*MAX(zrho, 1._wp)     ! rho*U10 
     624 
     625      pTau = zUrho * pCd * pwnd ! Wind stress module 
     626 
     627      zevap        = MIN( zUrho * pCe * (pqa - pqs) , 0._wp )   ! we do not want condensation & Qlat > 0 ! 
     628      pQsen =      zUrho * pCh * (pTa - pTs) * cp_air(pqa) 
     629      pQlat =  L_vap(pTs) * zevap 
     630 
     631      IF ( PRESENT(pEvap) ) pEvap = - zevap 
     632 
     633   END SUBROUTINE TURB_FLUXES_SCLR 
     634 
     635 
     636 
    521637 
    522638 
     
    529645      !! ** Author: L. Brodeau, june 2016 / AeroBulk (https://github.com/brodeau/aerobulk/) 
    530646      !!---------------------------------------------------------------------------------- 
    531       REAL(wp), DIMENSION(jpi,jpj)             ::   alpha_sw_vctr   ! latent heat of vaporization   [J/kg] 
     647      REAL(wp), DIMENSION(jpi,jpj)             ::   alpha_sw_vctr   ! thermal expansion coefficient of sea-water [1/K] 
    532648      REAL(wp), DIMENSION(jpi,jpj), INTENT(in) ::   psst   ! water temperature                [K] 
    533649      !!---------------------------------------------------------------------------------- 
     
    543659      !! ** Author: L. Brodeau, june 2016 / AeroBulk (https://github.com/brodeau/aerobulk/) 
    544660      !!---------------------------------------------------------------------------------- 
    545       REAL(wp)             ::   alpha_sw_sclr   ! latent heat of vaporization   [J/kg] 
     661      REAL(wp)             ::   alpha_sw_sclr   ! thermal expansion coefficient of sea-water [1/K] 
    546662      REAL(wp), INTENT(in) ::   psst   ! sea-water temperature                   [K] 
    547663      !!---------------------------------------------------------------------------------- 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/src/OCE/SBC/sbcblk_skin_coare.F90

    r11672 r11772  
    3838 
    3939   !! Cool-skin related parameters: 
    40    REAL(wp), PUBLIC, ALLOCATABLE, SAVE, DIMENSION(:,:) :: delta_vl  !: thickness of the surface viscous layer (in the water) right below the air-sea interface [m] 
     40   REAL(wp), ALLOCATABLE, SAVE, DIMENSION(:,:), PUBLIC :: & 
     41      &                        dT_cs         !: dT due to cool-skin effect => temperature difference between air-sea interface (z=0) and right below viscous layer (z=delta) 
     42   REAL(wp), PARAMETER :: zcon0 = -16._wp * grav * rho0_w * rCp0_w * rnu0_w*rnu0_w*rnu0_w / ( rk0_w*rk0_w ) ! "-" because ocean convention: Qabs > 0 => gain of heat for ocean! 
     43   !!                             => see eq.(14) in Fairall et al. 1996   (eq.(6) of Zeng aand Beljaars is WRONG! (typo?) 
    4144 
    4245   !! Warm-layer related parameters: 
    43    REAL(wp), PARAMETER, PUBLIC :: H_wl_max = 20._wp    !: maximum depth of warm layer (adjustable) 
     46   REAL(wp), ALLOCATABLE, SAVE, DIMENSION(:,:), PUBLIC :: & 
     47      &                        dT_wl,     &  !: dT due to warm-layer effect => difference between "almost surface (right below viscous layer, z=delta) and depth of bulk SST (z=gdept_1d(1)) 
     48      &                        Hz_wl,     &  !: depth of warm-layer [m] 
     49      &                        Qnt_ac,    &  !: time integral / accumulated heat stored by the warm layer Qxdt => [J/m^2] (reset to zero every midnight) 
     50      &                        Tau_ac        !: time integral / accumulated momentum Tauxdt => [N.s/m^2] (reset to zero every midnight) 
     51 
     52   REAL(wp), PARAMETER, PUBLIC :: Hwl_max = 20._wp    !: maximum depth of warm layer (adjustable) 
    4453   ! 
    4554   REAL(wp), PARAMETER :: rich   = 0.65_wp   !: critical Richardson number 
    4655   ! 
    47    REAL(wp), PARAMETER :: Qabs_thr = 50._wp  !: threshold for heat flux absorbed in WL 
    4856   REAL(wp), PARAMETER :: zfr0   = 0.5_wp    !: initial value of solar flux absorption 
    4957   ! 
    50    REAL(wp), PUBLIC, ALLOCATABLE, SAVE, DIMENSION(:,:) :: Tau_ac  ! time integral / accumulated momentum Tauxdt => [N.s/m^2] (reset to zero every midnight) 
    51    REAL(wp), PUBLIC, ALLOCATABLE, SAVE, DIMENSION(:,:) :: Qnt_ac    ! time integral / accumulated heat stored by the warm layer Qxdt => [J/m^2] (reset to zero every midnight) 
    52    REAL(wp), PUBLIC, ALLOCATABLE, SAVE, DIMENSION(:,:) :: H_wl     ! depth of warm-layer [m] 
    5358   !!---------------------------------------------------------------------- 
    5459CONTAINS 
    5560 
    5661 
    57    SUBROUTINE CS_COARE( pQsw, pQnsol, pustar, pSST, pQlat,  pdT ) 
     62   SUBROUTINE CS_COARE( pQsw, pQnsol, pustar, pSST, pQlat ) 
    5863      !!--------------------------------------------------------------------- 
    5964      !! 
    6065      !!  Cool-Skin scheme according to Fairall et al. 1996, revisited for COARE 3.6 (Fairall et al., 2019) 
    61       !!     ------------------------------------------------------------------ 
     66      !! 
     67      !! Fairall, C. W., Bradley, E. F., Godfrey, J. S., Wick, G. A., 
     68      !! Edson, J. B., and Young, G. S. ( 1996), Cool‐skin and warm‐layer 
     69      !! effects on sea surface temperature, J. Geophys. Res., 101( C1), 1295-1308, 
     70      !! doi:10.1029/95JC03190. 
     71      !! 
     72      !!------------------------------------------------------------------ 
    6273      !! 
    6374      !!  **   INPUT: 
     
    6879      !!     *pQlat*      surface latent heat flux                       [K] 
    6980      !! 
    70       !!  **  INPUT/OUTPUT: 
    71       !!     *pdT*  : as input =>  previous estimate of dT cool-skin 
    72       !!              as output =>  new estimate of dT cool-skin 
    73       !! 
    7481      !!------------------------------------------------------------------ 
    75       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pQsw   ! net solar a.k.a shortwave radiation into the ocean (after albedo) [W/m^2] 
    76       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pQnsol ! non-solar heat flux to the ocean [W/m^2] 
    77       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pustar  ! friction velocity, temperature and humidity (u*,t*,q*) 
    78       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pSST ! bulk SST [K] 
    79       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pQlat  ! latent heat flux [W/m^2] 
    80       !! 
    81       REAL(wp), DIMENSION(jpi,jpj), INTENT(inout) :: pdT    ! dT due to cool-skin effect 
    82       !!--------------------------------------------------------------------- 
    83       INTEGER  ::   ji, jj     ! dummy loop indices 
    84       REAL(wp) :: zQnet, zQnsol, zlamb, zdelta, zalpha_w, zfr, & 
    85          &        zz1, zz2, zus, & 
    86          &        ztf 
    87       !!--------------------------------------------------------------------- 
    88  
     82      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pQsw   ! net solar a.k.a shortwave radiation into the ocean (after albedo) [W/m^2] 
     83      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pQnsol ! non-solar heat flux to the ocean [W/m^2] 
     84      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pustar  ! friction velocity, temperature and humidity (u*,t*,q*) 
     85      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pSST ! bulk SST [K] 
     86      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pQlat  ! latent heat flux [W/m^2] 
     87      !!--------------------------------------------------------------------- 
     88      INTEGER  :: ji, jj, jc 
     89      REAL(wp) :: zQabs, zdelta, zfr 
     90      !!--------------------------------------------------------------------- 
    8991      DO jj = 1, jpj 
    9092         DO ji = 1, jpi 
    9193 
    92             zalpha_w = alpha_sw( pSST(ji,jj) ) ! thermal expansion coefficient of sea-water (SST accurate enough!) 
    93  
    94             zQnsol = MAX( 1._wp , - pQnsol(ji,jj) ) ! Non-solar heat loss to the atmosphere 
    95  
    96             zdelta = delta_vl(ji,jj)   ! using last value of delta 
    97  
    98             !! Fraction of the shortwave flux absorbed by the cool-skin sublayer: 
    99             zfr   = MAX( 0.137_wp + 11._wp*zdelta - 6.6E-5_wp/zdelta*(1._wp - EXP(-zdelta/8.E-4_wp)) , 0.01_wp ) ! Eq.16 (Fairall al. 1996b) /  !LB: why 0.065 and not 0.137 like in the paper??? Beljaars & Zeng use 0.065, not 0.137 ! 
    100  
    101             zQnet = MAX( 1._wp , zQnsol - zfr*pQsw(ji,jj) )  ! Total cooling at the interface 
    102  
    103             ztf = 0.5 + SIGN(0.5_wp, zQnet) ! Qt > 0 => cooling of the layer => ztf = 1 
    104             !                                 Qt < 0 => warming of the layer => ztf = 0 
    105  
    106             !! Term alpha*Qb (Qb is the virtual surface cooling inc. buoyancy effect of salinity due to evap): 
    107             zz1 = zalpha_w*zQnet - 0.026*MIN(pQlat(ji,jj),0._wp)*rCp0_w/rLevap  ! alpha*(Eq.8) == alpha*Qb "-" because Qlat < 0 
    108             !! LB: this terms only makes sense if > 0 i.e. in the cooling case 
    109             !! so similar to what's done in ECMWF: 
    110             zz1 = MAX(0._wp , zz1)    ! 1. instead of 0.1 though ZQ = MAX(1.0,-pQlw(ji,jj) - pQsen(ji,jj) - pQlat(ji,jj)) 
    111  
    112             zus = MAX(pustar(ji,jj), 1.E-4_wp) ! Laurent: too low wind (u*) might cause problem in stable cases: 
    113             zz2 = zus*zus * roadrw 
    114             zz2 = zz2*zz2 
    115             zlamb =  6._wp*( 1._wp + (rcst_cs*zz1/zz2)**0.75 )**(-1./3.) ! Lambda (Eq.14) (Saunders) 
    116  
    117             ! Updating molecular sublayer thickness (delta): 
    118             zz2    = rnu0_w/(SQRT(roadrw)*zus) 
    119             zdelta =      ztf    *          zlamb*zz2   &  ! Eq.12 (when alpha*Qb>0 / cooling of layer) 
    120                &    + (1._wp - ztf) * MIN(0.007_wp , 6._wp*zz2 )    ! Eq.12 (when alpha*Qb<0 / warming of layer) 
    121             !LB: changed 0.01 to 0.007 
    122  
    123             !! Once again with the new zdelta: 
    124             zfr   = MAX( 0.137_wp + 11._wp*zdelta - 6.6E-5_wp/zdelta*(1._wp - EXP(-zdelta/8.E-4_wp)) , 0.01_wp ) ! Solar absorption / Eq.16 (Fairall al. 1996b) 
    125             zQnet = MAX( 1._wp , zQnsol - zfr*pQsw(ji,jj) ) ! Total cooling at the interface 
    126  
    127             !! Update! 
    128             pdT(ji,jj) =  MIN( - zQnet*zdelta/rk0_w , 0._wp )   ! temperature increment 
    129             delta_vl(ji,jj) = zdelta 
     94            zQabs  = MIN( -0.1_wp , pQnsol(ji,jj) ) ! first guess, we do not miss a lot assuming 0 solar flux absorbed in the tiny layer of thicknes$ 
     95            !                                       ! also, we ONLY consider when the viscous layer is loosing heat to the atmosphere, we only deal with cool-skin! => hence the "MIN( -0$ 
     96 
     97            zdelta = delta_skin_layer( alpha_sw(pSST(ji,jj)), zQabs, pQlat(ji,jj), pustar(ji,jj) ) 
     98 
     99            DO jc = 1, 4 ! because implicit in terms of zdelta... 
     100               zfr    = MAX( 0.137_wp + 11._wp*zdelta - 6.6E-5_wp/zdelta*(1._wp - EXP(-zdelta/8.E-4_wp)) , 0.01_wp ) ! Solar absorption, Eq.16 (Fairall al. 1996b) /  !LB: why 0.065 and not 0.137 like in the paper??? Beljaars & Zeng use 0.065, not 0.137 ! 
     101               zQabs  = MIN( -0.1_wp , pQnsol(ji,jj) + zfr*pQsw(ji,jj) ) ! Total cooling at the interface 
     102               zdelta = delta_skin_layer( alpha_sw(pSST(ji,jj)), zQabs, pQlat(ji,jj), pustar(ji,jj) ) 
     103            END DO 
     104 
     105            dT_cs(ji,jj) = MIN( zQabs*zdelta/rk0_w , 0._wp )   ! temperature increment 
    130106 
    131107         END DO 
     
    135111 
    136112 
    137  
    138  
    139    SUBROUTINE WL_COARE( pQsw, pQnsol, pTau, pSST, iwait,  pdT, Hwl, mask_wl ) 
     113   SUBROUTINE WL_COARE( pQsw, pQnsol, pTau, pSST, iwait ) 
    140114      !!--------------------------------------------------------------------- 
    141115      !! 
     
    149123      !!     *pSST*       bulk SST  (taken at depth gdept_1d(1))         [K] 
    150124      !!     *iwait*      if /= 0 then wait before updating accumulated fluxes, we are within a converging itteration loop... 
    151       !! 
    152       !!  **   OUTPUT: 
    153       !!     *pdT*   dT due to warm-layer effect => difference between "almost surface (right below viscous layer) and depth of bulk SST 
    154       !!--------------------------------------------------------------------- 
    155       !! 
    156       !!   ** OPTIONAL OUTPUT: 
    157       !!     *Hwl*        depth of warm layer [m] 
    158       !!     *mask_wl*    mask for possible existence of a warm-layer (1) or not (0) 
    159       !! 
    160       !!------------------------------------------------------------------ 
     125      !!--------------------------------------------------------------------- 
    161126      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pQsw     ! surface net solar radiation into the ocean [W/m^2]     => >= 0 ! 
    162127      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pQnsol   ! surface net non-solar heat flux into the ocean [W/m^2] => normally < 0 ! 
     
    164129      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pSST     ! bulk SST at depth gdept_1d(1) [K] 
    165130      INTEGER ,                     INTENT(in)  :: iwait    ! if /= 0 then wait before updating accumulated fluxes 
    166       REAL(wp), DIMENSION(jpi,jpj), INTENT(out) :: pdT      ! dT due to warm-layer effect => difference between "almost surface (right below viscous layer) and depth of bulk SST 
    167       !! 
    168       REAL(wp),   DIMENSION(jpi,jpj), INTENT(out), OPTIONAL :: Hwl     ! depth of warm layer [m] 
    169       INTEGER(1), DIMENSION(jpi,jpj), INTENT(out), OPTIONAL :: mask_wl ! mask for possible existence of a warm-layer (1) or not (0) 
    170       ! 
    171       ! 
     131      !! 
    172132      INTEGER :: ji,jj 
    173133      ! 
    174       REAL(wp) :: zdT_wl, zQabs, zfr, zdz 
     134      REAL(wp) :: zdTwl, zHwl, zQabs, zfr 
    175135      REAL(wp) :: zqac, ztac 
    176       REAL(wp) :: zalpha_w, zcd1, zcd2, flg 
     136      REAL(wp) :: zalpha, zcd1, zcd2, flg 
    177137      !!--------------------------------------------------------------------- 
    178138 
     
    180140      INTEGER  :: jl 
    181141 
     142      LOGICAL :: l_exit, l_destroy_wl 
     143 
    182144      !! INITIALIZATION: 
    183       pdT(:,:) = 0._wp    ! dT initially set to 0._wp 
    184       zdT_wl = 0._wp       ! total warming (amplitude) in warm layer 
    185       zQabs  = 0._wp       ! total heat absorped in warm layer 
    186       zfr    = zfr0        ! initial value of solar flux absorption 
    187       ztac   = 0._wp 
    188       zqac   = 0._wp 
    189       IF ( PRESENT(mask_wl) ) mask_wl(:,:) = 0 
     145      zQabs  = 0._wp       ! total heat flux absorped in warm layer 
     146      zfr    = zfr0        ! initial value of solar flux absorption !LOLO: save it and use previous value !!! 
    190147 
    191148      IF( .NOT. ln_dm2dc ) CALL sbc_dcy_param() ! we need to call sbc_dcy_param (sbcdcy.F90) because rdawn_dcy and rdusk_dcy are unkonwn otherwize! 
     
    201158         DO ji = 1, jpi 
    202159 
    203             zdz   = MAX( MIN(H_wl(ji,jj),H_wl_max) , 0.1_wp) ! depth of warm layer 
     160            l_exit       = .FALSE. 
     161            l_destroy_wl = .FALSE. 
     162 
     163            zdTwl =  dT_wl(ji,jj)                          ! value of previous time step as first guess 
     164            zHwl  = MAX( MIN(Hz_wl(ji,jj),Hwl_max),0.1_wp) !   "                  "           " 
     165 
     166            zqac = Qnt_ac(ji,jj) ! previous time step Qnt_ac 
     167            ztac = Tau_ac(ji,jj) 
    204168 
    205169            !*****  variables for warm layer  *** 
    206             zalpha_w = alpha_sw( pSST(ji,jj) ) ! thermal expansion coefficient of sea-water (SST accurate enough!) 
    207  
    208             zcd1 = SQRT(2._wp*rich*rCp0_w/(zalpha_w*grav*rho0_w))        !mess-o-constants 1 
    209             zcd2 = SQRT(2._wp*zalpha_w*grav/(rich*rho0_w))/(rCp0_w**1.5) !mess-o-constants 2 
    210  
    211             !******************************************************** 
    212             !****  Compute apply warm layer  correction ************* 
    213             !******************************************************** 
     170            zalpha = alpha_sw( pSST(ji,jj) ) ! thermal expansion coefficient of sea-water (SST accurate enough!) 
     171 
     172            zcd1 = SQRT(2._wp*rich*rCp0_w/(zalpha*grav*rho0_w))        !mess-o-constants 1 
     173            zcd2 = SQRT(2._wp*zalpha*grav/(rich*rho0_w))/(rCp0_w**1.5) !mess-o-constants 2 
     174 
    214175             
    215176            znoon = MOD( 0.5_wp*(rdawn_dcy(ji,jj)+rdusk_dcy(ji,jj)), 1._wp )   ! 0<rnoon<1. => rnoon*24 = UTC time of local noon 
    216177            zmidn = MOD(              znoon-0.5_wp                 , 1._wp ) 
    217  
    218             IF (lwp .AND. (ji==2) .AND. (jj==2) ) WRITE(numout,*) 'LOLO: rdawn, rdusk, znoon, zmidn =', rdawn_dcy(ji,jj), rdusk_dcy(ji,jj), znoon, zmidn 
    219              
    220             ! When midnight is past and dawn is not there yet, do what they call the "midnight reset": 
    221             IF ( (ztime >= zmidn).AND.(ztime <= rdawn_dcy(ji,jj)) ) THEN 
    222                IF (lwp .AND. (ji==2) .AND. (jj==2) ) WRITE(numout,*) ' LOLO [WL_COARE] MIDNIGHT RESET !!!!, ztime =', ztime 
    223                zdz           = H_wl_max 
    224                Tau_ac(ji,jj) = 0._wp 
    225                Qnt_ac(ji,jj) = 0._wp 
    226             END IF 
    227  
    228  
    229             IF ( ztime > rdawn_dcy(ji,jj) ) THEN ! Dawn, a new day starts at current location 
    230                IF (lwp .AND. (ji==2) .AND. (jj==2) ) WRITE(numout,*) ' LOLO [WL_COARE] WE DO WL !!!!, ztime =', ztime 
    231                 
    232                !************************************ 
    233                !****   set warm layer constants  *** 
    234                !************************************ 
    235  
    236                zQabs = zfr*pQsw(ji,jj) + pQnsol(ji,jj)       ! tot heat absorbed in warm layer 
    237  
    238                !PRINT *, '  [WL_COARE] rdt,  pQsw, pQnsol, zQabs =', rdt, REAL(pQsw(ji,jj),4), REAL(pQnsol(ji,jj),4), REAL(zQabs,4) 
    239  
    240                IF ( zQabs >= Qabs_thr ) THEN         ! Check for threshold 
    241  
    242                   !PRINT *, '  [WL_COARE] Tau_ac, Qnt_ac =', REAL(Tau_ac(ji,jj),4), REAL(Qnt_ac(ji,jj),4) 
    243  
    244                   !Tau_ac(ji,jj) = Tau_ac(ji,jj) + MAX(.002_wp , pTau(ji,jj))*rdt      ! momentum integral 
    245                   ztac = Tau_ac(ji,jj) + MAX(.002_wp , pTau(ji,jj))*rdt      ! updated momentum integral 
    246  
    247                   IF ( Qnt_ac(ji,jj) + zQabs*rdt > 0._wp ) THEN         !check threshold for warm layer existence 
    248                      !****************************************** 
    249                      ! Compute the absorption profile 
    250                      !****************************************** 
    251                      DO jl = 1, 5                           !loop 5 times for zfr 
    252                         zfr = 1. - ( 0.28*0.014*(1. - EXP(-zdz/0.014)) + 0.27*0.357*(1. - EXP(-zdz/0.357)) & 
    253                            &        + 0.45*12.82*(1-EXP(-zdz/12.82)) ) / zdz 
    254                         zqac = Qnt_ac(ji,jj) + (zfr*pQsw(ji,jj) + pQnsol(ji,jj))*rdt ! updated heat absorbed 
    255                         IF ( zqac > 1._wp ) zdz = MAX( MIN( H_wl_max , zcd1*ztac/SQRT(zqac)) , 0.1_wp ) ! Warm-layer depth 
    256                      END DO 
    257  
    258                   ELSE 
    259                      !*********************** 
    260                      ! Warm layer wiped out 
    261                      !*********************** 
    262                      zfr  = 0.75 
    263                      zdz  = H_wl_max 
    264                      zqac = Qnt_ac(ji,jj) + (zfr*pQsw(ji,jj) + pQnsol(ji,jj))*rdt ! updated heat absorbed 
    265  
    266                   END IF !IF ( Qnt_ac(ji,jj) + zQabs*rdt > 0._wp ) 
    267  
    268                   IF ( zqac > 1._wp ) zdT_wl = zcd2*zqac**1.5/ztac * MAX(zqac/ABS(zqac),0._wp)  !! => IF(zqac>0._wp): zdT_wl=zcd2*zqac**1.5/ztac ; ELSE: zdT_wl=0. / ! normally: zqac > 0 ! 
    269                    
     178            zmidn = MOD( zmidn + 0.125_wp , 1._wp ) ! 3 hours past the local midnight  
     179 
     180            IF ( (ztime >= zmidn) .AND. (ztime < rdawn_dcy(ji,jj)) ) THEN 
     181               ! Dawn reset to 0! 
     182               l_exit       = .TRUE. 
     183               l_destroy_wl = .TRUE. 
     184            END IF 
     185 
     186            IF ( .NOT. l_exit ) THEN 
     187               !! Initial test on initial guess of absorbed heat flux in warm-layer: 
     188               zfr = 1._wp - ( 0.28*0.014*(1. - EXP(-zHwl/0.014)) + 0.27*0.357*(1. - EXP(-zHwl/0.357)) & 
     189                  &        + 0.45*12.82*(1-EXP(-zHwl/12.82)) ) / zHwl 
     190               zQabs = zfr*pQsw(ji,jj) + pQnsol(ji,jj) ! first guess of tot. heat flux absorbed in warm layer !LOLO: depends of zfr, which is wild guess... Wrong!!! 
     191               PRINT *, '#LBD:  Initial Qsw & Qnsol:', NINT(pQsw(ji,jj)), NINT(pQnsol(ji,jj)) 
     192               PRINT *, '#LBD:       =>Qabs:', zQabs,' zfr=', zfr 
     193 
     194               IF ( (ABS(zdTwl) < 1.E-6_wp) .AND. (zQabs <= 0._wp) ) THEN 
     195                  ! We have not started to build a WL yet (dT==0) and there's no way it can occur now 
     196                  ! since zQabs <= 0._wp 
     197                  ! => no need to go further 
     198                  PRINT *, '#LBD: we have not started to to build a WL yet (dT==0)' 
     199                  PRINT *, '#LBD: and theres no way it can occur now since zQabs=', zQabs 
     200                  PRINT *, '#LBD: => leaving without changing anything...' 
     201                  l_exit = .TRUE. 
     202               END IF 
     203 
     204            END IF 
     205 
     206            ! Okay test on updated absorbed flux: 
     207            !LOLO: remove??? has a strong influence !!! 
     208            IF ( (.NOT.(l_exit)) .AND. (Qnt_ac(ji,jj) + zQabs*rdt <= 0._wp) ) THEN 
     209               PRINT *, '#LBD: Oh boy! Next Qnt_ac looking weak! =>', Qnt_ac(ji,jj) + zQabs*rdt 
     210               PRINT *, '#LBD:  => time to destroy the warm-layer!' 
     211               l_exit       = .TRUE. 
     212               l_destroy_wl = .TRUE. 
     213            END IF 
     214 
     215 
     216            IF ( .NOT. l_exit) THEN 
     217 
     218               ! Two possibilities at this point: 
     219               ! 1/ A warm layer already exists (dT>0) but it is cooling down because Qabs<0 
     220               ! 2/ Regardless of WL formed (dT==0 or dT>0), we are in the process to initiate one or warm further it ! 
     221 
     222               PRINT *, '#LBD:======================================================' 
     223               PRINT *, '#LBD: WL action makes sense now! => zQabs,dT_wl=', REAL(zQabs,4), REAL(zdTwl,4) 
     224               PRINT *, '#LBD:======================================================' 
     225               PRINT *, '#LBD: current values for Qac and Tac=', REAL(Qnt_ac(ji,jj),4), REAL(Tau_ac(ji,jj),4) 
     226 
     227               ztac = Tau_ac(ji,jj) + MAX(.002_wp , pTau(ji,jj))*rdt      ! updated momentum integral 
     228               PRINT *, '#LBD: updated value for Tac=',  REAL(ztac,4) 
     229 
     230               !! We update the value of absorbtion and zQabs: 
     231               !! some part is useless if Qsw=0 !!! 
     232               DO jl = 1, 5 
     233                  zfr = 1. - ( 0.28*0.014*(1. - EXP(-zHwl/0.014)) + 0.27*0.357*(1. - EXP(-zHwl/0.357)) & 
     234                     &        + 0.45*12.82*(1-EXP(-zHwl/12.82)) ) / zHwl 
     235                  zQabs = zfr*pQsw(ji,jj) + pQnsol(ji,jj) 
     236                  zqac  = Qnt_ac(ji,jj) + zQabs*rdt ! updated heat absorbed 
     237                  IF ( zqac <= 0._wp ) EXIT 
     238                  zHwl = MAX( MIN( Hwl_max , zcd1*ztac/SQRT(zqac)) , 0.1_wp ) ! Warm-layer depth 
     239               END DO 
     240               PRINT *, '#LBD: updated absorption and WL depth=',  REAL(zfr,4), REAL(zHwl,4) 
     241               PRINT *, '#LBD: updated value for Qabs=',  REAL(zQabs,4), 'W/m2' 
     242               PRINT *, '#LBD: updated value for Qac =',  REAL(zqac,4), 'J' 
     243 
     244               IF ( zqac <= 0._wp ) THEN 
     245                  l_destroy_wl = .TRUE. 
     246                  l_exit       = .TRUE. 
     247               ELSE 
     248                  zdTwl = zcd2*zqac**1.5/ztac * MAX(zqac/ABS(zqac),0._wp)  !! => IF(zqac>0._wp): zdTwl=zcd2*zqac**1.5/ztac ; ELSE: zdTwl=0. / ! normally: zqac > 0 ! 
     249                  PRINT *, '#LBD: updated preliminary value for dT_wl=',  REAL(zdTwl,4) 
    270250                  ! Warm layer correction 
    271                   flg = 0.5_wp + SIGN( 0.5_wp , gdept_1d(1)-zdz )               ! => 1 when gdept_1d(1)>zdz (pdT(ji,jj) = zdT_wl) | 0 when gdept_1d(1)<zdz (pdT(ji,jj) = zdT_wl*gdept_1d(1)/zdz) 
    272                   pdT(ji,jj) = zdT_wl * ( flg + (1._wp-flg)*gdept_1d(1)/zdz ) 
    273                    
    274                END IF ! IF ( zQabs >= Qabs_thr ) 
    275  
    276             END IF ! IF ( isd_sol >= 21600 ) THEN  ! (21600 == 6am) 
     251                  flg = 0.5_wp + SIGN( 0.5_wp , gdept_1d(1)-zHwl )               ! => 1 when gdept_1d(1)>zHwl (zdTwl = zdTwl) | 0 when gdept_1d(1)<zHwl (zdTwl = zdTwl*gdept_1d(1)/zHwl) 
     252                  zdTwl = zdTwl * ( flg + (1._wp-flg)*gdept_1d(1)/zHwl ) 
     253               END IF 
     254 
     255            END IF !IF ( .NOT. l_exit) 
     256 
     257            IF ( l_destroy_wl ) THEN 
     258               zdTwl = 0._wp 
     259               zfr   = 0.75_wp 
     260               zHwl  = Hwl_max 
     261               zqac  = 0._wp 
     262               ztac  = 0._wp 
     263            END IF 
     264 
     265            PRINT *, '#LBD: exit values for Qac & Tac:', REAL(zqac,4), REAL(ztac,4) 
    277266 
    278267            IF ( iwait == 0 ) THEN 
    279                IF ( (zQabs >= Qabs_thr).AND.(ztime > rdawn_dcy(ji,jj)) ) THEN 
    280                   !PRINT *, '  [WL_COARE] WE UPDATE ACCUMULATED FLUXES !!!' 
    281                   Qnt_ac(ji,jj) = zqac ! Updating Qnt_ac, heat integral 
    282                   Tau_ac(ji,jj) = ztac ! 
    283                   IF ( PRESENT(mask_wl) ) mask_wl(ji,jj) = 1 
    284                END IF 
    285             END IF 
    286  
    287             H_wl(ji,jj) = zdz 
    288  
    289             IF ( PRESENT(Hwl) ) Hwl(ji,jj) = H_wl(ji,jj) 
     268               !! Iteration loop within bulk algo is over, time to update what needs to be updated: 
     269               dT_wl(ji,jj)  = zdTwl 
     270               Hz_wl(ji,jj)  = zHwl 
     271               PRINT *, '#LBD: FINAL EXIT values for dT_wl & Hz_wl:', REAL(dT_wl(ji,jj),4), REAL(Hz_wl(ji,jj),4) 
     272               Qnt_ac(ji,jj) = zqac ! Updating Qnt_ac, heat integral 
     273               Tau_ac(ji,jj) = ztac 
     274               PRINT *, '#LBD: FINAL EXIT values for Qac & Tac:', REAL(Qnt_ac(ji,jj),4), REAL(Tau_ac(ji,jj),4) 
     275               PRINT *, '#LBD' 
     276            END IF 
    290277 
    291278         END DO 
    292279      END DO 
    293        
     280 
    294281   END SUBROUTINE WL_COARE 
    295282 
     283 
     284 
     285 
     286   FUNCTION delta_skin_layer( palpha, pQabs, pQlat, pustar_a ) 
     287      !!--------------------------------------------------------------------- 
     288      !! Computes the thickness (m) of the viscous skin layer. 
     289      !! Based on Fairall et al., 1996 
     290      !! 
     291      !! Fairall, C. W., Bradley, E. F., Godfrey, J. S., Wick, G. A., 
     292      !! Edson, J. B., and Young, G. S. ( 1996), Cool‐skin and warm‐layer 
     293      !! effects on sea surface temperature, J. Geophys. Res., 101( C1), 1295-1308, 
     294      !! doi:10.1029/95JC03190. 
     295      !! 
     296      !! L. Brodeau, october 2019 
     297      !!--------------------------------------------------------------------- 
     298      REAL(wp)                :: delta_skin_layer 
     299      REAL(wp), INTENT(in)    :: palpha   ! thermal expansion coefficient of sea-water (SST accurate enough!) 
     300      REAL(wp), INTENT(in)    :: pQabs    ! < 0 !!! part of the net heat flux actually absorbed in the WL [W/m^2] => term "Q + Rs*fs" in eq.6 of Fairall et al. 1996 
     301      REAL(wp), INTENT(in)    :: pQlat    ! latent heat flux [W/m^2] 
     302      REAL(wp), INTENT(in)    :: pustar_a ! friction velocity in the air (u*) [m/s] 
     303      !!--------------------------------------------------------------------- 
     304      REAL(wp) :: zusw, zusw2, zlamb, zQb 
     305      !!--------------------------------------------------------------------- 
     306 
     307      zQb = pQabs + 0.026*MIN(pQlat,0._wp)*rCp0_w/rLevap/palpha   ! LOLO: Double check sign + division by palpha !!! units are okay! 
     308 
     309      zusw  = MAX(pustar_a, 1.E-4_wp) * sq_radrw    ! u* in the water 
     310      zusw2 = zusw*zusw 
     311 
     312      zlamb = 6._wp*( 1._wp + (palpha*zcon0/(zusw2*zusw2)*zQb)**0.75 )**(-1./3.) ! see eq.(14) in Fairall et al., 1996 
     313 
     314      delta_skin_layer = zlamb*rnu0_w/zusw 
     315 
     316   END FUNCTION delta_skin_layer 
    296317 
    297318   !!====================================================================== 
  • NEMO/branches/2019/dev_r11085_ASINTER-05_Brodeau_Advanced_Bulk/src/OCE/SBC/sbcblk_skin_ecmwf.F90

    r11637 r11772  
    3838 
    3939   !! Cool-skin related parameters: 
    40    ! ... 
     40   REAL(wp), ALLOCATABLE, SAVE, DIMENSION(:,:), PUBLIC :: & 
     41      &                        dT_cs         !: dT due to cool-skin effect => temperature difference between air-sea interface (z=0) and right below viscous layer (z=delta) 
     42   REAL(wp), PARAMETER :: zcon0 = -16._wp * grav * rho0_w * rCp0_w * rnu0_w*rnu0_w*rnu0_w / ( rk0_w*rk0_w ) ! "-" because ocean convention: Qabs > 0 => gain of heat for ocean! 
     43   !!                             => see eq.(14) in Fairall et al. 1996   (eq.(6) of Zeng aand Beljaars is WRONG! (typo?) 
    4144 
    4245   !! Warm-layer related parameters: 
    43    REAL(wp), PARAMETER :: rd0  = 3.        !: Depth scale [m] of warm layer, "d" in Eq.11 (Zeng & Beljaars 2005) 
    44    REAL(wp), PARAMETER :: zRhoCp_w = rho0_w*rCp0_w 
    45    REAL(wp), PARAMETER :: rNu0 = 1.0       !:  be closer to COARE3p6 ???!LOLO 
    46    !REAL(wp), PARAMETER :: rNu0 = 0.5       !: Nu (exponent of temperature profile) Eq.11 
    47    !                                       !: (Zeng & Beljaars 2005) !: set to 0.5 instead of 
    48    !                                       !: 0.3 to respect a warming of +3 K in calm 
    49    !                                       !: condition for the insolation peak of +1000W/m^2 
     46   REAL(wp), ALLOCATABLE, SAVE, DIMENSION(:,:), PUBLIC :: & 
     47      &                        dT_wl,  &   !: dT due to warm-layer effect => difference between "almost surface (right below viscous layer, z=delta) and depth of bulk SST (z=gdept_1d(1)) 
     48      &                        Hz_wl       !: depth of warm-layer [m] 
     49   ! 
     50   REAL(wp), PARAMETER, PUBLIC :: rd0  = 3.    !: Depth scale [m] of warm layer, "d" in Eq.11 (Zeng & Beljaars 2005) 
     51   REAL(wp), PARAMETER         :: zRhoCp_w = rho0_w*rCp0_w 
     52   ! 
     53   REAL(wp), PARAMETER         :: rNuwl0 = 0.5  !: Nu (exponent of temperature profile) Eq.11 
     54   !                                            !: (Zeng & Beljaars 2005) !: set to 0.5 instead of 
     55   !                                            !: 0.3 to respect a warming of +3 K in calm 
     56   !                                            !: condition for the insolation peak of +1000W/m^2 
    5057   !!---------------------------------------------------------------------- 
    5158CONTAINS 
    5259 
    5360 
    54    SUBROUTINE CS_ECMWF( pQsw, pQnsol, pustar, pSST,  pdT ) 
    55       !!--------------------------------------------------------------------- 
    56       !! 
    57       !!  Cool-Skin scheme according to Fairall et al. 1996 
    58       !! Warm-Layer scheme according to Zeng & Beljaars, 2005 (GRL) 
    59       !!  " A prognostic scheme of sea surface skin temperature for modeling and data assimilation " 
    60       !!     as parameterized in IFS Cy45r1 / E.C.M.W.F. 
    61       !!     ------------------------------------------------------------------ 
     61   SUBROUTINE CS_ECMWF( pQsw, pQnsol, pustar, pSST ) 
     62      !!--------------------------------------------------------------------- 
     63      !! 
     64      !! Cool-skin parameterization, based on Fairall et al., 1996: 
     65      !! 
     66      !! Fairall, C. W., Bradley, E. F., Godfrey, J. S., Wick, G. A., 
     67      !! Edson, J. B., and Young, G. S. ( 1996), Cool‐skin and warm‐layer 
     68      !! effects on sea surface temperature, J. Geophys. Res., 101( C1), 1295-1308, 
     69      !! doi:10.1029/95JC03190. 
     70      !! 
     71      !!------------------------------------------------------------------ 
    6272      !! 
    6373      !!  **   INPUT: 
     
    6676      !!     *pustar*     friction velocity u*                           [m/s] 
    6777      !!     *pSST*       bulk SST (taken at depth gdept_1d(1))          [K] 
    68       !! 
    69       !!  **  INPUT/OUTPUT: 
    70       !!     *pdT*  : as input =>  previous estimate of dT cool-skin 
    71       !!              as output =>  new estimate of dT cool-skin 
    72       !! 
    7378      !!------------------------------------------------------------------ 
    74       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pQsw   ! net solar a.k.a shortwave radiation into the ocean (after albedo) [W/m^2] 
    75       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pQnsol ! non-solar heat flux to the ocean [W/m^2] 
    76       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pustar  ! friction velocity, temperature and humidity (u*,t*,q*) 
    77       REAL(wp), DIMENSION(jpi,jpj), INTENT(in)    :: pSST ! bulk SST [K] 
    78       !! 
    79       REAL(wp), DIMENSION(jpi,jpj), INTENT(inout) :: pdT    ! dT due to cool-skin effect 
    80       !!--------------------------------------------------------------------- 
    81       INTEGER  ::   ji, jj     ! dummy loop indices 
    82       REAL(wp) :: zQnet, zQnsol, zlamb, zdelta, zalpha_w, zfr, & 
    83          & zusw, zusw2 
    84       !!--------------------------------------------------------------------- 
    85  
     79      REAL(wp), DIMENSION(jpi,jpj), INTENT(in) :: pQsw   ! net solar a.k.a shortwave radiation into the ocean (after albedo) [W/m^2] 
     80      REAL(wp), DIMENSION(jpi,jpj), INTENT(in) :: pQnsol ! non-solar heat flux to the ocean [W/m^2] 
     81      REAL(wp), DIMENSION(jpi,jpj), INTENT(in) :: pustar  ! friction velocity, temperature and humidity (u*,t*,q*) 
     82      REAL(wp), DIMENSION(jpi,jpj), INTENT(in) :: pSST ! bulk SST [K] 
     83      !!--------------------------------------------------------------------- 
     84      INTEGER  :: ji, jj, jc 
     85      REAL(wp) :: zQabs, zdelta, zfr 
     86      !!--------------------------------------------------------------------- 
    8687      DO jj = 1, jpj 
    8788         DO ji = 1, jpi 
    8889 
    89             zalpha_w = alpha_sw( pSST(ji,jj) ) ! thermal expansion coefficient of sea-water (SST accurate enough!) 
    90  
    91             zQnsol = MAX( 1._wp , - pQnsol(ji,jj) ) ! Non-solar heat loss to the atmosphere 
    92  
    93             zusw  = MAX(pustar(ji,jj), 1.E-4_wp)*SQRT(roadrw)    ! u* in the water 
    94             zusw2 = zusw*zusw 
    95  
    96             zlamb = 6._wp*( 1._wp + (zQnsol*zalpha_w*rcst_cs/(zusw2*zusw2 ))**0.75 )**(-1./3.)   ! w.r.t COARE 3p6 => seems to ommit absorbed zfr*Qsw (Qnet i.o. Qnsol) and effect of evap... 
    97             !                                                                                  ! so zlamb not implicit in terms of zdelta (zfr(delta)), so no need to have last guess of delta as in COARE 3.6... 
    98             zdelta = zlamb*rnu0_w/zusw 
    99  
    100             zfr   = MAX( 0.065_wp + 11._wp*zdelta - 6.6E-5_wp/zdelta*(1._wp - EXP(-zdelta/8.E-4_wp)) , 0.01_wp ) ! Solar absorption / Eq. 8.131 / IFS cy40r1, doc, Part IV, 
    101             zQnet = MAX( 1._wp , zQnsol - zfr*pQsw(ji,jj) ) ! Total cooling at the interface 
    102  
    103             !! Update! 
    104             pdT(ji,jj) =  MIN( - zQnet*zdelta/rk0_w , 0._wp )   ! temperature increment 
     90            zQabs  = MIN( -0.1_wp , pQnsol(ji,jj) ) ! first guess, we do not miss a lot assuming 0 solar flux absorbed in the tiny layer of thicknes$ 
     91            !                                       ! also, we ONLY consider when the viscous layer is loosing heat to the atmosphere, we only deal with cool-skin! => hence the "MIN( -0$ 
     92            !zQabs  = pQnsol(ji,jj) 
     93 
     94            zdelta = delta_skin_layer( alpha_sw(pSST(ji,jj)), zQabs, pustar(ji,jj) ) 
     95 
     96            DO jc = 1, 4 ! because implicit in terms of zdelta... 
     97               zfr    = MAX( 0.065_wp + 11._wp*zdelta - 6.6E-5_wp/zdelta*(1._wp - EXP(-zdelta/8.E-4_wp)) , 0.01_wp ) ! Solar absorption, Eq.(5) Zeng & Beljaars, 2005 
     98               !              =>  (WARNING: 0.065 rather than 0.137 in Fairal et al. 1996) 
     99               zQabs  = MIN( -0.1_wp , pQnsol(ji,jj) + zfr*pQsw(ji,jj) ) ! Total cooling at the interface 
     100               !zQabs = pQnsol(ji,jj) + zfr*pQsw(ji,jj) 
     101               zdelta = delta_skin_layer( alpha_sw(pSST(ji,jj)), zQabs, pustar(ji,jj) ) 
     102            END DO 
     103 
     104            dT_cs(ji,jj) = MIN( zQabs*zdelta/rk0_w , 0._wp )   ! temperature increment 
    105105 
    106106         END DO 
     
    111111 
    112112 
    113    SUBROUTINE WL_ECMWF( pQsw, pQnsol, pustar, pSST, pdT ) 
     113   SUBROUTINE WL_ECMWF( pQsw, pQnsol, pustar, pSST,  pustk ) 
    114114      !!--------------------------------------------------------------------- 
    115115      !! 
    116116      !!  Warm-Layer scheme according to Zeng & Beljaars, 2005 (GRL) 
    117117      !!  " A prognostic scheme of sea surface skin temperature for modeling and data assimilation " 
     118      !! 
     119      !!  STIL NO PROGNOSTIC EQUATION FOR THE DEPTH OF THE WARM-LAYER! 
    118120      !! 
    119121      !!    As included in IFS Cy45r1   /  E.C.M.W.F. 
     
    125127      !!     *pustar*     friction velocity u*                           [m/s] 
    126128      !!     *pSST*       bulk SST  (taken at depth gdept_1d(1))         [K] 
    127       !! 
    128       !!   **  INPUT/OUTPUT: 
    129       !!     *pdT*  : as input =>  previous estimate of dT warm-layer 
    130       !!             as output =>  new estimate of dT warm-layer 
    131       !! 
    132129      !!------------------------------------------------------------------ 
    133130      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pQsw     ! surface net solar radiation into the ocean [W/m^2]     => >= 0 ! 
     
    135132      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pustar   ! friction velocity [m/s] 
    136133      REAL(wp), DIMENSION(jpi,jpj), INTENT(in)  :: pSST     ! bulk SST at depth gdept_1d(1) [K] 
    137       ! 
    138       REAL(wp), DIMENSION(jpi,jpj), INTENT(inout) :: pdT    ! dT due to warm-layer effect => difference between "almost surface (right below viscous layer) and depth of bulk SST 
    139       ! 
    140       INTEGER :: ji,jj 
     134      !! 
     135      REAL(wp), DIMENSION(jpi,jpj), OPTIONAL, INTENT(in) :: pustk ! surface Stokes velocity [m/s] 
     136      ! 
     137      INTEGER :: ji, jj, jc 
    141138      ! 
    142139      REAL(wp) :: & 
    143          & zdz,    & !: thickness of the warm-layer [m] 
    144          & zalpha_w, & !: thermal expansion coefficient of sea-water 
    145          & ZSRD,   & 
    146          & dT_wl,   & ! temp. diff. between "almost surface (right below viscous layer) and bottom of WL 
    147          & zfr,zdL,zdL2, ztmp, & 
    148          & ZPHI, & 
    149          & zus_a, zusw, zusw2, & 
    150          & flg, zQabs, ZL1, ZL2 
    151       !!--------------------------------------------------------------------- 
     140         & zHwl,    &  !: thickness of the warm-layer [m] 
     141         & ztcorr,  &  !: correction of dT w.r.t measurement depth of bulk SST (first T-point) 
     142         & zalpha, & !: thermal expansion coefficient of sea-water [1/K] 
     143         & zdTwl_b, zdTwl_n, & ! temp. diff. between "almost surface (right below viscous layer) and bottom of WL 
     144         & zfr, zeta, ztmp, & 
     145      &