NUOPC Cap: Difference between revisions
| No edit summary   (change visibility)  | No edit summary   (change visibility)  | ||
| Line 20: | Line 20: | ||
| * Import and export fields mesh data. <div class="box">      <span class="darkTurquoise">TYPE</span> :: <span class="forestGreen">ESM_Mesh</span><br /><br />        <span class="darkTurquoise">integer</span> :: <span class="red">gid</span>                           <span class="twilightBlue">! grid ID</span><br />        <span class="darkTurquoise">integer</span> :: <span class="red">gtype</span>                         <span class="twilightBlue">! grid mesh type</span><br /><br />        <span class="darkTurquoise">integer</span> (<span class="red">i4b</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">mask(:,:)</span>  <span class="twilightBlue">! grid land/sea mask</span><br /><br />        <span class="darkTurquoise">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">lon(:,:)</span>       <span class="twilightBlue">! grid longitude</span><br />        <span class="red">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">lat(:,:)</span>       <span class="twilightBlue">! grid latitude</span><br />        <span class="darkTurquoise">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">area(:,:)</span>      <span class="twilightBlue">! grid area</span><br /><br />      <span class="darkTurquoise">END TYPE</span> <span class="forestGreen">ESM_Mesh</span></div> | * Import and export fields mesh data. <div class="box">      <span class="darkTurquoise">TYPE</span> :: <span class="forestGreen">ESM_Mesh</span><br /><br />        <span class="darkTurquoise">integer</span> :: <span class="red">gid</span>                           <span class="twilightBlue">! grid ID</span><br />        <span class="darkTurquoise">integer</span> :: <span class="red">gtype</span>                         <span class="twilightBlue">! grid mesh type</span><br /><br />        <span class="darkTurquoise">integer</span> (<span class="red">i4b</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">mask(:,:)</span>  <span class="twilightBlue">! grid land/sea mask</span><br /><br />        <span class="darkTurquoise">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">lon(:,:)</span>       <span class="twilightBlue">! grid longitude</span><br />        <span class="red">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">lat(:,:)</span>       <span class="twilightBlue">! grid latitude</span><br />        <span class="darkTurquoise">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">area(:,:)</span>      <span class="twilightBlue">! grid area</span><br /><br />      <span class="darkTurquoise">END TYPE</span> <span class="forestGreen">ESM_Mesh</span></div> | ||
| * Coupled models high-level object, [<span class="red">Nmodels=1</span>]. <div class="box">      <span class="darkTurquoise">TYPE | * Coupled models high-level object, [<span class="red">Nmodels=1</span>]. <div class="box">      <span class="darkTurquoise">TYPE</span> :: <span class="forestGreen">ESM_Model</span><br /><br />        <span class="darkTurquoise">logical</span> :: <span class="red">IsActive</span>                       <span class="twilightBlue">! active for coupling</span><br /><br />        <span class="darkTurquoise">integer</span> (<span class="red">i4b</span>) :: <span class="red">LandValue</span>                <span class="twilightBlue">! land mask value</span><br />        <span class="darkTurquoise">integer</span> (<span class="red">i4b</span>) :: <span class="red">SeaValue</span>                 <span class="twilightBlue">! sea  mask value</span><br /><br />        <span class="darkTurquoise">integer</span> :: <span class="red">Ngrids</span>                         <span class="twilightBlue">! number nested grids</span><br /><br />        <span class="darkTurquoise">integer</span> :: <span class="red">ExportCalls</span>                    <span class="twilightBlue">! export CALL counter</span><br />        <span class="darkTurquoise">integer</span> :: <span class="red">ImportCalls</span>                    <span class="twilightBlue">! import CALL counter</span><br /><br />        <span class="darkTurquoise">integer</span> :: <span class="red">nPETs</span>                          <span class="twilightBlue">! number model PETs</span><br />        <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">allocatable</span> :: <span class="red">PETlist(:)</span>        <span class="twilightBlue">! component PETs list</span><br /><br />        <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">allocatable</span> :: <span class="red">TimeFrac(:,:)</span>     <span class="twilightBlue">! driver time fraction</span><br /><br />        <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=:), <span class="darkTurquoise">allocatable</span> :: <span class="red">name</span>    <span class="twilightBlue">! component name</span><br /><br />        <span class="darkTurquoise">TYPE</span> (<span class="forestGreen">ESMF_Grid</span>),  <span class="darkTurquoise">allocatable</span> :: <span class="red">grid(:)</span>        <span class="twilightBlue">! grid object</span><br />        <span class="darkTurquoise">TYPE</span> (<span class="forestGreen">ESM_Mesh</span>),   <span class="darkTurquoise">allocatable</span> :: <span class="red">mesh(:)</span>        <span class="twilightBlue">! mesh</span><br />        <span class="darkTurquoise">TYPE</span> (<span class="forestGreen">ESM_Field</span>),  <span class="darkTurquoise">allocatable</span> :: <span class="red">ImportField(:)</span> <span class="twilightBlue">! import fields</span><br />        <span class="darkTurquoise">TYPE</span> (<span class="forestGreen">ESM_Field</span>),  <span class="darkTurquoise">allocatable</span> :: <span class="red">ExportField(:)</span> <span class="twilightBlue">! export fields</span><br />        <span class="darkTurquoise">TYPE</span> (<span class="forestGreen">ESMF_State</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">ImportState(:)</span> <span class="twilightBlue">! import state</span><br />        <span class="darkTurquoise">TYPE</span> (<span class="forestGreen">ESMF_State</span>), <span class="darkTurquoise">allocatable</span> :: <span class="red">ExportState(:)</span> <span class="twilightBlue">! export state</span><br /><br />      <span class="darkTurquoise">END TYPE</span> <span class="forestGreen">ESM_Model</span><br /><br />      <span class="darkTurquoise">TYPE</span> (<span class="forestGreen">ESM_Model</span>), <span class="darkTurquoise">allocatable</span>, <span class="darkTurquoise">target</span> :: <span class="red">MODELS(:)</span></div> | ||
| *  '''Internal module parameters and variables:'''<br />   | *  '''Internal module parameters and variables:'''<br />   | ||
| **  Switch to trace/track run sequence during debugging.  All information is written to Fortran unit trac. For now, it uses the standard output unit. <div class="box">      <span class="darkTurquoise">logical</span> :: <span class="red">ESM_track</span> = <span class="red">.TRUE.</span>  <span class="twilightBlue">! trace/track CALL sequence switch</span></div> | **  Switch to trace/track run sequence during debugging.  All information is written to Fortran unit trac. For now, it uses the standard output unit. <div class="box">      <span class="darkTurquoise">logical</span> :: <span class="red">ESM_track</span> = <span class="red">.TRUE.</span>  <span class="twilightBlue">! trace/track CALL sequence switch</span></div> | ||
| ** Number of coupled '''ESM''' gridded components and  | ** Number of coupled '''ESM''' gridded components. Currently, five ESM components are supported (ROMS, DATA, Atmosphere, Sea-ice, and wave model). <div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Nmodels</span> = <span class="red">5</span></div | ||
| ** Number of nested grids.  All are initialized to just one grid; its values are overwritten during processing. An additional variable NgridsR is created to avoid using ROMS module "mod_param" in the generic interface.  Both Ngrids and NgridsR will have the same value.<div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">NgridsA</span> = <span class="red">1</span>                  <span class="twilightBlue">! Atmosphere Model</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">NgridsD</span> = <span class="red">1</span>                  <span class="twilightBlue">! DATA Model</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">NgridsI</span> = <span class="red">1</span>                  <span class="twilightBlue">! Sea-ice Model</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">NgridsR</span> = <span class="red">1</span>                  <span class="twilightBlue">! ROMS</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">NgridsW</span> = <span class="red">1</span>                  <span class="twilightBlue">! Wave Model</span></div> | |||
| ** Coupled models identification indices.<div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Idriver</span> = <span class="red">0</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Iroms</span>   = <span class="red">1</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Iatmos</span>  = <span class="red">2</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Idata</span>   = <span class="red">3</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Iseaice</span> = <span class="red">4</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Iwave</span>   = <span class="red">5</span></div> | |||
| ** Number of ROMS export and import fields per component. <div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">allocatable</span> :: <span class="red">Nexport(:)</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">allocatable</span> :: <span class="red">Nimport(:)</span></div> | ** Number of ROMS export and import fields per component. <div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">allocatable</span> :: <span class="red">Nexport(:)</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">allocatable</span> :: <span class="red">Nimport(:)</span></div> | ||
| ** Model coupling type: [<span class="red">1</span>] Explicit, [<span class="red">otherwise</span>] Semi-Implicit. In <span class="red">explicit coupling</span>, exchange fields at the next time-step are defined using known values from the time-step before it. Explicit methods require less computational effort and are accurate for small coupling time-steps. In <span class="red">implicit coupling</span>, exchange fields at the next time-step are defined by including values at the next time-step. Implicit methods are stable and allow longer coupling time-steps but are more computationally expensive. In <span class="red">semi-implicit coupling</span>, '''ROMS -> ATM''' is explicit, '''ATM -> ROMS''' is implicit. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">CouplingType</span> = <span class="red">1</span></div> | ** Model coupling type: [<span class="red">1</span>] Explicit, [<span class="red">otherwise</span>] Semi-Implicit. In <span class="red">explicit coupling</span>, exchange fields at the next time-step are defined using known values from the time-step before it. Explicit methods require less computational effort and are accurate for small coupling time-steps. In <span class="red">implicit coupling</span>, exchange fields at the next time-step are defined by including values at the next time-step. Implicit methods are stable and allow longer coupling time-steps but are more computationally expensive. In <span class="red">semi-implicit coupling</span>, '''ROMS -> ATM''' is explicit, '''ATM -> ROMS''' is implicit. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">CouplingType</span> = <span class="red">1</span></div> | ||
| ** Linked/coupled ROMS nested grid number. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">linked_grid</span></div> | ** <span class="red">Is there an equivalant to this in the Native???</span>Linked/coupled ROMS nested grid number. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">linked_grid</span></div> | ||
| ** Distributed-memory communicator handle for each component, rank of each PET, and PET layout (sequential or concurrent). <div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">allocatable</span> :: <span class="red">ESMcomm(:)</span><br />      <span class="darkTurquoise">integer</span> :: <span class="red"> | ** Distributed-memory communicator handle for each component, Total number of PETs needed in concurrent PET layout, rank of each PET, and PET layout (sequential or concurrent). <div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">allocatable</span> :: <span class="red">ESMcomm(:)</span><br />      <span class="darkTurquoise">integer</span> :: <span class="red">sumPETs</span><br />      <span class="darkTurquoise">integer</span> :: <span class="red">PETrank</span><br />      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=10) :: <span class="red">PETlayoutOption</span></div> | ||
| ** Coupling debugging flag: [<span class="red">0</span>] no debugging, [<span class="red">1</span>] reports informative messages, or [<span class="red">2</span>] <span class="red">'1'</span> plus writes grid information in '''VTK''' format,  [<span class="red">3</span>] <span class="red">'2'</span> plus writes exchage fields into '''NetCDF''' files. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">DebugLevel</span> = <span class="red">0</span></div> | ** Coupling debugging flag: [<span class="red">0</span>] no debugging, [<span class="red">1</span>] reports informative messages, or [<span class="red">2</span>] <span class="red">'1'</span> plus writes grid information in '''VTK''' format,  [<span class="red">3</span>] <span class="red">'2'</span> plus writes exchage fields into '''NetCDF''' files. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">DebugLevel</span> = <span class="red">0</span></div> | ||
| ** Execution tracing level flag: [<span class="red">0</span>] no tracing, [<span class="red">1</span>] reports sequence of coupling subroutine calls, or [<span class="red">2</span>] <<span class="red">1</span>> plus writes voluminous '''ESMF''' library tracing information which slowdown performace, and creates large log file. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">TraceLevel</span> = <span class="red">0</span></div> | ** Execution tracing level flag: [<span class="red">0</span>] no tracing, [<span class="red">1</span>] reports sequence of coupling subroutine calls, or [<span class="red">2</span>] <<span class="red">1</span>> plus writes voluminous '''ESMF''' library tracing information which slowdown performace, and creates large log file. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">TraceLevel</span> = <span class="red">0</span></div> | ||
| ** Standard output units. <div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">cplout</span>  = <span class="red">77</span>         <span class="twilightBlue">! coupling driver</span><br />      <span class="darkTurquoise">integer</span> :: <span class="red"> | ** Standard output units and log messages filename for coupler and ESMF library.<div class="box">      <span class="darkTurquoise">integer</span> :: <span class="red">cplout</span>  = <span class="red">77</span>         <span class="twilightBlue">! coupling driver</span><br />      <span class="darkTurquoise">integer</span> :: <span class="red">dataout</span> = <span class="red">77</span>         <span class="twilightBlue">! data component</span><br /><br />      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>= 8), <span class="darkTurquoise">parameter</span> :: <span class="red">ESMnameLog</span> = '<span class="red">log.esmf</span>'<br />      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>= 8), <span class="darkTurquoise">parameter</span> :: <span class="red">CouplerLog</span> = '<span class="red">log.coupler</span>'</div> | ||
| ** Coupled model staggered grid-cell type indices. <div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Inan</span>    = <span class="red">0</span>     <span class="twilightBlue">! unstaggered, cell center</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Icenter</span> = <span class="red">1</span>     <span class="twilightBlue">! cell center</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Icorner</span> = <span class="red">2</span>     <span class="twilightBlue">! cell corners</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Iupoint</span> = <span class="red">3</span>     <span class="twilightBlue">! right and left cell faces</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Ivpoint</span> = <span class="red">4</span>     <span class="twilightBlue">! upper and lower cell faces</span><br /><br />      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=6), <span class="darkTurquoise">dimension</span>(0:4) :: <span class="red">GridType</span> =                   &<br />     &                                     (/ '<span class="red">N/A</span>   ',                 &<br />     &                                        '<span class="red">Center</span>',                 &<br />     &                                        '<span class="red">Corner</span>',                 &<br />     &                                        '<span class="red">U</span>     ',                 &<br />     &                                        '<span class="red">V</span>     ' /)</div> | ** Coupled model staggered grid-cell type indices. <div class="box">      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Inan</span>    = <span class="red">0</span>     <span class="twilightBlue">! unstaggered, cell center</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Icenter</span> = <span class="red">1</span>     <span class="twilightBlue">! cell center</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Icorner</span> = <span class="red">2</span>     <span class="twilightBlue">! cell corners</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Iupoint</span> = <span class="red">3</span>     <span class="twilightBlue">! right and left cell faces</span><br />      <span class="darkTurquoise">integer</span>, <span class="darkTurquoise">parameter</span> :: <span class="red">Ivpoint</span> = <span class="red">4</span>     <span class="twilightBlue">! upper and lower cell faces</span><br /><br />      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=6), <span class="darkTurquoise">dimension</span>(0:4) :: <span class="red">GridType</span> =                   &<br />     &                                     (/ '<span class="red">N/A</span>   ',                 &<br />     &                                        '<span class="red">Center</span>',                 &<br />     &                                        '<span class="red">Corner</span>',                 &<br />     &                                        '<span class="red">U</span>     ',                 &<br />     &                                        '<span class="red">V</span>     ' /)</div> | ||
| **  Standard input filename for each coupled model, [<span class="red">Nmodels</span>]. <div class="box">      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=256), <span class="darkTurquoise">allocatable</span> :: <span class="red">INPname(:)</span></div> | **  Standard input filename for each coupled model, [<span class="red">Nmodels</span>]. <div class="box">      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=256), <span class="darkTurquoise">allocatable</span> :: <span class="red">INPname(:)</span></div> | ||
| ** ROMS coupling '''YAML''' configuration filename. <div class="box">      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>= | ** ROMS coupling '''YAML''' configuration filename. <div class="box">      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=256), <span class="darkTurquoise">allocatable</span> :: <span class="red">CPLname</span></div> | ||
| ** '''ESM''' strings. <div class="box">      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=:), <span class="darkTurquoise">allocatable</span> :: <span class="red">CoupledSet</span><br />      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=:), <span class="darkTurquoise">allocatable</span> :: <span class="red">ExportStateName</span><br />      <span class="darkTurquoise">character</span> (len=:), <span class="darkTurquoise">allocatable</span> :: <span class="red">ImportStateName</span></div> | ** <span class="red">Is there an equivalant to this in the Native???</span> '''ESM''' strings. <div class="box">      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=:), <span class="darkTurquoise">allocatable</span> :: <span class="red">CoupledSet</span><br />      <span class="darkTurquoise">character</span> (<span class="darkTurquoise">len</span>=:), <span class="darkTurquoise">allocatable</span> :: <span class="red">ExportStateName</span><br />      <span class="darkTurquoise">character</span> (len=:), <span class="darkTurquoise">allocatable</span> :: <span class="red">ImportStateName</span></div> | ||
| **  '''ESM''' single and double precision constants. <div class="box">      <span class="darkTurquoise">integer</span> (<span class="red">i4b</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">MAPPED_MASK</span> = <span class="red">99_i4b</span><br />      <span class="darkTurquoise">integer</span> (<span class="red">i4b</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">UNMAPPED_MASK</span> = <span class="red">98_i4b</span><br /><br />      <span class="darkTurquoise">real</span> (<span class="red">dp</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">MISSING_dp</span> = <span class="red">1.0E20_dp</span><br />      <span class="darkTurquoise">real</span> (<span class="red">r4</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">MISSING_r4</span> = <span class="red">1.0E20_r4</span><br />      <span class="darkTurquoise">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">MISSING_r8</span> = <span class="red">1.0E20_r8</span><br /><br />      <span class="darkTurquoise">real</span> (<span class="red">dp</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">TOL_dp</span> = <span class="red">0.5E20_dp</span><br />      <span class="darkTurquoise">real</span> (<span class="red">r4</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">TOL_r4</span> = <span class="red">0.5E20_r4</span><br />      <span class="darkTurquoise">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">TOL_r8</span> = <span class="red">0.5E20_r8</span></div> | **  '''ESM''' single and double precision constants. <div class="box">      <span class="darkTurquoise">integer</span> (<span class="red">i4b</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">MAPPED_MASK</span> = <span class="red">99_i4b</span><br />      <span class="darkTurquoise">integer</span> (<span class="red">i4b</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">UNMAPPED_MASK</span> = <span class="red">98_i4b</span><br /><br />      <span class="darkTurquoise">real</span> (<span class="red">dp</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">MISSING_dp</span> = <span class="red">1.0E20_dp</span><br />      <span class="darkTurquoise">real</span> (<span class="red">r4</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">MISSING_r4</span> = <span class="red">1.0E20_r4</span><br />      <span class="darkTurquoise">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">MISSING_r8</span> = <span class="red">1.0E20_r8</span><br /><br />      <span class="darkTurquoise">real</span> (<span class="red">dp</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">TOL_dp</span> = <span class="red">0.5E20_dp</span><br />      <span class="darkTurquoise">real</span> (<span class="red">r4</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">TOL_r4</span> = <span class="red">0.5E20_r4</span><br />      <span class="darkTurquoise">real</span> (<span class="red">r8</span>), <span class="darkTurquoise">parameter</span> :: <span class="red">TOL_r8</span> = <span class="red">0.5E20_r8</span></div> | ||
Revision as of 16:11, 29 April 2022
Overview
This document describes the ROMS ESMF/NUOPC cap, which is a lightweight software layer that is required when the ROMS ocean model is used in National Unified Operation Prediction Capability (NUOPC) coupled systems. Detailed information about ESMF/NUOPC and how it is implemented in ROMS can be found on the Earth System Modeling Framework WikiROMS page.
A NUOPC cap is a Fortran module that serves as the interface to a model when it's used in a NUOPC-based coupled system. The term cap is used because it is a lightweight software layer that sits on top of model code, making calls to it and exposing model data structures in a standard way.
Implementation
The mod_esmf_esm.F module declares several derived-type structures to facilitate the management of all internal objects and variables:
- ESM coupling time managing variables and ESMF objects. TYPE :: ESM_Clock
 logical :: Restarted
 integer (i8b) :: AdvanceCount ! advance counter
 real (dp) :: Current_Time ! seconds
 real (dp) :: Time_Reference ! seconds
 real (dp) :: Time_Restart ! seconds
 real (dp) :: Time_Start ! seconds
 real (dp) :: Time_Stop ! seconds
 real (dp) :: Time_Step ! seconds
 character (len=22) :: Name
 character (len=22) :: CalendarString ! 360_day, gregorian
 character (len=22) :: Time_ReferenceString
 character (len=22) :: Time_RestartString
 character (len=22) :: Time_StartString
 character (len=22) :: Time_StopString
 TYPE (ESMF_Calendar) :: Calendar
 TYPE (ESMF_Clock) :: Clock
 TYPE (ESMF_Direction_flag) :: Direction
 TYPE (ESMF_Time) :: CurrentTime
 TYPE (ESMF_Time) :: ReferenceTime
 TYPE (ESMF_Time) :: RestartTime
 TYPE (ESMF_Time) :: StartTime
 TYPE (ESMF_Time) :: StopTime
 TYPE (ESMF_TimeInterval) :: TimeStep
 END TYPE ESM_Clock
 . . .
 TYPE (ESM_Clock), allocatable, target :: ClockInfo(:)
- ESM coupled state sets. If appropriate, it includes the logic for connecting nested grids. TYPE :: ESM_CplSet
 logical, allocatable :: LinkedGrid(:,:) ! connected grid
 logical, allocatable :: DataCoupledSets(:,:) ! DATA linked sets
 character (len=100), allocatable :: SetLabel(:) ! set label
 character (len=100), allocatable :: ExpLabel(:) ! export label
 character (len=100), allocatable :: ImpLabel(:) ! import label
 END TYPE ESM_CplSet
 TYPE (ESM_CplSet), allocatable, target :: COUPLED(:)
- Import and export fields metadata information. TYPE :: ESM_Field
 logical :: connected ! connected to coupler
 logical :: debug_write ! write exchanged field
 logical :: enable_integral_adj ! area integral adjusted
 integer :: fid ! internal field ID
 integer :: gtype ! field grid mesh type
 integer :: etype ! field extrapolation flag
 integer :: itype ! field interpolation flag
 integer :: Tindex ! rolling two-time indices
 character (len=20) :: Ctarget ! component destination
 character (len=22) :: DateString(2) ! date-snapshots string
 character (len=:), allocatable :: short_name ! short name
 character (len=:), allocatable :: standard_name ! standard name
 character (len=:), allocatable :: long_name ! long name
 character (len=:), allocatable :: dst_gtype ! DST grid type
 character (len=:), allocatable :: dst_units ! DST units
 character (len=:), allocatable :: src_gtype ! SRC grid type
 character (len=:), allocatable :: src_units ! SRC units
 character (len=:), allocatable :: nc_vname ! DATA Vname
 character (len=:), allocatable :: nc_tname ! DATA Tname
 character (len=:), allocatable :: RegridMethod ! regrid method
 character (len=:), allocatable :: ExtrapMethod ! extrapolate
 real (dp) :: scale_factor ! field scale factor
 real (dp) :: add_offset ! field add offset value
 real (dp) :: Tmin ! DATA time minimum value
 real (dp) :: Tmax ! DATA time maximum value
 real (dp) :: Tstr ! DATA lower time-snapshot
 real (dp) :: Tend ! DATA upper time-snapshot
 real (dp) :: Tintrp(2) ! interpolation time (day)
 real (dp) :: Vtime(2) ! latest two-time values
 TYPE (ESMF_RouteHandle) :: rhandle ! field RouteHandle
 END TYPE ESM_Field
- Import and export fields mesh data. TYPE :: ESM_Mesh
 integer :: gid ! grid ID
 integer :: gtype ! grid mesh type
 integer (i4b), allocatable :: mask(:,:) ! grid land/sea mask
 real (r8), allocatable :: lon(:,:) ! grid longitude
 real (r8), allocatable :: lat(:,:) ! grid latitude
 real (r8), allocatable :: area(:,:) ! grid area
 END TYPE ESM_Mesh
- Coupled models high-level object, [Nmodels=1]. TYPE :: ESM_Model
 logical :: IsActive ! active for coupling
 integer (i4b) :: LandValue ! land mask value
 integer (i4b) :: SeaValue ! sea mask value
 integer :: Ngrids ! number nested grids
 integer :: ExportCalls ! export CALL counter
 integer :: ImportCalls ! import CALL counter
 integer :: nPETs ! number model PETs
 integer, allocatable :: PETlist(:) ! component PETs list
 integer, allocatable :: TimeFrac(:,:) ! driver time fraction
 character (len=:), allocatable :: name ! component name
 TYPE (ESMF_Grid), allocatable :: grid(:) ! grid object
 TYPE (ESM_Mesh), allocatable :: mesh(:) ! mesh
 TYPE (ESM_Field), allocatable :: ImportField(:) ! import fields
 TYPE (ESM_Field), allocatable :: ExportField(:) ! export fields
 TYPE (ESMF_State), allocatable :: ImportState(:) ! import state
 TYPE (ESMF_State), allocatable :: ExportState(:) ! export state
 END TYPE ESM_Model
 TYPE (ESM_Model), allocatable, target :: MODELS(:)
- Internal module parameters and variables:
 - Switch to trace/track run sequence during debugging.  All information is written to Fortran unit trac. For now, it uses the standard output unit. logical :: ESM_track = .TRUE. ! trace/track CALL sequence switch
- Number of coupled ESM gridded components. Currently, five ESM components are supported (ROMS, DATA, Atmosphere, Sea-ice, and wave model). integer, parameter :: Nmodels = 5</div
- Number of nested grids.  All are initialized to just one grid; its values are overwritten during processing. An additional variable NgridsR is created to avoid using ROMS module "mod_param" in the generic interface.  Both Ngrids and NgridsR will have the same value.integer, parameter :: NgridsA = 1 ! Atmosphere Model
 integer, parameter :: NgridsD = 1 ! DATA Model
 integer, parameter :: NgridsI = 1 ! Sea-ice Model
 integer, parameter :: NgridsR = 1 ! ROMS
 integer, parameter :: NgridsW = 1 ! Wave Model
- Coupled models identification indices.integer, parameter :: Idriver = 0
 integer, parameter :: Iroms = 1
 integer, parameter :: Iatmos = 2
 integer, parameter :: Idata = 3
 integer, parameter :: Iseaice = 4
 integer, parameter :: Iwave = 5
- Number of ROMS export and import fields per component. integer, allocatable :: Nexport(:)
 integer, allocatable :: Nimport(:)
- Model coupling type: [1] Explicit, [otherwise] Semi-Implicit. In explicit coupling, exchange fields at the next time-step are defined using known values from the time-step before it. Explicit methods require less computational effort and are accurate for small coupling time-steps. In implicit coupling, exchange fields at the next time-step are defined by including values at the next time-step. Implicit methods are stable and allow longer coupling time-steps but are more computationally expensive. In semi-implicit coupling, ROMS -> ATM is explicit, ATM -> ROMS is implicit. integer :: CouplingType = 1
- Is there an equivalant to this in the Native???Linked/coupled ROMS nested grid number. integer :: linked_grid
- Distributed-memory communicator handle for each component, Total number of PETs needed in concurrent PET layout, rank of each PET, and PET layout (sequential or concurrent). integer, allocatable :: ESMcomm(:)
 integer :: sumPETs
 integer :: PETrank
 character (len=10) :: PETlayoutOption
- Coupling debugging flag: [0] no debugging, [1] reports informative messages, or [2] '1' plus writes grid information in VTK format,  [3] '2' plus writes exchage fields into NetCDF files. integer :: DebugLevel = 0
- Execution tracing level flag: [0] no tracing, [1] reports sequence of coupling subroutine calls, or [2] <1> plus writes voluminous ESMF library tracing information which slowdown performace, and creates large log file. integer :: TraceLevel = 0
- Standard output units and log messages filename for coupler and ESMF library.integer :: cplout = 77 ! coupling driver
 integer :: dataout = 77 ! data component
 character (len= 8), parameter :: ESMnameLog = 'log.esmf'
 character (len= 8), parameter :: CouplerLog = 'log.coupler'
- Coupled model staggered grid-cell type indices. integer, parameter :: Inan = 0 ! unstaggered, cell center
 integer, parameter :: Icenter = 1 ! cell center
 integer, parameter :: Icorner = 2 ! cell corners
 integer, parameter :: Iupoint = 3 ! right and left cell faces
 integer, parameter :: Ivpoint = 4 ! upper and lower cell faces
 character (len=6), dimension(0:4) :: GridType = &
 & (/ 'N/A ', &
 & 'Center', &
 & 'Corner', &
 & 'U ', &
 & 'V ' /)
- Standard input filename for each coupled model, [Nmodels]. character (len=256), allocatable :: INPname(:)
- ROMS coupling YAML configuration filename. character (len=256), allocatable :: CPLname
- Is there an equivalant to this in the Native??? ESM strings. character (len=:), allocatable :: CoupledSet
 character (len=:), allocatable :: ExportStateName
 character (len=:), allocatable :: ImportStateName
- ESM single and double precision constants. integer (i4b), parameter :: MAPPED_MASK = 99_i4b
 integer (i4b), parameter :: UNMAPPED_MASK = 98_i4b
 real (dp), parameter :: MISSING_dp = 1.0E20_dp
 real (r4), parameter :: MISSING_r4 = 1.0E20_r4
 real (r8), parameter :: MISSING_r8 = 1.0E20_r8
 real (dp), parameter :: TOL_dp = 0.5E20_dp
 real (r4), parameter :: TOL_r4 = 0.5E20_r4
 real (r8), parameter :: TOL_r8 = 0.5E20_r8
 
- Switch to trace/track run sequence during debugging.  All information is written to Fortran unit trac. For now, it uses the standard output unit. 
Capabilities
The ROMS cap module contains a set of subroutines that are required by NUOPC. These subroutines are called by the NUOPC infrastructure according to a predefined calling sequence. Some subroutines are called during initialization of the coupled system, some during the run of the coupled system, and some during finalization of the coupled system.
The initialization sequence is the most complex and is governed by the NUOPC technical rules. Details about the initialization sequence can be found in the NUOPC Reference Manual. The ROMS cap requires ESMF version 8 or higher.
| ROMS_SetServices | Entry point to the ROMS cap and the only public routine. It sets the ROMS component chared-object entry points for using NUOPC generic methods for initialize, run, and finalize. | 
| ROMS_SetInitializeP1 | ROMS component phase 1 initialization which sets import and export fields long and short names into its respective state. | 
| ROMS_SetInitializeP2 | ROMS component phase 2 initialization which initializes the ROMS component (ROMS_initialize), sets component grid (ROMS_SetGridArrays), and adds fields into import and export into respective states. | 
| ROMS_DataInit | Exports ROMS component fields during initialization or restart. | 
| ROMS_SetClock | Sets ROMS component date calendar, start and stop times, and coupling interval. At initialization, the variable tdays is the initial time measured in fractional days since the reference time. | 
| ROMS_SetRunClock | Sets ROMS run clock manually to avoid getting zero time stamps at the first regridding call. | 
| ROMS_CheckImport | Checks if ROMS component import field is at the correct time. | 
| ROMS_SetGridArrays | Sets ROMS component staggered, horizontal grid arrays, grid area, and land/sea mask if any. | 
| ROMS_SetStates | Adds ROMS component export and import fields into its respective state. | 
| ROMS_ModelAdvance | Advances ROMS component for a coupling interval. It calls ROMS_import and ROMS_export routines. | 
| ROMS_SetFinalize | Finalizes ROMS component execution. | 
| ROMS_Import | Imports fields into ROMS. The fields are loaded into the snapshot storage arrays to allow time interpolation elsewhere. | 
| ROMS_Export | Exports ROMS fields to other gridded components. | 
