source: CPL/oasis3-mct_5.0/doc/doxygen/html/mod__oasis__advance_8_f90_source.html @ 6328

Last change on this file since 6328 was 6328, checked in by aclsce, 17 months ago

First import of oasis3-mct_5.0 (from oasis git server, branch OASIS3-MCT_5.0)

File size: 488.1 KB
Line 
1<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2<html xmlns="http://www.w3.org/1999/xhtml">
3<head>
4<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
5<meta http-equiv="X-UA-Compatible" content="IE=9"/>
6<meta name="generator" content="Doxygen 1.8.13"/>
7<meta name="viewport" content="width=device-width, initial-scale=1"/>
8<title>Oasis3-MCT: /home/globc2/tcraig/oasis3-mct.trunk/lib/psmile/src/mod_oasis_advance.F90 Source File</title>
9<link href="tabs.css" rel="stylesheet" type="text/css"/>
10<script type="text/javascript" src="jquery.js"></script>
11<script type="text/javascript" src="dynsections.js"></script>
12<link href="search/search.css" rel="stylesheet" type="text/css"/>
13<script type="text/javascript" src="search/searchdata.js"></script>
14<script type="text/javascript" src="search/search.js"></script>
15<link href="doxygen.css" rel="stylesheet" type="text/css" />
16</head>
17<body>
18<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
19<div id="titlearea">
20<table cellspacing="0" cellpadding="0">
21 <tbody>
22 <tr style="height: 56px;">
23  <td id="projectalign" style="padding-left: 0.5em;">
24   <div id="projectname">Oasis3-MCT
25   </div>
26  </td>
27 </tr>
28 </tbody>
29</table>
30</div>
31<!-- end header part -->
32<!-- Generated by Doxygen 1.8.13 -->
33<script type="text/javascript">
34var searchBox = new SearchBox("searchBox", "search",false,'Search');
35</script>
36<script type="text/javascript" src="menudata.js"></script>
37<script type="text/javascript" src="menu.js"></script>
38<script type="text/javascript">
39$(function() {
40  initMenu('',true,false,'search.php','Search');
41  $(document).ready(function() { init_search(); });
42});
43</script>
44<div id="main-nav"></div>
45<!-- window showing the filter options -->
46<div id="MSearchSelectWindow"
47     onmouseover="return searchBox.OnSearchSelectShow()"
48     onmouseout="return searchBox.OnSearchSelectHide()"
49     onkeydown="return searchBox.OnSearchSelectKey(event)">
50</div>
51
52<!-- iframe showing the search results (closed by default) -->
53<div id="MSearchResultsWindow">
54<iframe src="javascript:void(0)" frameborder="0" 
55        name="MSearchResults" id="MSearchResults">
56</iframe>
57</div>
58
59<div id="nav-path" class="navpath">
60  <ul>
61<li class="navelem"><a class="el" href="dir_97aefd0d527b934f1d99a682da8fe6a9.html">lib</a></li><li class="navelem"><a class="el" href="dir_6f83a59929ac69cee82ded507f083b9f.html">psmile</a></li><li class="navelem"><a class="el" href="dir_dcfc5ad42d3b5a64023b870fcbdcd859.html">src</a></li>  </ul>
62</div>
63</div><!-- top -->
64<div class="header">
65  <div class="headertitle">
66<div class="title">mod_oasis_advance.F90</div>  </div>
67</div><!--header-->
68<div class="contents">
69<a href="mod__oasis__advance_8_f90.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;<span class="comment"></span></div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;<span class="comment">!&gt; Advances the OASIS coupling</span></div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;</div><div class="line"><a name="l00004"></a><span class="lineno"><a class="line" href="namespacemod__oasis__advance.html">    4</a></span>&#160;<span class="keyword">MODULE</span> <a class="code" href="namespacemod__oasis__advance.html">mod_oasis_advance</a></div><div class="line"><a name="l00005"></a><span class="lineno">    5</span>&#160;</div><div class="line"><a name="l00006"></a><span class="lineno">    6</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__kinds.html">mod_oasis_kinds</a></div><div class="line"><a name="l00007"></a><span class="lineno">    7</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__data.html">mod_oasis_data</a></div><div class="line"><a name="l00008"></a><span class="lineno">    8</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__parameters.html">mod_oasis_parameters</a></div><div class="line"><a name="l00009"></a><span class="lineno">    9</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__coupler.html">mod_oasis_coupler</a></div><div class="line"><a name="l00010"></a><span class="lineno">   10</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__map.html">mod_oasis_map</a></div><div class="line"><a name="l00011"></a><span class="lineno">   11</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__part.html">mod_oasis_part</a></div><div class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__timer.html">mod_oasis_timer</a></div><div class="line"><a name="l00013"></a><span class="lineno">   13</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__var.html">mod_oasis_var</a></div><div class="line"><a name="l00014"></a><span class="lineno">   14</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__sys.html">mod_oasis_sys</a></div><div class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__io.html">mod_oasis_io</a></div><div class="line"><a name="l00016"></a><span class="lineno">   16</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__mpi.html">mod_oasis_mpi</a></div><div class="line"><a name="l00017"></a><span class="lineno">   17</span>&#160;    <span class="keywordtype">USE </span><a class="code" href="namespacemod__oasis__reprosum.html">mod_oasis_reprosum</a></div><div class="line"><a name="l00018"></a><span class="lineno">   18</span>&#160;    <span class="keywordtype">USE </span>mct_mod</div><div class="line"><a name="l00019"></a><span class="lineno">   19</span>&#160;</div><div class="line"><a name="l00020"></a><span class="lineno">   20</span>&#160;    <span class="keywordtype">IMPLICIT NONE</span></div><div class="line"><a name="l00021"></a><span class="lineno">   21</span>&#160;</div><div class="line"><a name="l00022"></a><span class="lineno">   22</span>&#160;    <span class="keywordtype">private</span></div><div class="line"><a name="l00023"></a><span class="lineno">   23</span>&#160;</div><div class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;    <span class="keywordtype">public</span> <a class="code" href="namespacemod__oasis__advance.html#a480bfe5b333300c1084af8f9c239a81d">oasis_advance_init</a></div><div class="line"><a name="l00025"></a><span class="lineno">   25</span>&#160;    <span class="keywordtype">public</span> <a class="code" href="namespacemod__oasis__advance.html#a932b0cbe5d1f5fa27c283c6472be7baf">oasis_advance_run</a></div><div class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;</div><div class="line"><a name="l00027"></a><span class="lineno">   27</span>&#160;    <span class="comment">! local private</span></div><div class="line"><a name="l00028"></a><span class="lineno">   28</span>&#160;</div><div class="line"><a name="l00029"></a><span class="lineno"><a class="line" href="namespacemod__oasis__advance.html#ac617024af9299c27eaeb9156f647b028">   29</a></span>&#160;    <span class="keywordtype">logical</span>, <span class="keywordtype">parameter</span>    :: <a class="code" href="namespacemod__oasis__advance.html#ac617024af9299c27eaeb9156f647b028">map_barrier</a> = .false.</div><div class="line"><a name="l00030"></a><span class="lineno"><a class="line" href="namespacemod__oasis__advance.html#aad8e5c2e16b0270a7da0800a14ae1e07">   30</a></span>&#160;    <span class="keywordtype">logical</span>, <span class="keywordtype">parameter</span>    :: <a class="code" href="namespacemod__oasis__advance.html#aad8e5c2e16b0270a7da0800a14ae1e07">detailed_map_timing</a> = .false.</div><div class="line"><a name="l00031"></a><span class="lineno">   31</span>&#160;</div><div class="line"><a name="l00032"></a><span class="lineno">   32</span>&#160;<span class="keyword">contains</span></div><div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;</div><div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;<span class="comment">!---------------------------------------------------------------------</span></div><div class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span class="comment"></span></div><div class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;<span class="comment">!&gt; Initializes the OASIS fields</span></div><div class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;</div><div class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;<span class="keyword">  SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#a480bfe5b333300c1084af8f9c239a81d">oasis_advance_init</a>(kinfo)</div><div class="line"><a name="l00039"></a><span class="lineno"><a class="line" href="namespacemod__oasis__advance.html#a480bfe5b333300c1084af8f9c239a81d">   39</a></span>&#160;</div><div class="line"><a name="l00040"></a><span class="lineno">   40</span>&#160;<span class="comment">!   ----------------------------------------------------------------</span></div><div class="line"><a name="l00041"></a><span class="lineno">   41</span>&#160;<span class="comment">!   This routine handles initial restart and communication</span></div><div class="line"><a name="l00042"></a><span class="lineno">   42</span>&#160;<span class="comment">!   of data for fields with positive lags</span></div><div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;<span class="comment">!   ----------------------------------------------------------------</span></div><div class="line"><a name="l00044"></a><span class="lineno">   44</span>&#160;</div><div class="line"><a name="l00045"></a><span class="lineno">   45</span>&#160;    <span class="keywordtype">IMPLICIT none</span></div><div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;<span class="comment">!   ----------------------------------------------------------------</span></div><div class="line"><a name="l00047"></a><span class="lineno">   47</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span>, <span class="keywordtype">intent(inout)</span> :: kinfo<span class="comment">    !&lt; status, not used</span></div><div class="line"><a name="l00048"></a><span class="lineno">   48</span>&#160;<span class="comment">!   ----------------------------------------------------------------</span></div><div class="line"><a name="l00049"></a><span class="lineno">   49</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: cplid,partid,varid,mapid</div><div class="line"><a name="l00050"></a><span class="lineno">   50</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span> :: nf,lsize,nflds,npc</div><div class="line"><a name="l00051"></a><span class="lineno">   51</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: dt,ltime,lag,getput</div><div class="line"><a name="l00052"></a><span class="lineno">   52</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: msec</div><div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;    <span class="keywordtype">real   (kind=ip_r8_p)</span>, <span class="keywordtype">allocatable</span> :: array(:)  <span class="comment">! data</span></div><div class="line"><a name="l00054"></a><span class="lineno">   54</span>&#160;    <span class="keywordtype">real   (kind=ip_r8_p)</span>, <span class="keywordtype">allocatable</span> :: array2(:) <span class="comment">! data</span></div><div class="line"><a name="l00055"></a><span class="lineno">   55</span>&#160;    <span class="keywordtype">real   (kind=ip_r8_p)</span>, <span class="keywordtype">allocatable</span> :: array3(:) <span class="comment">! data</span></div><div class="line"><a name="l00056"></a><span class="lineno">   56</span>&#160;    <span class="keywordtype">real   (kind=ip_r8_p)</span>, <span class="keywordtype">allocatable</span> :: array4(:) <span class="comment">! data</span></div><div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;    <span class="keywordtype">real   (kind=ip_r8_p)</span>, <span class="keywordtype">allocatable</span> :: array5(:) <span class="comment">! data</span></div><div class="line"><a name="l00058"></a><span class="lineno">   58</span>&#160;    <span class="keywordtype">logical</span>               :: a2on,a3on,a4on,a5on    <span class="comment">! data 2-5 logicals</span></div><div class="line"><a name="l00059"></a><span class="lineno">   59</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: mseclag   <span class="comment">! model time + lag</span></div><div class="line"><a name="l00060"></a><span class="lineno">   60</span>&#160;    <span class="keywordtype">character(len=ic_xl)</span>  :: rstfile   <span class="comment">! restart filename</span></div><div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;    <span class="keywordtype">character(len=ic_xxl)</span> :: lstring   <span class="comment">! long temporary string</span></div><div class="line"><a name="l00062"></a><span class="lineno">   62</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: llstring  <span class="comment">! len of lstring</span></div><div class="line"><a name="l00063"></a><span class="lineno">   63</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: vstring   <span class="comment">! temporary string</span></div><div class="line"><a name="l00064"></a><span class="lineno">   64</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: lvarnum   <span class="comment">! local variable bundle number</span></div><div class="line"><a name="l00065"></a><span class="lineno">   65</span>&#160;    <span class="keywordtype">type</span>(mct_string)      :: mstring   <span class="comment">! mct char type</span></div><div class="line"><a name="l00066"></a><span class="lineno">   66</span>&#160;    <span class="keywordtype">character(len=64)</span>     :: vname     <span class="comment">! string converted to char</span></div><div class="line"><a name="l00067"></a><span class="lineno">   67</span>&#160;    <span class="keywordtype">type</span>(<a class="code" href="structmod__oasis__coupler_1_1prism__coupler__type.html">prism_coupler_type</a>),<span class="keywordtype">pointer</span> :: pcpointer</div><div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;    <span class="keywordtype">character(len=*)</span>,<span class="keywordtype">parameter</span> :: subname = <span class="stringliteral">&#39;(oasis_advance_init)&#39;</span></div><div class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;    <span class="keywordtype">logical</span>, <span class="keywordtype">parameter</span> :: local_timers_on = .false.</div><div class="line"><a name="l00070"></a><span class="lineno">   70</span>&#160;</div><div class="line"><a name="l00071"></a><span class="lineno">   71</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ab963e928a34a1521ec2c1921cc956cc5">oasis_debug_enter</a>(subname)</div><div class="line"><a name="l00072"></a><span class="lineno">   72</span>&#160;</div><div class="line"><a name="l00073"></a><span class="lineno">   73</span>&#160;    <span class="comment">!----------------------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00074"></a><span class="lineno">   74</span>&#160;<span class="comment">    !&gt; oasis_advance_init does the following</span></div><div class="line"><a name="l00075"></a><span class="lineno">   75</span>&#160;<span class="comment">    !&gt; * Aborts if it&#39;s called from non-active tasks</span></div><div class="line"><a name="l00076"></a><span class="lineno">   76</span>&#160;    <span class="comment">!----------------------------------------------------------------</span></div><div class="line"><a name="l00077"></a><span class="lineno">   77</span>&#160;</div><div class="line"><a name="l00078"></a><span class="lineno">   78</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#acd8801d4fab87a19c6f4f69a661d56c5">mpi_comm_local</a> == mpi_comm_null) <span class="keywordflow">then</span></div><div class="line"><a name="l00079"></a><span class="lineno">   79</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;called on non coupling task&#39;</span></div><div class="line"><a name="l00080"></a><span class="lineno">   80</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00081"></a><span class="lineno">   81</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00082"></a><span class="lineno">   82</span>&#160;</div><div class="line"><a name="l00083"></a><span class="lineno">   83</span>&#160;    kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a3ea125963822918ce37fd3cfd9658c9f">oasis_ok</a></div><div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;</div><div class="line"><a name="l00085"></a><span class="lineno">   85</span>&#160;    <span class="keywordflow">IF</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a> (<span class="stringliteral">&#39;advance_init&#39;</span>)</div><div class="line"><a name="l00086"></a><span class="lineno">   86</span>&#160;</div><div class="line"><a name="l00087"></a><span class="lineno">   87</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l00088"></a><span class="lineno">   88</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) <span class="stringliteral">&#39;   subname         at         time    time+lag   act: field &#39;</span></div><div class="line"><a name="l00089"></a><span class="lineno">   89</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) <span class="stringliteral">&#39;   diags :     fldname    min      max      sum &#39;</span></div><div class="line"><a name="l00090"></a><span class="lineno">   90</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00091"></a><span class="lineno">   91</span>&#160;</div><div class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;    <span class="comment">!----------------------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;<span class="comment">    !&gt; * Loop over all coupler connections, </span></div><div class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;<span class="comment">    !&gt;   Loop over get and put connections,</span></div><div class="line"><a name="l00095"></a><span class="lineno">   95</span>&#160;<span class="comment">    !&gt;   For valid connections</span></div><div class="line"><a name="l00096"></a><span class="lineno">   96</span>&#160;    <span class="comment">!----------------------------------------------------------------</span></div><div class="line"><a name="l00097"></a><span class="lineno">   97</span>&#160;</div><div class="line"><a name="l00098"></a><span class="lineno">   98</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; loop over cplid&#39;</span>)</div><div class="line"><a name="l00099"></a><span class="lineno">   99</span>&#160;    <span class="keywordflow">DO</span> cplid = 1,<a class="code" href="namespacemod__oasis__coupler.html#aaa019c39b0f657e7c37820697ecf354a">prism_mcoupler</a></div><div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;    <span class="keywordflow">DO</span> npc = 1,2</div><div class="line"><a name="l00101"></a><span class="lineno">  101</span>&#160;    <span class="keywordflow">if</span> (npc == 1) pcpointer =&gt; <a class="code" href="namespacemod__oasis__coupler.html#ae59d8823993d9ca8610efd9770393271">prism_coupler_put</a>(cplid)</div><div class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;    <span class="keywordflow">if</span> (npc == 2) pcpointer =&gt; <a class="code" href="namespacemod__oasis__coupler.html#a96df3ef2ec1b53597bb9beca43fe8349">prism_coupler_get</a>(cplid)</div><div class="line"><a name="l00103"></a><span class="lineno">  103</span>&#160;    <span class="keywordflow">if</span> (pcpointer%valid) <span class="keywordflow">then</span></div><div class="line"><a name="l00104"></a><span class="lineno">  104</span>&#160;       dt    = pcpointer%dt</div><div class="line"><a name="l00105"></a><span class="lineno">  105</span>&#160;       lag   = pcpointer%lag</div><div class="line"><a name="l00106"></a><span class="lineno">  106</span>&#160;       ltime = pcpointer%ltime</div><div class="line"><a name="l00107"></a><span class="lineno">  107</span>&#160;       getput= pcpointer%getput</div><div class="line"><a name="l00108"></a><span class="lineno">  108</span>&#160;       rstfile=trim(pcpointer%rstfile)</div><div class="line"><a name="l00109"></a><span class="lineno">  109</span>&#160;       partid= pcpointer%partID</div><div class="line"><a name="l00110"></a><span class="lineno">  110</span>&#160;       mapid   = pcpointer%mapperid</div><div class="line"><a name="l00111"></a><span class="lineno">  111</span>&#160;       msec = 0   <span class="comment">! reasonable default to start with</span></div><div class="line"><a name="l00112"></a><span class="lineno">  112</span>&#160;       mseclag = msec</div><div class="line"><a name="l00113"></a><span class="lineno">  113</span>&#160;</div><div class="line"><a name="l00114"></a><span class="lineno">  114</span>&#160;       <span class="keywordflow">IF</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00115"></a><span class="lineno">  115</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) <span class="stringliteral">&#39;----------------------------------------------------------------&#39;</span></div><div class="line"><a name="l00116"></a><span class="lineno">  116</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; Field cplid :&#39;</span>,cplid</div><div class="line"><a name="l00117"></a><span class="lineno">  117</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; read restart:&#39;</span>,npc,trim(pcpointer%fldlist)</div><div class="line"><a name="l00118"></a><span class="lineno">  118</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; lag prism_mcoupler :&#39;</span>,lag,<a class="code" href="namespacemod__oasis__coupler.html#aaa019c39b0f657e7c37820697ecf354a">prism_mcoupler</a></div><div class="line"><a name="l00119"></a><span class="lineno">  119</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; getput , mapid :&#39;</span>,getput, mapid</div><div class="line"><a name="l00120"></a><span class="lineno">  120</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) <span class="stringliteral">&#39;----------------------------------------------------------------&#39;</span></div><div class="line"><a name="l00121"></a><span class="lineno">  121</span>&#160;           <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;<span class="keywordflow">       ENDIF</span></div><div class="line"><a name="l00123"></a><span class="lineno">  123</span>&#160;</div><div class="line"><a name="l00124"></a><span class="lineno">  124</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00125"></a><span class="lineno">  125</span>&#160;<span class="comment">       !&gt;   * Checks that lag is reasonable</span></div><div class="line"><a name="l00126"></a><span class="lineno">  126</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00127"></a><span class="lineno">  127</span>&#160;</div><div class="line"><a name="l00128"></a><span class="lineno">  128</span>&#160;       <span class="keywordflow">IF</span> (lag &gt; dt .OR. lag &lt;= -dt) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00129"></a><span class="lineno">  129</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;lag out of dt range cplid/dt/lag=&#39;</span>,cplid,dt,lag</div><div class="line"><a name="l00130"></a><span class="lineno">  130</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00131"></a><span class="lineno">  131</span>&#160;<span class="keywordflow">       ENDIF</span></div><div class="line"><a name="l00132"></a><span class="lineno">  132</span>&#160;</div><div class="line"><a name="l00133"></a><span class="lineno">  133</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00134"></a><span class="lineno">  134</span>&#160;<span class="comment">       !&gt;   * For put fields that need to read a restart file because of a lag, </span></div><div class="line"><a name="l00135"></a><span class="lineno">  135</span>&#160;<span class="comment">       !&gt;     call oasis_advance_run and read in the restart file.</span></div><div class="line"><a name="l00136"></a><span class="lineno">  136</span>&#160;<span class="comment">       !&gt;     Set readrest to true in oasis_advance_run to indicate it&#39;s called from init.</span></div><div class="line"><a name="l00137"></a><span class="lineno">  137</span>&#160;       <span class="comment">! right now, do not know whether any hot map terms are there</span></div><div class="line"><a name="l00138"></a><span class="lineno">  138</span>&#160;       <span class="comment">! assume they are if something is read, otherwise not</span></div><div class="line"><a name="l00139"></a><span class="lineno">  139</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;       <span class="keywordflow">IF</span> ( (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a> .AND. lag &gt; 0) ) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;          msec=0-lag</div><div class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;          lsize = mct_avect_lsize(pcpointer%aVect1)</div><div class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;          nflds = mct_avect_nrattr(pcpointer%aVect1)</div><div class="line"><a name="l00144"></a><span class="lineno">  144</span>&#160;</div><div class="line"><a name="l00145"></a><span class="lineno">  145</span>&#160;          <span class="keyword">ALLOCATE</span>(array(lsize))</div><div class="line"><a name="l00146"></a><span class="lineno">  146</span>&#160;          <span class="keyword">ALLOCATE</span>(array2(lsize))</div><div class="line"><a name="l00147"></a><span class="lineno">  147</span>&#160;          <span class="keyword">ALLOCATE</span>(array3(lsize))</div><div class="line"><a name="l00148"></a><span class="lineno">  148</span>&#160;          <span class="keyword">ALLOCATE</span>(array4(lsize))</div><div class="line"><a name="l00149"></a><span class="lineno">  149</span>&#160;          <span class="keyword">ALLOCATE</span>(array5(lsize))</div><div class="line"><a name="l00150"></a><span class="lineno">  150</span>&#160;</div><div class="line"><a name="l00151"></a><span class="lineno">  151</span>&#160;          a2on=.false.          </div><div class="line"><a name="l00152"></a><span class="lineno">  152</span>&#160;          a3on=.false.</div><div class="line"><a name="l00153"></a><span class="lineno">  153</span>&#160;          a4on=.false.</div><div class="line"><a name="l00154"></a><span class="lineno">  154</span>&#160;          a5on=.false.</div><div class="line"><a name="l00155"></a><span class="lineno">  155</span>&#160;</div><div class="line"><a name="l00156"></a><span class="lineno">  156</span>&#160;          <span class="keywordflow">if</span> (mapid &gt; 0) <span class="keywordflow">then</span></div><div class="line"><a name="l00157"></a><span class="lineno">  157</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">prism_mapper</a>(mapid)%nwgts &gt;= 2) a2on=.true.</div><div class="line"><a name="l00158"></a><span class="lineno">  158</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">prism_mapper</a>(mapid)%nwgts &gt;= 3) a3on=.true.</div><div class="line"><a name="l00159"></a><span class="lineno">  159</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">prism_mapper</a>(mapid)%nwgts &gt;= 4) a4on=.true.</div><div class="line"><a name="l00160"></a><span class="lineno">  160</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">prism_mapper</a>(mapid)%nwgts &gt;= 5) a5on=.true.</div><div class="line"><a name="l00161"></a><span class="lineno">  161</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00162"></a><span class="lineno">  162</span>&#160;</div><div class="line"><a name="l00163"></a><span class="lineno">  163</span>&#160;          <span class="keywordflow">DO</span> nf = 1,nflds</div><div class="line"><a name="l00164"></a><span class="lineno">  164</span>&#160;             varid = pcpointer%varid(nf)</div><div class="line"><a name="l00165"></a><span class="lineno">  165</span>&#160;             <span class="keyword">call </span>mct_avect_getrlist(mstring,nf,pcpointer%aVect1)</div><div class="line"><a name="l00166"></a><span class="lineno">  166</span>&#160;             vname = mct_string_tochar(mstring)</div><div class="line"><a name="l00167"></a><span class="lineno">  167</span>&#160;             <span class="keyword">call </span>mct_string_clean(mstring)</div><div class="line"><a name="l00168"></a><span class="lineno">  168</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__coupler.html#ad8c9a74a349ea4420ac38e2da2dc3cd2">oasis_coupler_unbldvarname</a>(varid,vname,lvarnum)</div><div class="line"><a name="l00169"></a><span class="lineno">  169</span>&#160;             <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__advance.html#a932b0cbe5d1f5fa27c283c6472be7baf">oasis_advance_run</a>(<a class="code" href="namespacemod__oasis__parameters.html#a76a150fa8ef6ed0b35183e627d757439">oasis_out</a>,varid,msec,kinfo,nff=nf, &amp;</div><div class="line"><a name="l00170"></a><span class="lineno">  170</span>&#160;                                 namid=cplid,array1din=array,&amp;</div><div class="line"><a name="l00171"></a><span class="lineno">  171</span>&#160;                                 readrest=.true., a2on=a2on,array2=array2, &amp;</div><div class="line"><a name="l00172"></a><span class="lineno">  172</span>&#160;                                 a3on=a3on,array3=array3, &amp;</div><div class="line"><a name="l00173"></a><span class="lineno">  173</span>&#160;                                 a4on=a4on,array4=array4,a5on=a5on,array5=array5, &amp;</div><div class="line"><a name="l00174"></a><span class="lineno">  174</span>&#160;                                 varnum=lvarnum)</div><div class="line"><a name="l00175"></a><span class="lineno">  175</span>&#160;<span class="keywordflow">          ENDDO</span></div><div class="line"><a name="l00176"></a><span class="lineno">  176</span>&#160;          <span class="keywordflow">IF</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00177"></a><span class="lineno">  177</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; advance_run &#39;</span>,cplid,trim(pcpointer%fldlist)</div><div class="line"><a name="l00178"></a><span class="lineno">  178</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;</div><div class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;          <span class="keyword">DEALLOCATE</span>(array)</div><div class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;          <span class="keyword">DEALLOCATE</span>(array2)</div><div class="line"><a name="l00182"></a><span class="lineno">  182</span>&#160;          <span class="keyword">DEALLOCATE</span>(array3)</div><div class="line"><a name="l00183"></a><span class="lineno">  183</span>&#160;          <span class="keyword">DEALLOCATE</span>(array4)</div><div class="line"><a name="l00184"></a><span class="lineno">  184</span>&#160;          <span class="keyword">DEALLOCATE</span>(array5)</div><div class="line"><a name="l00185"></a><span class="lineno">  185</span>&#160;<span class="keywordflow">       ENDIF</span>  <span class="comment">! put</span></div><div class="line"><a name="l00186"></a><span class="lineno">  186</span>&#160;<span class="keywordflow">    ENDIF</span> <span class="comment">! valid</span></div><div class="line"><a name="l00187"></a><span class="lineno">  187</span>&#160;<span class="keywordflow">    enddo</span> <span class="comment">! npc</span></div><div class="line"><a name="l00188"></a><span class="lineno">  188</span>&#160;<span class="keywordflow">    ENDDO</span> <span class="comment">! cplid</span></div><div class="line"><a name="l00189"></a><span class="lineno">  189</span>&#160;</div><div class="line"><a name="l00190"></a><span class="lineno">  190</span>&#160;    <span class="comment">!----------------------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00191"></a><span class="lineno">  191</span>&#160;<span class="comment">    !&gt; * Loop over all coupler connections, </span></div><div class="line"><a name="l00192"></a><span class="lineno">  192</span>&#160;<span class="comment">    !&gt;   Loop over get and put connections,</span></div><div class="line"><a name="l00193"></a><span class="lineno">  193</span>&#160;<span class="comment">    !&gt;   For valid connections</span></div><div class="line"><a name="l00194"></a><span class="lineno">  194</span>&#160;    <span class="comment">!----------------------------------------------------------------</span></div><div class="line"><a name="l00195"></a><span class="lineno">  195</span>&#160;</div><div class="line"><a name="l00196"></a><span class="lineno">  196</span>&#160;    <span class="keywordflow">DO</span> cplid=1, <a class="code" href="namespacemod__oasis__coupler.html#aaa019c39b0f657e7c37820697ecf354a">prism_mcoupler</a></div><div class="line"><a name="l00197"></a><span class="lineno">  197</span>&#160;    <span class="keywordflow">DO</span> npc = 1,2</div><div class="line"><a name="l00198"></a><span class="lineno">  198</span>&#160;    <span class="keywordflow">if</span> (npc == 1) pcpointer =&gt; <a class="code" href="namespacemod__oasis__coupler.html#ae59d8823993d9ca8610efd9770393271">prism_coupler_put</a>(cplid)</div><div class="line"><a name="l00199"></a><span class="lineno">  199</span>&#160;    <span class="keywordflow">if</span> (npc == 2) pcpointer =&gt; <a class="code" href="namespacemod__oasis__coupler.html#a96df3ef2ec1b53597bb9beca43fe8349">prism_coupler_get</a>(cplid)</div><div class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;    <span class="keywordflow">IF</span> (pcpointer%valid) <span class="keywordflow">then</span></div><div class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;       dt    = pcpointer%dt</div><div class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;       lag   = pcpointer%lag</div><div class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;       ltime = pcpointer%ltime</div><div class="line"><a name="l00204"></a><span class="lineno">  204</span>&#160;       getput= pcpointer%getput</div><div class="line"><a name="l00205"></a><span class="lineno">  205</span>&#160;       rstfile=trim(pcpointer%rstfile)</div><div class="line"><a name="l00206"></a><span class="lineno">  206</span>&#160;       partid= pcpointer%partID</div><div class="line"><a name="l00207"></a><span class="lineno">  207</span>&#160;       msec = 0   <span class="comment">! reasonable default to start with</span></div><div class="line"><a name="l00208"></a><span class="lineno">  208</span>&#160;       mseclag = msec</div><div class="line"><a name="l00209"></a><span class="lineno">  209</span>&#160;      </div><div class="line"><a name="l00210"></a><span class="lineno">  210</span>&#160;       <span class="keywordflow">IF</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00211"></a><span class="lineno">  211</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) <span class="stringliteral">&#39;----------------------------------------------------------------&#39;</span></div><div class="line"><a name="l00212"></a><span class="lineno">  212</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; Field cplid :&#39;</span>,cplid</div><div class="line"><a name="l00213"></a><span class="lineno">  213</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; loctrans:&#39;</span>,npc,trim(pcpointer%fldlist)</div><div class="line"><a name="l00214"></a><span class="lineno">  214</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) <span class="stringliteral">&#39;----------------------------------------------------------------&#39;</span></div><div class="line"><a name="l00215"></a><span class="lineno">  215</span>&#160;           <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l00216"></a><span class="lineno">  216</span>&#160;<span class="keywordflow">       ENDIF</span></div><div class="line"><a name="l00217"></a><span class="lineno">  217</span>&#160;</div><div class="line"><a name="l00218"></a><span class="lineno">  218</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00219"></a><span class="lineno">  219</span>&#160;<span class="comment">       !&gt;   * Read restart for LOCTRANS fields.</span></div><div class="line"><a name="l00220"></a><span class="lineno">  220</span>&#160;<span class="comment">       !&gt;     Do after restart and advance above because prism_advance_run</span></div><div class="line"><a name="l00221"></a><span class="lineno">  221</span>&#160;<span class="comment">       !&gt;     fills in the avect with the array info</span></div><div class="line"><a name="l00222"></a><span class="lineno">  222</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00223"></a><span class="lineno">  223</span>&#160;</div><div class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; check for loctrans restart&#39;</span>)</div><div class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;       <span class="keywordflow">IF</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a> .AND. pcpointer%trans /= <a class="code" href="namespacemod__oasis__parameters.html#a1028581caadcb9d7506b25c6cd3efd01">ip_instant</a>) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;          <span class="keywordflow">if</span> (len_trim(rstfile) &lt; 1) <span class="keywordflow">then</span></div><div class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;restart undefined&#39;</span></div><div class="line"><a name="l00228"></a><span class="lineno">  228</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00229"></a><span class="lineno">  229</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00230"></a><span class="lineno">  230</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l00231"></a><span class="lineno">  231</span>&#160;             lstring = pcpointer%fldlist</div><div class="line"><a name="l00232"></a><span class="lineno">  232</span>&#160;             llstring = len_trim(lstring)</div><div class="line"><a name="l00233"></a><span class="lineno">  233</span>&#160;             <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l00234"></a><span class="lineno">  234</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; RTRN: &#39;</span>, &amp;</div><div class="line"><a name="l00235"></a><span class="lineno">  235</span>&#160;                   trim(lstring),<span class="stringliteral">&#39; &#39;</span>,trim(rstfile)</div><div class="line"><a name="l00236"></a><span class="lineno">  236</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l00237"></a><span class="lineno">  237</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; RTRN: &#39;</span>,lstring(1:20), &amp;</div><div class="line"><a name="l00238"></a><span class="lineno">  238</span>&#160;                   lstring(21:llstring),<span class="stringliteral">&#39; &#39;</span>,trim(rstfile)</div><div class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00241"></a><span class="lineno">  241</span>&#160;          lsize = mct_avect_lsize(pcpointer%aVect1)</div><div class="line"><a name="l00242"></a><span class="lineno">  242</span>&#160;</div><div class="line"><a name="l00243"></a><span class="lineno">  243</span>&#160;          <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_cnt&#39;</span></div><div class="line"><a name="l00244"></a><span class="lineno">  244</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#a8b604f89345d74c74c6bc3b4760b2e29">oasis_io_read_array</a>(rstfile,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,iarray=pcpointer%avcnt,&amp;</div><div class="line"><a name="l00245"></a><span class="lineno">  245</span>&#160;                                   ivarname=trim(vstring),abort=.false.)</div><div class="line"><a name="l00246"></a><span class="lineno">  246</span>&#160;</div><div class="line"><a name="l00247"></a><span class="lineno">  247</span>&#160;          <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l00248"></a><span class="lineno">  248</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#a65e17e4a065e8e4dea33754fb9c1d32c">oasis_io_read_avfile</a>(rstfile,pcpointer%avect1,&amp;</div><div class="line"><a name="l00249"></a><span class="lineno">  249</span>&#160;                                    <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, &amp;</div><div class="line"><a name="l00250"></a><span class="lineno">  250</span>&#160;                                    abort=.false.,nampre=trim(vstring))</div><div class="line"><a name="l00251"></a><span class="lineno">  251</span>&#160;</div><div class="line"><a name="l00252"></a><span class="lineno">  252</span>&#160;          <span class="keyword">call </span>mct_avect_init(pcpointer%aVect2,pcpointer%aVect1,lsize)</div><div class="line"><a name="l00253"></a><span class="lineno">  253</span>&#160;          <span class="keyword">call </span>mct_avect_zero(pcpointer%aVect2)</div><div class="line"><a name="l00254"></a><span class="lineno">  254</span>&#160;          <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;av2loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l00255"></a><span class="lineno">  255</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#a65e17e4a065e8e4dea33754fb9c1d32c">oasis_io_read_avfile</a>(rstfile,pcpointer%avect2,&amp;</div><div class="line"><a name="l00256"></a><span class="lineno">  256</span>&#160;                                    <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, &amp;</div><div class="line"><a name="l00257"></a><span class="lineno">  257</span>&#160;                                    abort=.false.,nampre=trim(vstring),&amp;</div><div class="line"><a name="l00258"></a><span class="lineno">  258</span>&#160;                                    didread=pcpointer%aVon(2))</div><div class="line"><a name="l00259"></a><span class="lineno">  259</span>&#160;          <span class="keywordflow">if</span> (.not. pcpointer%aVon(2)) <span class="keywordflow">then</span></div><div class="line"><a name="l00260"></a><span class="lineno">  260</span>&#160;             <span class="keyword">call </span>mct_avect_clean(pcpointer%avect2)</div><div class="line"><a name="l00261"></a><span class="lineno">  261</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00262"></a><span class="lineno">  262</span>&#160;</div><div class="line"><a name="l00263"></a><span class="lineno">  263</span>&#160;          <span class="keyword">call </span>mct_avect_init(pcpointer%aVect3,pcpointer%aVect1,lsize)</div><div class="line"><a name="l00264"></a><span class="lineno">  264</span>&#160;          <span class="keyword">call </span>mct_avect_zero(pcpointer%aVect3)</div><div class="line"><a name="l00265"></a><span class="lineno">  265</span>&#160;          <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;av3loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l00266"></a><span class="lineno">  266</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#a65e17e4a065e8e4dea33754fb9c1d32c">oasis_io_read_avfile</a>(rstfile,pcpointer%avect3,&amp;</div><div class="line"><a name="l00267"></a><span class="lineno">  267</span>&#160;                                    <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, &amp;</div><div class="line"><a name="l00268"></a><span class="lineno">  268</span>&#160;                                    abort=.false.,nampre=trim(vstring),&amp;</div><div class="line"><a name="l00269"></a><span class="lineno">  269</span>&#160;                                    didread=pcpointer%aVon(3))</div><div class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;          <span class="keywordflow">if</span> (.not. pcpointer%aVon(3)) <span class="keywordflow">then</span></div><div class="line"><a name="l00271"></a><span class="lineno">  271</span>&#160;             <span class="keyword">call </span>mct_avect_clean(pcpointer%avect3)</div><div class="line"><a name="l00272"></a><span class="lineno">  272</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00273"></a><span class="lineno">  273</span>&#160;</div><div class="line"><a name="l00274"></a><span class="lineno">  274</span>&#160;          <span class="keyword">call </span>mct_avect_init(pcpointer%aVect4,pcpointer%aVect1,lsize)</div><div class="line"><a name="l00275"></a><span class="lineno">  275</span>&#160;          <span class="keyword">call </span>mct_avect_zero(pcpointer%aVect4)</div><div class="line"><a name="l00276"></a><span class="lineno">  276</span>&#160;          <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;av4loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l00277"></a><span class="lineno">  277</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#a65e17e4a065e8e4dea33754fb9c1d32c">oasis_io_read_avfile</a>(rstfile,pcpointer%avect4,&amp;</div><div class="line"><a name="l00278"></a><span class="lineno">  278</span>&#160;                                    <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, &amp;</div><div class="line"><a name="l00279"></a><span class="lineno">  279</span>&#160;                                    abort=.false.,nampre=trim(vstring),&amp;</div><div class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;                                    didread=pcpointer%aVon(4))</div><div class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;          <span class="keywordflow">if</span> (.not. pcpointer%aVon(4)) <span class="keywordflow">then</span></div><div class="line"><a name="l00282"></a><span class="lineno">  282</span>&#160;             <span class="keyword">call </span>mct_avect_clean(pcpointer%avect4)</div><div class="line"><a name="l00283"></a><span class="lineno">  283</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00284"></a><span class="lineno">  284</span>&#160;</div><div class="line"><a name="l00285"></a><span class="lineno">  285</span>&#160;          <span class="keyword">call </span>mct_avect_init(pcpointer%aVect5,pcpointer%aVect1,lsize)</div><div class="line"><a name="l00286"></a><span class="lineno">  286</span>&#160;          <span class="keyword">call </span>mct_avect_zero(pcpointer%aVect5)</div><div class="line"><a name="l00287"></a><span class="lineno">  287</span>&#160;          <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;av5loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l00288"></a><span class="lineno">  288</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#a65e17e4a065e8e4dea33754fb9c1d32c">oasis_io_read_avfile</a>(rstfile,pcpointer%avect5,&amp;</div><div class="line"><a name="l00289"></a><span class="lineno">  289</span>&#160;                                    <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, &amp;</div><div class="line"><a name="l00290"></a><span class="lineno">  290</span>&#160;                                    abort=.false.,nampre=trim(vstring),&amp;</div><div class="line"><a name="l00291"></a><span class="lineno">  291</span>&#160;                                    didread=pcpointer%aVon(5))</div><div class="line"><a name="l00292"></a><span class="lineno">  292</span>&#160;          <span class="keywordflow">if</span> (.not. pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00293"></a><span class="lineno">  293</span>&#160;             <span class="keyword">call </span>mct_avect_clean(pcpointer%avect5)</div><div class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00295"></a><span class="lineno">  295</span>&#160;</div><div class="line"><a name="l00296"></a><span class="lineno">  296</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l00297"></a><span class="lineno">  297</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG read loctrans restart&#39;</span>,&amp;</div><div class="line"><a name="l00298"></a><span class="lineno">  298</span>&#160;                             cplid,pcpointer%avcnt</div><div class="line"><a name="l00299"></a><span class="lineno">  299</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG read loctrans restart&#39;</span>,cplid,&amp;</div><div class="line"><a name="l00300"></a><span class="lineno">  300</span>&#160;                             minval(pcpointer%avect1%rAttr),&amp;</div><div class="line"><a name="l00301"></a><span class="lineno">  301</span>&#160;                             maxval(pcpointer%avect1%rAttr)</div><div class="line"><a name="l00302"></a><span class="lineno">  302</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00303"></a><span class="lineno">  303</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00304"></a><span class="lineno">  304</span>&#160;<span class="keywordflow">    ENDIF</span>  <span class="comment">! valid</span></div><div class="line"><a name="l00305"></a><span class="lineno">  305</span>&#160;<span class="keywordflow">    enddo</span>  <span class="comment">! npc</span></div><div class="line"><a name="l00306"></a><span class="lineno">  306</span>&#160;<span class="keywordflow">    ENDDO</span>  <span class="comment">! cplid</span></div><div class="line"><a name="l00307"></a><span class="lineno">  307</span>&#160;    <span class="keywordflow">IF</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a> (<span class="stringliteral">&#39;advance_init&#39;</span>)</div><div class="line"><a name="l00308"></a><span class="lineno">  308</span>&#160;</div><div class="line"><a name="l00309"></a><span class="lineno">  309</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a349f71cba2df935179d78f3858992c83">oasis_debug_exit</a>(subname)</div><div class="line"><a name="l00310"></a><span class="lineno">  310</span>&#160;</div><div class="line"><a name="l00311"></a><span class="lineno">  311</span>&#160;<span class="keyword">  end SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#a480bfe5b333300c1084af8f9c239a81d">oasis_advance_init</a></div><div class="line"><a name="l00312"></a><span class="lineno">  312</span>&#160;<span class="comment">!---------------------------------------------------------------------</span></div><div class="line"><a name="l00313"></a><span class="lineno">  313</span>&#160;<span class="comment"></span></div><div class="line"><a name="l00314"></a><span class="lineno">  314</span>&#160;<span class="comment">!&gt; Advances the OASIS coupling</span></div><div class="line"><a name="l00315"></a><span class="lineno">  315</span>&#160;<span class="comment"></span></div><div class="line"><a name="l00316"></a><span class="lineno">  316</span>&#160;<span class="comment">!&gt; Only one from array1din, array1dout, or array2dout can be passed in.</span></div><div class="line"><a name="l00317"></a><span class="lineno">  317</span>&#160;<span class="comment">!&gt; readrest is set to true when called by the oasis_advance_init method.</span></div><div class="line"><a name="l00318"></a><span class="lineno">  318</span>&#160;<span class="comment">!&gt; Arrays 2 to 5 are for the higher order terms (hot)</span></div><div class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;</div><div class="line"><a name="l00320"></a><span class="lineno">  320</span>&#160;<span class="keyword">  SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#a932b0cbe5d1f5fa27c283c6472be7baf">oasis_advance_run</a>(mop,varid,msec,kinfo,nff,namid,&amp;</div><div class="line"><a name="l00321"></a><span class="lineno">  321</span>&#160;             array1din,array1dout,array2dout,readrest,&amp;</div><div class="line"><a name="l00322"></a><span class="lineno">  322</span>&#160;             a2on,array2,a3on,array3,a4on,array4,a5on,array5, &amp;</div><div class="line"><a name="l00323"></a><span class="lineno">  323</span>&#160;             writrest,varnum)</div><div class="line"><a name="l00324"></a><span class="lineno"><a class="line" href="namespacemod__oasis__advance.html#a932b0cbe5d1f5fa27c283c6472be7baf">  324</a></span>&#160;</div><div class="line"><a name="l00325"></a><span class="lineno">  325</span>&#160;    <span class="keywordtype">IMPLICIT none</span></div><div class="line"><a name="l00326"></a><span class="lineno">  326</span>&#160;<span class="comment">!   ----------------------------------------------------------------</span></div><div class="line"><a name="l00327"></a><span class="lineno">  327</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>, <span class="keywordtype">intent(in)</span>    :: mop<span class="comment">      !&lt; OASIS_Out or OASIS_In</span></div><div class="line"><a name="l00328"></a><span class="lineno">  328</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span>, <span class="keywordtype">intent(in)</span>    :: varid<span class="comment">    !&lt; prism_var id</span></div><div class="line"><a name="l00329"></a><span class="lineno">  329</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span>, <span class="keywordtype">intent(in)</span>    :: msec<span class="comment">     !&lt; model time</span></div><div class="line"><a name="l00330"></a><span class="lineno">  330</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span>, <span class="keywordtype">intent(inout)</span> :: kinfo<span class="comment">    !&lt; status</span></div><div class="line"><a name="l00331"></a><span class="lineno">  331</span>&#160;</div><div class="line"><a name="l00332"></a><span class="lineno">  332</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span>, <span class="keywordtype">optional</span> :: nff<span class="comment">           !&lt; specify particular field for restart</span></div><div class="line"><a name="l00333"></a><span class="lineno">  333</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span>, <span class="keywordtype">optional</span> :: namid<span class="comment">         !&lt; only do this namcouple</span></div><div class="line"><a name="l00334"></a><span class="lineno">  334</span>&#160;<span class="comment">                                                     !&lt; method for restart</span></div><div class="line"><a name="l00335"></a><span class="lineno">  335</span>&#160;    <span class="keywordtype">REAL   (kind=ip_r8_p)</span>, <span class="keywordtype">optional</span> :: array1din(:)<span class="comment">  !&lt; 1D put data</span></div><div class="line"><a name="l00336"></a><span class="lineno">  336</span>&#160;    <span class="keywordtype">REAL   (kind=ip_r8_p)</span>, <span class="keywordtype">optional</span> :: array1dout(:)<span class="comment"> !&lt; 1D get data</span></div><div class="line"><a name="l00337"></a><span class="lineno">  337</span>&#160;    <span class="keywordtype">REAL   (kind=ip_r8_p)</span>, <span class="keywordtype">optional</span> :: array2dout(:,:)<span class="comment"> !&lt; 2D get data</span></div><div class="line"><a name="l00338"></a><span class="lineno">  338</span>&#160;    <span class="keywordtype">logical</span>              , <span class="keywordtype">optional</span> :: readrest<span class="comment">      !&lt; special flag to indicate this </span></div><div class="line"><a name="l00339"></a><span class="lineno">  339</span>&#160;<span class="comment">                                                     !&lt; is called from the advance_init</span></div><div class="line"><a name="l00340"></a><span class="lineno">  340</span>&#160;    <span class="keywordtype">logical</span>              , <span class="keywordtype">optional</span> :: a2on<span class="comment">      !&lt; logical for array2</span></div><div class="line"><a name="l00341"></a><span class="lineno">  341</span>&#160;    <span class="keywordtype">REAL   (kind=ip_r8_p)</span>, <span class="keywordtype">optional</span> :: array2(:)<span class="comment"> !&lt; hot put data</span></div><div class="line"><a name="l00342"></a><span class="lineno">  342</span>&#160;    <span class="keywordtype">logical</span>              , <span class="keywordtype">optional</span> :: a3on<span class="comment">      !&lt; logical for array3</span></div><div class="line"><a name="l00343"></a><span class="lineno">  343</span>&#160;    <span class="keywordtype">REAL   (kind=ip_r8_p)</span>, <span class="keywordtype">optional</span> :: array3(:)<span class="comment"> !&lt; hot put data</span></div><div class="line"><a name="l00344"></a><span class="lineno">  344</span>&#160;    <span class="keywordtype">logical</span>              , <span class="keywordtype">optional</span> :: a4on<span class="comment">      !&lt; logical for array4</span></div><div class="line"><a name="l00345"></a><span class="lineno">  345</span>&#160;    <span class="keywordtype">REAL   (kind=ip_r8_p)</span>, <span class="keywordtype">optional</span> :: array4(:)<span class="comment"> !&lt; hot put data</span></div><div class="line"><a name="l00346"></a><span class="lineno">  346</span>&#160;    <span class="keywordtype">logical</span>              , <span class="keywordtype">optional</span> :: a5on<span class="comment">      !&lt; logical for array5</span></div><div class="line"><a name="l00347"></a><span class="lineno">  347</span>&#160;    <span class="keywordtype">REAL   (kind=ip_r8_p)</span>, <span class="keywordtype">optional</span> :: array5(:)<span class="comment"> !&lt; hot put data</span></div><div class="line"><a name="l00348"></a><span class="lineno">  348</span>&#160;    <span class="keywordtype">logical</span>              , <span class="keywordtype">optional</span> :: writrest<span class="comment">  !&lt; flag to write restart now</span></div><div class="line"><a name="l00349"></a><span class="lineno">  349</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span>, <span class="keywordtype">optional</span> :: varnum<span class="comment">    !&lt; variable bundle number</span></div><div class="line"><a name="l00350"></a><span class="lineno">  350</span>&#160;<span class="comment">!   ----------------------------------------------------------------</span></div><div class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;    <span class="keywordtype">character(len=ic_lvar)</span>:: vname</div><div class="line"><a name="l00352"></a><span class="lineno">  352</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span> :: cplid,rouid,mapid,partid</div><div class="line"><a name="l00353"></a><span class="lineno">  353</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span> :: nfav,nsav,nsa,n,nc,nf,npc</div><div class="line"><a name="l00354"></a><span class="lineno">  354</span>&#160;    <span class="keywordtype">INTEGER(kind=ip_i4_p)</span> :: lsize,nflds,ierr</div><div class="line"><a name="l00355"></a><span class="lineno">  355</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: tag,dt,ltime,lag,getput,maxtime,conserv</div><div class="line"><a name="l00356"></a><span class="lineno">  356</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: consopt</div><div class="line"><a name="l00357"></a><span class="lineno">  357</span>&#160;    <span class="keywordtype">logical</span>               :: sndrcv,output,input,unpack</div><div class="line"><a name="l00358"></a><span class="lineno">  358</span>&#160;    <span class="keywordtype">logical</span>               :: snddiag,rcvdiag</div><div class="line"><a name="l00359"></a><span class="lineno">  359</span>&#160;    <span class="keywordtype">logical</span>               :: arrayon(<a class="code" href="namespacemod__oasis__coupler.html#a6f166f099a134dffba97a168d28a3c01">prism_coupler_avsmax</a>)</div><div class="line"><a name="l00360"></a><span class="lineno">  360</span>&#160;    <span class="keywordtype">LOGICAL</span>               :: didread, readabort</div><div class="line"><a name="l00361"></a><span class="lineno">  361</span>&#160;    <span class="keywordtype">real(kind=ip_double_p)</span>:: sndmult,sndadd,rcvmult,rcvadd</div><div class="line"><a name="l00362"></a><span class="lineno">  362</span>&#160;    <span class="keywordtype">character(len=ic_xl)</span>  :: rstfile   <span class="comment">! restart filename</span></div><div class="line"><a name="l00363"></a><span class="lineno">  363</span>&#160;    <span class="keywordtype">character(len=ic_xl)</span>  :: rstfile2  <span class="comment">! restart filename</span></div><div class="line"><a name="l00364"></a><span class="lineno">  364</span>&#160;    <span class="keywordtype">character(len=ic_xl)</span>  :: inpfile   <span class="comment">! input filename</span></div><div class="line"><a name="l00365"></a><span class="lineno">  365</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: nx,ny</div><div class="line"><a name="l00366"></a><span class="lineno">  366</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: mseclag   <span class="comment">! model time + lag</span></div><div class="line"><a name="l00367"></a><span class="lineno">  367</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: lvarnum   <span class="comment">! local variable bundle number</span></div><div class="line"><a name="l00368"></a><span class="lineno">  368</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>    :: rcnt      <span class="comment">! 1./cnt</span></div><div class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: tstring   <span class="comment">! timer label string</span></div><div class="line"><a name="l00370"></a><span class="lineno">  370</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: fstring   <span class="comment">! output file string</span></div><div class="line"><a name="l00371"></a><span class="lineno">  371</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: cstring   <span class="comment">! temporary string</span></div><div class="line"><a name="l00372"></a><span class="lineno">  372</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: vstring   <span class="comment">! temporary string</span></div><div class="line"><a name="l00373"></a><span class="lineno">  373</span>&#160;    <span class="keywordtype">character(len=ic_xxl)</span> :: lstring   <span class="comment">! long temporary string</span></div><div class="line"><a name="l00374"></a><span class="lineno">  374</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: llstring  <span class="comment">! len of lstring</span></div><div class="line"><a name="l00375"></a><span class="lineno">  375</span>&#160;    <span class="keywordtype">logical</span>               :: comm_now  <span class="comment">! time to communicate</span></div><div class="line"><a name="l00376"></a><span class="lineno">  376</span>&#160;    <span class="keywordtype">logical</span>               :: time_now  <span class="comment">! coupling time</span></div><div class="line"><a name="l00377"></a><span class="lineno">  377</span>&#160;    <span class="keywordtype">logical</span>               :: lreadrest <span class="comment">! local readrest</span></div><div class="line"><a name="l00378"></a><span class="lineno">  378</span>&#160;    <span class="keywordtype">logical</span>               :: runit     <span class="comment">! advance the variable</span></div><div class="line"><a name="l00379"></a><span class="lineno">  379</span>&#160;    <span class="keywordtype">TYPE</span>(mct_avect)       :: avtest    <span class="comment">! temporary</span></div><div class="line"><a name="l00380"></a><span class="lineno">  380</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: avtmp   <span class="comment">! data read from restart</span></div><div class="line"><a name="l00381"></a><span class="lineno">  381</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: avtmp2  <span class="comment">! data read from restart</span></div><div class="line"><a name="l00382"></a><span class="lineno">  382</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: avtmp3  <span class="comment">! data read from restart</span></div><div class="line"><a name="l00383"></a><span class="lineno">  383</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: avtmp4  <span class="comment">! data read from restart</span></div><div class="line"><a name="l00384"></a><span class="lineno">  384</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: avtmp5  <span class="comment">! data read from restart</span></div><div class="line"><a name="l00385"></a><span class="lineno">  385</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: avtmpW  <span class="comment">! for writing restart</span></div><div class="line"><a name="l00386"></a><span class="lineno">  386</span>&#160;    <span class="keywordtype">type</span>(<a class="code" href="structmod__oasis__coupler_1_1prism__coupler__type.html">prism_coupler_type</a>),<span class="keywordtype">pointer</span> :: pcpointer</div><div class="line"><a name="l00387"></a><span class="lineno">  387</span>&#160;    <span class="keywordtype">type</span>(<a class="code" href="structmod__oasis__coupler_1_1prism__coupler__type.html">prism_coupler_type</a>),<span class="keywordtype">pointer</span> :: pcpointmp</div><div class="line"><a name="l00388"></a><span class="lineno">  388</span>&#160;    <span class="keywordtype">logical</span>, <span class="keywordtype">parameter</span> :: local_timers_on = .false.</div><div class="line"><a name="l00389"></a><span class="lineno">  389</span>&#160;    <span class="keywordtype">character(len=*)</span>,<span class="keywordtype">parameter</span> :: subname = <span class="stringliteral">&#39;(oasis_advance_run)&#39;</span></div><div class="line"><a name="l00390"></a><span class="lineno">  390</span>&#160;    <span class="keywordtype">character(len=*)</span>,<span class="keywordtype">parameter</span> :: F01 = <span class="stringliteral">&#39;(a,i3.3)&#39;</span></div><div class="line"><a name="l00391"></a><span class="lineno">  391</span>&#160;<span class="comment">!   ----------------------------------------------------------------</span></div><div class="line"><a name="l00392"></a><span class="lineno">  392</span>&#160;</div><div class="line"><a name="l00393"></a><span class="lineno">  393</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ab963e928a34a1521ec2c1921cc956cc5">oasis_debug_enter</a>(subname)</div><div class="line"><a name="l00394"></a><span class="lineno">  394</span>&#160;</div><div class="line"><a name="l00395"></a><span class="lineno">  395</span>&#160;    <span class="comment">!----------------------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00396"></a><span class="lineno">  396</span>&#160;<span class="comment">    !&gt; oasis_advance_run does the following</span></div><div class="line"><a name="l00397"></a><span class="lineno">  397</span>&#160;<span class="comment">    !&gt; * Aborts if it&#39;s called from non-active tasks</span></div><div class="line"><a name="l00398"></a><span class="lineno">  398</span>&#160;    <span class="comment">!----------------------------------------------------------------</span></div><div class="line"><a name="l00399"></a><span class="lineno">  399</span>&#160;</div><div class="line"><a name="l00400"></a><span class="lineno">  400</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#acd8801d4fab87a19c6f4f69a661d56c5">mpi_comm_local</a> == mpi_comm_null) <span class="keywordflow">then</span></div><div class="line"><a name="l00401"></a><span class="lineno">  401</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;called on non coupling task&#39;</span></div><div class="line"><a name="l00402"></a><span class="lineno">  402</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00403"></a><span class="lineno">  403</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00404"></a><span class="lineno">  404</span>&#160;</div><div class="line"><a name="l00405"></a><span class="lineno">  405</span>&#160;    kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a3ea125963822918ce37fd3cfd9658c9f">oasis_ok</a></div><div class="line"><a name="l00406"></a><span class="lineno">  406</span>&#160;    <span class="keywordflow">if</span> (varid &lt; 1 .or. varid &gt; <a class="code" href="namespacemod__oasis__var.html#a095f8ad84e6afbcbe1744d4a9f924e08">prism_nvar</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00407"></a><span class="lineno">  407</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;invalid varid&#39;</span>,varid,trim(<a class="code" href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">prism_var</a>(varid)%name),<a class="code" href="namespacemod__oasis__var.html#a095f8ad84e6afbcbe1744d4a9f924e08">prism_nvar</a></div><div class="line"><a name="l00408"></a><span class="lineno">  408</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00409"></a><span class="lineno">  409</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00410"></a><span class="lineno">  410</span>&#160;</div><div class="line"><a name="l00411"></a><span class="lineno">  411</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(varnum)) <span class="keywordflow">then</span></div><div class="line"><a name="l00412"></a><span class="lineno">  412</span>&#160;       lvarnum = varnum</div><div class="line"><a name="l00413"></a><span class="lineno">  413</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;       lvarnum = 1</div><div class="line"><a name="l00415"></a><span class="lineno">  415</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00416"></a><span class="lineno">  416</span>&#160;</div><div class="line"><a name="l00417"></a><span class="lineno">  417</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__coupler.html#a65adf0558cfd9a9d316bd22ad1f9dc23">oasis_coupler_bldvarname</a>(varid,lvarnum,vname)</div><div class="line"><a name="l00418"></a><span class="lineno">  418</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l00419"></a><span class="lineno">  419</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG vname &#39;</span>,varid,lvarnum,<span class="stringliteral">&#39; &#39;</span>,trim(vname)</div><div class="line"><a name="l00420"></a><span class="lineno">  420</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00421"></a><span class="lineno">  421</span>&#160;</div><div class="line"><a name="l00422"></a><span class="lineno">  422</span>&#160;    lreadrest = .false.</div><div class="line"><a name="l00423"></a><span class="lineno">  423</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(readrest)) <span class="keywordflow">then</span></div><div class="line"><a name="l00424"></a><span class="lineno">  424</span>&#160;       lreadrest = readrest</div><div class="line"><a name="l00425"></a><span class="lineno">  425</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00426"></a><span class="lineno">  426</span>&#160;    <span class="keywordflow">if</span> (lreadrest) kinfo = <a class="code" href="namespacemod__oasis__parameters.html#aa0584909970d34364b7ec319292b1682">oasis_fromrest</a></div><div class="line"><a name="l00427"></a><span class="lineno">  427</span>&#160;</div><div class="line"><a name="l00428"></a><span class="lineno">  428</span>&#160;    <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00429"></a><span class="lineno">  429</span>&#160;<span class="comment">    !&gt; * Verify field (var) is either In or Out</span></div><div class="line"><a name="l00430"></a><span class="lineno">  430</span>&#160;    <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00431"></a><span class="lineno">  431</span>&#160;</div><div class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;    <span class="keywordflow">if</span> (mop /= <a class="code" href="namespacemod__oasis__parameters.html#a76a150fa8ef6ed0b35183e627d757439">oasis_out</a> .and. mop /= <a class="code" href="namespacemod__oasis__parameters.html#a16809ad581bb609aa5b0661927478653">oasis_in</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00433"></a><span class="lineno">  433</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00434"></a><span class="lineno">  434</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;mop invalid expecting OASIS_Out or OASIS_In = &#39;</span>,mop</div><div class="line"><a name="l00435"></a><span class="lineno">  435</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00436"></a><span class="lineno">  436</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00437"></a><span class="lineno">  437</span>&#160;</div><div class="line"><a name="l00438"></a><span class="lineno">  438</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; loop over var ncpl&#39;</span>)</div><div class="line"><a name="l00439"></a><span class="lineno">  439</span>&#160;</div><div class="line"><a name="l00440"></a><span class="lineno">  440</span>&#160;    <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00441"></a><span class="lineno">  441</span>&#160;    <span class="comment">! Check namid</span></div><div class="line"><a name="l00442"></a><span class="lineno">  442</span>&#160;    <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00443"></a><span class="lineno">  443</span>&#160;</div><div class="line"><a name="l00444"></a><span class="lineno">  444</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(namid)) <span class="keywordflow">then</span></div><div class="line"><a name="l00445"></a><span class="lineno">  445</span>&#160;       <span class="keywordflow">IF</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00446"></a><span class="lineno">  446</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39;namid&#39;</span>,namid,<a class="code" href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">prism_var</a>(varid)%cpl(1:<a class="code" href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">prism_var</a>(varid)%ncpl)</div><div class="line"><a name="l00447"></a><span class="lineno">  447</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00448"></a><span class="lineno">  448</span>&#160;       <span class="comment">! verify namid is associated with the variable or abort</span></div><div class="line"><a name="l00449"></a><span class="lineno">  449</span>&#160;       runit = .false.</div><div class="line"><a name="l00450"></a><span class="lineno">  450</span>&#160;       <span class="keywordflow">do</span> nc = 1,<a class="code" href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">prism_var</a>(varid)%ncpl</div><div class="line"><a name="l00451"></a><span class="lineno">  451</span>&#160;          cplid   = <a class="code" href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">prism_var</a>(varid)%cpl(nc)</div><div class="line"><a name="l00452"></a><span class="lineno">  452</span>&#160;          <span class="keywordflow">if</span> (cplid == namid) runit = .true.</div><div class="line"><a name="l00453"></a><span class="lineno">  453</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l00454"></a><span class="lineno">  454</span>&#160;       <span class="keywordflow">if</span> (.not.runit) <span class="keywordflow">then</span></div><div class="line"><a name="l00455"></a><span class="lineno">  455</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;namid not found for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00456"></a><span class="lineno">  456</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;namid = &#39;</span>,namid</div><div class="line"><a name="l00457"></a><span class="lineno">  457</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00458"></a><span class="lineno">  458</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00459"></a><span class="lineno">  459</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00460"></a><span class="lineno">  460</span>&#160;</div><div class="line"><a name="l00461"></a><span class="lineno">  461</span>&#160;    <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00462"></a><span class="lineno">  462</span>&#160;    <span class="comment">! Set arrayon</span></div><div class="line"><a name="l00463"></a><span class="lineno">  463</span>&#160;    <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00464"></a><span class="lineno">  464</span>&#160;</div><div class="line"><a name="l00465"></a><span class="lineno">  465</span>&#160;    arrayon = .false.</div><div class="line"><a name="l00466"></a><span class="lineno">  466</span>&#160;    arrayon(1) = .true.</div><div class="line"><a name="l00467"></a><span class="lineno">  467</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(a2on)) arrayon(2) = a2on</div><div class="line"><a name="l00468"></a><span class="lineno">  468</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(a3on)) arrayon(3) = a3on</div><div class="line"><a name="l00469"></a><span class="lineno">  469</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(a4on)) arrayon(4) = a4on</div><div class="line"><a name="l00470"></a><span class="lineno">  470</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(a5on)) arrayon(5) = a5on</div><div class="line"><a name="l00471"></a><span class="lineno">  471</span>&#160;</div><div class="line"><a name="l00472"></a><span class="lineno">  472</span>&#160;    <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 10) <span class="keywordflow">then</span></div><div class="line"><a name="l00473"></a><span class="lineno">  473</span>&#160;       <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; lreadrest :&#39;</span>,lreadrest,<span class="stringliteral">&#39; arrayon = &#39;</span>,arrayon</div><div class="line"><a name="l00474"></a><span class="lineno">  474</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l00475"></a><span class="lineno">  475</span>&#160;</div><div class="line"><a name="l00476"></a><span class="lineno">  476</span>&#160;    <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00477"></a><span class="lineno">  477</span>&#160;<span class="comment">    !&gt; * Loop over all the couplers associated with this var</span></div><div class="line"><a name="l00478"></a><span class="lineno">  478</span>&#160;    <span class="comment">!  or if nam is present, just for nc == nam</span></div><div class="line"><a name="l00479"></a><span class="lineno">  479</span>&#160;    <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00480"></a><span class="lineno">  480</span>&#160;</div><div class="line"><a name="l00481"></a><span class="lineno">  481</span>&#160;    <span class="keywordflow">DO</span> nc = 1,<a class="code" href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">prism_var</a>(varid)%ncpl</div><div class="line"><a name="l00482"></a><span class="lineno">  482</span>&#160;     cplid   = <a class="code" href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">prism_var</a>(varid)%cpl(nc)</div><div class="line"><a name="l00483"></a><span class="lineno">  483</span>&#160;     runit = .true.</div><div class="line"><a name="l00484"></a><span class="lineno">  484</span>&#160;     <span class="keywordflow">if</span> (<span class="keyword">present</span>(namid)) <span class="keywordflow">then</span></div><div class="line"><a name="l00485"></a><span class="lineno">  485</span>&#160;        runit = .false.</div><div class="line"><a name="l00486"></a><span class="lineno">  486</span>&#160;        <span class="keywordflow">if</span> (cplid == namid) runit = .true.</div><div class="line"><a name="l00487"></a><span class="lineno">  487</span>&#160;<span class="keywordflow">     endif</span></div><div class="line"><a name="l00488"></a><span class="lineno">  488</span>&#160;     <span class="keywordflow">if</span> (runit) <span class="keywordflow">then</span></div><div class="line"><a name="l00489"></a><span class="lineno">  489</span>&#160;       cplid   = <a class="code" href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">prism_var</a>(varid)%cpl(nc)</div><div class="line"><a name="l00490"></a><span class="lineno">  490</span>&#160;       <span class="keywordflow">if</span> (mop == <a class="code" href="namespacemod__oasis__parameters.html#a76a150fa8ef6ed0b35183e627d757439">oasis_out</a>) pcpointer =&gt; <a class="code" href="namespacemod__oasis__coupler.html#ae59d8823993d9ca8610efd9770393271">prism_coupler_put</a>(cplid)</div><div class="line"><a name="l00491"></a><span class="lineno">  491</span>&#160;       <span class="keywordflow">if</span> (mop == <a class="code" href="namespacemod__oasis__parameters.html#a16809ad581bb609aa5b0661927478653">oasis_in</a> ) pcpointer =&gt; <a class="code" href="namespacemod__oasis__coupler.html#a96df3ef2ec1b53597bb9beca43fe8349">prism_coupler_get</a>(cplid)</div><div class="line"><a name="l00492"></a><span class="lineno">  492</span>&#160;</div><div class="line"><a name="l00493"></a><span class="lineno">  493</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00494"></a><span class="lineno">  494</span>&#160;<span class="comment">       !&gt;   * check this prism_coupler is valid</span></div><div class="line"><a name="l00495"></a><span class="lineno">  495</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00496"></a><span class="lineno">  496</span>&#160;       <span class="keywordflow">if</span> (.not.pcpointer%valid) <span class="keywordflow">then</span></div><div class="line"><a name="l00497"></a><span class="lineno">  497</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;invalid prism_coupler for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00498"></a><span class="lineno">  498</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00499"></a><span class="lineno">  499</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00500"></a><span class="lineno">  500</span>&#160;</div><div class="line"><a name="l00501"></a><span class="lineno">  501</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00502"></a><span class="lineno">  502</span>&#160;<span class="comment">       !&gt;   *  check again that model op matches coupler op</span></div><div class="line"><a name="l00503"></a><span class="lineno">  503</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00504"></a><span class="lineno">  504</span>&#160;       getput  = pcpointer%getput</div><div class="line"><a name="l00505"></a><span class="lineno">  505</span>&#160;       <span class="keywordflow">if</span> ((mop == <a class="code" href="namespacemod__oasis__parameters.html#a76a150fa8ef6ed0b35183e627d757439">oasis_out</a> .and. getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a>) .or. &amp;</div><div class="line"><a name="l00506"></a><span class="lineno">  506</span>&#160;           (mop == <a class="code" href="namespacemod__oasis__parameters.html#a16809ad581bb609aa5b0661927478653">oasis_in</a>  .and. getput == <a class="code" href="namespacemod__oasis__parameters.html#aa2ac99363b8f1aa7ff950fda3e3f5fff">oasis3_get</a>)) <span class="keywordflow">then</span></div><div class="line"><a name="l00507"></a><span class="lineno">  507</span>&#160;          <span class="comment">!-continue</span></div><div class="line"><a name="l00508"></a><span class="lineno">  508</span>&#160;       <span class="keywordflow">else</span></div><div class="line"><a name="l00509"></a><span class="lineno">  509</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;model def_var in-out does not match model get-put call for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00510"></a><span class="lineno">  510</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00511"></a><span class="lineno">  511</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00512"></a><span class="lineno">  512</span>&#160;</div><div class="line"><a name="l00513"></a><span class="lineno">  513</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00514"></a><span class="lineno">  514</span>&#160;<span class="comment">       !&gt;   *  set a bunch of local variables</span></div><div class="line"><a name="l00515"></a><span class="lineno">  515</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00516"></a><span class="lineno">  516</span>&#160;       rouid   = pcpointer%routerid</div><div class="line"><a name="l00517"></a><span class="lineno">  517</span>&#160;       mapid   = pcpointer%mapperid</div><div class="line"><a name="l00518"></a><span class="lineno">  518</span>&#160;       tag     = pcpointer%tag</div><div class="line"><a name="l00519"></a><span class="lineno">  519</span>&#160;       dt      = pcpointer%dt</div><div class="line"><a name="l00520"></a><span class="lineno">  520</span>&#160;       lag     = pcpointer%lag</div><div class="line"><a name="l00521"></a><span class="lineno">  521</span>&#160;       ltime   = pcpointer%ltime</div><div class="line"><a name="l00522"></a><span class="lineno">  522</span>&#160;       sndrcv  = pcpointer%sndrcv</div><div class="line"><a name="l00523"></a><span class="lineno">  523</span>&#160;       rstfile = trim(pcpointer%rstfile)</div><div class="line"><a name="l00524"></a><span class="lineno">  524</span>&#160;       inpfile = trim(pcpointer%inpfile)</div><div class="line"><a name="l00525"></a><span class="lineno">  525</span>&#160;       maxtime = pcpointer%maxtime</div><div class="line"><a name="l00526"></a><span class="lineno">  526</span>&#160;       output  = pcpointer%output</div><div class="line"><a name="l00527"></a><span class="lineno">  527</span>&#160;       input   = pcpointer%input</div><div class="line"><a name="l00528"></a><span class="lineno">  528</span>&#160;       partid  = pcpointer%partID</div><div class="line"><a name="l00529"></a><span class="lineno">  529</span>&#160;       conserv = pcpointer%conserv</div><div class="line"><a name="l00530"></a><span class="lineno">  530</span>&#160;       consopt = pcpointer%consopt</div><div class="line"><a name="l00531"></a><span class="lineno">  531</span>&#160;       snddiag = pcpointer%snddiag</div><div class="line"><a name="l00532"></a><span class="lineno">  532</span>&#160;       rcvdiag = pcpointer%rcvdiag</div><div class="line"><a name="l00533"></a><span class="lineno">  533</span>&#160;       sndadd  = pcpointer%sndadd</div><div class="line"><a name="l00534"></a><span class="lineno">  534</span>&#160;       sndmult = pcpointer%sndmult</div><div class="line"><a name="l00535"></a><span class="lineno">  535</span>&#160;       rcvadd  = pcpointer%rcvadd</div><div class="line"><a name="l00536"></a><span class="lineno">  536</span>&#160;       rcvmult = pcpointer%rcvmult</div><div class="line"><a name="l00537"></a><span class="lineno">  537</span>&#160;</div><div class="line"><a name="l00538"></a><span class="lineno">  538</span>&#160;       <span class="comment">! update writrest only if true</span></div><div class="line"><a name="l00539"></a><span class="lineno">  539</span>&#160;       <span class="comment">! never want to switch to false here</span></div><div class="line"><a name="l00540"></a><span class="lineno">  540</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(writrest)) <span class="keywordflow">then</span></div><div class="line"><a name="l00541"></a><span class="lineno">  541</span>&#160;          <span class="keywordflow">if</span> (writrest .and. mop /= <a class="code" href="namespacemod__oasis__parameters.html#a76a150fa8ef6ed0b35183e627d757439">oasis_out</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00542"></a><span class="lineno">  542</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;mop must be OASIS_Out if writrest is true, mop=&#39;</span>,mop</div><div class="line"><a name="l00543"></a><span class="lineno">  543</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00544"></a><span class="lineno">  544</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00545"></a><span class="lineno">  545</span>&#160;          <span class="keywordflow">if</span> (writrest) pcpointer%writrest = writrest</div><div class="line"><a name="l00546"></a><span class="lineno">  546</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00547"></a><span class="lineno">  547</span>&#160;</div><div class="line"><a name="l00548"></a><span class="lineno">  548</span>&#160;       unpack = (sndrcv .OR. input)</div><div class="line"><a name="l00549"></a><span class="lineno">  549</span>&#160;      </div><div class="line"><a name="l00550"></a><span class="lineno">  550</span>&#160;       <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; set nx and ny&#39;</span>)</div><div class="line"><a name="l00551"></a><span class="lineno">  551</span>&#160;       <span class="keywordflow">IF</span> (<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%nx &gt;= 1) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00552"></a><span class="lineno">  552</span>&#160;          nx = <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%nx</div><div class="line"><a name="l00553"></a><span class="lineno">  553</span>&#160;          ny = <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%ny</div><div class="line"><a name="l00554"></a><span class="lineno">  554</span>&#160;       <span class="keywordflow">ELSE</span></div><div class="line"><a name="l00555"></a><span class="lineno">  555</span>&#160;          nx = <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%gsize</div><div class="line"><a name="l00556"></a><span class="lineno">  556</span>&#160;          ny = 1</div><div class="line"><a name="l00557"></a><span class="lineno">  557</span>&#160;<span class="keywordflow">       ENDIF</span></div><div class="line"><a name="l00558"></a><span class="lineno">  558</span>&#160;      </div><div class="line"><a name="l00559"></a><span class="lineno">  559</span>&#160;       <span class="keywordflow">IF</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00560"></a><span class="lineno">  560</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG nx, ny = &#39;</span>,nx,ny</div><div class="line"><a name="l00561"></a><span class="lineno">  561</span>&#160;          <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l00562"></a><span class="lineno">  562</span>&#160;<span class="keywordflow">       ENDIF</span></div><div class="line"><a name="l00563"></a><span class="lineno">  563</span>&#160;</div><div class="line"><a name="l00564"></a><span class="lineno">  564</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00565"></a><span class="lineno">  565</span>&#160;<span class="comment">       !&gt;   * check that lag is reasonable</span></div><div class="line"><a name="l00566"></a><span class="lineno">  566</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00567"></a><span class="lineno">  567</span>&#160;</div><div class="line"><a name="l00568"></a><span class="lineno">  568</span>&#160;       <span class="keywordflow">IF</span> (abs(lag) &gt; dt) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00569"></a><span class="lineno">  569</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;lag setting greater than dt for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00570"></a><span class="lineno">  570</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00571"></a><span class="lineno">  571</span>&#160;<span class="keywordflow">       ENDIF</span></div><div class="line"><a name="l00572"></a><span class="lineno">  572</span>&#160;</div><div class="line"><a name="l00573"></a><span class="lineno">  573</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00574"></a><span class="lineno">  574</span>&#160;<span class="comment">       !&gt;   *  read restart for call from init phase</span></div><div class="line"><a name="l00575"></a><span class="lineno">  575</span>&#160;       <span class="comment">! right now, do not know whether any hot map terms are there</span></div><div class="line"><a name="l00576"></a><span class="lineno">  576</span>&#160;       <span class="comment">! assume they are if something is read, otherwise not</span></div><div class="line"><a name="l00577"></a><span class="lineno">  577</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00578"></a><span class="lineno">  578</span>&#160;</div><div class="line"><a name="l00579"></a><span class="lineno">  579</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; check for lag restart&#39;</span>)</div><div class="line"><a name="l00580"></a><span class="lineno">  580</span>&#160;       <span class="keywordflow">IF</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a> .AND. lag &gt; 0 .AND. lreadrest) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00581"></a><span class="lineno">  581</span>&#160;       <span class="comment">! effective model time of restart : msec</span></div><div class="line"><a name="l00582"></a><span class="lineno">  582</span>&#160;          mseclag = msec + lag</div><div class="line"><a name="l00583"></a><span class="lineno">  583</span>&#160;</div><div class="line"><a name="l00584"></a><span class="lineno">  584</span>&#160;          <span class="keywordflow">IF</span> (.not.<span class="keyword">present</span>(nff)) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00585"></a><span class="lineno">  585</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;nff optional argument not passed but expected for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00586"></a><span class="lineno">  586</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00587"></a><span class="lineno">  587</span>&#160;<span class="keywordflow">          ENDIF</span></div><div class="line"><a name="l00588"></a><span class="lineno">  588</span>&#160;          <span class="keywordflow">IF</span> (len_trim(rstfile) &lt; 1) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00589"></a><span class="lineno">  589</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;restart file undefined for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00590"></a><span class="lineno">  590</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00591"></a><span class="lineno">  591</span>&#160;<span class="keywordflow">          ENDIF</span></div><div class="line"><a name="l00592"></a><span class="lineno">  592</span>&#160;          lsize = mct_avect_lsize(pcpointer%aVect1)</div><div class="line"><a name="l00593"></a><span class="lineno">  593</span>&#160;          <span class="keywordflow">IF</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">THEN</span></div><div class="line"><a name="l00594"></a><span class="lineno">  594</span>&#160;             lstring = pcpointer%fldlist</div><div class="line"><a name="l00595"></a><span class="lineno">  595</span>&#160;             llstring = len_trim(lstring)</div><div class="line"><a name="l00596"></a><span class="lineno">  596</span>&#160;             <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l00597"></a><span class="lineno">  597</span>&#160;                <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; RRST: &#39;</span>, &amp;</div><div class="line"><a name="l00598"></a><span class="lineno">  598</span>&#160;                   trim(lstring),<span class="stringliteral">&#39; &#39;</span>,trim(rstfile)</div><div class="line"><a name="l00599"></a><span class="lineno">  599</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l00600"></a><span class="lineno">  600</span>&#160;                <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; RRST: &#39;</span>,lstring(1:20),&amp;</div><div class="line"><a name="l00601"></a><span class="lineno">  601</span>&#160;                   lstring(21:llstring),<span class="stringliteral">&#39; &#39;</span>,trim(rstfile)</div><div class="line"><a name="l00602"></a><span class="lineno">  602</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l00603"></a><span class="lineno">  603</span>&#160;<span class="keywordflow">          ENDIF</span></div><div class="line"><a name="l00604"></a><span class="lineno">  604</span>&#160;</div><div class="line"><a name="l00605"></a><span class="lineno">  605</span>&#160;          <span class="keyword">CALL </span>mct_avect_init(avtmp,rlist=pcpointer%fldlist,lsize=lsize)</div><div class="line"><a name="l00606"></a><span class="lineno">  606</span>&#160;          readabort = .true.</div><div class="line"><a name="l00607"></a><span class="lineno">  607</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__coupler.html#ab494fbbb8065f3a006892828f288e44a">allow_no_restart</a>) readabort = .false.</div><div class="line"><a name="l00608"></a><span class="lineno">  608</span>&#160;</div><div class="line"><a name="l00609"></a><span class="lineno">  609</span>&#160;          <span class="keywordflow">do</span> n = 1,5</div><div class="line"><a name="l00610"></a><span class="lineno">  610</span>&#160;             <span class="keywordflow">if</span> (n == 1) <span class="keywordflow">then</span></div><div class="line"><a name="l00611"></a><span class="lineno">  611</span>&#160;                vstring = <span class="stringliteral">&quot;&quot;</span></div><div class="line"><a name="l00612"></a><span class="lineno">  612</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l00613"></a><span class="lineno">  613</span>&#160;                <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a2,i1.1,a1)&#39;</span>) <span class="stringliteral">&#39;av&#39;</span>,n,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l00614"></a><span class="lineno">  614</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l00615"></a><span class="lineno">  615</span>&#160;</div><div class="line"><a name="l00616"></a><span class="lineno">  616</span>&#160;             <span class="comment">! NOTES: array* only valid if arrayon(n) is true</span></div><div class="line"><a name="l00617"></a><span class="lineno">  617</span>&#160;             <span class="comment">!  if readabort = T and didread = T then will copy values into array*</span></div><div class="line"><a name="l00618"></a><span class="lineno">  618</span>&#160;             <span class="comment">!  if readabort = T and didread = F then will abort in io_read_avfile</span></div><div class="line"><a name="l00619"></a><span class="lineno">  619</span>&#160;             <span class="comment">!  if readabort = F and didread = T then will copy values into array*</span></div><div class="line"><a name="l00620"></a><span class="lineno">  620</span>&#160;             <span class="comment">!  if readabort = F and didread = F then will 0s into array*</span></div><div class="line"><a name="l00621"></a><span class="lineno">  621</span>&#160;</div><div class="line"><a name="l00622"></a><span class="lineno">  622</span>&#160;             <span class="keywordflow">if</span> (arrayon(n)) <span class="keywordflow">then</span></div><div class="line"><a name="l00623"></a><span class="lineno">  623</span>&#160;                avtmp%rAttr(nff,1:lsize) = 0.0</div><div class="line"><a name="l00624"></a><span class="lineno">  624</span>&#160;                <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__io.html#a65e17e4a065e8e4dea33754fb9c1d32c">oasis_io_read_avfile</a>(trim(rstfile),avtmp,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, &amp;</div><div class="line"><a name="l00625"></a><span class="lineno">  625</span>&#160;                                          abort=readabort,nampre=vstring,didread=didread)</div><div class="line"><a name="l00626"></a><span class="lineno">  626</span>&#160;                <span class="keywordflow">if</span> (n == 1) array1din(1:lsize) = avtmp%rAttr(nff,1:lsize)</div><div class="line"><a name="l00627"></a><span class="lineno">  627</span>&#160;                <span class="keywordflow">if</span> (n == 2) array2(1:lsize) = avtmp%rAttr(nff,1:lsize)</div><div class="line"><a name="l00628"></a><span class="lineno">  628</span>&#160;                <span class="keywordflow">if</span> (n == 3) array3(1:lsize) = avtmp%rAttr(nff,1:lsize)</div><div class="line"><a name="l00629"></a><span class="lineno">  629</span>&#160;                <span class="keywordflow">if</span> (n == 4) array4(1:lsize) = avtmp%rAttr(nff,1:lsize)</div><div class="line"><a name="l00630"></a><span class="lineno">  630</span>&#160;                <span class="keywordflow">if</span> (n == 5) array5(1:lsize) = avtmp%rAttr(nff,1:lsize)</div><div class="line"><a name="l00631"></a><span class="lineno">  631</span>&#160;</div><div class="line"><a name="l00632"></a><span class="lineno">  632</span>&#160;                <span class="keywordflow">if</span> (.not.readabort .and. .not.didread) <span class="keywordflow">then</span></div><div class="line"><a name="l00633"></a><span class="lineno">  633</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a4e16ba69c68a3a39c8b8aa3b92234ce1">wstr</a>,<span class="stringliteral">&#39;restart field missing with readabort = &#39;</span>,readabort</div><div class="line"><a name="l00634"></a><span class="lineno">  634</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a4e16ba69c68a3a39c8b8aa3b92234ce1">wstr</a>,<span class="stringliteral">&#39;restart field missing for file = &#39;</span>,trim(rstfile)</div><div class="line"><a name="l00635"></a><span class="lineno">  635</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a4e16ba69c68a3a39c8b8aa3b92234ce1">wstr</a>,<span class="stringliteral">&#39;restart field missing for hot = &#39;</span>,n</div><div class="line"><a name="l00636"></a><span class="lineno">  636</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a4e16ba69c68a3a39c8b8aa3b92234ce1">wstr</a>,<span class="stringliteral">&#39;restart field missing setting values to zero&#39;</span></div><div class="line"><a name="l00637"></a><span class="lineno">  637</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00638"></a><span class="lineno">  638</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l00639"></a><span class="lineno">  639</span>&#160;<span class="keywordflow">          enddo</span></div><div class="line"><a name="l00640"></a><span class="lineno">  640</span>&#160;          <span class="keyword">CALL </span>mct_avect_clean(avtmp)</div><div class="line"><a name="l00641"></a><span class="lineno">  641</span>&#160;<span class="keywordflow">       ENDIF</span></div><div class="line"><a name="l00642"></a><span class="lineno">  642</span>&#160;</div><div class="line"><a name="l00643"></a><span class="lineno">  643</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00644"></a><span class="lineno">  644</span>&#160;<span class="comment">       !&gt;   * compute lag time, only on put side</span></div><div class="line"><a name="l00645"></a><span class="lineno">  645</span>&#160;<span class="comment">       !&gt;   * set time_now, is it a coupling period?</span></div><div class="line"><a name="l00646"></a><span class="lineno">  646</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00647"></a><span class="lineno">  647</span>&#160;</div><div class="line"><a name="l00648"></a><span class="lineno">  648</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; set mseclag&#39;</span>)</div><div class="line"><a name="l00649"></a><span class="lineno">  649</span>&#160;       <span class="keywordflow">if</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00650"></a><span class="lineno">  650</span>&#160;          mseclag = msec + lag</div><div class="line"><a name="l00651"></a><span class="lineno">  651</span>&#160;       <span class="keywordflow">elseif</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#aa2ac99363b8f1aa7ff950fda3e3f5fff">oasis3_get</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00652"></a><span class="lineno">  652</span>&#160;          mseclag = msec</div><div class="line"><a name="l00653"></a><span class="lineno">  653</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00654"></a><span class="lineno">  654</span>&#160;</div><div class="line"><a name="l00655"></a><span class="lineno">  655</span>&#160;       <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l00656"></a><span class="lineno">  656</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG msec,mseclag = &#39;</span>,msec,mseclag</div><div class="line"><a name="l00657"></a><span class="lineno">  657</span>&#160;          <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l00658"></a><span class="lineno">  658</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00659"></a><span class="lineno">  659</span>&#160;</div><div class="line"><a name="l00660"></a><span class="lineno">  660</span>&#160;       time_now = .false.</div><div class="line"><a name="l00661"></a><span class="lineno">  661</span>&#160;       <span class="keywordflow">if</span> (mod(mseclag,dt) == 0) time_now = .true.</div><div class="line"><a name="l00662"></a><span class="lineno">  662</span>&#160;</div><div class="line"><a name="l00663"></a><span class="lineno">  663</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00664"></a><span class="lineno">  664</span>&#160;<span class="comment">       !&gt;   * check that model hasn&#39;t gone past maxtime</span></div><div class="line"><a name="l00665"></a><span class="lineno">  665</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00666"></a><span class="lineno">  666</span>&#160;</div><div class="line"><a name="l00667"></a><span class="lineno">  667</span>&#160;       <span class="keywordflow">if</span> (msec &gt;= maxtime) <span class="keywordflow">then</span></div><div class="line"><a name="l00668"></a><span class="lineno">  668</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00669"></a><span class="lineno">  669</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;model time beyond namcouple maxtime = &#39;</span>,msec,maxtime</div><div class="line"><a name="l00670"></a><span class="lineno">  670</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00671"></a><span class="lineno">  671</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00672"></a><span class="lineno">  672</span>&#160;</div><div class="line"><a name="l00673"></a><span class="lineno">  673</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00674"></a><span class="lineno">  674</span>&#160;<span class="comment">       !&gt;   * check that model isn&#39;t going backwards</span></div><div class="line"><a name="l00675"></a><span class="lineno">  675</span>&#160;       <span class="comment">! msec &gt;= 0 does the check only in run mode, not in initialization</span></div><div class="line"><a name="l00676"></a><span class="lineno">  676</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00677"></a><span class="lineno">  677</span>&#160;</div><div class="line"><a name="l00678"></a><span class="lineno">  678</span>&#160;       <span class="keywordflow">if</span> (pcpointer%ctime /= <a class="code" href="namespacemod__oasis__data.html#a66bd35eca1454b6d8c8ac0449f2ca475">ispval</a> .and. msec &gt;= 0 .and. msec &lt; pcpointer%ctime) <span class="keywordflow">then</span></div><div class="line"><a name="l00679"></a><span class="lineno">  679</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00680"></a><span class="lineno">  680</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;model seems to be running backwards = &#39;</span>,pcpointer%ctime</div><div class="line"><a name="l00681"></a><span class="lineno">  681</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00682"></a><span class="lineno">  682</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00683"></a><span class="lineno">  683</span>&#160;</div><div class="line"><a name="l00684"></a><span class="lineno">  684</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00685"></a><span class="lineno">  685</span>&#160;<span class="comment">       !&gt;   * check that variable didn&#39;t miss a coupling period </span></div><div class="line"><a name="l00686"></a><span class="lineno">  686</span>&#160;       <span class="comment">! check only for send recv operations where deadlock </span></div><div class="line"><a name="l00687"></a><span class="lineno">  687</span>&#160;       <span class="comment">! is possible.  Allow 1*dt for synchronous operations,</span></div><div class="line"><a name="l00688"></a><span class="lineno">  688</span>&#160;       <span class="comment">! 2*dt for asynchronous operations</span></div><div class="line"><a name="l00689"></a><span class="lineno">  689</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00690"></a><span class="lineno">  690</span>&#160;</div><div class="line"><a name="l00691"></a><span class="lineno">  691</span>&#160;       <span class="keywordflow">do</span> n = 1,<a class="code" href="namespacemod__oasis__coupler.html#aaa019c39b0f657e7c37820697ecf354a">prism_mcoupler</a></div><div class="line"><a name="l00692"></a><span class="lineno">  692</span>&#160;       <span class="keywordflow">do</span> npc = 1,2</div><div class="line"><a name="l00693"></a><span class="lineno">  693</span>&#160;       <span class="keywordflow">if</span> (npc == 1) pcpointmp =&gt; <a class="code" href="namespacemod__oasis__coupler.html#ae59d8823993d9ca8610efd9770393271">prism_coupler_put</a>(n)</div><div class="line"><a name="l00694"></a><span class="lineno">  694</span>&#160;       <span class="keywordflow">if</span> (npc == 2) pcpointmp =&gt; <a class="code" href="namespacemod__oasis__coupler.html#a96df3ef2ec1b53597bb9beca43fe8349">prism_coupler_get</a>(n)</div><div class="line"><a name="l00695"></a><span class="lineno">  695</span>&#160;       <span class="keywordflow">if</span> (pcpointmp%valid) <span class="keywordflow">then</span></div><div class="line"><a name="l00696"></a><span class="lineno">  696</span>&#160;       <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(pcpointmp%partID)%lsize &gt; 0) <span class="keywordflow">then</span></div><div class="line"><a name="l00697"></a><span class="lineno">  697</span>&#160;</div><div class="line"><a name="l00698"></a><span class="lineno">  698</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l00699"></a><span class="lineno">  699</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(2a,4i6,2l3,i8)&#39;</span>) subname,<span class="stringliteral">&#39;deadlock_chkA &#39;</span>,varid,nc,n,npc,sndrcv,pcpointmp%sndrcv,msec</div><div class="line"><a name="l00700"></a><span class="lineno">  700</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(2a,1x,a,2i8,1x,a,2i8)&#39;</span>) subname,<span class="stringliteral">&#39;deadlock_chkB &#39;</span>,trim(pcpointer%fldlist),pcpointer%ltime,pcpointer%dt,trim(pcpointmp%fldlist),pcpointmp%ltime,pcpointmp%dt</div><div class="line"><a name="l00701"></a><span class="lineno">  701</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00702"></a><span class="lineno">  702</span>&#160;</div><div class="line"><a name="l00703"></a><span class="lineno">  703</span>&#160;          <span class="keywordflow">if</span> ((sndrcv .and. pcpointmp%sndrcv .and. time_now) .and. &amp;</div><div class="line"><a name="l00704"></a><span class="lineno">  704</span>&#160;              ((pcpointmp%ltime /= <a class="code" href="namespacemod__oasis__data.html#a66bd35eca1454b6d8c8ac0449f2ca475">ispval</a> .and. msec &gt;  pcpointmp%ltime + pcpointmp%dt) .or. &amp;</div><div class="line"><a name="l00705"></a><span class="lineno">  705</span>&#160;               (pcpointmp%ltime == <a class="code" href="namespacemod__oasis__data.html#a66bd35eca1454b6d8c8ac0449f2ca475">ispval</a> .and. pcpointer%ltime /= <a class="code" href="namespacemod__oasis__data.html#a66bd35eca1454b6d8c8ac0449f2ca475">ispval</a> .and. msec &gt;= pcpointmp%dt ))) <span class="keywordflow">then</span></div><div class="line"><a name="l00706"></a><span class="lineno">  706</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(3a)&#39;</span>) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;coupling skipped at earlier time, potential deadlock &#39;</span></div><div class="line"><a name="l00707"></a><span class="lineno">  707</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(3a,i8,2a)&#39;</span>) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;my coupler = &#39;</span>,cplid,<span class="stringliteral">&#39; variable = &#39;</span>,&amp;</div><div class="line"><a name="l00708"></a><span class="lineno">  708</span>&#160;                             trim(pcpointer%fldlist)</div><div class="line"><a name="l00709"></a><span class="lineno">  709</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(3a,i12,a,i12)&#39;</span>) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;current time = &#39;</span>,msec,<span class="stringliteral">&#39; mseclag = &#39;</span>,mseclag</div><div class="line"><a name="l00710"></a><span class="lineno">  710</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(3a,2i12)&#39;</span>) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;my coupler last time and dt = &#39;</span>,pcpointer%ltime,pcpointer%dt</div><div class="line"><a name="l00711"></a><span class="lineno">  711</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(3a,i8,2a)&#39;</span>) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;skipped coupler = &#39;</span>,n,<span class="stringliteral">&#39; variable = &#39;</span>,&amp;</div><div class="line"><a name="l00712"></a><span class="lineno">  712</span>&#160;                             trim(pcpointmp%fldlist)</div><div class="line"><a name="l00713"></a><span class="lineno">  713</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(3a,2i12)&#39;</span>) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;skipped coupler last time and dt = &#39;</span>,&amp;</div><div class="line"><a name="l00714"></a><span class="lineno">  714</span>&#160;                             pcpointmp%ltime,pcpointmp%dt</div><div class="line"><a name="l00715"></a><span class="lineno">  715</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00716"></a><span class="lineno">  716</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00717"></a><span class="lineno">  717</span>&#160;<span class="keywordflow">       endif</span>  <span class="comment">! part lsize</span></div><div class="line"><a name="l00718"></a><span class="lineno">  718</span>&#160;<span class="keywordflow">       endif</span>  <span class="comment">! valid</span></div><div class="line"><a name="l00719"></a><span class="lineno">  719</span>&#160;<span class="keywordflow">       enddo</span>  <span class="comment">! npc</span></div><div class="line"><a name="l00720"></a><span class="lineno">  720</span>&#160;<span class="keywordflow">       enddo</span>  <span class="comment">! prism_mcoupler</span></div><div class="line"><a name="l00721"></a><span class="lineno">  721</span>&#160;</div><div class="line"><a name="l00722"></a><span class="lineno">  722</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00723"></a><span class="lineno">  723</span>&#160;<span class="comment">       !&gt;   * check that prior sequences weren&#39;t missed at this </span></div><div class="line"><a name="l00724"></a><span class="lineno">  724</span>&#160;<span class="comment">       !&gt;     step for get (recv) operation.</span></div><div class="line"><a name="l00725"></a><span class="lineno">  725</span>&#160;       <span class="comment">! attempts to trap deadlocks before they happen</span></div><div class="line"><a name="l00726"></a><span class="lineno">  726</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00727"></a><span class="lineno">  727</span>&#160;</div><div class="line"><a name="l00728"></a><span class="lineno">  728</span>&#160;       <span class="keywordflow">if</span> (sndrcv .and. getput == <a class="code" href="namespacemod__oasis__parameters.html#aa2ac99363b8f1aa7ff950fda3e3f5fff">oasis3_get</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00729"></a><span class="lineno">  729</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__coupler.html#a47f4727f94719892d837f6a1545d3d08">lastseqtime</a> /= <a class="code" href="namespacemod__oasis__data.html#a66bd35eca1454b6d8c8ac0449f2ca475">ispval</a> .and. msec == <a class="code" href="namespacemod__oasis__coupler.html#a47f4727f94719892d837f6a1545d3d08">lastseqtime</a>  .and. pcpointer%seq &lt; <a class="code" href="namespacemod__oasis__coupler.html#a0cb9b8a96c10385d38fa244d920c7eaf">lastseq</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00730"></a><span class="lineno">  730</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;coupling sequence out of order, potential deadlock &#39;</span></div><div class="line"><a name="l00731"></a><span class="lineno">  731</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;my coupler = &#39;</span>,cplid,<span class="stringliteral">&#39; variable = &#39;</span>,&amp;</div><div class="line"><a name="l00732"></a><span class="lineno">  732</span>&#160;                             trim(pcpointer%fldlist)</div><div class="line"><a name="l00733"></a><span class="lineno">  733</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; ERRRO: sequence number = &#39;</span>,pcpointer%seq</div><div class="line"><a name="l00734"></a><span class="lineno">  734</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;current time = &#39;</span>,msec,<span class="stringliteral">&#39; mseclag = &#39;</span>,mseclag</div><div class="line"><a name="l00735"></a><span class="lineno">  735</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;last sequence and time = &#39;</span>,<a class="code" href="namespacemod__oasis__coupler.html#a0cb9b8a96c10385d38fa244d920c7eaf">lastseq</a>,<a class="code" href="namespacemod__oasis__coupler.html#a47f4727f94719892d837f6a1545d3d08">lastseqtime</a></div><div class="line"><a name="l00736"></a><span class="lineno">  736</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;model sequence does not match coupling sequence&#39;</span></div><div class="line"><a name="l00737"></a><span class="lineno">  737</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00738"></a><span class="lineno">  738</span>&#160;          <span class="keywordflow">else</span></div><div class="line"><a name="l00739"></a><span class="lineno">  739</span>&#160;             <a class="code" href="namespacemod__oasis__coupler.html#a0cb9b8a96c10385d38fa244d920c7eaf">lastseq</a> = pcpointer%seq</div><div class="line"><a name="l00740"></a><span class="lineno">  740</span>&#160;             <a class="code" href="namespacemod__oasis__coupler.html#a47f4727f94719892d837f6a1545d3d08">lastseqtime</a> = msec</div><div class="line"><a name="l00741"></a><span class="lineno">  741</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00742"></a><span class="lineno">  742</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l00743"></a><span class="lineno">  743</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG sequence &#39;</span>,trim(vname),msec,<a class="code" href="namespacemod__oasis__coupler.html#a47f4727f94719892d837f6a1545d3d08">lastseqtime</a>,<a class="code" href="namespacemod__oasis__coupler.html#a0cb9b8a96c10385d38fa244d920c7eaf">lastseq</a>,pcpointer%seq</div><div class="line"><a name="l00744"></a><span class="lineno">  744</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00745"></a><span class="lineno">  745</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00746"></a><span class="lineno">  746</span>&#160;</div><div class="line"><a name="l00747"></a><span class="lineno">  747</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00748"></a><span class="lineno">  748</span>&#160;<span class="comment">       !&gt;   * compute field index and check sizes</span></div><div class="line"><a name="l00749"></a><span class="lineno">  749</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00750"></a><span class="lineno">  750</span>&#160;</div><div class="line"><a name="l00751"></a><span class="lineno">  751</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; compute field index and sizes&#39;</span>)</div><div class="line"><a name="l00752"></a><span class="lineno">  752</span>&#160;       nfav = mct_avect_indexra(pcpointer%avect1,trim(vname))</div><div class="line"><a name="l00753"></a><span class="lineno">  753</span>&#160;       nsav = mct_avect_lsize(pcpointer%avect1)</div><div class="line"><a name="l00754"></a><span class="lineno">  754</span>&#160;       <span class="keywordflow">if</span> (lag &gt; 0 .and. lreadrest) nsa=<span class="keyword">size</span>(array1din)</div><div class="line"><a name="l00755"></a><span class="lineno">  755</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(array1din )) nsa = <span class="keyword">size</span>(array1din )</div><div class="line"><a name="l00756"></a><span class="lineno">  756</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(array1dout)) nsa = <span class="keyword">size</span>(array1dout)</div><div class="line"><a name="l00757"></a><span class="lineno">  757</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(array2dout)) nsa = <span class="keyword">size</span>(array2dout)</div><div class="line"><a name="l00758"></a><span class="lineno">  758</span>&#160;</div><div class="line"><a name="l00759"></a><span class="lineno">  759</span>&#160;       <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l00760"></a><span class="lineno">  760</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG nfav,nsav,nsa = &#39;</span>,nfav,nsav,nsa</div><div class="line"><a name="l00761"></a><span class="lineno">  761</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00762"></a><span class="lineno">  762</span>&#160;</div><div class="line"><a name="l00763"></a><span class="lineno">  763</span>&#160;       <span class="keywordflow">if</span> (nsav /= nsa) <span class="keywordflow">then</span></div><div class="line"><a name="l00764"></a><span class="lineno">  764</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00765"></a><span class="lineno">  765</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;in field size passed into get/put compare to expected size &#39;</span>,nsav,nsa</div><div class="line"><a name="l00766"></a><span class="lineno">  766</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00767"></a><span class="lineno">  767</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00768"></a><span class="lineno">  768</span>&#160;</div><div class="line"><a name="l00769"></a><span class="lineno">  769</span>&#160;       <span class="keywordflow">if</span> (nfav &lt; 1 .or. nfav &gt; mct_avect_nrattr(pcpointer%avect1)) <span class="keywordflow">then</span></div><div class="line"><a name="l00770"></a><span class="lineno">  770</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00771"></a><span class="lineno">  771</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;ivalid variable name nfav = &#39;</span>,nfav</div><div class="line"><a name="l00772"></a><span class="lineno">  772</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00773"></a><span class="lineno">  773</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00774"></a><span class="lineno">  774</span>&#160;</div><div class="line"><a name="l00775"></a><span class="lineno">  775</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00776"></a><span class="lineno">  776</span>&#160;<span class="comment">       !&gt;   * check for higher order coupling fields</span></div><div class="line"><a name="l00777"></a><span class="lineno">  777</span>&#160;<span class="comment">       !&gt;     and get everything ready</span></div><div class="line"><a name="l00778"></a><span class="lineno">  778</span>&#160;       <span class="comment">! arrayon is what&#39;s passed this time</span></div><div class="line"><a name="l00779"></a><span class="lineno">  779</span>&#160;       <span class="comment">! optional args only on put side</span></div><div class="line"><a name="l00780"></a><span class="lineno">  780</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00781"></a><span class="lineno">  781</span>&#160;</div><div class="line"><a name="l00782"></a><span class="lineno">  782</span>&#160;       <span class="keywordflow">if</span> ((getput == <a class="code" href="namespacemod__oasis__parameters.html#aa2ac99363b8f1aa7ff950fda3e3f5fff">oasis3_get</a>) .or. &amp;</div><div class="line"><a name="l00783"></a><span class="lineno">  783</span>&#160;           (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a> .and. trim(pcpointer%maploc) == <span class="stringliteral">&quot;dst&quot;</span> )) <span class="keywordflow">then</span></div><div class="line"><a name="l00784"></a><span class="lineno">  784</span>&#160;          <span class="keywordflow">if</span> (arrayon(2) .or. arrayon(3) .or. &amp;</div><div class="line"><a name="l00785"></a><span class="lineno">  785</span>&#160;              arrayon(4) .or. arrayon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00786"></a><span class="lineno">  786</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00787"></a><span class="lineno">  787</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;higher order mapping not allowed on get side&#39;</span></div><div class="line"><a name="l00788"></a><span class="lineno">  788</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;consider changing map location from dst to src&#39;</span></div><div class="line"><a name="l00789"></a><span class="lineno">  789</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00790"></a><span class="lineno">  790</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00791"></a><span class="lineno">  791</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00792"></a><span class="lineno">  792</span>&#160;</div><div class="line"><a name="l00793"></a><span class="lineno">  793</span>&#160;       <span class="keywordflow">if</span> ((arrayon(2) .and. .not.<span class="keyword">present</span>(array2)) .or. &amp;</div><div class="line"><a name="l00794"></a><span class="lineno">  794</span>&#160;           (arrayon(3) .and. .not.<span class="keyword">present</span>(array3)) .or. &amp;</div><div class="line"><a name="l00795"></a><span class="lineno">  795</span>&#160;           (arrayon(4) .and. .not.<span class="keyword">present</span>(array4)) .or. &amp;</div><div class="line"><a name="l00796"></a><span class="lineno">  796</span>&#160;           (arrayon(5) .and. .not.<span class="keyword">present</span>(array5))) <span class="keywordflow">then</span></div><div class="line"><a name="l00797"></a><span class="lineno">  797</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00798"></a><span class="lineno">  798</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;arrayon true but array not sent&#39;</span></div><div class="line"><a name="l00799"></a><span class="lineno">  799</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l00800"></a><span class="lineno">  800</span>&#160;       <span class="comment">! With the current way of using oasis_advance_run, the above test is useless but we keep the test</span></div><div class="line"><a name="l00801"></a><span class="lineno">  801</span>&#160;       <span class="comment">! as someone might be later adding an interface call that would violate the consistency</span></div><div class="line"><a name="l00802"></a><span class="lineno">  802</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00803"></a><span class="lineno">  803</span>&#160;</div><div class="line"><a name="l00804"></a><span class="lineno">  804</span>&#160;       <span class="comment">! initialize aVect2-5 here if not already allocated</span></div><div class="line"><a name="l00805"></a><span class="lineno">  805</span>&#160;</div><div class="line"><a name="l00806"></a><span class="lineno">  806</span>&#160;       <span class="keywordflow">if</span> (arrayon(2) .and. .not. pcpointer%aVon(2)) <span class="keywordflow">then</span></div><div class="line"><a name="l00807"></a><span class="lineno">  807</span>&#160;          <span class="keyword">call </span>mct_avect_init(pcpointer%aVect2,pcpointer%aVect1,nsav)</div><div class="line"><a name="l00808"></a><span class="lineno">  808</span>&#160;          <span class="keyword">call </span>mct_avect_zero(pcpointer%aVect2)</div><div class="line"><a name="l00809"></a><span class="lineno">  809</span>&#160;          pcpointer%aVon(2) = .true.</div><div class="line"><a name="l00810"></a><span class="lineno">  810</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l00811"></a><span class="lineno">  811</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; ALLO: &#39;</span>,&amp;</div><div class="line"><a name="l00812"></a><span class="lineno">  812</span>&#160;                             trim(vname),<span class="stringliteral">&#39; &#39;</span>,<span class="stringliteral">&#39;aVect2&#39;</span></div><div class="line"><a name="l00813"></a><span class="lineno">  813</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00814"></a><span class="lineno">  814</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00815"></a><span class="lineno">  815</span>&#160;</div><div class="line"><a name="l00816"></a><span class="lineno">  816</span>&#160;       <span class="keywordflow">if</span> (arrayon(3) .and. .not. pcpointer%aVon(3)) <span class="keywordflow">then</span></div><div class="line"><a name="l00817"></a><span class="lineno">  817</span>&#160;          <span class="keyword">call </span>mct_avect_init(pcpointer%aVect3,pcpointer%aVect1,nsav)</div><div class="line"><a name="l00818"></a><span class="lineno">  818</span>&#160;          <span class="keyword">call </span>mct_avect_zero(pcpointer%aVect3)</div><div class="line"><a name="l00819"></a><span class="lineno">  819</span>&#160;          pcpointer%aVon(3) = .true.</div><div class="line"><a name="l00820"></a><span class="lineno">  820</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l00821"></a><span class="lineno">  821</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; ALLO: &#39;</span>,&amp;</div><div class="line"><a name="l00822"></a><span class="lineno">  822</span>&#160;                             trim(vname),<span class="stringliteral">&#39; &#39;</span>,<span class="stringliteral">&#39;aVect3&#39;</span></div><div class="line"><a name="l00823"></a><span class="lineno">  823</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00824"></a><span class="lineno">  824</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00825"></a><span class="lineno">  825</span>&#160;</div><div class="line"><a name="l00826"></a><span class="lineno">  826</span>&#160;       <span class="keywordflow">if</span> (arrayon(4) .and. .not. pcpointer%aVon(4)) <span class="keywordflow">then</span></div><div class="line"><a name="l00827"></a><span class="lineno">  827</span>&#160;          <span class="keyword">call </span>mct_avect_init(pcpointer%aVect4,pcpointer%aVect1,nsav)</div><div class="line"><a name="l00828"></a><span class="lineno">  828</span>&#160;          <span class="keyword">call </span>mct_avect_zero(pcpointer%aVect4)</div><div class="line"><a name="l00829"></a><span class="lineno">  829</span>&#160;          pcpointer%aVon(4) = .true.</div><div class="line"><a name="l00830"></a><span class="lineno">  830</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l00831"></a><span class="lineno">  831</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; ALLO: &#39;</span>,&amp;</div><div class="line"><a name="l00832"></a><span class="lineno">  832</span>&#160;                             trim(vname),<span class="stringliteral">&#39; &#39;</span>,<span class="stringliteral">&#39;aVect4&#39;</span></div><div class="line"><a name="l00833"></a><span class="lineno">  833</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00834"></a><span class="lineno">  834</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00835"></a><span class="lineno">  835</span>&#160;</div><div class="line"><a name="l00836"></a><span class="lineno">  836</span>&#160;       <span class="keywordflow">if</span> (arrayon(5) .and. .not. pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00837"></a><span class="lineno">  837</span>&#160;          <span class="keyword">call </span>mct_avect_init(pcpointer%aVect5,pcpointer%aVect1,nsav)</div><div class="line"><a name="l00838"></a><span class="lineno">  838</span>&#160;          <span class="keyword">call </span>mct_avect_zero(pcpointer%aVect5)</div><div class="line"><a name="l00839"></a><span class="lineno">  839</span>&#160;          pcpointer%aVon(5) = .true.</div><div class="line"><a name="l00840"></a><span class="lineno">  840</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l00841"></a><span class="lineno">  841</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; ALLO: &#39;</span>,&amp;</div><div class="line"><a name="l00842"></a><span class="lineno">  842</span>&#160;                             trim(vname),<span class="stringliteral">&#39; &#39;</span>,<span class="stringliteral">&#39;aVect5&#39;</span></div><div class="line"><a name="l00843"></a><span class="lineno">  843</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l00844"></a><span class="lineno">  844</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l00845"></a><span class="lineno">  845</span>&#160;</div><div class="line"><a name="l00846"></a><span class="lineno">  846</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l00847"></a><span class="lineno">  847</span>&#160;<span class="comment">       !&gt;   * update avect1-5 on put side and apply appropriate transform</span></div><div class="line"><a name="l00848"></a><span class="lineno">  848</span>&#160;<span class="comment">       !&gt;   * if its coupling time, set status of this var to ready</span></div><div class="line"><a name="l00849"></a><span class="lineno">  849</span>&#160;<span class="comment">       !&gt;   * write restart if requested by interface</span></div><div class="line"><a name="l00850"></a><span class="lineno">  850</span>&#160;       <span class="comment">! on restart, treat as instant value</span></div><div class="line"><a name="l00851"></a><span class="lineno">  851</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l00852"></a><span class="lineno">  852</span>&#160;</div><div class="line"><a name="l00853"></a><span class="lineno">  853</span>&#160;       <span class="keywordflow">if</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00854"></a><span class="lineno">  854</span>&#160;</div><div class="line"><a name="l00855"></a><span class="lineno">  855</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; loctrans operation&#39;</span>)</div><div class="line"><a name="l00856"></a><span class="lineno">  856</span>&#160;          <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;pcpy_&#39;</span>,cplid</div><div class="line"><a name="l00857"></a><span class="lineno">  857</span>&#160;</div><div class="line"><a name="l00858"></a><span class="lineno">  858</span>&#160;          <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l00859"></a><span class="lineno">  859</span>&#160;</div><div class="line"><a name="l00860"></a><span class="lineno">  860</span>&#160;          cstring = <span class="stringliteral">&#39;none&#39;</span></div><div class="line"><a name="l00861"></a><span class="lineno">  861</span>&#160;          <span class="keywordflow">if</span> (lreadrest .or. pcpointer%trans == <a class="code" href="namespacemod__oasis__parameters.html#a1028581caadcb9d7506b25c6cd3efd01">ip_instant</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00862"></a><span class="lineno">  862</span>&#160;             <span class="keywordflow">if</span> (time_now) <span class="keywordflow">then</span></div><div class="line"><a name="l00863"></a><span class="lineno">  863</span>&#160;                cstring = <span class="stringliteral">&#39;instant&#39;</span></div><div class="line"><a name="l00864"></a><span class="lineno">  864</span>&#160;                <span class="keywordflow">do</span> n = 1,nsav</div><div class="line"><a name="l00865"></a><span class="lineno">  865</span>&#160;                   pcpointer%avect1%rAttr(nfav,n) = array1din(n)</div><div class="line"><a name="l00866"></a><span class="lineno">  866</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(2)) <span class="keywordflow">then</span></div><div class="line"><a name="l00867"></a><span class="lineno">  867</span>&#160;                      <span class="keywordflow">if</span> (<span class="keyword">present</span>(array2)) <span class="keywordflow">then</span></div><div class="line"><a name="l00868"></a><span class="lineno">  868</span>&#160;                         pcpointer%avect2%rAttr(nfav,n) = array2(n)</div><div class="line"><a name="l00869"></a><span class="lineno">  869</span>&#160;                      <span class="keywordflow">else</span></div><div class="line"><a name="l00870"></a><span class="lineno">  870</span>&#160;                         pcpointer%avect2%rAttr(nfav,n) = 0.0</div><div class="line"><a name="l00871"></a><span class="lineno">  871</span>&#160;<span class="keywordflow">                      endif</span></div><div class="line"><a name="l00872"></a><span class="lineno">  872</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00873"></a><span class="lineno">  873</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(3)) <span class="keywordflow">then</span></div><div class="line"><a name="l00874"></a><span class="lineno">  874</span>&#160;                      <span class="keywordflow">if</span> (<span class="keyword">present</span>(array3)) <span class="keywordflow">then</span></div><div class="line"><a name="l00875"></a><span class="lineno">  875</span>&#160;                         pcpointer%avect3%rAttr(nfav,n) = array3(n)</div><div class="line"><a name="l00876"></a><span class="lineno">  876</span>&#160;                      <span class="keywordflow">else</span></div><div class="line"><a name="l00877"></a><span class="lineno">  877</span>&#160;                         pcpointer%avect3%rAttr(nfav,n) = 0.0</div><div class="line"><a name="l00878"></a><span class="lineno">  878</span>&#160;<span class="keywordflow">                      endif</span></div><div class="line"><a name="l00879"></a><span class="lineno">  879</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00880"></a><span class="lineno">  880</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(4)) <span class="keywordflow">then</span></div><div class="line"><a name="l00881"></a><span class="lineno">  881</span>&#160;                      <span class="keywordflow">if</span> (<span class="keyword">present</span>(array4)) <span class="keywordflow">then</span></div><div class="line"><a name="l00882"></a><span class="lineno">  882</span>&#160;                         pcpointer%avect4%rAttr(nfav,n) = array4(n)</div><div class="line"><a name="l00883"></a><span class="lineno">  883</span>&#160;                      <span class="keywordflow">else</span></div><div class="line"><a name="l00884"></a><span class="lineno">  884</span>&#160;                         pcpointer%avect4%rAttr(nfav,n) = 0.0</div><div class="line"><a name="l00885"></a><span class="lineno">  885</span>&#160;<span class="keywordflow">                      endif</span></div><div class="line"><a name="l00886"></a><span class="lineno">  886</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00887"></a><span class="lineno">  887</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00888"></a><span class="lineno">  888</span>&#160;                      <span class="keywordflow">if</span> (<span class="keyword">present</span>(array5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00889"></a><span class="lineno">  889</span>&#160;                         pcpointer%avect5%rAttr(nfav,n) = array5(n)</div><div class="line"><a name="l00890"></a><span class="lineno">  890</span>&#160;                      <span class="keywordflow">else</span></div><div class="line"><a name="l00891"></a><span class="lineno">  891</span>&#160;                         pcpointer%avect5%rAttr(nfav,n) = 0.0</div><div class="line"><a name="l00892"></a><span class="lineno">  892</span>&#160;<span class="keywordflow">                      endif</span></div><div class="line"><a name="l00893"></a><span class="lineno">  893</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00894"></a><span class="lineno">  894</span>&#160;<span class="keywordflow">                enddo</span></div><div class="line"><a name="l00895"></a><span class="lineno">  895</span>&#160;                pcpointer%avcnt(nfav) = 1</div><div class="line"><a name="l00896"></a><span class="lineno">  896</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l00897"></a><span class="lineno">  897</span>&#160;</div><div class="line"><a name="l00898"></a><span class="lineno">  898</span>&#160;          <span class="keywordflow">elseif</span> (pcpointer%trans == <a class="code" href="namespacemod__oasis__parameters.html#a5e40e91da22fca8f2b6a9d4f1c1ace5d">ip_average</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00899"></a><span class="lineno">  899</span>&#160;             cstring = <span class="stringliteral">&#39;average&#39;</span></div><div class="line"><a name="l00900"></a><span class="lineno">  900</span>&#160;             <span class="keywordflow">if</span> (kinfo == <a class="code" href="namespacemod__oasis__parameters.html#a3ea125963822918ce37fd3cfd9658c9f">oasis_ok</a>) kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a8b206cc178182e3526d400ea7a6587b5">oasis_loctrans</a></div><div class="line"><a name="l00901"></a><span class="lineno">  901</span>&#160;             <span class="keywordflow">do</span> n = 1,nsav</div><div class="line"><a name="l00902"></a><span class="lineno">  902</span>&#160;                pcpointer%avect1%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00903"></a><span class="lineno">  903</span>&#160;                   pcpointer%avect1%rAttr(nfav,n) + array1din(n)</div><div class="line"><a name="l00904"></a><span class="lineno">  904</span>&#160;                <span class="keywordflow">if</span> (pcpointer%aVon(2)) <span class="keywordflow">then</span></div><div class="line"><a name="l00905"></a><span class="lineno">  905</span>&#160;                   <span class="keywordflow">if</span> (<span class="keyword">present</span>(array2)) <span class="keywordflow">then</span></div><div class="line"><a name="l00906"></a><span class="lineno">  906</span>&#160;                      pcpointer%avect2%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00907"></a><span class="lineno">  907</span>&#160;                         pcpointer%avect2%rAttr(nfav,n) + array2(n)</div><div class="line"><a name="l00908"></a><span class="lineno">  908</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00909"></a><span class="lineno">  909</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00910"></a><span class="lineno">  910</span>&#160;                <span class="keywordflow">if</span> (pcpointer%aVon(3)) <span class="keywordflow">then</span></div><div class="line"><a name="l00911"></a><span class="lineno">  911</span>&#160;                   <span class="keywordflow">if</span> (<span class="keyword">present</span>(array3)) <span class="keywordflow">then</span></div><div class="line"><a name="l00912"></a><span class="lineno">  912</span>&#160;                      pcpointer%avect3%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00913"></a><span class="lineno">  913</span>&#160;                         pcpointer%avect3%rAttr(nfav,n) + array3(n)</div><div class="line"><a name="l00914"></a><span class="lineno">  914</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00915"></a><span class="lineno">  915</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00916"></a><span class="lineno">  916</span>&#160;                <span class="keywordflow">if</span> (pcpointer%aVon(4)) <span class="keywordflow">then</span></div><div class="line"><a name="l00917"></a><span class="lineno">  917</span>&#160;                   <span class="keywordflow">if</span> (<span class="keyword">present</span>(array4)) <span class="keywordflow">then</span></div><div class="line"><a name="l00918"></a><span class="lineno">  918</span>&#160;                      pcpointer%avect4%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00919"></a><span class="lineno">  919</span>&#160;                         pcpointer%avect4%rAttr(nfav,n) + array4(n)</div><div class="line"><a name="l00920"></a><span class="lineno">  920</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00921"></a><span class="lineno">  921</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00922"></a><span class="lineno">  922</span>&#160;                <span class="keywordflow">if</span> (pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00923"></a><span class="lineno">  923</span>&#160;                   <span class="keywordflow">if</span> (<span class="keyword">present</span>(array5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00924"></a><span class="lineno">  924</span>&#160;                      pcpointer%avect5%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00925"></a><span class="lineno">  925</span>&#160;                         pcpointer%avect5%rAttr(nfav,n) + array5(n)</div><div class="line"><a name="l00926"></a><span class="lineno">  926</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00927"></a><span class="lineno">  927</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00928"></a><span class="lineno">  928</span>&#160;<span class="keywordflow">             enddo</span></div><div class="line"><a name="l00929"></a><span class="lineno">  929</span>&#160;             pcpointer%avcnt(nfav) = pcpointer%avcnt(nfav) + 1</div><div class="line"><a name="l00930"></a><span class="lineno">  930</span>&#160;</div><div class="line"><a name="l00931"></a><span class="lineno">  931</span>&#160;          <span class="keywordflow">elseif</span> (pcpointer%trans == <a class="code" href="namespacemod__oasis__parameters.html#adfaf98517b8396e4ba667f2f8bcd0ed5">ip_accumul</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00932"></a><span class="lineno">  932</span>&#160;             cstring = <span class="stringliteral">&#39;accumul&#39;</span></div><div class="line"><a name="l00933"></a><span class="lineno">  933</span>&#160;             <span class="keywordflow">if</span> (kinfo == <a class="code" href="namespacemod__oasis__parameters.html#a3ea125963822918ce37fd3cfd9658c9f">oasis_ok</a>) kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a8b206cc178182e3526d400ea7a6587b5">oasis_loctrans</a></div><div class="line"><a name="l00934"></a><span class="lineno">  934</span>&#160;             <span class="keywordflow">do</span> n = 1,nsav</div><div class="line"><a name="l00935"></a><span class="lineno">  935</span>&#160;                pcpointer%avect1%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00936"></a><span class="lineno">  936</span>&#160;                   pcpointer%avect1%rAttr(nfav,n) + array1din(n)</div><div class="line"><a name="l00937"></a><span class="lineno">  937</span>&#160;                <span class="keywordflow">if</span> (pcpointer%aVon(2)) <span class="keywordflow">then</span></div><div class="line"><a name="l00938"></a><span class="lineno">  938</span>&#160;                   <span class="keywordflow">if</span> (<span class="keyword">present</span>(array2)) <span class="keywordflow">then</span></div><div class="line"><a name="l00939"></a><span class="lineno">  939</span>&#160;                      pcpointer%avect2%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00940"></a><span class="lineno">  940</span>&#160;                         pcpointer%avect2%rAttr(nfav,n) + array2(n)</div><div class="line"><a name="l00941"></a><span class="lineno">  941</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00942"></a><span class="lineno">  942</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00943"></a><span class="lineno">  943</span>&#160;                <span class="keywordflow">if</span> (pcpointer%aVon(3)) <span class="keywordflow">then</span></div><div class="line"><a name="l00944"></a><span class="lineno">  944</span>&#160;                   <span class="keywordflow">if</span> (<span class="keyword">present</span>(array3)) <span class="keywordflow">then</span></div><div class="line"><a name="l00945"></a><span class="lineno">  945</span>&#160;                      pcpointer%avect3%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00946"></a><span class="lineno">  946</span>&#160;                         pcpointer%avect3%rAttr(nfav,n) + array3(n)</div><div class="line"><a name="l00947"></a><span class="lineno">  947</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00948"></a><span class="lineno">  948</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00949"></a><span class="lineno">  949</span>&#160;                <span class="keywordflow">if</span> (pcpointer%aVon(4)) <span class="keywordflow">then</span></div><div class="line"><a name="l00950"></a><span class="lineno">  950</span>&#160;                   <span class="keywordflow">if</span> (<span class="keyword">present</span>(array4)) <span class="keywordflow">then</span></div><div class="line"><a name="l00951"></a><span class="lineno">  951</span>&#160;                      pcpointer%avect4%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00952"></a><span class="lineno">  952</span>&#160;                         pcpointer%avect4%rAttr(nfav,n) + array4(n)</div><div class="line"><a name="l00953"></a><span class="lineno">  953</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00954"></a><span class="lineno">  954</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00955"></a><span class="lineno">  955</span>&#160;                <span class="keywordflow">if</span> (pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00956"></a><span class="lineno">  956</span>&#160;                   <span class="keywordflow">if</span> (<span class="keyword">present</span>(array5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00957"></a><span class="lineno">  957</span>&#160;                      pcpointer%avect5%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00958"></a><span class="lineno">  958</span>&#160;                         pcpointer%avect5%rAttr(nfav,n) + array5(n)</div><div class="line"><a name="l00959"></a><span class="lineno">  959</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l00960"></a><span class="lineno">  960</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00961"></a><span class="lineno">  961</span>&#160;<span class="keywordflow">             enddo</span></div><div class="line"><a name="l00962"></a><span class="lineno">  962</span>&#160;             pcpointer%avcnt(nfav) = 1</div><div class="line"><a name="l00963"></a><span class="lineno">  963</span>&#160;</div><div class="line"><a name="l00964"></a><span class="lineno">  964</span>&#160;          <span class="keywordflow">elseif</span> (pcpointer%trans == <a class="code" href="namespacemod__oasis__parameters.html#abe7b7d586b50bd7c7d77c7834efa2801">ip_max</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00965"></a><span class="lineno">  965</span>&#160;             cstring = <span class="stringliteral">&#39;max&#39;</span></div><div class="line"><a name="l00966"></a><span class="lineno">  966</span>&#160;             <span class="keywordflow">if</span> (kinfo == <a class="code" href="namespacemod__oasis__parameters.html#a3ea125963822918ce37fd3cfd9658c9f">oasis_ok</a>) kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a8b206cc178182e3526d400ea7a6587b5">oasis_loctrans</a></div><div class="line"><a name="l00967"></a><span class="lineno">  967</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(2) .or. pcpointer%aVon(3) .or. &amp;</div><div class="line"><a name="l00968"></a><span class="lineno">  968</span>&#160;                 pcpointer%aVon(4) .or. pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00969"></a><span class="lineno">  969</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00970"></a><span class="lineno">  970</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;higher order mapping with MAX transform not supported&#39;</span></div><div class="line"><a name="l00971"></a><span class="lineno">  971</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)      </div><div class="line"><a name="l00972"></a><span class="lineno">  972</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l00973"></a><span class="lineno">  973</span>&#160;             <span class="keywordflow">do</span> n = 1,nsav</div><div class="line"><a name="l00974"></a><span class="lineno">  974</span>&#160;                <span class="keywordflow">if</span> (pcpointer%avcnt(nfav) == 0) <span class="keywordflow">then</span></div><div class="line"><a name="l00975"></a><span class="lineno">  975</span>&#160;                   pcpointer%avect1%rAttr(nfav,n) = array1din(n)</div><div class="line"><a name="l00976"></a><span class="lineno">  976</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l00977"></a><span class="lineno">  977</span>&#160;                   pcpointer%avect1%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00978"></a><span class="lineno">  978</span>&#160;                      max(pcpointer%avect1%rAttr(nfav,n),array1din(n))</div><div class="line"><a name="l00979"></a><span class="lineno">  979</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00980"></a><span class="lineno">  980</span>&#160;<span class="keywordflow">             enddo</span></div><div class="line"><a name="l00981"></a><span class="lineno">  981</span>&#160;             pcpointer%avcnt(nfav) = 1</div><div class="line"><a name="l00982"></a><span class="lineno">  982</span>&#160;</div><div class="line"><a name="l00983"></a><span class="lineno">  983</span>&#160;          <span class="keywordflow">elseif</span> (pcpointer%trans == <a class="code" href="namespacemod__oasis__parameters.html#a194cfc3b7f2d515492e04fd6e8931c60">ip_min</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l00984"></a><span class="lineno">  984</span>&#160;             cstring = <span class="stringliteral">&#39;min&#39;</span></div><div class="line"><a name="l00985"></a><span class="lineno">  985</span>&#160;             <span class="keywordflow">if</span> (kinfo == <a class="code" href="namespacemod__oasis__parameters.html#a3ea125963822918ce37fd3cfd9658c9f">oasis_ok</a>) kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a8b206cc178182e3526d400ea7a6587b5">oasis_loctrans</a></div><div class="line"><a name="l00986"></a><span class="lineno">  986</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(2) .or. pcpointer%aVon(3) .or. &amp;</div><div class="line"><a name="l00987"></a><span class="lineno">  987</span>&#160;                 pcpointer%aVon(4) .or. pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l00988"></a><span class="lineno">  988</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l00989"></a><span class="lineno">  989</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;higher order mapping with MIN transform not supported&#39;</span></div><div class="line"><a name="l00990"></a><span class="lineno">  990</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)      </div><div class="line"><a name="l00991"></a><span class="lineno">  991</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l00992"></a><span class="lineno">  992</span>&#160;             <span class="keywordflow">do</span> n = 1,nsav</div><div class="line"><a name="l00993"></a><span class="lineno">  993</span>&#160;                <span class="keywordflow">if</span> (pcpointer%avcnt(nfav) == 0) <span class="keywordflow">then</span></div><div class="line"><a name="l00994"></a><span class="lineno">  994</span>&#160;                   pcpointer%avect1%rAttr(nfav,n) = array1din(n)</div><div class="line"><a name="l00995"></a><span class="lineno">  995</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l00996"></a><span class="lineno">  996</span>&#160;                   pcpointer%avect1%rAttr(nfav,n) = &amp;</div><div class="line"><a name="l00997"></a><span class="lineno">  997</span>&#160;                      min(pcpointer%avect1%rAttr(nfav,n),array1din(n))</div><div class="line"><a name="l00998"></a><span class="lineno">  998</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l00999"></a><span class="lineno">  999</span>&#160;<span class="keywordflow">             enddo</span></div><div class="line"><a name="l01000"></a><span class="lineno"> 1000</span>&#160;             pcpointer%avcnt(nfav) = 1</div><div class="line"><a name="l01001"></a><span class="lineno"> 1001</span>&#160;</div><div class="line"><a name="l01002"></a><span class="lineno"> 1002</span>&#160;          <span class="keywordflow">else</span></div><div class="line"><a name="l01003"></a><span class="lineno"> 1003</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;transform not known for var = &#39;</span>,trim(vname),pcpointer%trans</div><div class="line"><a name="l01004"></a><span class="lineno"> 1004</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01005"></a><span class="lineno"> 1005</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01006"></a><span class="lineno"> 1006</span>&#160;          <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01007"></a><span class="lineno"> 1007</span>&#160;</div><div class="line"><a name="l01008"></a><span class="lineno"> 1008</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2 .and. trim(cstring) /= <span class="stringliteral">&#39;none&#39;</span>) <span class="keywordflow">then</span></div><div class="line"><a name="l01009"></a><span class="lineno"> 1009</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; PACK: &#39;</span>,&amp;</div><div class="line"><a name="l01010"></a><span class="lineno"> 1010</span>&#160;                             trim(vname),<span class="stringliteral">&#39; &#39;</span>,trim(cstring)</div><div class="line"><a name="l01011"></a><span class="lineno"> 1011</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01012"></a><span class="lineno"> 1012</span>&#160;</div><div class="line"><a name="l01013"></a><span class="lineno"> 1013</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01014"></a><span class="lineno"> 1014</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG loctrans update &#39;</span>,cplid,<span class="stringliteral">&#39; &#39;</span>,&amp;</div><div class="line"><a name="l01015"></a><span class="lineno"> 1015</span>&#160;             trim(cstring),pcpointer%avcnt(nfav)</div><div class="line"><a name="l01016"></a><span class="lineno"> 1016</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01017"></a><span class="lineno"> 1017</span>&#160;</div><div class="line"><a name="l01018"></a><span class="lineno"> 1018</span>&#160;          <span class="keywordflow">if</span> (time_now) <span class="keywordflow">then</span></div><div class="line"><a name="l01019"></a><span class="lineno"> 1019</span>&#160;             pcpointer%status(nfav) = <a class="code" href="namespacemod__oasis__parameters.html#a8484e196ef7469adbeaef850787d7502">oasis_comm_ready</a></div><div class="line"><a name="l01020"></a><span class="lineno"> 1020</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01021"></a><span class="lineno"> 1021</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01022"></a><span class="lineno"> 1022</span>&#160;</div><div class="line"><a name="l01023"></a><span class="lineno"> 1023</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01024"></a><span class="lineno"> 1024</span>&#160;<span class="comment">       !&gt;   * decide if it&#39;s time to communicate based on time</span></div><div class="line"><a name="l01025"></a><span class="lineno"> 1025</span>&#160;       <span class="comment">! also, on the put side, status of all vars</span></div><div class="line"><a name="l01026"></a><span class="lineno"> 1026</span>&#160;       <span class="comment">! must be ready which means all vars have called put.</span></div><div class="line"><a name="l01027"></a><span class="lineno"> 1027</span>&#160;       <span class="comment">! on get side, all ready means all vars have unpacked</span></div><div class="line"><a name="l01028"></a><span class="lineno"> 1028</span>&#160;       <span class="comment">! from last get.</span></div><div class="line"><a name="l01029"></a><span class="lineno"> 1029</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01030"></a><span class="lineno"> 1030</span>&#160;</div><div class="line"><a name="l01031"></a><span class="lineno"> 1031</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; comm_now compute&#39;</span>)</div><div class="line"><a name="l01032"></a><span class="lineno"> 1032</span>&#160;       comm_now = .false.</div><div class="line"><a name="l01033"></a><span class="lineno"> 1033</span>&#160;       <span class="keywordflow">if</span> (time_now) <span class="keywordflow">then</span></div><div class="line"><a name="l01034"></a><span class="lineno"> 1034</span>&#160;          comm_now = .true.</div><div class="line"><a name="l01035"></a><span class="lineno"> 1035</span>&#160;          <span class="keywordflow">do</span> nf = 1,pcpointer%nflds</div><div class="line"><a name="l01036"></a><span class="lineno"> 1036</span>&#160;             <span class="keywordflow">if</span> (pcpointer%status(nf) /= <a class="code" href="namespacemod__oasis__parameters.html#a8484e196ef7469adbeaef850787d7502">oasis_comm_ready</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01037"></a><span class="lineno"> 1037</span>&#160;                comm_now = .false.</div><div class="line"><a name="l01038"></a><span class="lineno"> 1038</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 15) <span class="keywordflow">then</span></div><div class="line"><a name="l01039"></a><span class="lineno"> 1039</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; STAT: &#39;</span>,nf,<span class="stringliteral">&#39; NOT READY&#39;</span></div><div class="line"><a name="l01040"></a><span class="lineno"> 1040</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01041"></a><span class="lineno"> 1041</span>&#160;                 kinfo=<a class="code" href="namespacemod__oasis__parameters.html#a2cc23572d33c536d49a53587359b68f0">oasis_waitgroup</a></div><div class="line"><a name="l01042"></a><span class="lineno"> 1042</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l01043"></a><span class="lineno"> 1043</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 15) <span class="keywordflow">then</span></div><div class="line"><a name="l01044"></a><span class="lineno"> 1044</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; STAT: &#39;</span>,nf,<span class="stringliteral">&#39; READY&#39;</span></div><div class="line"><a name="l01045"></a><span class="lineno"> 1045</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01046"></a><span class="lineno"> 1046</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01047"></a><span class="lineno"> 1047</span>&#160;<span class="keywordflow">          enddo</span></div><div class="line"><a name="l01048"></a><span class="lineno"> 1048</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01049"></a><span class="lineno"> 1049</span>&#160;</div><div class="line"><a name="l01050"></a><span class="lineno"> 1050</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01051"></a><span class="lineno"> 1051</span>&#160;<span class="comment">       !&gt;   * If it&#39;s time to communicate</span></div><div class="line"><a name="l01052"></a><span class="lineno"> 1052</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01053"></a><span class="lineno"> 1053</span>&#160;</div><div class="line"><a name="l01054"></a><span class="lineno"> 1054</span>&#160;       <span class="keywordflow">if</span> (comm_now) <span class="keywordflow">then</span></div><div class="line"><a name="l01055"></a><span class="lineno"> 1055</span>&#160;</div><div class="line"><a name="l01056"></a><span class="lineno"> 1056</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; comm_now&#39;</span>)</div><div class="line"><a name="l01057"></a><span class="lineno"> 1057</span>&#160;</div><div class="line"><a name="l01058"></a><span class="lineno"> 1058</span>&#160;          <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01059"></a><span class="lineno"> 1059</span>&#160;<span class="comment">          !&gt;     * check again that time is correct</span></div><div class="line"><a name="l01060"></a><span class="lineno"> 1060</span>&#160;          <span class="comment">! this is the time critical bit, we need to make sure the</span></div><div class="line"><a name="l01061"></a><span class="lineno"> 1061</span>&#160;          <span class="comment">! model is truly advancing in time when comms are called.</span></div><div class="line"><a name="l01062"></a><span class="lineno"> 1062</span>&#160;          <span class="comment">! must ignore the initial call, ltime = 0</span></div><div class="line"><a name="l01063"></a><span class="lineno"> 1063</span>&#160;          <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01064"></a><span class="lineno"> 1064</span>&#160;</div><div class="line"><a name="l01065"></a><span class="lineno"> 1065</span>&#160;          <span class="keywordflow">if</span> (pcpointer%ltime /= <a class="code" href="namespacemod__oasis__data.html#a66bd35eca1454b6d8c8ac0449f2ca475">ispval</a> .and. msec &lt;= pcpointer%ltime) <span class="keywordflow">then</span></div><div class="line"><a name="l01066"></a><span class="lineno"> 1066</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;model did not advance in time correctly for var = &#39;</span>,trim(vname)</div><div class="line"><a name="l01067"></a><span class="lineno"> 1067</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;msec, ltime = &#39;</span>,msec,pcpointer%ltime</div><div class="line"><a name="l01068"></a><span class="lineno"> 1068</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01069"></a><span class="lineno"> 1069</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01070"></a><span class="lineno"> 1070</span>&#160;</div><div class="line"><a name="l01071"></a><span class="lineno"> 1071</span>&#160;          <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01072"></a><span class="lineno"> 1072</span>&#160;<span class="comment">          !&gt;     * average as needed for some transforms</span></div><div class="line"><a name="l01073"></a><span class="lineno"> 1073</span>&#160;          <span class="comment">! (not cache friendly yet)</span></div><div class="line"><a name="l01074"></a><span class="lineno"> 1074</span>&#160;          <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01075"></a><span class="lineno"> 1075</span>&#160;</div><div class="line"><a name="l01076"></a><span class="lineno"> 1076</span>&#160;          <span class="keywordflow">if</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01077"></a><span class="lineno"> 1077</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; loctrans calc&#39;</span>)</div><div class="line"><a name="l01078"></a><span class="lineno"> 1078</span>&#160;             <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;pavg_&#39;</span>,cplid</div><div class="line"><a name="l01079"></a><span class="lineno"> 1079</span>&#160;             <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01080"></a><span class="lineno"> 1080</span>&#160;             <span class="keywordflow">do</span> nf = 1,pcpointer%nflds</div><div class="line"><a name="l01081"></a><span class="lineno"> 1081</span>&#160;                <span class="keywordflow">if</span> (pcpointer%avcnt(nf) &gt; 1) <span class="keywordflow">then</span></div><div class="line"><a name="l01082"></a><span class="lineno"> 1082</span>&#160;                   rcnt = 1.0/pcpointer%avcnt(nf)</div><div class="line"><a name="l01083"></a><span class="lineno"> 1083</span>&#160;                   <span class="keywordflow">do</span> n = 1,nsav</div><div class="line"><a name="l01084"></a><span class="lineno"> 1084</span>&#160;                      pcpointer%avect1%rAttr(nf,n) = &amp;</div><div class="line"><a name="l01085"></a><span class="lineno"> 1085</span>&#160;                         pcpointer%avect1%rAttr(nf,n) * rcnt</div><div class="line"><a name="l01086"></a><span class="lineno"> 1086</span>&#160;                      <span class="keywordflow">if</span> (pcpointer%aVon(2)) <span class="keywordflow">then</span></div><div class="line"><a name="l01087"></a><span class="lineno"> 1087</span>&#160;                         pcpointer%avect2%rAttr(nf,n) = &amp;</div><div class="line"><a name="l01088"></a><span class="lineno"> 1088</span>&#160;                            pcpointer%avect2%rAttr(nf,n) * rcnt</div><div class="line"><a name="l01089"></a><span class="lineno"> 1089</span>&#160;<span class="keywordflow">                      endif</span></div><div class="line"><a name="l01090"></a><span class="lineno"> 1090</span>&#160;                      <span class="keywordflow">if</span> (pcpointer%aVon(3)) <span class="keywordflow">then</span></div><div class="line"><a name="l01091"></a><span class="lineno"> 1091</span>&#160;                         pcpointer%avect3%rAttr(nf,n) = &amp;</div><div class="line"><a name="l01092"></a><span class="lineno"> 1092</span>&#160;                            pcpointer%avect3%rAttr(nf,n) * rcnt</div><div class="line"><a name="l01093"></a><span class="lineno"> 1093</span>&#160;<span class="keywordflow">                      endif</span></div><div class="line"><a name="l01094"></a><span class="lineno"> 1094</span>&#160;                      <span class="keywordflow">if</span> (pcpointer%aVon(4)) <span class="keywordflow">then</span></div><div class="line"><a name="l01095"></a><span class="lineno"> 1095</span>&#160;                         pcpointer%avect4%rAttr(nf,n) = &amp;</div><div class="line"><a name="l01096"></a><span class="lineno"> 1096</span>&#160;                            pcpointer%avect4%rAttr(nf,n) * rcnt</div><div class="line"><a name="l01097"></a><span class="lineno"> 1097</span>&#160;<span class="keywordflow">                      endif</span></div><div class="line"><a name="l01098"></a><span class="lineno"> 1098</span>&#160;                      <span class="keywordflow">if</span> (pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l01099"></a><span class="lineno"> 1099</span>&#160;                         pcpointer%avect5%rAttr(nf,n) = &amp;</div><div class="line"><a name="l01100"></a><span class="lineno"> 1100</span>&#160;                            pcpointer%avect5%rAttr(nf,n) * rcnt</div><div class="line"><a name="l01101"></a><span class="lineno"> 1101</span>&#160;<span class="keywordflow">                      endif</span></div><div class="line"><a name="l01102"></a><span class="lineno"> 1102</span>&#160;<span class="keywordflow">                   enddo</span>             </div><div class="line"><a name="l01103"></a><span class="lineno"> 1103</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01104"></a><span class="lineno"> 1104</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01105"></a><span class="lineno"> 1105</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG loctrans calc0 = &#39;</span>,cplid,nf,&amp;</div><div class="line"><a name="l01106"></a><span class="lineno"> 1106</span>&#160;                                   pcpointer%avcnt(nf)</div><div class="line"><a name="l01107"></a><span class="lineno"> 1107</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG loctrans calc1 = &#39;</span>,cplid,nf,&amp;</div><div class="line"><a name="l01108"></a><span class="lineno"> 1108</span>&#160;                                   minval(pcpointer%avect1%rAttr(nf,:)),&amp;</div><div class="line"><a name="l01109"></a><span class="lineno"> 1109</span>&#160;                                   maxval(pcpointer%avect1%rAttr(nf,:))</div><div class="line"><a name="l01110"></a><span class="lineno"> 1110</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01111"></a><span class="lineno"> 1111</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(2)) &amp;</div><div class="line"><a name="l01112"></a><span class="lineno"> 1112</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG loctrans calc2 = &#39;</span>,cplid,nf,&amp;</div><div class="line"><a name="l01113"></a><span class="lineno"> 1113</span>&#160;                                   minval(pcpointer%avect2%rAttr(nf,:)),&amp;</div><div class="line"><a name="l01114"></a><span class="lineno"> 1114</span>&#160;                                   maxval(pcpointer%avect2%rAttr(nf,:))</div><div class="line"><a name="l01115"></a><span class="lineno"> 1115</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(3)) &amp;</div><div class="line"><a name="l01116"></a><span class="lineno"> 1116</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG loctrans calc3 = &#39;</span>,cplid,nf,&amp;</div><div class="line"><a name="l01117"></a><span class="lineno"> 1117</span>&#160;                                   minval(pcpointer%avect3%rAttr(nf,:)),&amp;</div><div class="line"><a name="l01118"></a><span class="lineno"> 1118</span>&#160;                                   maxval(pcpointer%avect3%rAttr(nf,:))</div><div class="line"><a name="l01119"></a><span class="lineno"> 1119</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(4)) &amp;</div><div class="line"><a name="l01120"></a><span class="lineno"> 1120</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG loctrans calc4 = &#39;</span>,cplid,nf,&amp;</div><div class="line"><a name="l01121"></a><span class="lineno"> 1121</span>&#160;                                   minval(pcpointer%avect4%rAttr(nf,:)),&amp;</div><div class="line"><a name="l01122"></a><span class="lineno"> 1122</span>&#160;                                   maxval(pcpointer%avect4%rAttr(nf,:))</div><div class="line"><a name="l01123"></a><span class="lineno"> 1123</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(5)) &amp;</div><div class="line"><a name="l01124"></a><span class="lineno"> 1124</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG loctrans calc5 = &#39;</span>,cplid,nf,&amp;</div><div class="line"><a name="l01125"></a><span class="lineno"> 1125</span>&#160;                                   minval(pcpointer%avect5%rAttr(nf,:)),&amp;</div><div class="line"><a name="l01126"></a><span class="lineno"> 1126</span>&#160;                                   maxval(pcpointer%avect5%rAttr(nf,:))</div><div class="line"><a name="l01127"></a><span class="lineno"> 1127</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01128"></a><span class="lineno"> 1128</span>&#160;<span class="keywordflow">             enddo</span>             </div><div class="line"><a name="l01129"></a><span class="lineno"> 1129</span>&#160;             <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01130"></a><span class="lineno"> 1130</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01131"></a><span class="lineno"> 1131</span>&#160;</div><div class="line"><a name="l01132"></a><span class="lineno"> 1132</span>&#160;          <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01133"></a><span class="lineno"> 1133</span>&#160;<span class="comment">          !&gt;     * write to restart file if put and at the end of the run, </span></div><div class="line"><a name="l01134"></a><span class="lineno"> 1134</span>&#160;<span class="comment">          !&gt;       turn off communication</span></div><div class="line"><a name="l01135"></a><span class="lineno"> 1135</span>&#160;          <span class="comment">! past namcouple runtime (maxtime) no communication</span></div><div class="line"><a name="l01136"></a><span class="lineno"> 1136</span>&#160;          <span class="comment">! do restart if time+lag = maxtime, this assumes coupling</span></div><div class="line"><a name="l01137"></a><span class="lineno"> 1137</span>&#160;          <span class="comment">! period and lag and maxtime are all nicely consistent</span></div><div class="line"><a name="l01138"></a><span class="lineno"> 1138</span>&#160;          <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01139"></a><span class="lineno"> 1139</span>&#160;</div><div class="line"><a name="l01140"></a><span class="lineno"> 1140</span>&#160;          <span class="keywordflow">if</span> (mseclag &gt;= maxtime) <span class="keywordflow">then</span></div><div class="line"><a name="l01141"></a><span class="lineno"> 1141</span>&#160;             sndrcv = .false.   <span class="comment">! turn off communication</span></div><div class="line"><a name="l01142"></a><span class="lineno"> 1142</span>&#160;             unpack = .false.   <span class="comment">! nothing to unpack</span></div><div class="line"><a name="l01143"></a><span class="lineno"> 1143</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01144"></a><span class="lineno"> 1144</span>&#160;</div><div class="line"><a name="l01145"></a><span class="lineno"> 1145</span>&#160;          <span class="keywordflow">if</span> (len_trim(rstfile) &gt; 0) <span class="keywordflow">then</span></div><div class="line"><a name="l01146"></a><span class="lineno"> 1146</span>&#160;          <span class="keywordflow">if</span> ((getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a> .and. lag &gt; 0 .and. mseclag == maxtime) .or. &amp;</div><div class="line"><a name="l01147"></a><span class="lineno"> 1147</span>&#160;              (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a> .and. pcpointer%writrest)) <span class="keywordflow">then</span></div><div class="line"><a name="l01148"></a><span class="lineno"> 1148</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; lag restart write&#39;</span>)</div><div class="line"><a name="l01149"></a><span class="lineno"> 1149</span>&#160;</div><div class="line"><a name="l01150"></a><span class="lineno"> 1150</span>&#160;             <span class="keywordflow">if</span> (lag &gt; 0 .and. mseclag == maxtime) <span class="keywordflow">then</span></div><div class="line"><a name="l01151"></a><span class="lineno"> 1151</span>&#160;                kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a875abcc1cc679cb72f20d42d3dbfac97">oasis_torest</a></div><div class="line"><a name="l01152"></a><span class="lineno"> 1152</span>&#160;                rstfile2 = rstfile</div><div class="line"><a name="l01153"></a><span class="lineno"> 1153</span>&#160;             <span class="keywordflow">else</span>  <span class="comment">! writrest</span></div><div class="line"><a name="l01154"></a><span class="lineno"> 1154</span>&#160;                pcpointer%writrest = .false.</div><div class="line"><a name="l01155"></a><span class="lineno"> 1155</span>&#160;                <span class="keyword">write</span>(rstfile2,<span class="stringliteral">&#39;(a,i9.9,a,a)&#39;</span>) <span class="stringliteral">&#39;TC&#39;</span>,msec,<span class="stringliteral">&#39;_&#39;</span>,trim(rstfile)</div><div class="line"><a name="l01156"></a><span class="lineno"> 1156</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01157"></a><span class="lineno"> 1157</span>&#160;</div><div class="line"><a name="l01158"></a><span class="lineno"> 1158</span>&#160;             <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;wrst_&#39;</span>,cplid</div><div class="line"><a name="l01159"></a><span class="lineno"> 1159</span>&#160;             <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01160"></a><span class="lineno"> 1160</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect1, &amp;</div><div class="line"><a name="l01161"></a><span class="lineno"> 1161</span>&#160;                <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny)</div><div class="line"><a name="l01162"></a><span class="lineno"> 1162</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(2)) &amp;</div><div class="line"><a name="l01163"></a><span class="lineno"> 1163</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect2, &amp;</div><div class="line"><a name="l01164"></a><span class="lineno"> 1164</span>&#160;                   <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=<span class="stringliteral">&#39;av2_&#39;</span>)</div><div class="line"><a name="l01165"></a><span class="lineno"> 1165</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(3)) &amp;</div><div class="line"><a name="l01166"></a><span class="lineno"> 1166</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect3, &amp;</div><div class="line"><a name="l01167"></a><span class="lineno"> 1167</span>&#160;                   <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=<span class="stringliteral">&#39;av3_&#39;</span>)</div><div class="line"><a name="l01168"></a><span class="lineno"> 1168</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(4)) &amp;</div><div class="line"><a name="l01169"></a><span class="lineno"> 1169</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect4, &amp;</div><div class="line"><a name="l01170"></a><span class="lineno"> 1170</span>&#160;                   <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=<span class="stringliteral">&#39;av4_&#39;</span>)</div><div class="line"><a name="l01171"></a><span class="lineno"> 1171</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(5)) &amp;</div><div class="line"><a name="l01172"></a><span class="lineno"> 1172</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect5, &amp;</div><div class="line"><a name="l01173"></a><span class="lineno"> 1173</span>&#160;                   <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=<span class="stringliteral">&#39;av5_&#39;</span>)</div><div class="line"><a name="l01174"></a><span class="lineno"> 1174</span>&#160;             <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01175"></a><span class="lineno"> 1175</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l01176"></a><span class="lineno"> 1176</span>&#160;                lstring = mct_avect_exportrlist2c(pcpointer%avect1)</div><div class="line"><a name="l01177"></a><span class="lineno"> 1177</span>&#160;                llstring = len_trim(lstring)</div><div class="line"><a name="l01178"></a><span class="lineno"> 1178</span>&#160;                <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01179"></a><span class="lineno"> 1179</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; WRST: &#39;</span>, &amp;</div><div class="line"><a name="l01180"></a><span class="lineno"> 1180</span>&#160;                      trim(lstring),<span class="stringliteral">&#39; &#39;</span>,trim(rstfile2)</div><div class="line"><a name="l01181"></a><span class="lineno"> 1181</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l01182"></a><span class="lineno"> 1182</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; WRST: &#39;</span>, lstring(1:20), &amp;</div><div class="line"><a name="l01183"></a><span class="lineno"> 1183</span>&#160;                      lstring(21:llstring),<span class="stringliteral">&#39; &#39;</span>,trim(rstfile2)</div><div class="line"><a name="l01184"></a><span class="lineno"> 1184</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01185"></a><span class="lineno"> 1185</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01186"></a><span class="lineno"> 1186</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01187"></a><span class="lineno"> 1187</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01188"></a><span class="lineno"> 1188</span>&#160;<span class="keywordflow">          endif</span>  <span class="comment">! len_trim(rstfile)</span></div><div class="line"><a name="l01189"></a><span class="lineno"> 1189</span>&#160;</div><div class="line"><a name="l01190"></a><span class="lineno"> 1190</span>&#160;          <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01191"></a><span class="lineno"> 1191</span>&#160;<span class="comment">          !&gt;     * map and communicate operations</span></div><div class="line"><a name="l01192"></a><span class="lineno"> 1192</span>&#160;          <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01193"></a><span class="lineno"> 1193</span>&#160;</div><div class="line"><a name="l01194"></a><span class="lineno"> 1194</span>&#160;          <span class="keywordflow">if</span> (sndrcv) <span class="keywordflow">then</span></div><div class="line"><a name="l01195"></a><span class="lineno"> 1195</span>&#160;          <span class="keywordflow">if</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01196"></a><span class="lineno"> 1196</span>&#160;             kinfo = <a class="code" href="namespacemod__oasis__parameters.html#af739945ec2da833423cdc6e220e1c847">oasis_sent</a></div><div class="line"><a name="l01197"></a><span class="lineno"> 1197</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; put section&#39;</span>)</div><div class="line"><a name="l01198"></a><span class="lineno"> 1198</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l01199"></a><span class="lineno"> 1199</span>&#160;                lstring = mct_avect_exportrlist2c(pcpointer%avect1)</div><div class="line"><a name="l01200"></a><span class="lineno"> 1200</span>&#160;                llstring = len_trim(lstring)</div><div class="line"><a name="l01201"></a><span class="lineno"> 1201</span>&#160;                <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01202"></a><span class="lineno"> 1202</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; SEND: &#39;</span>, &amp;</div><div class="line"><a name="l01203"></a><span class="lineno"> 1203</span>&#160;                      trim(lstring)</div><div class="line"><a name="l01204"></a><span class="lineno"> 1204</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l01205"></a><span class="lineno"> 1205</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; SEND: &#39;</span>,lstring(1:20), &amp;</div><div class="line"><a name="l01206"></a><span class="lineno"> 1206</span>&#160;                      lstring(21:llstring)</div><div class="line"><a name="l01207"></a><span class="lineno"> 1207</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01208"></a><span class="lineno"> 1208</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01209"></a><span class="lineno"> 1209</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01210"></a><span class="lineno"> 1210</span>&#160;             <span class="keywordflow">if</span> (sndadd /= 0.0_ip_double_p .or. sndmult /= 1.0_ip_double_p) <span class="keywordflow">then</span></div><div class="line"><a name="l01211"></a><span class="lineno"> 1211</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; apply sndmult sndadd&#39;</span>)</div><div class="line"><a name="l01212"></a><span class="lineno"> 1212</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01213"></a><span class="lineno"> 1213</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG sndmult,add = &#39;</span>,sndmult,sndadd</div><div class="line"><a name="l01214"></a><span class="lineno"> 1214</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put b4 sndmult,add = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01215"></a><span class="lineno"> 1215</span>&#160;                                   minval(pcpointer%avect1%rAttr),&amp;</div><div class="line"><a name="l01216"></a><span class="lineno"> 1216</span>&#160;                                   maxval(pcpointer%avect1%rAttr)</div><div class="line"><a name="l01217"></a><span class="lineno"> 1217</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01218"></a><span class="lineno"> 1218</span>&#160;                pcpointer%avect1%rAttr(:,:) = pcpointer%avect1%rAttr(:,:)*sndmult &amp;</div><div class="line"><a name="l01219"></a><span class="lineno"> 1219</span>&#160;                                                         + sndadd</div><div class="line"><a name="l01220"></a><span class="lineno"> 1220</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01221"></a><span class="lineno"> 1221</span>&#160;             <span class="keywordflow">if</span> (snddiag) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#af611b26fe4601ded488fd5d3c03b12a2">oasis_advance_avdiag</a>(pcpointer%avect1,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom)</div><div class="line"><a name="l01222"></a><span class="lineno"> 1222</span>&#160;             <span class="keywordflow">if</span> (mapid &gt; 0) <span class="keywordflow">then</span></div><div class="line"><a name="l01223"></a><span class="lineno"> 1223</span>&#160;                <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;pmap_&#39;</span>,cplid</div><div class="line"><a name="l01224"></a><span class="lineno"> 1224</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; put map&#39;</span>)</div><div class="line"><a name="l01225"></a><span class="lineno"> 1225</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01226"></a><span class="lineno"> 1226</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put av11 b4 map = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01227"></a><span class="lineno"> 1227</span>&#160;                                   minval(pcpointer%avect1%rAttr),&amp;</div><div class="line"><a name="l01228"></a><span class="lineno"> 1228</span>&#160;                                   maxval(pcpointer%avect1%rAttr)</div><div class="line"><a name="l01229"></a><span class="lineno"> 1229</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(2)) &amp;</div><div class="line"><a name="l01230"></a><span class="lineno"> 1230</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put av2 b4 map = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01231"></a><span class="lineno"> 1231</span>&#160;                                   minval(pcpointer%avect2%rAttr),&amp;</div><div class="line"><a name="l01232"></a><span class="lineno"> 1232</span>&#160;                                   maxval(pcpointer%avect2%rAttr)</div><div class="line"><a name="l01233"></a><span class="lineno"> 1233</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(3)) &amp;</div><div class="line"><a name="l01234"></a><span class="lineno"> 1234</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put av3 b4 map = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01235"></a><span class="lineno"> 1235</span>&#160;                                   minval(pcpointer%avect3%rAttr),&amp;</div><div class="line"><a name="l01236"></a><span class="lineno"> 1236</span>&#160;                                   maxval(pcpointer%avect3%rAttr)</div><div class="line"><a name="l01237"></a><span class="lineno"> 1237</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(4)) &amp;</div><div class="line"><a name="l01238"></a><span class="lineno"> 1238</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put av4 b4 map = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01239"></a><span class="lineno"> 1239</span>&#160;                                   minval(pcpointer%avect4%rAttr),&amp;</div><div class="line"><a name="l01240"></a><span class="lineno"> 1240</span>&#160;                                   maxval(pcpointer%avect4%rAttr)</div><div class="line"><a name="l01241"></a><span class="lineno"> 1241</span>&#160;                   <span class="keywordflow">if</span> (pcpointer%aVon(5)) &amp;</div><div class="line"><a name="l01242"></a><span class="lineno"> 1242</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put av5 b4 map = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01243"></a><span class="lineno"> 1243</span>&#160;                                   minval(pcpointer%avect5%rAttr),&amp;</div><div class="line"><a name="l01244"></a><span class="lineno"> 1244</span>&#160;                                   maxval(pcpointer%avect5%rAttr)</div><div class="line"><a name="l01245"></a><span class="lineno"> 1245</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01246"></a><span class="lineno"> 1246</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__advance.html#ac617024af9299c27eaeb9156f647b028">map_barrier</a> .and. <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom /= mpi_comm_null) <span class="keywordflow">then</span></div><div class="line"><a name="l01247"></a><span class="lineno"> 1247</span>&#160;                   <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstring)//<span class="stringliteral">&#39;_prebarrier&#39;</span>)</div><div class="line"><a name="l01248"></a><span class="lineno"> 1248</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__mpi.html#aaf477847380fbbbc1341520b0b3e66da">oasis_mpi_barrier</a>(<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, trim(tstring))</div><div class="line"><a name="l01249"></a><span class="lineno"> 1249</span>&#160;                   <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstring)//<span class="stringliteral">&#39;_prebarrier&#39;</span>)</div><div class="line"><a name="l01250"></a><span class="lineno"> 1250</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01251"></a><span class="lineno"> 1251</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01252"></a><span class="lineno"> 1252</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01253"></a><span class="lineno"> 1253</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01254"></a><span class="lineno"> 1254</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; Before interpo &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01255"></a><span class="lineno"> 1255</span>&#160;                <span class="keyword">call </span>mct_avect_zero(pcpointer%avect1m)</div><div class="line"><a name="l01256"></a><span class="lineno"> 1256</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__advance.html#aad8e5c2e16b0270a7da0800a14ae1e07">detailed_map_timing</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01257"></a><span class="lineno"> 1257</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#a0514c843d051b8ee16adfb349eaee6a7">oasis_advance_map</a>(pcpointer%avect1, &amp;</div><div class="line"><a name="l01258"></a><span class="lineno"> 1258</span>&#160;                        pcpointer%avect1m,<a class="code" href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">prism_mapper</a>(mapid),conserv,consopt, &amp;</div><div class="line"><a name="l01259"></a><span class="lineno"> 1259</span>&#160;                        pcpointer%aVon  ,pcpointer%avect2, &amp;</div><div class="line"><a name="l01260"></a><span class="lineno"> 1260</span>&#160;                        pcpointer%avect3,pcpointer%avect4, &amp;</div><div class="line"><a name="l01261"></a><span class="lineno"> 1261</span>&#160;                        pcpointer%avect5,tstrinp=tstring)</div><div class="line"><a name="l01262"></a><span class="lineno"> 1262</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l01263"></a><span class="lineno"> 1263</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#a0514c843d051b8ee16adfb349eaee6a7">oasis_advance_map</a>(pcpointer%avect1, &amp;</div><div class="line"><a name="l01264"></a><span class="lineno"> 1264</span>&#160;                        pcpointer%avect1m,<a class="code" href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">prism_mapper</a>(mapid),conserv,consopt, &amp;</div><div class="line"><a name="l01265"></a><span class="lineno"> 1265</span>&#160;                        pcpointer%aVon  ,pcpointer%avect2, &amp;</div><div class="line"><a name="l01266"></a><span class="lineno"> 1266</span>&#160;                        pcpointer%avect3,pcpointer%avect4, &amp;</div><div class="line"><a name="l01267"></a><span class="lineno"> 1267</span>&#160;                        pcpointer%avect5)</div><div class="line"><a name="l01268"></a><span class="lineno"> 1268</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01269"></a><span class="lineno"> 1269</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01270"></a><span class="lineno"> 1270</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01271"></a><span class="lineno"> 1271</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; After  interpo &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01272"></a><span class="lineno"> 1272</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01273"></a><span class="lineno"> 1273</span>&#160;                <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;psnd_&#39;</span>,cplid</div><div class="line"><a name="l01274"></a><span class="lineno"> 1274</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; put send&#39;</span>)</div><div class="line"><a name="l01275"></a><span class="lineno"> 1275</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01276"></a><span class="lineno"> 1276</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put av1m b4 send = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01277"></a><span class="lineno"> 1277</span>&#160;                                   minval(pcpointer%avect1m%rAttr),&amp;</div><div class="line"><a name="l01278"></a><span class="lineno"> 1278</span>&#160;                                   maxval(pcpointer%avect1m%rAttr)</div><div class="line"><a name="l01279"></a><span class="lineno"> 1279</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01280"></a><span class="lineno"> 1280</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01281"></a><span class="lineno"> 1281</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01282"></a><span class="lineno"> 1282</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01283"></a><span class="lineno"> 1283</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; Before MPI put &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01284"></a><span class="lineno"> 1284</span>&#160;                <span class="keyword">call </span>mct_waitsend(<a class="code" href="namespacemod__oasis__coupler.html#a33dbf692ad73f83f73fe083e252badd8">prism_router</a>(rouid)%router)</div><div class="line"><a name="l01285"></a><span class="lineno"> 1285</span>&#160;                <span class="keyword">call </span>mct_isend(pcpointer%avect1m,<a class="code" href="namespacemod__oasis__coupler.html#a33dbf692ad73f83f73fe083e252badd8">prism_router</a>(rouid)%router,tag)</div><div class="line"><a name="l01286"></a><span class="lineno"> 1286</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01287"></a><span class="lineno"> 1287</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01288"></a><span class="lineno"> 1288</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; After  MPI put &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01289"></a><span class="lineno"> 1289</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01290"></a><span class="lineno"> 1290</span>&#160;             <span class="keywordflow">ELSE</span></div><div class="line"><a name="l01291"></a><span class="lineno"> 1291</span>&#160;                <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;psnd_&#39;</span>,cplid</div><div class="line"><a name="l01292"></a><span class="lineno"> 1292</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; put send&#39;</span>)</div><div class="line"><a name="l01293"></a><span class="lineno"> 1293</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01294"></a><span class="lineno"> 1294</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put av1 b4 send = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01295"></a><span class="lineno"> 1295</span>&#160;                                   minval(pcpointer%avect1%rAttr),&amp;</div><div class="line"><a name="l01296"></a><span class="lineno"> 1296</span>&#160;                                   maxval(pcpointer%avect1%rAttr)</div><div class="line"><a name="l01297"></a><span class="lineno"> 1297</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01298"></a><span class="lineno"> 1298</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01299"></a><span class="lineno"> 1299</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01300"></a><span class="lineno"> 1300</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01301"></a><span class="lineno"> 1301</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; Before MPI put &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01302"></a><span class="lineno"> 1302</span>&#160;                <span class="keyword">call </span>mct_waitsend(<a class="code" href="namespacemod__oasis__coupler.html#a33dbf692ad73f83f73fe083e252badd8">prism_router</a>(rouid)%router)</div><div class="line"><a name="l01303"></a><span class="lineno"> 1303</span>&#160;                <span class="keyword">call </span>mct_isend(pcpointer%avect1,<a class="code" href="namespacemod__oasis__coupler.html#a33dbf692ad73f83f73fe083e252badd8">prism_router</a>(rouid)%router,tag)</div><div class="line"><a name="l01304"></a><span class="lineno"> 1304</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01305"></a><span class="lineno"> 1305</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01306"></a><span class="lineno"> 1306</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; After  MPI put &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01307"></a><span class="lineno"> 1307</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01308"></a><span class="lineno"> 1308</span>&#160;<span class="keywordflow">             ENDIF</span></div><div class="line"><a name="l01309"></a><span class="lineno"> 1309</span>&#160;          <span class="keywordflow">elseif</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#aa2ac99363b8f1aa7ff950fda3e3f5fff">oasis3_get</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01310"></a><span class="lineno"> 1310</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; get section&#39;</span>)</div><div class="line"><a name="l01311"></a><span class="lineno"> 1311</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2 ) <span class="keywordflow">then</span></div><div class="line"><a name="l01312"></a><span class="lineno"> 1312</span>&#160;                lstring = mct_avect_exportrlist2c(pcpointer%avect1)</div><div class="line"><a name="l01313"></a><span class="lineno"> 1313</span>&#160;                llstring = len_trim(lstring)</div><div class="line"><a name="l01314"></a><span class="lineno"> 1314</span>&#160;                <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01315"></a><span class="lineno"> 1315</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; RECV: &#39;</span>, &amp;</div><div class="line"><a name="l01316"></a><span class="lineno"> 1316</span>&#160;                      trim(lstring)</div><div class="line"><a name="l01317"></a><span class="lineno"> 1317</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l01318"></a><span class="lineno"> 1318</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; RECV: &#39;</span>,lstring(1:20), &amp;</div><div class="line"><a name="l01319"></a><span class="lineno"> 1319</span>&#160;                      lstring(21:llstring)</div><div class="line"><a name="l01320"></a><span class="lineno"> 1320</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01321"></a><span class="lineno"> 1321</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01322"></a><span class="lineno"> 1322</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01323"></a><span class="lineno"> 1323</span>&#160;             <span class="keywordflow">if</span> (mapid &gt; 0) <span class="keywordflow">then</span></div><div class="line"><a name="l01324"></a><span class="lineno"> 1324</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; get recv&#39;</span>)</div><div class="line"><a name="l01325"></a><span class="lineno"> 1325</span>&#160;                <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;grcv_&#39;</span>,cplid</div><div class="line"><a name="l01326"></a><span class="lineno"> 1326</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01327"></a><span class="lineno"> 1327</span>&#160;                <span class="keyword">call </span>mct_avect_zero(pcpointer%avect1m)</div><div class="line"><a name="l01328"></a><span class="lineno"> 1328</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01329"></a><span class="lineno"> 1329</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01330"></a><span class="lineno"> 1330</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; Before MPI get &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01331"></a><span class="lineno"> 1331</span>&#160;                <span class="keyword">call </span>mct_recv(pcpointer%avect1m,<a class="code" href="namespacemod__oasis__coupler.html#a33dbf692ad73f83f73fe083e252badd8">prism_router</a>(rouid)%router,tag)</div><div class="line"><a name="l01332"></a><span class="lineno"> 1332</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01333"></a><span class="lineno"> 1333</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01334"></a><span class="lineno"> 1334</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; After  MPI get &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01335"></a><span class="lineno"> 1335</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01336"></a><span class="lineno"> 1336</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01337"></a><span class="lineno"> 1337</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG get af recv = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01338"></a><span class="lineno"> 1338</span>&#160;                                   minval(pcpointer%avect1m%rAttr),&amp;</div><div class="line"><a name="l01339"></a><span class="lineno"> 1339</span>&#160;                                   maxval(pcpointer%avect1m%rAttr)</div><div class="line"><a name="l01340"></a><span class="lineno"> 1340</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01341"></a><span class="lineno"> 1341</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; get map&#39;</span>)</div><div class="line"><a name="l01342"></a><span class="lineno"> 1342</span>&#160;                <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;gmap_&#39;</span>,cplid</div><div class="line"><a name="l01343"></a><span class="lineno"> 1343</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__advance.html#ac617024af9299c27eaeb9156f647b028">map_barrier</a> .and. <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom /= mpi_comm_null) <span class="keywordflow">then</span></div><div class="line"><a name="l01344"></a><span class="lineno"> 1344</span>&#160;                   <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstring)//<span class="stringliteral">&#39;_prebarrier&#39;</span>)</div><div class="line"><a name="l01345"></a><span class="lineno"> 1345</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__mpi.html#aaf477847380fbbbc1341520b0b3e66da">oasis_mpi_barrier</a>(<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, trim(tstring))</div><div class="line"><a name="l01346"></a><span class="lineno"> 1346</span>&#160;                   <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstring)//<span class="stringliteral">&#39;_prebarrier&#39;</span>)</div><div class="line"><a name="l01347"></a><span class="lineno"> 1347</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01348"></a><span class="lineno"> 1348</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01349"></a><span class="lineno"> 1349</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01350"></a><span class="lineno"> 1350</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01351"></a><span class="lineno"> 1351</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; Before interpo &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01352"></a><span class="lineno"> 1352</span>&#160;                <span class="keyword">call </span>mct_avect_zero(pcpointer%avect1)</div><div class="line"><a name="l01353"></a><span class="lineno"> 1353</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__advance.html#aad8e5c2e16b0270a7da0800a14ae1e07">detailed_map_timing</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01354"></a><span class="lineno"> 1354</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#a0514c843d051b8ee16adfb349eaee6a7">oasis_advance_map</a>(pcpointer%avect1m, &amp;</div><div class="line"><a name="l01355"></a><span class="lineno"> 1355</span>&#160;                        pcpointer%avect1,<a class="code" href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">prism_mapper</a>(mapid),conserv,consopt,tstrinp=tstring)</div><div class="line"><a name="l01356"></a><span class="lineno"> 1356</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l01357"></a><span class="lineno"> 1357</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#a0514c843d051b8ee16adfb349eaee6a7">oasis_advance_map</a>(pcpointer%avect1m, &amp;</div><div class="line"><a name="l01358"></a><span class="lineno"> 1358</span>&#160;                        pcpointer%avect1,<a class="code" href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">prism_mapper</a>(mapid),conserv,consopt)</div><div class="line"><a name="l01359"></a><span class="lineno"> 1359</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01360"></a><span class="lineno"> 1360</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01361"></a><span class="lineno"> 1361</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01362"></a><span class="lineno"> 1362</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; After  interpo &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01363"></a><span class="lineno"> 1363</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01364"></a><span class="lineno"> 1364</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01365"></a><span class="lineno"> 1365</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG get af map = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01366"></a><span class="lineno"> 1366</span>&#160;                                   minval(pcpointer%avect1%rAttr),&amp;</div><div class="line"><a name="l01367"></a><span class="lineno"> 1367</span>&#160;                                   maxval(pcpointer%avect1%rAttr)</div><div class="line"><a name="l01368"></a><span class="lineno"> 1368</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01369"></a><span class="lineno"> 1369</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l01370"></a><span class="lineno"> 1370</span>&#160;                <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;grcv_&#39;</span>,cplid</div><div class="line"><a name="l01371"></a><span class="lineno"> 1371</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; get recv&#39;</span>)</div><div class="line"><a name="l01372"></a><span class="lineno"> 1372</span>&#160;                <span class="keyword">call </span>mct_avect_zero(pcpointer%avect1)</div><div class="line"><a name="l01373"></a><span class="lineno"> 1373</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01374"></a><span class="lineno"> 1374</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01375"></a><span class="lineno"> 1375</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01376"></a><span class="lineno"> 1376</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; Before MPI get &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01377"></a><span class="lineno"> 1377</span>&#160;                <span class="keyword">call </span>mct_recv(pcpointer%avect1,<a class="code" href="namespacemod__oasis__coupler.html#a33dbf692ad73f83f73fe083e252badd8">prism_router</a>(rouid)%router,tag)</div><div class="line"><a name="l01378"></a><span class="lineno"> 1378</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">lucia_debug</a> &gt; 0) &amp;</div><div class="line"><a name="l01379"></a><span class="lineno"> 1379</span>&#160;                   <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">nullucia</a>, fmt=<span class="stringliteral">&#39;(A,I3.3,A,F16.5)&#39;</span>) &amp;</div><div class="line"><a name="l01380"></a><span class="lineno"> 1380</span>&#160;                              <span class="stringliteral">&#39;Balance: &#39;</span>,pcpointer%namID,<span class="stringliteral">&#39; After  MPI get &#39;</span>, mpi_wtime()</div><div class="line"><a name="l01381"></a><span class="lineno"> 1381</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01382"></a><span class="lineno"> 1382</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01383"></a><span class="lineno"> 1383</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG get af recv = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01384"></a><span class="lineno"> 1384</span>&#160;                                   minval(pcpointer%avect1%rAttr),&amp;</div><div class="line"><a name="l01385"></a><span class="lineno"> 1385</span>&#160;                                   maxval(pcpointer%avect1%rAttr)</div><div class="line"><a name="l01386"></a><span class="lineno"> 1386</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01387"></a><span class="lineno"> 1387</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01388"></a><span class="lineno"> 1388</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; apply rcvmult rcvadd&#39;</span>)</div><div class="line"><a name="l01389"></a><span class="lineno"> 1389</span>&#160;             <span class="keywordflow">if</span> (rcvadd /= 0.0_ip_double_p .or. rcvmult /= 1.0_ip_double_p) <span class="keywordflow">then</span></div><div class="line"><a name="l01390"></a><span class="lineno"> 1390</span>&#160;                pcpointer%avect1%rAttr(:,:) = pcpointer%avect1%rAttr(:,:)*rcvmult &amp;</div><div class="line"><a name="l01391"></a><span class="lineno"> 1391</span>&#160;                                                         + rcvadd</div><div class="line"><a name="l01392"></a><span class="lineno"> 1392</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01393"></a><span class="lineno"> 1393</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG rcvmult,add = &#39;</span>,rcvmult,rcvadd</div><div class="line"><a name="l01394"></a><span class="lineno"> 1394</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG get af rcvmult,add = &#39;</span>,cplid,&amp;</div><div class="line"><a name="l01395"></a><span class="lineno"> 1395</span>&#160;                                   minval(pcpointer%avect1%rAttr),&amp;</div><div class="line"><a name="l01396"></a><span class="lineno"> 1396</span>&#160;                                   maxval(pcpointer%avect1%rAttr)</div><div class="line"><a name="l01397"></a><span class="lineno"> 1397</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01398"></a><span class="lineno"> 1398</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01399"></a><span class="lineno"> 1399</span>&#160;             <span class="keywordflow">if</span> (rcvdiag) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#af611b26fe4601ded488fd5d3c03b12a2">oasis_advance_avdiag</a>(pcpointer%avect1,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom)</div><div class="line"><a name="l01400"></a><span class="lineno"> 1400</span>&#160;<span class="keywordflow">          endif</span>  <span class="comment">! getput</span></div><div class="line"><a name="l01401"></a><span class="lineno"> 1401</span>&#160;<span class="keywordflow">          endif</span>  <span class="comment">! sndrcv</span></div><div class="line"><a name="l01402"></a><span class="lineno"> 1402</span>&#160;</div><div class="line"><a name="l01403"></a><span class="lineno"> 1403</span>&#160;          <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01404"></a><span class="lineno"> 1404</span>&#160;<span class="comment">          !&gt;     * write to output files if output is turned on</span></div><div class="line"><a name="l01405"></a><span class="lineno"> 1405</span>&#160;          <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01406"></a><span class="lineno"> 1406</span>&#160;</div><div class="line"><a name="l01407"></a><span class="lineno"> 1407</span>&#160;          <span class="keywordflow">if</span> (output) <span class="keywordflow">then</span></div><div class="line"><a name="l01408"></a><span class="lineno"> 1408</span>&#160;             <span class="keywordflow">if</span> (kinfo == <a class="code" href="namespacemod__oasis__parameters.html#af739945ec2da833423cdc6e220e1c847">oasis_sent</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01409"></a><span class="lineno"> 1409</span>&#160;                kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a1804e9b27d8d7ace38fd4c3f99ade6dd">oasis_sentout</a></div><div class="line"><a name="l01410"></a><span class="lineno"> 1410</span>&#160;             <span class="keywordflow">elseif</span> (kinfo == <a class="code" href="namespacemod__oasis__parameters.html#a875abcc1cc679cb72f20d42d3dbfac97">oasis_torest</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01411"></a><span class="lineno"> 1411</span>&#160;                kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a390018877602efede436bd0721add299">oasis_torestout</a></div><div class="line"><a name="l01412"></a><span class="lineno"> 1412</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l01413"></a><span class="lineno"> 1413</span>&#160;                kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a7f9f81f3b1f2c8b09a460aeca27ea859">oasis_output</a></div><div class="line"><a name="l01414"></a><span class="lineno"> 1414</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01415"></a><span class="lineno"> 1415</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; output&#39;</span>)</div><div class="line"><a name="l01416"></a><span class="lineno"> 1416</span>&#160;             <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;wout_&#39;</span>,cplid</div><div class="line"><a name="l01417"></a><span class="lineno"> 1417</span>&#160;             <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01418"></a><span class="lineno"> 1418</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l01419"></a><span class="lineno"> 1419</span>&#160;                lstring = mct_avect_exportrlist2c(pcpointer%avect1)</div><div class="line"><a name="l01420"></a><span class="lineno"> 1420</span>&#160;                llstring = len_trim(lstring)</div><div class="line"><a name="l01421"></a><span class="lineno"> 1421</span>&#160;                <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01422"></a><span class="lineno"> 1422</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; WRIT: &#39;</span>, &amp;</div><div class="line"><a name="l01423"></a><span class="lineno"> 1423</span>&#160;                      trim(lstring)</div><div class="line"><a name="l01424"></a><span class="lineno"> 1424</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l01425"></a><span class="lineno"> 1425</span>&#160;                   <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; WRIT: &#39;</span>,lstring(1:20), &amp;</div><div class="line"><a name="l01426"></a><span class="lineno"> 1426</span>&#160;                      lstring(21:llstring)</div><div class="line"><a name="l01427"></a><span class="lineno"> 1427</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01428"></a><span class="lineno"> 1428</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01429"></a><span class="lineno"> 1429</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01430"></a><span class="lineno"> 1430</span>&#160;             <span class="keyword">write</span>(fstring,<span class="stringliteral">&#39;(A,I2.2)&#39;</span>) <span class="stringliteral">&#39;_&#39;</span>//trim(<a class="code" href="namespacemod__oasis__data.html#a8379835615758ccf7a4287dde5785681">compnm</a>)//<span class="stringliteral">&#39;_&#39;</span>,cplid</div><div class="line"><a name="l01431"></a><span class="lineno"> 1431</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#a42b325557a774b08d4cba24f387f8b01">oasis_io_write_avfbf</a>(pcpointer%avect1,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom, &amp;</div><div class="line"><a name="l01432"></a><span class="lineno"> 1432</span>&#160;                nx,ny,msec,fstring)</div><div class="line"><a name="l01433"></a><span class="lineno"> 1433</span>&#160;             <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01434"></a><span class="lineno"> 1434</span>&#160;</div><div class="line"><a name="l01435"></a><span class="lineno"> 1435</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 30) <span class="keywordflow">then</span></div><div class="line"><a name="l01436"></a><span class="lineno"> 1436</span>&#160;                <span class="keyword">call </span>mct_avect_init(avtest,pcpointer%avect1,&amp;</div><div class="line"><a name="l01437"></a><span class="lineno"> 1437</span>&#160;                                    mct_avect_lsize(pcpointer%avect1))</div><div class="line"><a name="l01438"></a><span class="lineno"> 1438</span>&#160;                <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;rinp_&#39;</span>,cplid</div><div class="line"><a name="l01439"></a><span class="lineno"> 1439</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01440"></a><span class="lineno"> 1440</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#ac4a465a698824fb473074bfbd3d92f79">oasis_io_read_avfbf</a>(avtest,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,msec,fstring)</div><div class="line"><a name="l01441"></a><span class="lineno"> 1441</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG write/read test avfbf should be zero &#39;</span>,&amp;</div><div class="line"><a name="l01442"></a><span class="lineno"> 1442</span>&#160;                                sum(pcpointer%avect1%rAttr-avtest%rAttr)</div><div class="line"><a name="l01443"></a><span class="lineno"> 1443</span>&#160;                <span class="keyword">call </span>mct_avect_clean(avtest)</div><div class="line"><a name="l01444"></a><span class="lineno"> 1444</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01445"></a><span class="lineno"> 1445</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01446"></a><span class="lineno"> 1446</span>&#160;</div><div class="line"><a name="l01447"></a><span class="lineno"> 1447</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01448"></a><span class="lineno"> 1448</span>&#160;</div><div class="line"><a name="l01449"></a><span class="lineno"> 1449</span>&#160;          <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01450"></a><span class="lineno"> 1450</span>&#160;<span class="comment">          !&gt;     * set avcnt, avect1, ltime, and status</span></div><div class="line"><a name="l01451"></a><span class="lineno"> 1451</span>&#160;          <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01452"></a><span class="lineno"> 1452</span>&#160;</div><div class="line"><a name="l01453"></a><span class="lineno"> 1453</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; reset status&#39;</span>)</div><div class="line"><a name="l01454"></a><span class="lineno"> 1454</span>&#160;          <span class="keywordflow">if</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01455"></a><span class="lineno"> 1455</span>&#160;             <span class="keywordflow">if</span> (.not.lreadrest) pcpointer%ltime = msec</div><div class="line"><a name="l01456"></a><span class="lineno"> 1456</span>&#160;             pcpointer%status(:) = <a class="code" href="namespacemod__oasis__parameters.html#a9df795bd9123857642aae31661b6c13a">oasis_comm_wait</a></div><div class="line"><a name="l01457"></a><span class="lineno"> 1457</span>&#160;             pcpointer%avcnt(:) = 0</div><div class="line"><a name="l01458"></a><span class="lineno"> 1458</span>&#160;             <span class="keyword">call </span>mct_avect_zero(pcpointer%avect1)</div><div class="line"><a name="l01459"></a><span class="lineno"> 1459</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(2)) &amp;</div><div class="line"><a name="l01460"></a><span class="lineno"> 1460</span>&#160;                <span class="keyword">call </span>mct_avect_zero(pcpointer%avect2)</div><div class="line"><a name="l01461"></a><span class="lineno"> 1461</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(3)) &amp;</div><div class="line"><a name="l01462"></a><span class="lineno"> 1462</span>&#160;                <span class="keyword">call </span>mct_avect_zero(pcpointer%avect3)</div><div class="line"><a name="l01463"></a><span class="lineno"> 1463</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(4)) &amp;</div><div class="line"><a name="l01464"></a><span class="lineno"> 1464</span>&#160;                <span class="keyword">call </span>mct_avect_zero(pcpointer%avect4)</div><div class="line"><a name="l01465"></a><span class="lineno"> 1465</span>&#160;             <span class="keywordflow">if</span> (pcpointer%aVon(5)) &amp;</div><div class="line"><a name="l01466"></a><span class="lineno"> 1466</span>&#160;                <span class="keyword">call </span>mct_avect_zero(pcpointer%avect5)</div><div class="line"><a name="l01467"></a><span class="lineno"> 1467</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01468"></a><span class="lineno"> 1468</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG put reset status = &#39;</span></div><div class="line"><a name="l01469"></a><span class="lineno"> 1469</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01470"></a><span class="lineno"> 1470</span>&#160;          <span class="keywordflow">elseif</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#aa2ac99363b8f1aa7ff950fda3e3f5fff">oasis3_get</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01471"></a><span class="lineno"> 1471</span>&#160;             <span class="keywordflow">if</span> (.not.lreadrest) pcpointer%ltime = msec</div><div class="line"><a name="l01472"></a><span class="lineno"> 1472</span>&#160;             pcpointer%status(:) = <a class="code" href="namespacemod__oasis__parameters.html#a9df795bd9123857642aae31661b6c13a">oasis_comm_wait</a></div><div class="line"><a name="l01473"></a><span class="lineno"> 1473</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01474"></a><span class="lineno"> 1474</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG get reset status = &#39;</span></div><div class="line"><a name="l01475"></a><span class="lineno"> 1475</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01476"></a><span class="lineno"> 1476</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01477"></a><span class="lineno"> 1477</span>&#160;</div><div class="line"><a name="l01478"></a><span class="lineno"> 1478</span>&#160;       <span class="keywordflow">else</span></div><div class="line"><a name="l01479"></a><span class="lineno"> 1479</span>&#160;</div><div class="line"><a name="l01480"></a><span class="lineno"> 1480</span>&#160;          <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01481"></a><span class="lineno"> 1481</span>&#160;          <span class="comment">! no action, document</span></div><div class="line"><a name="l01482"></a><span class="lineno"> 1482</span>&#160;          <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01483"></a><span class="lineno"> 1483</span>&#160;</div><div class="line"><a name="l01484"></a><span class="lineno"> 1484</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 15) <span class="keywordflow">then</span></div><div class="line"><a name="l01485"></a><span class="lineno"> 1485</span>&#160;             lstring = mct_avect_exportrlist2c(pcpointer%avect1)</div><div class="line"><a name="l01486"></a><span class="lineno"> 1486</span>&#160;             llstring = len_trim(lstring)</div><div class="line"><a name="l01487"></a><span class="lineno"> 1487</span>&#160;             <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01488"></a><span class="lineno"> 1488</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; SKIP: &#39;</span>, &amp;</div><div class="line"><a name="l01489"></a><span class="lineno"> 1489</span>&#160;                   trim(lstring)</div><div class="line"><a name="l01490"></a><span class="lineno"> 1490</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l01491"></a><span class="lineno"> 1491</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; SKIP: &#39;</span>,lstring(1:20), &amp;</div><div class="line"><a name="l01492"></a><span class="lineno"> 1492</span>&#160;                   lstring(21:llstring)</div><div class="line"><a name="l01493"></a><span class="lineno"> 1493</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01494"></a><span class="lineno"> 1494</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01495"></a><span class="lineno"> 1495</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01496"></a><span class="lineno"> 1496</span>&#160;</div><div class="line"><a name="l01497"></a><span class="lineno"> 1497</span>&#160;<span class="keywordflow">       endif</span>   <span class="comment">! comm_now</span></div><div class="line"><a name="l01498"></a><span class="lineno"> 1498</span>&#160;</div><div class="line"><a name="l01499"></a><span class="lineno"> 1499</span>&#160;       pcpointer%ctime = msec</div><div class="line"><a name="l01500"></a><span class="lineno"> 1500</span>&#160;</div><div class="line"><a name="l01501"></a><span class="lineno"> 1501</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01502"></a><span class="lineno"> 1502</span>&#160;<span class="comment">       !&gt;   * at the end of the run only,  save fields associated</span></div><div class="line"><a name="l01503"></a><span class="lineno"> 1503</span>&#160;<span class="comment">       !&gt;     with non-instant loctrans operations to restart files</span></div><div class="line"><a name="l01504"></a><span class="lineno"> 1504</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01505"></a><span class="lineno"> 1505</span>&#160;</div><div class="line"><a name="l01506"></a><span class="lineno"> 1506</span>&#160;       <span class="keywordflow">IF</span> ((mseclag + dt &gt;= maxtime .AND. &amp;</div><div class="line"><a name="l01507"></a><span class="lineno"> 1507</span>&#160;           getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a> .and. pcpointer%trans /= <a class="code" href="namespacemod__oasis__parameters.html#a1028581caadcb9d7506b25c6cd3efd01">ip_instant</a> .and. &amp;</div><div class="line"><a name="l01508"></a><span class="lineno"> 1508</span>&#160;           len_trim(rstfile) &gt; 0) .or. &amp;</div><div class="line"><a name="l01509"></a><span class="lineno"> 1509</span>&#160;           (getput == <a class="code" href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">oasis3_put</a> .and. pcpointer%writrest .and. len_trim(rstfile) &gt; 0)) <span class="keywordflow">then</span></div><div class="line"><a name="l01510"></a><span class="lineno"> 1510</span>&#160;</div><div class="line"><a name="l01511"></a><span class="lineno"> 1511</span>&#160;          <span class="keywordflow">if</span> (mseclag + dt &gt;= maxtime) <span class="keywordflow">then</span></div><div class="line"><a name="l01512"></a><span class="lineno"> 1512</span>&#160;             rstfile2 = rstfile</div><div class="line"><a name="l01513"></a><span class="lineno"> 1513</span>&#160;          <span class="keywordflow">else</span>  <span class="comment">! writrest</span></div><div class="line"><a name="l01514"></a><span class="lineno"> 1514</span>&#160;             pcpointer%writrest = .false.</div><div class="line"><a name="l01515"></a><span class="lineno"> 1515</span>&#160;             <span class="keyword">write</span>(rstfile2,<span class="stringliteral">&#39;(a,i9.9,a,a)&#39;</span>) <span class="stringliteral">&#39;TA&#39;</span>,msec,<span class="stringliteral">&#39;_&#39;</span>,trim(rstfile)</div><div class="line"><a name="l01516"></a><span class="lineno"> 1516</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01517"></a><span class="lineno"> 1517</span>&#160;</div><div class="line"><a name="l01518"></a><span class="lineno"> 1518</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; loctrans restart write&#39;</span>)</div><div class="line"><a name="l01519"></a><span class="lineno"> 1519</span>&#160;          <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;wtrn_&#39;</span>,cplid</div><div class="line"><a name="l01520"></a><span class="lineno"> 1520</span>&#160;          <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01521"></a><span class="lineno"> 1521</span>&#160;          <span class="keyword">WRITE</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_cnt&#39;</span></div><div class="line"><a name="l01522"></a><span class="lineno"> 1522</span>&#160;          <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__io.html#a9ac8ce0ba3223fb59f7f003b50b229cf">oasis_io_write_array</a>(rstfile2,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,iarray=pcpointer%avcnt,&amp;</div><div class="line"><a name="l01523"></a><span class="lineno"> 1523</span>&#160;                                    ivarname=trim(vstring))</div><div class="line"><a name="l01524"></a><span class="lineno"> 1524</span>&#160;          <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l01525"></a><span class="lineno"> 1525</span>&#160;          <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect1, &amp;</div><div class="line"><a name="l01526"></a><span class="lineno"> 1526</span>&#160;             <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=trim(vstring))</div><div class="line"><a name="l01527"></a><span class="lineno"> 1527</span>&#160;          <span class="keywordflow">if</span> (pcpointer%aVon(2)) <span class="keywordflow">then</span></div><div class="line"><a name="l01528"></a><span class="lineno"> 1528</span>&#160;             <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;av2loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l01529"></a><span class="lineno"> 1529</span>&#160;             <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect2, &amp;</div><div class="line"><a name="l01530"></a><span class="lineno"> 1530</span>&#160;                <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=trim(vstring))</div><div class="line"><a name="l01531"></a><span class="lineno"> 1531</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01532"></a><span class="lineno"> 1532</span>&#160;          <span class="keywordflow">if</span> (pcpointer%aVon(3)) <span class="keywordflow">then</span></div><div class="line"><a name="l01533"></a><span class="lineno"> 1533</span>&#160;             <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;av3loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l01534"></a><span class="lineno"> 1534</span>&#160;             <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect3, &amp;</div><div class="line"><a name="l01535"></a><span class="lineno"> 1535</span>&#160;                <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=trim(vstring))</div><div class="line"><a name="l01536"></a><span class="lineno"> 1536</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01537"></a><span class="lineno"> 1537</span>&#160;          <span class="keywordflow">if</span> (pcpointer%aVon(4)) <span class="keywordflow">then</span></div><div class="line"><a name="l01538"></a><span class="lineno"> 1538</span>&#160;             <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;av4loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l01539"></a><span class="lineno"> 1539</span>&#160;             <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect4, &amp;</div><div class="line"><a name="l01540"></a><span class="lineno"> 1540</span>&#160;                <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=trim(vstring))</div><div class="line"><a name="l01541"></a><span class="lineno"> 1541</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01542"></a><span class="lineno"> 1542</span>&#160;          <span class="keywordflow">if</span> (pcpointer%aVon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l01543"></a><span class="lineno"> 1543</span>&#160;             <span class="keyword">write</span>(vstring,<span class="stringliteral">&#39;(a,i6.6,a)&#39;</span>) <span class="stringliteral">&#39;av5loc&#39;</span>,pcpointer%namID,<span class="stringliteral">&#39;_&#39;</span></div><div class="line"><a name="l01544"></a><span class="lineno"> 1544</span>&#160;             <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">oasis_io_write_avfile</a>(rstfile2,pcpointer%avect5, &amp;</div><div class="line"><a name="l01545"></a><span class="lineno"> 1545</span>&#160;                <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,nx,ny,nampre=trim(vstring))</div><div class="line"><a name="l01546"></a><span class="lineno"> 1546</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01547"></a><span class="lineno"> 1547</span>&#160;          <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01548"></a><span class="lineno"> 1548</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l01549"></a><span class="lineno"> 1549</span>&#160;             lstring = mct_avect_exportrlist2c(pcpointer%avect1)</div><div class="line"><a name="l01550"></a><span class="lineno"> 1550</span>&#160;             llstring = len_trim(lstring)</div><div class="line"><a name="l01551"></a><span class="lineno"> 1551</span>&#160;             <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01552"></a><span class="lineno"> 1552</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; WTRN: &#39;</span>, &amp;</div><div class="line"><a name="l01553"></a><span class="lineno"> 1553</span>&#160;                   trim(lstring),<span class="stringliteral">&#39; &#39;</span>,trim(rstfile2)</div><div class="line"><a name="l01554"></a><span class="lineno"> 1554</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l01555"></a><span class="lineno"> 1555</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; WTRN: &#39;</span>,lstring(1:20), &amp;</div><div class="line"><a name="l01556"></a><span class="lineno"> 1556</span>&#160;                   lstring(21:llstring),<span class="stringliteral">&#39; &#39;</span>,trim(rstfile2)</div><div class="line"><a name="l01557"></a><span class="lineno"> 1557</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01558"></a><span class="lineno"> 1558</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01559"></a><span class="lineno"> 1559</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01560"></a><span class="lineno"> 1560</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01561"></a><span class="lineno"> 1561</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG write loctrans restart&#39;</span>,cplid,&amp;</div><div class="line"><a name="l01562"></a><span class="lineno"> 1562</span>&#160;                             pcpointer%avcnt</div><div class="line"><a name="l01563"></a><span class="lineno"> 1563</span>&#160;             <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG write loctrans restart&#39;</span>,cplid,&amp;</div><div class="line"><a name="l01564"></a><span class="lineno"> 1564</span>&#160;                             minval(pcpointer%avect1%rAttr),&amp;</div><div class="line"><a name="l01565"></a><span class="lineno"> 1565</span>&#160;                             maxval(pcpointer%avect1%rAttr)</div><div class="line"><a name="l01566"></a><span class="lineno"> 1566</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01567"></a><span class="lineno"> 1567</span>&#160;<span class="keywordflow">       ENDIF</span></div><div class="line"><a name="l01568"></a><span class="lineno"> 1568</span>&#160;</div><div class="line"><a name="l01569"></a><span class="lineno"> 1569</span>&#160;       <span class="comment">!------------------------------------------------</span><span class="comment"></span></div><div class="line"><a name="l01570"></a><span class="lineno"> 1570</span>&#160;<span class="comment">       !&gt;   * GET only, unpack avect1 if it&#39;s newly received</span></div><div class="line"><a name="l01571"></a><span class="lineno"> 1571</span>&#160;       <span class="comment">!------------------------------------------------</span></div><div class="line"><a name="l01572"></a><span class="lineno"> 1572</span>&#160;</div><div class="line"><a name="l01573"></a><span class="lineno"> 1573</span>&#160;       <span class="keywordflow">if</span> (getput == <a class="code" href="namespacemod__oasis__parameters.html#aa2ac99363b8f1aa7ff950fda3e3f5fff">oasis3_get</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01574"></a><span class="lineno"> 1574</span>&#160;         <span class="keywordflow">IF</span> (time_now .AND. unpack) <span class="keywordflow">THEN</span></div><div class="line"><a name="l01575"></a><span class="lineno"> 1575</span>&#160;             <span class="keywordflow">if</span> (kinfo == <a class="code" href="namespacemod__oasis__parameters.html#a7f9f81f3b1f2c8b09a460aeca27ea859">oasis_output</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01576"></a><span class="lineno"> 1576</span>&#160;                kinfo = <a class="code" href="namespacemod__oasis__parameters.html#ac7406e7f558491599acfbb6f4628f811">oasis_recvout</a></div><div class="line"><a name="l01577"></a><span class="lineno"> 1577</span>&#160;             <span class="keywordflow">elseif</span> (kinfo == <a class="code" href="namespacemod__oasis__parameters.html#aa0584909970d34364b7ec319292b1682">oasis_fromrest</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01578"></a><span class="lineno"> 1578</span>&#160;                kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a76a87a170e0c08863ae981693eb88fb8">oasis_fromrestout</a></div><div class="line"><a name="l01579"></a><span class="lineno"> 1579</span>&#160;             <span class="keywordflow">else</span></div><div class="line"><a name="l01580"></a><span class="lineno"> 1580</span>&#160;                kinfo = <a class="code" href="namespacemod__oasis__parameters.html#a50fc92036d81ca0ea23918e1feddfe75">oasis_recvd</a></div><div class="line"><a name="l01581"></a><span class="lineno"> 1581</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01582"></a><span class="lineno"> 1582</span>&#160;             <span class="keywordflow">if</span> (input) <span class="keywordflow">then</span></div><div class="line"><a name="l01583"></a><span class="lineno"> 1583</span>&#160;                kinfo = <a class="code" href="namespacemod__oasis__parameters.html#ae65ca856d776de249fc624b2d76bc4e8">oasis_input</a></div><div class="line"><a name="l01584"></a><span class="lineno"> 1584</span>&#160;                <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; input&#39;</span>)</div><div class="line"><a name="l01585"></a><span class="lineno"> 1585</span>&#160;                <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l01586"></a><span class="lineno"> 1586</span>&#160;                   lstring = mct_avect_exportrlist2c(pcpointer%avect1)</div><div class="line"><a name="l01587"></a><span class="lineno"> 1587</span>&#160;                   llstring = len_trim(lstring)</div><div class="line"><a name="l01588"></a><span class="lineno"> 1588</span>&#160;                   <span class="keywordflow">if</span> (llstring &lt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01589"></a><span class="lineno"> 1589</span>&#160;                      <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; READ: &#39;</span>, &amp;</div><div class="line"><a name="l01590"></a><span class="lineno"> 1590</span>&#160;                         trim(lstring)</div><div class="line"><a name="l01591"></a><span class="lineno"> 1591</span>&#160;                   <span class="keywordflow">else</span></div><div class="line"><a name="l01592"></a><span class="lineno"> 1592</span>&#160;                      <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; READ: &#39;</span>,lstring(1:20), &amp;</div><div class="line"><a name="l01593"></a><span class="lineno"> 1593</span>&#160;                         lstring(21:llstring)</div><div class="line"><a name="l01594"></a><span class="lineno"> 1594</span>&#160;<span class="keywordflow">                   endif</span></div><div class="line"><a name="l01595"></a><span class="lineno"> 1595</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01596"></a><span class="lineno"> 1596</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01597"></a><span class="lineno"> 1597</span>&#160;                <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;grin_&#39;</span>,cplid</div><div class="line"><a name="l01598"></a><span class="lineno"> 1598</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01599"></a><span class="lineno"> 1599</span>&#160;                <span class="keywordflow">if</span> (trim(inpfile) /= trim(<a class="code" href="namespacemod__oasis__data.html#acfb160b3d147e7cb667b0dc0f5bb2960">cspval</a>)) <span class="keywordflow">then</span></div><div class="line"><a name="l01600"></a><span class="lineno"> 1600</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#ac4a465a698824fb473074bfbd3d92f79">oasis_io_read_avfbf</a>(pcpointer%avect1,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,&amp;</div><div class="line"><a name="l01601"></a><span class="lineno"> 1601</span>&#160;                                            msec,filename=trim(inpfile))</div><div class="line"><a name="l01602"></a><span class="lineno"> 1602</span>&#160;                <span class="keywordflow">else</span></div><div class="line"><a name="l01603"></a><span class="lineno"> 1603</span>&#160;                   fstring = <span class="stringliteral">&#39;_&#39;</span>//trim(<a class="code" href="namespacemod__oasis__data.html#a8379835615758ccf7a4287dde5785681">compnm</a>)</div><div class="line"><a name="l01604"></a><span class="lineno"> 1604</span>&#160;                   <span class="keyword">call </span><a class="code" href="namespacemod__oasis__io.html#ac4a465a698824fb473074bfbd3d92f79">oasis_io_read_avfbf</a>(pcpointer%avect1,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(partid)%mpicom,&amp;</div><div class="line"><a name="l01605"></a><span class="lineno"> 1605</span>&#160;                                            msec,f_string=fstring)</div><div class="line"><a name="l01606"></a><span class="lineno"> 1606</span>&#160;<span class="keywordflow">                endif</span></div><div class="line"><a name="l01607"></a><span class="lineno"> 1607</span>&#160;                <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01608"></a><span class="lineno"> 1608</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01609"></a><span class="lineno"> 1609</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l01610"></a><span class="lineno"> 1610</span>&#160;                <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; UPCK: &#39;</span>,trim(vname)</div><div class="line"><a name="l01611"></a><span class="lineno"> 1611</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01612"></a><span class="lineno"> 1612</span>&#160;             <span class="keyword">write</span>(tstring,f01) <span class="stringliteral">&#39;gcpy_&#39;</span>,cplid</div><div class="line"><a name="l01613"></a><span class="lineno"> 1613</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; get copy to array&#39;</span>)</div><div class="line"><a name="l01614"></a><span class="lineno"> 1614</span>&#160;             <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(tstring)</div><div class="line"><a name="l01615"></a><span class="lineno"> 1615</span>&#160;             <span class="keywordflow">if</span> (<span class="keyword">present</span>(array1dout)) array1dout(:) = &amp;</div><div class="line"><a name="l01616"></a><span class="lineno"> 1616</span>&#160;                       pcpointer%avect1%rAttr(nfav,:)</div><div class="line"><a name="l01617"></a><span class="lineno"> 1617</span>&#160;             <span class="keywordflow">if</span> (<span class="keyword">present</span>(array2dout)) array2dout(:,:) = &amp;</div><div class="line"><a name="l01618"></a><span class="lineno"> 1618</span>&#160;                      reshape(pcpointer%avect1%rAttr(nfav,:),shape(array2dout))</div><div class="line"><a name="l01619"></a><span class="lineno"> 1619</span>&#160;             <span class="keywordflow">if</span> (local_timers_on) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(tstring)</div><div class="line"><a name="l01620"></a><span class="lineno"> 1620</span>&#160;             <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01621"></a><span class="lineno"> 1621</span>&#160;                <span class="keywordflow">if</span> (<span class="keyword">present</span>(array1dout)) <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG array copy = &#39;</span>,&amp;</div><div class="line"><a name="l01622"></a><span class="lineno"> 1622</span>&#160;                         cplid,minval(array1dout),maxval(array1dout)</div><div class="line"><a name="l01623"></a><span class="lineno"> 1623</span>&#160;                <span class="keywordflow">if</span> (<span class="keyword">present</span>(array2dout)) <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG array copy = &#39;</span>,&amp;</div><div class="line"><a name="l01624"></a><span class="lineno"> 1624</span>&#160;                         cplid,minval(array2dout),maxval(array2dout)</div><div class="line"><a name="l01625"></a><span class="lineno"> 1625</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01626"></a><span class="lineno"> 1626</span>&#160;<span class="keywordflow">         ENDIF</span></div><div class="line"><a name="l01627"></a><span class="lineno"> 1627</span>&#160;          <span class="keywordflow">if</span> (time_now) pcpointer%status(nfav) = <a class="code" href="namespacemod__oasis__parameters.html#a8484e196ef7469adbeaef850787d7502">oasis_comm_ready</a></div><div class="line"><a name="l01628"></a><span class="lineno"> 1628</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01629"></a><span class="lineno"> 1629</span>&#160;</div><div class="line"><a name="l01630"></a><span class="lineno"> 1630</span>&#160;       <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 2) <span class="keywordflow">then</span></div><div class="line"><a name="l01631"></a><span class="lineno"> 1631</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; at &#39;</span>,msec,mseclag,<span class="stringliteral">&#39; KINF: &#39;</span>,trim(vname),kinfo</div><div class="line"><a name="l01632"></a><span class="lineno"> 1632</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01633"></a><span class="lineno"> 1633</span>&#160;</div><div class="line"><a name="l01634"></a><span class="lineno"> 1634</span>&#160;<span class="keywordflow">     endif</span>  <span class="comment">! runit</span></div><div class="line"><a name="l01635"></a><span class="lineno"> 1635</span>&#160;<span class="keywordflow">    enddo</span>  <span class="comment">! nc = 1,var%ncpl</span></div><div class="line"><a name="l01636"></a><span class="lineno"> 1636</span>&#160;</div><div class="line"><a name="l01637"></a><span class="lineno"> 1637</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a349f71cba2df935179d78f3858992c83">oasis_debug_exit</a>(subname)</div><div class="line"><a name="l01638"></a><span class="lineno"> 1638</span>&#160;</div><div class="line"><a name="l01639"></a><span class="lineno"> 1639</span>&#160;<span class="keyword">  END SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#a932b0cbe5d1f5fa27c283c6472be7baf">oasis_advance_run</a></div><div class="line"><a name="l01640"></a><span class="lineno"> 1640</span>&#160;</div><div class="line"><a name="l01641"></a><span class="lineno"> 1641</span>&#160;</div><div class="line"><a name="l01642"></a><span class="lineno"> 1642</span>&#160;<span class="comment">!-------------------------------------------------------------------</span></div><div class="line"><a name="l01643"></a><span class="lineno"> 1643</span>&#160;<span class="comment"></span></div><div class="line"><a name="l01644"></a><span class="lineno"> 1644</span>&#160;<span class="comment">!&gt; Provides interpolation functionality</span></div><div class="line"><a name="l01645"></a><span class="lineno"> 1645</span>&#160;<span class="comment"></span></div><div class="line"><a name="l01646"></a><span class="lineno"> 1646</span>&#160;<span class="comment">!&gt; Maps (regrids, interpolates) data from av1 to avd.</span></div><div class="line"><a name="l01647"></a><span class="lineno"> 1647</span>&#160;<span class="comment">!&gt; av2-av5 are for higher order mapping (hot).</span></div><div class="line"><a name="l01648"></a><span class="lineno"> 1648</span>&#160;</div><div class="line"><a name="l01649"></a><span class="lineno"> 1649</span>&#160;<span class="keyword">  SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#a0514c843d051b8ee16adfb349eaee6a7">oasis_advance_map</a>(av1,avd,mapper,conserv,consopt,&amp;</div><div class="line"><a name="l01650"></a><span class="lineno"> 1650</span>&#160;                               avon,av2,av3,av4,av5,tstrinp)</div><div class="line"><a name="l01651"></a><span class="lineno"><a class="line" href="namespacemod__oasis__advance.html#a0514c843d051b8ee16adfb349eaee6a7"> 1651</a></span>&#160;</div><div class="line"><a name="l01652"></a><span class="lineno"> 1652</span>&#160;    <span class="comment">! NOTE: mask = 0 is active point according to oasis3 conserv.f</span></div><div class="line"><a name="l01653"></a><span class="lineno"> 1653</span>&#160;</div><div class="line"><a name="l01654"></a><span class="lineno"> 1654</span>&#160;    <span class="keywordtype">implicit none</span></div><div class="line"><a name="l01655"></a><span class="lineno"> 1655</span>&#160;    <span class="keywordtype">type</span>(mct_avect)        ,<span class="keywordtype">intent(in)</span>    :: av1<span class="comment">  !&lt; source av</span></div><div class="line"><a name="l01656"></a><span class="lineno"> 1656</span>&#160;    <span class="keywordtype">type</span>(mct_avect)        ,<span class="keywordtype">intent(inout)</span> :: avd<span class="comment">    !&lt; dst av</span></div><div class="line"><a name="l01657"></a><span class="lineno"> 1657</span>&#160;    <span class="keywordtype">type</span>(<a class="code" href="structmod__oasis__map_1_1prism__mapper__type.html">prism_mapper_type</a>),<span class="keywordtype">intent(inout)</span> :: mapper<span class="comment"> !&lt; prism_mapper</span></div><div class="line"><a name="l01658"></a><span class="lineno"> 1658</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>  ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: conserv<span class="comment">  !&lt; conserv flag</span></div><div class="line"><a name="l01659"></a><span class="lineno"> 1659</span>&#160;    <span class="keywordtype">character(len=ic_med)</span>  ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: consopt<span class="comment">  !&lt; conserv algorithm option</span></div><div class="line"><a name="l01660"></a><span class="lineno"> 1660</span>&#160;    <span class="keywordtype">logical</span>                ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: avon(:)<span class="comment"> !&lt; which source hot are on</span></div><div class="line"><a name="l01661"></a><span class="lineno"> 1661</span>&#160;    <span class="keywordtype">type</span>(mct_avect)        ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: av2<span class="comment">  !&lt; source av2 hot</span></div><div class="line"><a name="l01662"></a><span class="lineno"> 1662</span>&#160;    <span class="keywordtype">type</span>(mct_avect)        ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: av3<span class="comment">  !&lt; source av3 hot</span></div><div class="line"><a name="l01663"></a><span class="lineno"> 1663</span>&#160;    <span class="keywordtype">type</span>(mct_avect)        ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: av4<span class="comment">  !&lt; source av4 hot</span></div><div class="line"><a name="l01664"></a><span class="lineno"> 1664</span>&#160;    <span class="keywordtype">type</span>(mct_avect)        ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: av5<span class="comment">  !&lt; source av5 hot</span></div><div class="line"><a name="l01665"></a><span class="lineno"> 1665</span>&#160;    <span class="keywordtype">character(len=*)</span>       ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: tstrinp<span class="comment">  !&lt; timer label string</span></div><div class="line"><a name="l01666"></a><span class="lineno"> 1666</span>&#160;</div><div class="line"><a name="l01667"></a><span class="lineno"> 1667</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>  :: fsize,lsizes,lsized,nf,ni,n,m,ierr</div><div class="line"><a name="l01668"></a><span class="lineno"> 1668</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>     :: sumtmp, wts_sums, wts_sumd, zradi, zlagr</div><div class="line"><a name="l01669"></a><span class="lineno"> 1669</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>     :: wts_sums1(1), wts_sumd1(1)</div><div class="line"><a name="l01670"></a><span class="lineno"> 1670</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>,<span class="keywordtype">allocatable</span> :: imasks(:),imaskd(:)</div><div class="line"><a name="l01671"></a><span class="lineno"> 1671</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span> :: areas(:),aread(:)</div><div class="line"><a name="l01672"></a><span class="lineno"> 1672</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: av_sums(:),av_sumd(:)  <span class="comment">! local sums</span></div><div class="line"><a name="l01673"></a><span class="lineno"> 1673</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: avdtmp    <span class="comment">! for summing multiple mapping weights</span></div><div class="line"><a name="l01674"></a><span class="lineno"> 1674</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: av2g      <span class="comment">! for bfb sums</span></div><div class="line"><a name="l01675"></a><span class="lineno"> 1675</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: avone     <span class="comment">! for conserve</span></div><div class="line"><a name="l01676"></a><span class="lineno"> 1676</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: lconsopt  <span class="comment">! conserve algorithm option</span></div><div class="line"><a name="l01677"></a><span class="lineno"> 1677</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: tstring   <span class="comment">! timer string</span></div><div class="line"><a name="l01678"></a><span class="lineno"> 1678</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>,<span class="keywordtype">parameter</span> :: avsmax = <a class="code" href="namespacemod__oasis__coupler.html#a6f166f099a134dffba97a168d28a3c01">prism_coupler_avsmax</a></div><div class="line"><a name="l01679"></a><span class="lineno"> 1679</span>&#160;    <span class="keywordtype">logical</span>               :: locavon(avsmax)   <span class="comment">! local avon</span></div><div class="line"><a name="l01680"></a><span class="lineno"> 1680</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: avonsize</div><div class="line"><a name="l01681"></a><span class="lineno"> 1681</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: higher_order_check</div><div class="line"><a name="l01682"></a><span class="lineno"> 1682</span>&#160;    <span class="keywordtype">character(len=*)</span>,<span class="keywordtype">parameter</span> :: subname = <span class="stringliteral">&#39;(oasis_advance_map)&#39;</span></div><div class="line"><a name="l01683"></a><span class="lineno"> 1683</span>&#160;</div><div class="line"><a name="l01684"></a><span class="lineno"> 1684</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ab963e928a34a1521ec2c1921cc956cc5">oasis_debug_enter</a>(subname)</div><div class="line"><a name="l01685"></a><span class="lineno"> 1685</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_start&#39;</span>)</div><div class="line"><a name="l01686"></a><span class="lineno"> 1686</span>&#160;<span class="comment"></span></div><div class="line"><a name="l01687"></a><span class="lineno"> 1687</span>&#160;<span class="comment">    !&gt; oasis_advance_map does the following</span></div><div class="line"><a name="l01688"></a><span class="lineno"> 1688</span>&#160;<span class="comment">    !&gt; * check for conservation flags</span></div><div class="line"><a name="l01689"></a><span class="lineno"> 1689</span>&#160;</div><div class="line"><a name="l01690"></a><span class="lineno"> 1690</span>&#160;    lconsopt = <span class="stringliteral">&#39;bfb&#39;</span></div><div class="line"><a name="l01691"></a><span class="lineno"> 1691</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(consopt)) <span class="keywordflow">then</span></div><div class="line"><a name="l01692"></a><span class="lineno"> 1692</span>&#160;       lconsopt = consopt</div><div class="line"><a name="l01693"></a><span class="lineno"> 1693</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l01694"></a><span class="lineno"> 1694</span>&#160;<span class="comment"></span></div><div class="line"><a name="l01695"></a><span class="lineno"> 1695</span>&#160;<span class="comment">    !&gt; * check for higher order terms</span></div><div class="line"><a name="l01696"></a><span class="lineno"> 1696</span>&#160;    <span class="comment">!--- assume avon and av2-5 are not passed but av1 always is ---</span></div><div class="line"><a name="l01697"></a><span class="lineno"> 1697</span>&#160;    avonsize = 1</div><div class="line"><a name="l01698"></a><span class="lineno"> 1698</span>&#160;    locavon = .false.</div><div class="line"><a name="l01699"></a><span class="lineno"> 1699</span>&#160;    locavon(1) = .true.</div><div class="line"><a name="l01700"></a><span class="lineno"> 1700</span>&#160;</div><div class="line"><a name="l01701"></a><span class="lineno"> 1701</span>&#160;    <span class="comment">!--- but if avon is passed, use avon flags ---</span></div><div class="line"><a name="l01702"></a><span class="lineno"> 1702</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(avon)) <span class="keywordflow">then</span></div><div class="line"><a name="l01703"></a><span class="lineno"> 1703</span>&#160;       avonsize = <span class="keyword">size</span>(avon)</div><div class="line"><a name="l01704"></a><span class="lineno"> 1704</span>&#160;       <span class="keywordflow">if</span> (avonsize &gt; avsmax) <span class="keywordflow">then</span></div><div class="line"><a name="l01705"></a><span class="lineno"> 1705</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;avon size&#39;</span>,avonsize,<span class="stringliteral">&#39; passed in is too large&#39;</span>,avsmax</div><div class="line"><a name="l01706"></a><span class="lineno"> 1706</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01707"></a><span class="lineno"> 1707</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01708"></a><span class="lineno"> 1708</span>&#160;       locavon(1:avonsize) = avon(1:avonsize)</div><div class="line"><a name="l01709"></a><span class="lineno"> 1709</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l01710"></a><span class="lineno"> 1710</span>&#160;       <span class="comment">!--- if avon is not passed, av2-5 should not be ---</span></div><div class="line"><a name="l01711"></a><span class="lineno"> 1711</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(av2) .or. <span class="keyword">present</span>(av3) .or. <span class="keyword">present</span>(av4) .or. <span class="keyword">present</span>(av5)) <span class="keywordflow">then</span></div><div class="line"><a name="l01712"></a><span class="lineno"> 1712</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;av2-5 passed but avon not passed&#39;</span></div><div class="line"><a name="l01713"></a><span class="lineno"> 1713</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01714"></a><span class="lineno"> 1714</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01715"></a><span class="lineno"> 1715</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l01716"></a><span class="lineno"> 1716</span>&#160;<span class="comment"></span></div><div class="line"><a name="l01717"></a><span class="lineno"> 1717</span>&#160;<span class="comment">    !&gt; * check consistency between weights and coupling terms</span></div><div class="line"><a name="l01718"></a><span class="lineno"> 1718</span>&#160;</div><div class="line"><a name="l01719"></a><span class="lineno"> 1719</span>&#160;    <span class="comment">! tcraig, redmine #709, add this to increase checking consistency, Aug 2016.</span></div><div class="line"><a name="l01720"></a><span class="lineno"> 1720</span>&#160;    higher_order_check = 1</div><div class="line"><a name="l01721"></a><span class="lineno"> 1721</span>&#160;</div><div class="line"><a name="l01722"></a><span class="lineno"> 1722</span>&#160;    <span class="comment">! tcraig, redmine #709, comment this out to increase checking consistency, Aug 2016.</span></div><div class="line"><a name="l01723"></a><span class="lineno"> 1723</span>&#160;    <span class="comment">! this section only enforces consistency when bicubic is used</span></div><div class="line"><a name="l01724"></a><span class="lineno"> 1724</span>&#160;    <span class="comment">! nwgts=4 assumes bicubic which requires 4 higher order fields</span></div><div class="line"><a name="l01725"></a><span class="lineno"> 1725</span>&#160;<span class="comment">!    higher_order_check = 0</span></div><div class="line"><a name="l01726"></a><span class="lineno"> 1726</span>&#160;<span class="comment">!    if (mapper%nwgts == 4) higher_order_check = 1</span></div><div class="line"><a name="l01727"></a><span class="lineno"> 1727</span>&#160;</div><div class="line"><a name="l01728"></a><span class="lineno"> 1728</span>&#160;    <span class="keywordflow">if</span> (higher_order_check == 0) <span class="keywordflow">then</span></div><div class="line"><a name="l01729"></a><span class="lineno"> 1729</span>&#160;       <span class="comment">! must have weights for each higher order field passed but can have extra weights</span></div><div class="line"><a name="l01730"></a><span class="lineno"> 1730</span>&#160;       <span class="keywordflow">do</span> n = 1,avsmax</div><div class="line"><a name="l01731"></a><span class="lineno"> 1731</span>&#160;          <span class="keywordflow">if</span> (locavon(n) .and. n &gt; mapper%nwgts) <span class="keywordflow">then</span></div><div class="line"><a name="l01732"></a><span class="lineno"> 1732</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;higher_order_check = &#39;</span>,higher_order_check</div><div class="line"><a name="l01733"></a><span class="lineno"> 1733</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;missing weights for higher order field&#39;</span></div><div class="line"><a name="l01734"></a><span class="lineno"> 1734</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;missing weights output &#39;</span>,n,avsmax,mapper%nwgts,locavon(n)</div><div class="line"><a name="l01735"></a><span class="lineno"> 1735</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01736"></a><span class="lineno"> 1736</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01737"></a><span class="lineno"> 1737</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l01738"></a><span class="lineno"> 1738</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l01739"></a><span class="lineno"> 1739</span>&#160;       <span class="comment">! number of higher order fields passed must exactly match the number of higher order weights</span></div><div class="line"><a name="l01740"></a><span class="lineno"> 1740</span>&#160;       <span class="keywordflow">do</span> n = 1,avsmax</div><div class="line"><a name="l01741"></a><span class="lineno"> 1741</span>&#160;          <span class="keywordflow">if</span> ((locavon(n) .and. n &gt; mapper%nwgts) .or. &amp;</div><div class="line"><a name="l01742"></a><span class="lineno"> 1742</span>&#160;              (.not. locavon(n) .and. n &lt;= mapper%nwgts)) <span class="keywordflow">then</span></div><div class="line"><a name="l01743"></a><span class="lineno"> 1743</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;higher_order_check = &#39;</span>,higher_order_check</div><div class="line"><a name="l01744"></a><span class="lineno"> 1744</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;mismatch of higher order fields passed and weights&#39;</span></div><div class="line"><a name="l01745"></a><span class="lineno"> 1745</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;mismatch weights output &#39;</span>,n,avsmax,mapper%nwgts,locavon(n)</div><div class="line"><a name="l01746"></a><span class="lineno"> 1746</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01747"></a><span class="lineno"> 1747</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01748"></a><span class="lineno"> 1748</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l01749"></a><span class="lineno"> 1749</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l01750"></a><span class="lineno"> 1750</span>&#160;<span class="comment"></span></div><div class="line"><a name="l01751"></a><span class="lineno"> 1751</span>&#160;<span class="comment">    !&gt; * run mct sparse matrix mapper on data and separately on hot as needed</span></div><div class="line"><a name="l01752"></a><span class="lineno"> 1752</span>&#160;</div><div class="line"><a name="l01753"></a><span class="lineno"> 1753</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_start&#39;</span>)</div><div class="line"><a name="l01754"></a><span class="lineno"> 1754</span>&#160;</div><div class="line"><a name="l01755"></a><span class="lineno"> 1755</span>&#160;    <span class="keywordflow">if</span> (locavon(1)) <span class="keywordflow">then</span></div><div class="line"><a name="l01756"></a><span class="lineno"> 1756</span>&#160;       <span class="keywordflow">if</span> (mct_avect_nrattr(av1) /= mct_avect_nrattr(avd)) <span class="keywordflow">then</span></div><div class="line"><a name="l01757"></a><span class="lineno"> 1757</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;in av1 num of flds&#39;</span></div><div class="line"><a name="l01758"></a><span class="lineno"> 1758</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01759"></a><span class="lineno"> 1759</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01760"></a><span class="lineno"> 1760</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult1&#39;</span>)</div><div class="line"><a name="l01761"></a><span class="lineno"> 1761</span>&#160;       <span class="keyword">call </span>mct_smat_avmult(av1, mapper%sMatP(1), avd)</div><div class="line"><a name="l01762"></a><span class="lineno"> 1762</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult1&#39;</span>)</div><div class="line"><a name="l01763"></a><span class="lineno"> 1763</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l01764"></a><span class="lineno"> 1764</span>&#160;</div><div class="line"><a name="l01765"></a><span class="lineno"> 1765</span>&#160;    <span class="keywordflow">if</span> (locavon(2).or.locavon(3).or.locavon(4).or.locavon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l01766"></a><span class="lineno"> 1766</span>&#160;       lsized = mct_avect_lsize(avd)</div><div class="line"><a name="l01767"></a><span class="lineno"> 1767</span>&#160;       <span class="keyword">call </span>mct_avect_init(avdtmp,avd,lsized)</div><div class="line"><a name="l01768"></a><span class="lineno"> 1768</span>&#160;</div><div class="line"><a name="l01769"></a><span class="lineno"> 1769</span>&#160;       <span class="keywordflow">if</span> (locavon(2)) <span class="keywordflow">then</span></div><div class="line"><a name="l01770"></a><span class="lineno"> 1770</span>&#160;          <span class="keywordflow">if</span> (mct_avect_nrattr(av2) /= mct_avect_nrattr(avd)) <span class="keywordflow">then</span></div><div class="line"><a name="l01771"></a><span class="lineno"> 1771</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;in av2 num of flds&#39;</span></div><div class="line"><a name="l01772"></a><span class="lineno"> 1772</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01773"></a><span class="lineno"> 1773</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01774"></a><span class="lineno"> 1774</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult2&#39;</span>)</div><div class="line"><a name="l01775"></a><span class="lineno"> 1775</span>&#160;          <span class="keyword">call </span>mct_smat_avmult(av2, mapper%sMatP(2), avdtmp)</div><div class="line"><a name="l01776"></a><span class="lineno"> 1776</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult2&#39;</span>)</div><div class="line"><a name="l01777"></a><span class="lineno"> 1777</span>&#160;          avd%rAttr = avd%rAttr + avdtmp%rAttr</div><div class="line"><a name="l01778"></a><span class="lineno"> 1778</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01779"></a><span class="lineno"> 1779</span>&#160;</div><div class="line"><a name="l01780"></a><span class="lineno"> 1780</span>&#160;       <span class="keywordflow">if</span> (locavon(3)) <span class="keywordflow">then</span></div><div class="line"><a name="l01781"></a><span class="lineno"> 1781</span>&#160;          <span class="keywordflow">if</span> (mct_avect_nrattr(av3) /= mct_avect_nrattr(avd)) <span class="keywordflow">then</span></div><div class="line"><a name="l01782"></a><span class="lineno"> 1782</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;in av3 num of flds&#39;</span></div><div class="line"><a name="l01783"></a><span class="lineno"> 1783</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01784"></a><span class="lineno"> 1784</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01785"></a><span class="lineno"> 1785</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult3&#39;</span>)</div><div class="line"><a name="l01786"></a><span class="lineno"> 1786</span>&#160;          <span class="keyword">call </span>mct_smat_avmult(av3, mapper%sMatP(3), avdtmp)</div><div class="line"><a name="l01787"></a><span class="lineno"> 1787</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult3&#39;</span>)</div><div class="line"><a name="l01788"></a><span class="lineno"> 1788</span>&#160;          avd%rAttr = avd%rAttr + avdtmp%rAttr</div><div class="line"><a name="l01789"></a><span class="lineno"> 1789</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01790"></a><span class="lineno"> 1790</span>&#160;</div><div class="line"><a name="l01791"></a><span class="lineno"> 1791</span>&#160;       <span class="keywordflow">if</span> (locavon(4)) <span class="keywordflow">then</span></div><div class="line"><a name="l01792"></a><span class="lineno"> 1792</span>&#160;          <span class="keywordflow">if</span> (mct_avect_nrattr(av4) /= mct_avect_nrattr(avd)) <span class="keywordflow">then</span></div><div class="line"><a name="l01793"></a><span class="lineno"> 1793</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;in av4 num of flds&#39;</span></div><div class="line"><a name="l01794"></a><span class="lineno"> 1794</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01795"></a><span class="lineno"> 1795</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01796"></a><span class="lineno"> 1796</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult4&#39;</span>)</div><div class="line"><a name="l01797"></a><span class="lineno"> 1797</span>&#160;          <span class="keyword">call </span>mct_smat_avmult(av4, mapper%sMatP(4), avdtmp)</div><div class="line"><a name="l01798"></a><span class="lineno"> 1798</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult4&#39;</span>)</div><div class="line"><a name="l01799"></a><span class="lineno"> 1799</span>&#160;          avd%rAttr = avd%rAttr + avdtmp%rAttr</div><div class="line"><a name="l01800"></a><span class="lineno"> 1800</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01801"></a><span class="lineno"> 1801</span>&#160;</div><div class="line"><a name="l01802"></a><span class="lineno"> 1802</span>&#160;       <span class="keywordflow">if</span> (locavon(5)) <span class="keywordflow">then</span></div><div class="line"><a name="l01803"></a><span class="lineno"> 1803</span>&#160;          <span class="keywordflow">if</span> (mct_avect_nrattr(av5) /= mct_avect_nrattr(avd)) <span class="keywordflow">then</span></div><div class="line"><a name="l01804"></a><span class="lineno"> 1804</span>&#160;             <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;in av5 num of flds&#39;</span></div><div class="line"><a name="l01805"></a><span class="lineno"> 1805</span>&#160;             <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01806"></a><span class="lineno"> 1806</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01807"></a><span class="lineno"> 1807</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult5&#39;</span>)</div><div class="line"><a name="l01808"></a><span class="lineno"> 1808</span>&#160;          <span class="keyword">call </span>mct_smat_avmult(av5, mapper%sMatP(5), avdtmp)</div><div class="line"><a name="l01809"></a><span class="lineno"> 1809</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avMult5&#39;</span>)</div><div class="line"><a name="l01810"></a><span class="lineno"> 1810</span>&#160;          avd%rAttr = avd%rAttr + avdtmp%rAttr</div><div class="line"><a name="l01811"></a><span class="lineno"> 1811</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01812"></a><span class="lineno"> 1812</span>&#160;</div><div class="line"><a name="l01813"></a><span class="lineno"> 1813</span>&#160;       <span class="keyword">call </span>mct_avect_clean(avdtmp)</div><div class="line"><a name="l01814"></a><span class="lineno"> 1814</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l01815"></a><span class="lineno"> 1815</span>&#160;</div><div class="line"><a name="l01816"></a><span class="lineno"> 1816</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; map&#39;</span>)</div><div class="line"><a name="l01817"></a><span class="lineno"> 1817</span>&#160;<span class="comment"></span></div><div class="line"><a name="l01818"></a><span class="lineno"> 1818</span>&#160;<span class="comment">    !&gt; * enforce conservation</span></div><div class="line"><a name="l01819"></a><span class="lineno"> 1819</span>&#160;</div><div class="line"><a name="l01820"></a><span class="lineno"> 1820</span>&#160;    <span class="keywordflow">IF</span> (<span class="keyword">PRESENT</span>(conserv)) <span class="keywordflow">THEN</span></div><div class="line"><a name="l01821"></a><span class="lineno"> 1821</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">oasis_debug_note</a>(subname//<span class="stringliteral">&#39; conserv&#39;</span>)</div><div class="line"><a name="l01822"></a><span class="lineno"> 1822</span>&#160;    <span class="keywordflow">IF</span> (conserv /= <a class="code" href="namespacemod__oasis__parameters.html#ae043e4e2c2b7f04fec7d8c061ef52934">ip_cnone</a>) <span class="keywordflow">THEN</span></div><div class="line"><a name="l01823"></a><span class="lineno"> 1823</span>&#160;</div><div class="line"><a name="l01824"></a><span class="lineno"> 1824</span>&#160;       <span class="comment">!-------------------</span></div><div class="line"><a name="l01825"></a><span class="lineno"> 1825</span>&#160;       <span class="comment">! check that conservation can be computed for two partitions on overlapping pes only</span></div><div class="line"><a name="l01826"></a><span class="lineno"> 1826</span>&#160;       <span class="comment">! this should be true all the time as the spart and dpart depend on each other and are</span></div><div class="line"><a name="l01827"></a><span class="lineno"> 1827</span>&#160;       <span class="comment">!   on the same pes in the initialization.  add this check in case that changes.</span></div><div class="line"><a name="l01828"></a><span class="lineno"> 1828</span>&#160;       <span class="comment">! then run the conserve on only the active pes</span></div><div class="line"><a name="l01829"></a><span class="lineno"> 1829</span>&#160;       <span class="comment">!-------------------</span></div><div class="line"><a name="l01830"></a><span class="lineno"> 1830</span>&#160;       <span class="keywordflow">if</span> ((<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom /= mpi_comm_null .and. <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%mpicom == mpi_comm_null) .or. &amp;</div><div class="line"><a name="l01831"></a><span class="lineno"> 1831</span>&#160;           (<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom == mpi_comm_null .and. <a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%mpicom /= mpi_comm_null)) <span class="keywordflow">then</span></div><div class="line"><a name="l01832"></a><span class="lineno"> 1832</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;illegal conserve on non overlapping pes &#39;</span></div><div class="line"><a name="l01833"></a><span class="lineno"> 1833</span>&#160;           <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01834"></a><span class="lineno"> 1834</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01835"></a><span class="lineno"> 1835</span>&#160;</div><div class="line"><a name="l01836"></a><span class="lineno"> 1836</span>&#160;    <span class="keywordflow">IF</span> (<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom /= mpi_comm_null) <span class="keywordflow">then</span></div><div class="line"><a name="l01837"></a><span class="lineno"> 1837</span>&#160;</div><div class="line"><a name="l01838"></a><span class="lineno"> 1838</span>&#160;       fsize = mct_avect_nrattr(av1)</div><div class="line"><a name="l01839"></a><span class="lineno"> 1839</span>&#160;       <span class="keyword">allocate</span>(av_sums(fsize),av_sumd(fsize))</div><div class="line"><a name="l01840"></a><span class="lineno"> 1840</span>&#160;</div><div class="line"><a name="l01841"></a><span class="lineno"> 1841</span>&#160;       zradi = 1./(<a class="code" href="namespacemod__oasis__data.html#a7f361db125e5554d0427e964b698f10c">eradius</a>*<a class="code" href="namespacemod__oasis__data.html#a7f361db125e5554d0427e964b698f10c">eradius</a>)</div><div class="line"><a name="l01842"></a><span class="lineno"> 1842</span>&#160;</div><div class="line"><a name="l01843"></a><span class="lineno"> 1843</span>&#160;       <span class="comment">!-------------------</span></div><div class="line"><a name="l01844"></a><span class="lineno"> 1844</span>&#160;       <span class="comment">! extract mask and area and compute sum of masked area for source</span></div><div class="line"><a name="l01845"></a><span class="lineno"> 1845</span>&#160;       <span class="comment">!-------------------</span></div><div class="line"><a name="l01846"></a><span class="lineno"> 1846</span>&#160;       lsizes = mct_avect_lsize(mapper%av_ms)</div><div class="line"><a name="l01847"></a><span class="lineno"> 1847</span>&#160;       <span class="keyword">allocate</span>(imasks(lsizes),areas(lsizes))</div><div class="line"><a name="l01848"></a><span class="lineno"> 1848</span>&#160;       nf = mct_avect_indexia(mapper%av_ms,<span class="stringliteral">&#39;mask&#39;</span>)</div><div class="line"><a name="l01849"></a><span class="lineno"> 1849</span>&#160;       imasks(:) = mapper%av_ms%iAttr(nf,:)</div><div class="line"><a name="l01850"></a><span class="lineno"> 1850</span>&#160;       nf = mct_avect_indexra(mapper%av_ms,<span class="stringliteral">&#39;area&#39;</span>)</div><div class="line"><a name="l01851"></a><span class="lineno"> 1851</span>&#160;       areas(:) = mapper%av_ms%rAttr(nf,:)*zradi</div><div class="line"><a name="l01852"></a><span class="lineno"> 1852</span>&#160;</div><div class="line"><a name="l01853"></a><span class="lineno"> 1853</span>&#160;       <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__advance.html#ac617024af9299c27eaeb9156f647b028">map_barrier</a> .and. <span class="keyword">present</span>(tstrinp)) <span class="keywordflow">then</span></div><div class="line"><a name="l01854"></a><span class="lineno"> 1854</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cons_prebarrier&#39;</span>)</div><div class="line"><a name="l01855"></a><span class="lineno"> 1855</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__mpi.html#aaf477847380fbbbc1341520b0b3e66da">oasis_mpi_barrier</a>(<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom, trim(tstrinp))</div><div class="line"><a name="l01856"></a><span class="lineno"> 1856</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cons_prebarrier&#39;</span>)</div><div class="line"><a name="l01857"></a><span class="lineno"> 1857</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01858"></a><span class="lineno"> 1858</span>&#160;</div><div class="line"><a name="l01859"></a><span class="lineno"> 1859</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cons1&#39;</span>)</div><div class="line"><a name="l01860"></a><span class="lineno"> 1860</span>&#160;       <span class="keyword">call </span>mct_avect_init(avone,rlist=<span class="stringliteral">&#39;one&#39;</span>,lsize=lsizes)</div><div class="line"><a name="l01861"></a><span class="lineno"> 1861</span>&#160;       avone%rAttr = 1.0_ip_r8_p</div><div class="line"><a name="l01862"></a><span class="lineno"> 1862</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">oasis_advance_avsum</a>(avone,wts_sums1,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom, &amp;</div><div class="line"><a name="l01863"></a><span class="lineno"> 1863</span>&#160;                                mask=imasks,wts=areas,consopt=lconsopt)</div><div class="line"><a name="l01864"></a><span class="lineno"> 1864</span>&#160;       wts_sums = wts_sums1(1)</div><div class="line"><a name="l01865"></a><span class="lineno"> 1865</span>&#160;       <span class="keyword">call </span>mct_avect_clean(avone)</div><div class="line"><a name="l01866"></a><span class="lineno"> 1866</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cons1&#39;</span>)</div><div class="line"><a name="l01867"></a><span class="lineno"> 1867</span>&#160;</div><div class="line"><a name="l01868"></a><span class="lineno"> 1868</span>&#160;       <span class="comment">!-------------------</span></div><div class="line"><a name="l01869"></a><span class="lineno"> 1869</span>&#160;       <span class="comment">! extract mask and area and compute sum of masked area for destination</span></div><div class="line"><a name="l01870"></a><span class="lineno"> 1870</span>&#160;       <span class="comment">!-------------------</span></div><div class="line"><a name="l01871"></a><span class="lineno"> 1871</span>&#160;       lsized = mct_avect_lsize(mapper%av_md)</div><div class="line"><a name="l01872"></a><span class="lineno"> 1872</span>&#160;       <span class="keyword">allocate</span>(imaskd(lsized),aread(lsized))</div><div class="line"><a name="l01873"></a><span class="lineno"> 1873</span>&#160;       nf = mct_avect_indexia(mapper%av_md,<span class="stringliteral">&#39;mask&#39;</span>)</div><div class="line"><a name="l01874"></a><span class="lineno"> 1874</span>&#160;       imaskd(:) = mapper%av_md%iAttr(nf,:)</div><div class="line"><a name="l01875"></a><span class="lineno"> 1875</span>&#160;       nf = mct_avect_indexra(mapper%av_md,<span class="stringliteral">&#39;area&#39;</span>)</div><div class="line"><a name="l01876"></a><span class="lineno"> 1876</span>&#160;       aread(:) = mapper%av_md%rAttr(nf,:)*zradi</div><div class="line"><a name="l01877"></a><span class="lineno"> 1877</span>&#160;</div><div class="line"><a name="l01878"></a><span class="lineno"> 1878</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cons2&#39;</span>)</div><div class="line"><a name="l01879"></a><span class="lineno"> 1879</span>&#160;       <span class="keyword">call </span>mct_avect_init(avone,rlist=<span class="stringliteral">&#39;one&#39;</span>,lsize=lsized)</div><div class="line"><a name="l01880"></a><span class="lineno"> 1880</span>&#160;       avone%rAttr = 1.0_ip_r8_p</div><div class="line"><a name="l01881"></a><span class="lineno"> 1881</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">oasis_advance_avsum</a>(avone,wts_sumd1,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%mpicom, &amp;</div><div class="line"><a name="l01882"></a><span class="lineno"> 1882</span>&#160;                                mask=imaskd,wts=aread,consopt=lconsopt)</div><div class="line"><a name="l01883"></a><span class="lineno"> 1883</span>&#160;       wts_sumd = wts_sumd1(1)</div><div class="line"><a name="l01884"></a><span class="lineno"> 1884</span>&#160;       <span class="keyword">call </span>mct_avect_clean(avone)</div><div class="line"><a name="l01885"></a><span class="lineno"> 1885</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cons2&#39;</span>)</div><div class="line"><a name="l01886"></a><span class="lineno"> 1886</span>&#160;</div><div class="line"><a name="l01887"></a><span class="lineno"> 1887</span>&#160;       <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 30) <span class="keywordflow">then</span></div><div class="line"><a name="l01888"></a><span class="lineno"> 1888</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG conserve src mask &#39;</span>,minval(imasks),&amp;</div><div class="line"><a name="l01889"></a><span class="lineno"> 1889</span>&#160;                          maxval(imasks),sum(imasks)</div><div class="line"><a name="l01890"></a><span class="lineno"> 1890</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG conserve dst mask &#39;</span>,minval(imaskd),&amp;</div><div class="line"><a name="l01891"></a><span class="lineno"> 1891</span>&#160;                          maxval(imaskd),sum(imaskd)</div><div class="line"><a name="l01892"></a><span class="lineno"> 1892</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG conserve src area &#39;</span>,minval(areas),&amp;</div><div class="line"><a name="l01893"></a><span class="lineno"> 1893</span>&#160;                          maxval(areas),sum(areas)</div><div class="line"><a name="l01894"></a><span class="lineno"> 1894</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG conserve dst area &#39;</span>,minval(aread),&amp;</div><div class="line"><a name="l01895"></a><span class="lineno"> 1895</span>&#160;                          maxval(aread),sum(aread)</div><div class="line"><a name="l01896"></a><span class="lineno"> 1896</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG conserve wts_sum  &#39;</span>,wts_sums,wts_sumd</div><div class="line"><a name="l01897"></a><span class="lineno"> 1897</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01898"></a><span class="lineno"> 1898</span>&#160;</div><div class="line"><a name="l01899"></a><span class="lineno"> 1899</span>&#160;       <span class="comment">!-------------------</span></div><div class="line"><a name="l01900"></a><span class="lineno"> 1900</span>&#160;       <span class="comment">! compute global sums of av1</span></div><div class="line"><a name="l01901"></a><span class="lineno"> 1901</span>&#160;       <span class="comment">! assume av1 is the thing to be conserved</span></div><div class="line"><a name="l01902"></a><span class="lineno"> 1902</span>&#160;       <span class="comment">!-------------------</span></div><div class="line"><a name="l01903"></a><span class="lineno"> 1903</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avsum&#39;</span>)</div><div class="line"><a name="l01904"></a><span class="lineno"> 1904</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">oasis_advance_avsum</a>(av1,av_sums,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom, &amp;</div><div class="line"><a name="l01905"></a><span class="lineno"> 1905</span>&#160;                                mask=imasks,wts=areas,consopt=lconsopt)</div><div class="line"><a name="l01906"></a><span class="lineno"> 1906</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">oasis_advance_avsum</a>(avd,av_sumd,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%mpicom, &amp;</div><div class="line"><a name="l01907"></a><span class="lineno"> 1907</span>&#160;                                mask=imaskd,wts=aread,consopt=lconsopt)</div><div class="line"><a name="l01908"></a><span class="lineno"> 1908</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avsum&#39;</span>)</div><div class="line"><a name="l01909"></a><span class="lineno"> 1909</span>&#160;</div><div class="line"><a name="l01910"></a><span class="lineno"> 1910</span>&#160;       <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01911"></a><span class="lineno"> 1911</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom /= mpi_comm_null) <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG src sum b4 conserve &#39;</span>,av_sums</div><div class="line"><a name="l01912"></a><span class="lineno"> 1912</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%mpicom /= mpi_comm_null) <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG dst sum b4 conserve &#39;</span>,av_sumd</div><div class="line"><a name="l01913"></a><span class="lineno"> 1913</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01914"></a><span class="lineno"> 1914</span>&#160;</div><div class="line"><a name="l01915"></a><span class="lineno"> 1915</span>&#160;       <span class="keywordflow">if</span> (conserv == <a class="code" href="namespacemod__oasis__parameters.html#ae251e3ac1c9c82ae5db2a768d2d59d5f">ip_cglobal</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01916"></a><span class="lineno"> 1916</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cglobal&#39;</span>)</div><div class="line"><a name="l01917"></a><span class="lineno"> 1917</span>&#160;          <span class="keywordflow">if</span> (wts_sumd == 0.0_ip_r8_p) <span class="keywordflow">then</span></div><div class="line"><a name="l01918"></a><span class="lineno"> 1918</span>&#160;              <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;global conserve sums to zero &#39;</span></div><div class="line"><a name="l01919"></a><span class="lineno"> 1919</span>&#160;              <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01920"></a><span class="lineno"> 1920</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01921"></a><span class="lineno"> 1921</span>&#160;          <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l01922"></a><span class="lineno"> 1922</span>&#160;             zlagr = (av_sumd(m) - av_sums(m)) / wts_sumd</div><div class="line"><a name="l01923"></a><span class="lineno"> 1923</span>&#160;             <span class="keywordflow">do</span> n = 1,lsized</div><div class="line"><a name="l01924"></a><span class="lineno"> 1924</span>&#160;                <span class="keywordflow">if</span> (imaskd(n) == 0) avd%rAttr(m,n) = avd%rAttr(m,n) - zlagr</div><div class="line"><a name="l01925"></a><span class="lineno"> 1925</span>&#160;<span class="keywordflow">             enddo</span></div><div class="line"><a name="l01926"></a><span class="lineno"> 1926</span>&#160;<span class="keywordflow">          enddo</span></div><div class="line"><a name="l01927"></a><span class="lineno"> 1927</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cglobal&#39;</span>)</div><div class="line"><a name="l01928"></a><span class="lineno"> 1928</span>&#160;       <span class="keywordflow">elseif</span> (conserv == <a class="code" href="namespacemod__oasis__parameters.html#aec700ad0c6a11dd35e5d6c2afb745fd0">ip_cglbpos</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01929"></a><span class="lineno"> 1929</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cglbpos&#39;</span>)</div><div class="line"><a name="l01930"></a><span class="lineno"> 1930</span>&#160;          <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l01931"></a><span class="lineno"> 1931</span>&#160;             <span class="keywordflow">if</span> (av_sumd(m) == 0.0_ip_r8_p .and. av_sums(m) /= 0.0_ip_r8_p) <span class="keywordflow">then</span></div><div class="line"><a name="l01932"></a><span class="lineno"> 1932</span>&#160;                 <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;cglpos conserve one of the sums is zero&#39;</span></div><div class="line"><a name="l01933"></a><span class="lineno"> 1933</span>&#160;                 <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01934"></a><span class="lineno"> 1934</span>&#160;             <span class="keywordflow">elseif</span> (av_sumd(m) /= 0.0_ip_r8_p) <span class="keywordflow">then</span></div><div class="line"><a name="l01935"></a><span class="lineno"> 1935</span>&#160;                zlagr = av_sums(m) / av_sumd(m)</div><div class="line"><a name="l01936"></a><span class="lineno"> 1936</span>&#160;                <span class="keywordflow">do</span> n = 1,lsized</div><div class="line"><a name="l01937"></a><span class="lineno"> 1937</span>&#160;                   <span class="keywordflow">if</span> (imaskd(n) == 0) avd%rAttr(m,n) = avd%rAttr(m,n) * zlagr</div><div class="line"><a name="l01938"></a><span class="lineno"> 1938</span>&#160;<span class="keywordflow">                enddo</span></div><div class="line"><a name="l01939"></a><span class="lineno"> 1939</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01940"></a><span class="lineno"> 1940</span>&#160;<span class="keywordflow">          enddo</span></div><div class="line"><a name="l01941"></a><span class="lineno"> 1941</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cglbpos&#39;</span>)</div><div class="line"><a name="l01942"></a><span class="lineno"> 1942</span>&#160;       <span class="keywordflow">elseif</span> (conserv == <a class="code" href="namespacemod__oasis__parameters.html#aaa7ead98ff7d53acfd539a32fca9e2c7">ip_cbasbal</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01943"></a><span class="lineno"> 1943</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cbasbal&#39;</span>)</div><div class="line"><a name="l01944"></a><span class="lineno"> 1944</span>&#160;          <span class="keywordflow">if</span> (wts_sumd == 0.0_ip_r8_p .or. wts_sums == 0.0_ip_r8_p) <span class="keywordflow">then</span></div><div class="line"><a name="l01945"></a><span class="lineno"> 1945</span>&#160;              <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;cbasbal conserve both sums are zero&#39;</span></div><div class="line"><a name="l01946"></a><span class="lineno"> 1946</span>&#160;              <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01947"></a><span class="lineno"> 1947</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l01948"></a><span class="lineno"> 1948</span>&#160;          <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l01949"></a><span class="lineno"> 1949</span>&#160;             zlagr = (av_sumd(m) - (av_sums(m)*(wts_sumd/wts_sums))) / wts_sumd</div><div class="line"><a name="l01950"></a><span class="lineno"> 1950</span>&#160;             <span class="keywordflow">do</span> n = 1,lsized</div><div class="line"><a name="l01951"></a><span class="lineno"> 1951</span>&#160;                <span class="keywordflow">if</span> (imaskd(n) == 0) avd%rAttr(m,n) = avd%rAttr(m,n) - zlagr</div><div class="line"><a name="l01952"></a><span class="lineno"> 1952</span>&#160;<span class="keywordflow">             enddo</span></div><div class="line"><a name="l01953"></a><span class="lineno"> 1953</span>&#160;<span class="keywordflow">          enddo</span></div><div class="line"><a name="l01954"></a><span class="lineno"> 1954</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cbasbal&#39;</span>)</div><div class="line"><a name="l01955"></a><span class="lineno"> 1955</span>&#160;       <span class="keywordflow">elseif</span> (conserv == <a class="code" href="namespacemod__oasis__parameters.html#a3b96d31bbe142d84df2b93880498936f">ip_cbaspos</a>) <span class="keywordflow">then</span></div><div class="line"><a name="l01956"></a><span class="lineno"> 1956</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cbaspos&#39;</span>)</div><div class="line"><a name="l01957"></a><span class="lineno"> 1957</span>&#160;          <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l01958"></a><span class="lineno"> 1958</span>&#160;             <span class="keywordflow">if</span> (av_sumd(m) == 0.0_ip_r8_p .and. av_sums(m) /= 0.0_ip_r8_p) <span class="keywordflow">then</span></div><div class="line"><a name="l01959"></a><span class="lineno"> 1959</span>&#160;                 <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;cbaspos conserve one of the sums is zero&#39;</span></div><div class="line"><a name="l01960"></a><span class="lineno"> 1960</span>&#160;                 <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01961"></a><span class="lineno"> 1961</span>&#160;             <span class="keywordflow">elseif</span> (av_sumd(m) /= 0.0_ip_r8_p) <span class="keywordflow">then</span></div><div class="line"><a name="l01962"></a><span class="lineno"> 1962</span>&#160;                zlagr = (av_sums(m)/av_sumd(m)) * (wts_sumd/wts_sums)</div><div class="line"><a name="l01963"></a><span class="lineno"> 1963</span>&#160;                <span class="keywordflow">do</span> n = 1,lsized</div><div class="line"><a name="l01964"></a><span class="lineno"> 1964</span>&#160;                   <span class="keywordflow">if</span> (imaskd(n) == 0) avd%rAttr(m,n) = avd%rAttr(m,n) * zlagr</div><div class="line"><a name="l01965"></a><span class="lineno"> 1965</span>&#160;<span class="keywordflow">                enddo</span></div><div class="line"><a name="l01966"></a><span class="lineno"> 1966</span>&#160;<span class="keywordflow">             endif</span></div><div class="line"><a name="l01967"></a><span class="lineno"> 1967</span>&#160;<span class="keywordflow">          enddo</span></div><div class="line"><a name="l01968"></a><span class="lineno"> 1968</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_cbaspos&#39;</span>)</div><div class="line"><a name="l01969"></a><span class="lineno"> 1969</span>&#160;       <span class="keywordflow">else</span></div><div class="line"><a name="l01970"></a><span class="lineno"> 1970</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;conserv option unknown = &#39;</span>,conserv</div><div class="line"><a name="l01971"></a><span class="lineno"> 1971</span>&#160;           <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l01972"></a><span class="lineno"> 1972</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01973"></a><span class="lineno"> 1973</span>&#160;</div><div class="line"><a name="l01974"></a><span class="lineno"> 1974</span>&#160;       <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">oasis_debug</a> &gt;= 20) <span class="keywordflow">then</span></div><div class="line"><a name="l01975"></a><span class="lineno"> 1975</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">oasis_timer_start</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avsumdiag&#39;</span>)</div><div class="line"><a name="l01976"></a><span class="lineno"> 1976</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">oasis_advance_avsum</a>(av1,av_sums,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom, &amp;</div><div class="line"><a name="l01977"></a><span class="lineno"> 1977</span>&#160;                                   mask=imasks,wts=areas,consopt=lconsopt)</div><div class="line"><a name="l01978"></a><span class="lineno"> 1978</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">oasis_advance_avsum</a>(avd,av_sumd,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%pgsmap,<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%mpicom, &amp;</div><div class="line"><a name="l01979"></a><span class="lineno"> 1979</span>&#160;                                   mask=imaskd,wts=aread,consopt=lconsopt)</div><div class="line"><a name="l01980"></a><span class="lineno"> 1980</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%spart)%mpicom /= mpi_comm_null) <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG src sum af conserve &#39;</span>,av_sums </div><div class="line"><a name="l01981"></a><span class="lineno"> 1981</span>&#160;          <span class="keywordflow">if</span> (<a class="code" href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">prism_part</a>(mapper%dpart)%mpicom /= mpi_comm_null) <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<span class="stringliteral">&#39; DEBUG dst sum af conserve &#39;</span>,av_sumd</div><div class="line"><a name="l01982"></a><span class="lineno"> 1982</span>&#160;          <span class="keyword">CALL </span><a class="code" href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">oasis_flush</a>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>)</div><div class="line"><a name="l01983"></a><span class="lineno"> 1983</span>&#160;          <span class="keywordflow">if</span> (<span class="keyword">present</span>(tstrinp)) <span class="keyword">call </span><a class="code" href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">oasis_timer_stop</a>(trim(tstrinp)//<span class="stringliteral">&#39;_avsumdiag&#39;</span>)</div><div class="line"><a name="l01984"></a><span class="lineno"> 1984</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l01985"></a><span class="lineno"> 1985</span>&#160;</div><div class="line"><a name="l01986"></a><span class="lineno"> 1986</span>&#160;       <span class="keyword">deallocate</span>(imasks,imaskd,areas,aread)</div><div class="line"><a name="l01987"></a><span class="lineno"> 1987</span>&#160;       <span class="keyword">deallocate</span>(av_sums,av_sumd)</div><div class="line"><a name="l01988"></a><span class="lineno"> 1988</span>&#160;</div><div class="line"><a name="l01989"></a><span class="lineno"> 1989</span>&#160;<span class="keywordflow">   ENDIF</span>  <span class="comment">! part%mpicom /= MPI_COMM_NULL</span></div><div class="line"><a name="l01990"></a><span class="lineno"> 1990</span>&#160;<span class="keywordflow">   ENDIF</span>  <span class="comment">! .not. ip_cnone</span></div><div class="line"><a name="l01991"></a><span class="lineno"> 1991</span>&#160;<span class="keywordflow">   ENDIF</span>  <span class="comment">! present conserve</span></div><div class="line"><a name="l01992"></a><span class="lineno"> 1992</span>&#160;</div><div class="line"><a name="l01993"></a><span class="lineno"> 1993</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a349f71cba2df935179d78f3858992c83">oasis_debug_exit</a>(subname)</div><div class="line"><a name="l01994"></a><span class="lineno"> 1994</span>&#160;</div><div class="line"><a name="l01995"></a><span class="lineno"> 1995</span>&#160;<span class="keyword">  END SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#a0514c843d051b8ee16adfb349eaee6a7">oasis_advance_map</a></div><div class="line"><a name="l01996"></a><span class="lineno"> 1996</span>&#160;</div><div class="line"><a name="l01997"></a><span class="lineno"> 1997</span>&#160;<span class="comment">!-------------------------------------------------------------------</span></div><div class="line"><a name="l01998"></a><span class="lineno"> 1998</span>&#160;<span class="comment"></span></div><div class="line"><a name="l01999"></a><span class="lineno"> 1999</span>&#160;<span class="comment">!&gt; A generic method for summing fields in an attribute vector</span></div><div class="line"><a name="l02000"></a><span class="lineno"> 2000</span>&#160;</div><div class="line"><a name="l02001"></a><span class="lineno"> 2001</span>&#160;<span class="keyword">  SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">oasis_advance_avsum</a>(av,sum,gsmap,mpicom,mask,wts,consopt)</div><div class="line"><a name="l02002"></a><span class="lineno"><a class="line" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d"> 2002</a></span>&#160;</div><div class="line"><a name="l02003"></a><span class="lineno"> 2003</span>&#160;    <span class="keywordtype">implicit none</span></div><div class="line"><a name="l02004"></a><span class="lineno"> 2004</span>&#160;    <span class="keywordtype">type</span>(mct_avect)      ,<span class="keywordtype">intent(in)</span>    :: av      <span class="comment">! input av</span></div><div class="line"><a name="l02005"></a><span class="lineno"> 2005</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>   ,<span class="keywordtype">intent(inout)</span> :: sum(:)  <span class="comment">! sum of av fields</span></div><div class="line"><a name="l02006"></a><span class="lineno"> 2006</span>&#160;    <span class="keywordtype">type</span>(mct_gsmap)      ,<span class="keywordtype">intent(in)</span>    :: gsmap   <span class="comment">! gsmap associate with av</span></div><div class="line"><a name="l02007"></a><span class="lineno"> 2007</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>,<span class="keywordtype">intent(in)</span>    :: mpicom  <span class="comment">! mpicom</span></div><div class="line"><a name="l02008"></a><span class="lineno"> 2008</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: mask(:) <span class="comment">! mask to apply to av</span></div><div class="line"><a name="l02009"></a><span class="lineno"> 2009</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>   ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: wts(:)  <span class="comment">! wts to apply to av</span></div><div class="line"><a name="l02010"></a><span class="lineno"> 2010</span>&#160;    <span class="keywordtype">character(len=ic_med)</span>,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: consopt <span class="comment">! conserve algorithm option</span></div><div class="line"><a name="l02011"></a><span class="lineno"> 2011</span>&#160;</div><div class="line"><a name="l02012"></a><span class="lineno"> 2012</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: n,m,ierr,mytask</div><div class="line"><a name="l02013"></a><span class="lineno"> 2013</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: lsize,fsize        <span class="comment">! local size of av, number of flds in av</span></div><div class="line"><a name="l02014"></a><span class="lineno"> 2014</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: lsum(:)  <span class="comment">! local sums</span></div><div class="line"><a name="l02015"></a><span class="lineno"> 2015</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: lwts(:)  <span class="comment">! local wts taking into account mask and wts</span></div><div class="line"><a name="l02016"></a><span class="lineno"> 2016</span>&#160;    <span class="keywordtype">real(kind=ip_r16_p)</span>,<span class="keywordtype">allocatable</span> :: lsum16(:)<span class="comment">! local sums</span></div><div class="line"><a name="l02017"></a><span class="lineno"> 2017</span>&#160;    <span class="keywordtype">real(kind=ip_r16_p)</span>,<span class="keywordtype">allocatable</span> :: sum16(:) <span class="comment">! global sums</span></div><div class="line"><a name="l02018"></a><span class="lineno"> 2018</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: reproarr(:,:) <span class="comment">! array of data and flds for reprosum</span></div><div class="line"><a name="l02019"></a><span class="lineno"> 2019</span>&#160;    <span class="keywordtype">type</span>(mct_avect)       :: av1, av1g    <span class="comment">! use av1,av1g for gather and bfb sum</span></div><div class="line"><a name="l02020"></a><span class="lineno"> 2020</span>&#160;    <span class="keywordtype">character(len=ic_med)</span> :: lconsopt     <span class="comment">! local conserve algorithm option</span></div><div class="line"><a name="l02021"></a><span class="lineno"> 2021</span>&#160;    <span class="keywordtype">character(len=*)</span>,<span class="keywordtype">parameter</span> :: subname = <span class="stringliteral">&#39;(oasis_advance_avsum)&#39;</span></div><div class="line"><a name="l02022"></a><span class="lineno"> 2022</span>&#160;</div><div class="line"><a name="l02023"></a><span class="lineno"> 2023</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ab963e928a34a1521ec2c1921cc956cc5">oasis_debug_enter</a>(subname)</div><div class="line"><a name="l02024"></a><span class="lineno"> 2024</span>&#160;</div><div class="line"><a name="l02025"></a><span class="lineno"> 2025</span>&#160;    <span class="keywordflow">if</span> (mpicom == mpi_comm_null) <span class="keywordflow">then</span></div><div class="line"><a name="l02026"></a><span class="lineno"> 2026</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a349f71cba2df935179d78f3858992c83">oasis_debug_exit</a>(subname)</div><div class="line"><a name="l02027"></a><span class="lineno"> 2027</span>&#160;       <span class="keywordflow">return</span></div><div class="line"><a name="l02028"></a><span class="lineno"> 2028</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02029"></a><span class="lineno"> 2029</span>&#160;</div><div class="line"><a name="l02030"></a><span class="lineno"> 2030</span>&#160;    lconsopt = <span class="stringliteral">&#39;bfb&#39;</span></div><div class="line"><a name="l02031"></a><span class="lineno"> 2031</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(consopt)) <span class="keywordflow">then</span></div><div class="line"><a name="l02032"></a><span class="lineno"> 2032</span>&#160;       lconsopt = consopt</div><div class="line"><a name="l02033"></a><span class="lineno"> 2033</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02034"></a><span class="lineno"> 2034</span>&#160;</div><div class="line"><a name="l02035"></a><span class="lineno"> 2035</span>&#160;    fsize = mct_avect_nrattr(av)</div><div class="line"><a name="l02036"></a><span class="lineno"> 2036</span>&#160;    lsize = mct_avect_lsize(av)</div><div class="line"><a name="l02037"></a><span class="lineno"> 2037</span>&#160;</div><div class="line"><a name="l02038"></a><span class="lineno"> 2038</span>&#160;    <span class="keyword">allocate</span>(lsum(fsize))</div><div class="line"><a name="l02039"></a><span class="lineno"> 2039</span>&#160;    lsum = 0.0_ip_r8_p</div><div class="line"><a name="l02040"></a><span class="lineno"> 2040</span>&#160;    <span class="keyword">allocate</span>(lwts(lsize))</div><div class="line"><a name="l02041"></a><span class="lineno"> 2041</span>&#160;    lwts = 1.0_ip_r8_p</div><div class="line"><a name="l02042"></a><span class="lineno"> 2042</span>&#160;</div><div class="line"><a name="l02043"></a><span class="lineno"> 2043</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">size</span>(sum) /= fsize) <span class="keywordflow">then</span></div><div class="line"><a name="l02044"></a><span class="lineno"> 2044</span>&#160;       <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;size sum ne size av&#39;</span></div><div class="line"><a name="l02045"></a><span class="lineno"> 2045</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l02046"></a><span class="lineno"> 2046</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02047"></a><span class="lineno"> 2047</span>&#160;</div><div class="line"><a name="l02048"></a><span class="lineno"> 2048</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(mask)) <span class="keywordflow">then</span></div><div class="line"><a name="l02049"></a><span class="lineno"> 2049</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">size</span>(mask) /= lsize) <span class="keywordflow">then</span></div><div class="line"><a name="l02050"></a><span class="lineno"> 2050</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;size mask ne size av&#39;</span></div><div class="line"><a name="l02051"></a><span class="lineno"> 2051</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l02052"></a><span class="lineno"> 2052</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l02053"></a><span class="lineno"> 2053</span>&#160;       <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02054"></a><span class="lineno"> 2054</span>&#160;          <span class="keywordflow">if</span> (mask(n) /= 0) lwts(n) = 0.0_ip_r8_p</div><div class="line"><a name="l02055"></a><span class="lineno"> 2055</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02056"></a><span class="lineno"> 2056</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02057"></a><span class="lineno"> 2057</span>&#160;</div><div class="line"><a name="l02058"></a><span class="lineno"> 2058</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(wts)) <span class="keywordflow">then</span></div><div class="line"><a name="l02059"></a><span class="lineno"> 2059</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">size</span>(wts) /= lsize) <span class="keywordflow">then</span></div><div class="line"><a name="l02060"></a><span class="lineno"> 2060</span>&#160;          <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;size wts ne size av&#39;</span></div><div class="line"><a name="l02061"></a><span class="lineno"> 2061</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l02062"></a><span class="lineno"> 2062</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l02063"></a><span class="lineno"> 2063</span>&#160;       <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02064"></a><span class="lineno"> 2064</span>&#160;          lwts(n) = lwts(n) * wts(n)</div><div class="line"><a name="l02065"></a><span class="lineno"> 2065</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02066"></a><span class="lineno"> 2066</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02067"></a><span class="lineno"> 2067</span>&#160;</div><div class="line"><a name="l02068"></a><span class="lineno"> 2068</span>&#160;    <span class="keywordflow">if</span> (lconsopt == <span class="stringliteral">&#39;gather&#39;</span>) <span class="keywordflow">then</span></div><div class="line"><a name="l02069"></a><span class="lineno"> 2069</span>&#160;       <span class="keyword">call </span>mct_avect_init(av1,av,lsize)</div><div class="line"><a name="l02070"></a><span class="lineno"> 2070</span>&#160;       <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02071"></a><span class="lineno"> 2071</span>&#160;       <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l02072"></a><span class="lineno"> 2072</span>&#160;          av1%rAttr(m,n) = av%rAttr(m,n)*lwts(n)</div><div class="line"><a name="l02073"></a><span class="lineno"> 2073</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02074"></a><span class="lineno"> 2074</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02075"></a><span class="lineno"> 2075</span>&#160;       <span class="keyword">call </span>mct_avect_gather(av1,av1g,gsmap,0,mpicom)</div><div class="line"><a name="l02076"></a><span class="lineno"> 2076</span>&#160;       <span class="keyword">call </span>mpi_comm_rank(mpicom,mytask,ierr)</div><div class="line"><a name="l02077"></a><span class="lineno"> 2077</span>&#160;       sum = 0.0_ip_r8_p</div><div class="line"><a name="l02078"></a><span class="lineno"> 2078</span>&#160;       <span class="keywordflow">if</span> (mytask == 0) <span class="keywordflow">then</span></div><div class="line"><a name="l02079"></a><span class="lineno"> 2079</span>&#160;          <span class="keywordflow">do</span> n = 1,mct_avect_lsize(av1g)</div><div class="line"><a name="l02080"></a><span class="lineno"> 2080</span>&#160;          <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l02081"></a><span class="lineno"> 2081</span>&#160;             sum(m) = sum(m) + av1g%rAttr(m,n)</div><div class="line"><a name="l02082"></a><span class="lineno"> 2082</span>&#160;<span class="keywordflow">          enddo</span></div><div class="line"><a name="l02083"></a><span class="lineno"> 2083</span>&#160;<span class="keywordflow">          enddo</span></div><div class="line"><a name="l02084"></a><span class="lineno"> 2084</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l02085"></a><span class="lineno"> 2085</span>&#160;       <span class="keyword">call </span><a class="code" href="interfacemod__oasis__mpi_1_1oasis__mpi__bcast.html">oasis_mpi_bcast</a>(sum,mpicom,subname//<span class="stringliteral">&quot; bcast sum&quot;</span>)</div><div class="line"><a name="l02086"></a><span class="lineno"> 2086</span>&#160;       <span class="keyword">call </span>mct_avect_clean(av1)</div><div class="line"><a name="l02087"></a><span class="lineno"> 2087</span>&#160;       <span class="keywordflow">if</span> (mytask == 0) <span class="keywordflow">then</span> </div><div class="line"><a name="l02088"></a><span class="lineno"> 2088</span>&#160;          <span class="keyword">call </span>mct_avect_clean(av1g)</div><div class="line"><a name="l02089"></a><span class="lineno"> 2089</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l02090"></a><span class="lineno"> 2090</span>&#160;</div><div class="line"><a name="l02091"></a><span class="lineno"> 2091</span>&#160;    <span class="keywordflow">elseif</span> (lconsopt == <span class="stringliteral">&#39;lsum8&#39;</span> .or. lconsopt == <span class="stringliteral">&#39;opt&#39;</span>) <span class="keywordflow">then</span></div><div class="line"><a name="l02092"></a><span class="lineno"> 2092</span>&#160;       lsum = 0.0_ip_r8_p</div><div class="line"><a name="l02093"></a><span class="lineno"> 2093</span>&#160;       <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02094"></a><span class="lineno"> 2094</span>&#160;       <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l02095"></a><span class="lineno"> 2095</span>&#160;          lsum(m) = lsum(m) + av%rAttr(m,n)*lwts(n)</div><div class="line"><a name="l02096"></a><span class="lineno"> 2096</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02097"></a><span class="lineno"> 2097</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02098"></a><span class="lineno"> 2098</span>&#160;       <span class="keyword">call </span><a class="code" href="interfacemod__oasis__mpi_1_1oasis__mpi__sum.html">oasis_mpi_sum</a>(lsum,sum,mpicom,string=trim(subname)//<span class="stringliteral">&#39;:sum&#39;</span>,all=.true.)</div><div class="line"><a name="l02099"></a><span class="lineno"> 2099</span>&#160;</div><div class="line"><a name="l02100"></a><span class="lineno"> 2100</span>&#160;    <span class="keywordflow">elseif</span> (lconsopt == <span class="stringliteral">&#39;lsum16&#39;</span>) <span class="keywordflow">then</span></div><div class="line"><a name="l02101"></a><span class="lineno"> 2101</span>&#160;<span class="preprocessor">#ifdef __NO_16BYTE_REALS</span></div><div class="line"><a name="l02102"></a><span class="lineno"> 2102</span>&#160;<span class="preprocessor"></span>       <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;consopt lsum16 not support with __NO_16BYTE_REALS cpp&#39;</span></div><div class="line"><a name="l02103"></a><span class="lineno"> 2103</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l02104"></a><span class="lineno"> 2104</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l02105"></a><span class="lineno"> 2105</span>&#160;<span class="preprocessor"></span>       <span class="keyword">allocate</span>(lsum16(fsize))</div><div class="line"><a name="l02106"></a><span class="lineno"> 2106</span>&#160;       <span class="keyword">allocate</span>(sum16(fsize))</div><div class="line"><a name="l02107"></a><span class="lineno"> 2107</span>&#160;       lsum16 = 0.0_ip_r16_p</div><div class="line"><a name="l02108"></a><span class="lineno"> 2108</span>&#160;       <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02109"></a><span class="lineno"> 2109</span>&#160;       <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l02110"></a><span class="lineno"> 2110</span>&#160;          lsum16(m) = lsum16(m) + <span class="keywordtype">real(av%rAttr(m,n)</span>,ip_r16_p)*<span class="keywordtype">real(lwts(n)</span>,ip_r16_p)</div><div class="line"><a name="l02111"></a><span class="lineno"> 2111</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02112"></a><span class="lineno"> 2112</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02113"></a><span class="lineno"> 2113</span>&#160;       <span class="keyword">call </span><a class="code" href="interfacemod__oasis__mpi_1_1oasis__mpi__sum.html">oasis_mpi_sum</a>(lsum16,sum16,mpicom,string=trim(subname)//<span class="stringliteral">&#39;:sum&#39;</span>,all=.true.)</div><div class="line"><a name="l02114"></a><span class="lineno"> 2114</span>&#160;       sum = <span class="keywordtype">real</span>(sum16,<a class="code" href="namespacemod__oasis__kinds.html#a6129e979d32b55cb020fb76068ce9808">ip_r8_p</a>)</div><div class="line"><a name="l02115"></a><span class="lineno"> 2115</span>&#160;       <span class="keyword">deallocate</span>(lsum16)</div><div class="line"><a name="l02116"></a><span class="lineno"> 2116</span>&#160;       <span class="keyword">deallocate</span>(sum16)</div><div class="line"><a name="l02117"></a><span class="lineno"> 2117</span>&#160;</div><div class="line"><a name="l02118"></a><span class="lineno"> 2118</span>&#160;    <span class="keywordflow">elseif</span> (lconsopt == <span class="stringliteral">&#39;reprosum&#39;</span> .or. lconsopt == <span class="stringliteral">&#39;ddpdd&#39;</span> .or. lconsopt == <span class="stringliteral">&#39;bfb&#39;</span>) <span class="keywordflow">then</span></div><div class="line"><a name="l02119"></a><span class="lineno"> 2119</span>&#160;       <span class="keyword">allocate</span>(reproarr(lsize,fsize))</div><div class="line"><a name="l02120"></a><span class="lineno"> 2120</span>&#160;       <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02121"></a><span class="lineno"> 2121</span>&#160;       <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l02122"></a><span class="lineno"> 2122</span>&#160;          reproarr(n,m) = av%rAttr(m,n)*lwts(n)</div><div class="line"><a name="l02123"></a><span class="lineno"> 2123</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02124"></a><span class="lineno"> 2124</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02125"></a><span class="lineno"> 2125</span>&#160;       <span class="keywordflow">if</span> (lconsopt == <span class="stringliteral">&#39;reprosum&#39;</span> .or. lconsopt == <span class="stringliteral">&#39;bfb&#39;</span>) <span class="keywordflow">then</span></div><div class="line"><a name="l02126"></a><span class="lineno"> 2126</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__reprosum.html#a398280c78cff126b7622dbd96af675e4">oasis_reprosum_calc</a>(reproarr,sum,lsize,lsize,fsize,ddpdd_sum=.false.,commid=mpicom)</div><div class="line"><a name="l02127"></a><span class="lineno"> 2127</span>&#160;       <span class="keywordflow">else</span></div><div class="line"><a name="l02128"></a><span class="lineno"> 2128</span>&#160;          <span class="keyword">call </span><a class="code" href="namespacemod__oasis__reprosum.html#a398280c78cff126b7622dbd96af675e4">oasis_reprosum_calc</a>(reproarr,sum,lsize,lsize,fsize,ddpdd_sum=.true. ,commid=mpicom)</div><div class="line"><a name="l02129"></a><span class="lineno"> 2129</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l02130"></a><span class="lineno"> 2130</span>&#160;       <span class="keyword">deallocate</span>(reproarr)</div><div class="line"><a name="l02131"></a><span class="lineno"> 2131</span>&#160;</div><div class="line"><a name="l02132"></a><span class="lineno"> 2132</span>&#160;    <span class="keywordflow">else</span></div><div class="line"><a name="l02133"></a><span class="lineno"> 2133</span>&#160;       <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;consopt unknown: &#39;</span>//trim(lconsopt)</div><div class="line"><a name="l02134"></a><span class="lineno"> 2134</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l02135"></a><span class="lineno"> 2135</span>&#160;</div><div class="line"><a name="l02136"></a><span class="lineno"> 2136</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02137"></a><span class="lineno"> 2137</span>&#160;</div><div class="line"><a name="l02138"></a><span class="lineno"> 2138</span>&#160;    <span class="keyword">deallocate</span>(lsum)</div><div class="line"><a name="l02139"></a><span class="lineno"> 2139</span>&#160;    <span class="keyword">deallocate</span>(lwts)</div><div class="line"><a name="l02140"></a><span class="lineno"> 2140</span>&#160;</div><div class="line"><a name="l02141"></a><span class="lineno"> 2141</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a349f71cba2df935179d78f3858992c83">oasis_debug_exit</a>(subname)</div><div class="line"><a name="l02142"></a><span class="lineno"> 2142</span>&#160;</div><div class="line"><a name="l02143"></a><span class="lineno"> 2143</span>&#160;<span class="keyword">  END SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">oasis_advance_avsum</a></div><div class="line"><a name="l02144"></a><span class="lineno"> 2144</span>&#160;</div><div class="line"><a name="l02145"></a><span class="lineno"> 2145</span>&#160;<span class="comment">!-------------------------------------------------------------------</span></div><div class="line"><a name="l02146"></a><span class="lineno"> 2146</span>&#160;<span class="comment"></span></div><div class="line"><a name="l02147"></a><span class="lineno"> 2147</span>&#160;<span class="comment">!&gt; A generic method for writing the global sums of fields in an attribute vector</span></div><div class="line"><a name="l02148"></a><span class="lineno"> 2148</span>&#160;</div><div class="line"><a name="l02149"></a><span class="lineno"> 2149</span>&#160;<span class="keyword">  SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#af611b26fe4601ded488fd5d3c03b12a2">oasis_advance_avdiag</a>(av,mpicom,mask,wts)</div><div class="line"><a name="l02150"></a><span class="lineno"><a class="line" href="namespacemod__oasis__advance.html#af611b26fe4601ded488fd5d3c03b12a2"> 2150</a></span>&#160;</div><div class="line"><a name="l02151"></a><span class="lineno"> 2151</span>&#160;    <span class="keywordtype">implicit none</span></div><div class="line"><a name="l02152"></a><span class="lineno"> 2152</span>&#160;    <span class="keywordtype">type</span>(mct_avect)      ,<span class="keywordtype">intent(in)</span>    :: av    <span class="comment">! input av</span></div><div class="line"><a name="l02153"></a><span class="lineno"> 2153</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>,<span class="keywordtype">intent(in)</span>    :: mpicom  <span class="comment">! mpi communicator</span></div><div class="line"><a name="l02154"></a><span class="lineno"> 2154</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span>,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: mask(:) <span class="comment">! mask to apply to av</span></div><div class="line"><a name="l02155"></a><span class="lineno"> 2155</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>   ,<span class="keywordtype">intent(in)</span>,<span class="keywordtype">optional</span> :: wts(:)  <span class="comment">! wts to apply to av</span></div><div class="line"><a name="l02156"></a><span class="lineno"> 2156</span>&#160;</div><div class="line"><a name="l02157"></a><span class="lineno"> 2157</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: n,m,ierr,mype</div><div class="line"><a name="l02158"></a><span class="lineno"> 2158</span>&#160;    <span class="keywordtype">integer(kind=ip_i4_p)</span> :: lsize,fsize        <span class="comment">! local size of av, number of flds in av</span></div><div class="line"><a name="l02159"></a><span class="lineno"> 2159</span>&#160;    <span class="keywordtype">logical</span>               :: first_call  </div><div class="line"><a name="l02160"></a><span class="lineno"> 2160</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>    :: lval               <span class="comment">! local temporary</span></div><div class="line"><a name="l02161"></a><span class="lineno"> 2161</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: lsum(:)  <span class="comment">! local sum</span></div><div class="line"><a name="l02162"></a><span class="lineno"> 2162</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: lmin(:)  <span class="comment">! local min</span></div><div class="line"><a name="l02163"></a><span class="lineno"> 2163</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: lmax(:)  <span class="comment">! local max</span></div><div class="line"><a name="l02164"></a><span class="lineno"> 2164</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: gsum(:)  <span class="comment">! global sum</span></div><div class="line"><a name="l02165"></a><span class="lineno"> 2165</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: gmin(:)  <span class="comment">! global min</span></div><div class="line"><a name="l02166"></a><span class="lineno"> 2166</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: gmax(:)  <span class="comment">! global max</span></div><div class="line"><a name="l02167"></a><span class="lineno"> 2167</span>&#160;    <span class="keywordtype">real(kind=ip_r8_p)</span>,<span class="keywordtype">allocatable</span>  :: lwts(:)  <span class="comment">! local wts taking into account mask and wts</span></div><div class="line"><a name="l02168"></a><span class="lineno"> 2168</span>&#160;    <span class="keywordtype">type</span>(mct_string) :: mstring     <span class="comment">! mct char type</span></div><div class="line"><a name="l02169"></a><span class="lineno"> 2169</span>&#160;    <span class="keywordtype">character(len=64)</span>:: itemc       <span class="comment">! string converted to char</span></div><div class="line"><a name="l02170"></a><span class="lineno"> 2170</span>&#160;    <span class="keywordtype">character(len=*)</span>,<span class="keywordtype">parameter</span> :: subname = <span class="stringliteral">&#39;(oasis_advance_avdiag)&#39;</span></div><div class="line"><a name="l02171"></a><span class="lineno"> 2171</span>&#160;</div><div class="line"><a name="l02172"></a><span class="lineno"> 2172</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#ab963e928a34a1521ec2c1921cc956cc5">oasis_debug_enter</a>(subname)</div><div class="line"><a name="l02173"></a><span class="lineno"> 2173</span>&#160;</div><div class="line"><a name="l02174"></a><span class="lineno"> 2174</span>&#160;    <span class="keywordflow">if</span> (mpicom == mpi_comm_null) <span class="keywordflow">then</span></div><div class="line"><a name="l02175"></a><span class="lineno"> 2175</span>&#160;       <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a349f71cba2df935179d78f3858992c83">oasis_debug_exit</a>(subname)</div><div class="line"><a name="l02176"></a><span class="lineno"> 2176</span>&#160;       <span class="keywordflow">return</span></div><div class="line"><a name="l02177"></a><span class="lineno"> 2177</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02178"></a><span class="lineno"> 2178</span>&#160;</div><div class="line"><a name="l02179"></a><span class="lineno"> 2179</span>&#160;    fsize = mct_avect_nrattr(av)</div><div class="line"><a name="l02180"></a><span class="lineno"> 2180</span>&#160;    lsize = mct_avect_lsize(av)</div><div class="line"><a name="l02181"></a><span class="lineno"> 2181</span>&#160;</div><div class="line"><a name="l02182"></a><span class="lineno"> 2182</span>&#160;    <span class="keyword">allocate</span>(lsum(fsize))</div><div class="line"><a name="l02183"></a><span class="lineno"> 2183</span>&#160;    <span class="keyword">allocate</span>(lmin(fsize))</div><div class="line"><a name="l02184"></a><span class="lineno"> 2184</span>&#160;    <span class="keyword">allocate</span>(lmax(fsize))</div><div class="line"><a name="l02185"></a><span class="lineno"> 2185</span>&#160;    <span class="keyword">allocate</span>(gsum(fsize))</div><div class="line"><a name="l02186"></a><span class="lineno"> 2186</span>&#160;    <span class="keyword">allocate</span>(gmin(fsize))</div><div class="line"><a name="l02187"></a><span class="lineno"> 2187</span>&#160;    <span class="keyword">allocate</span>(gmax(fsize))</div><div class="line"><a name="l02188"></a><span class="lineno"> 2188</span>&#160;</div><div class="line"><a name="l02189"></a><span class="lineno"> 2189</span>&#160;    <span class="keyword">allocate</span>(lwts(lsize))</div><div class="line"><a name="l02190"></a><span class="lineno"> 2190</span>&#160;    lwts = 1.0_ip_r8_p</div><div class="line"><a name="l02191"></a><span class="lineno"> 2191</span>&#160;<span class="comment">!!$    lmin=HUGE(lwts)</span></div><div class="line"><a name="l02192"></a><span class="lineno"> 2192</span>&#160;<span class="comment">!!$    lmax=-lmin</span></div><div class="line"><a name="l02193"></a><span class="lineno"> 2193</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(mask)) <span class="keywordflow">then</span></div><div class="line"><a name="l02194"></a><span class="lineno"> 2194</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">size</span>(mask) /= lsize) <span class="keywordflow">then</span></div><div class="line"><a name="l02195"></a><span class="lineno"> 2195</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;size mask ne size av&#39;</span></div><div class="line"><a name="l02196"></a><span class="lineno"> 2196</span>&#160;           <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l02197"></a><span class="lineno"> 2197</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l02198"></a><span class="lineno"> 2198</span>&#160;       <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02199"></a><span class="lineno"> 2199</span>&#160;          <span class="keywordflow">if</span> (mask(n) /= 0) lwts(n) = 0.0_ip_r8_p</div><div class="line"><a name="l02200"></a><span class="lineno"> 2200</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02201"></a><span class="lineno"> 2201</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02202"></a><span class="lineno"> 2202</span>&#160;</div><div class="line"><a name="l02203"></a><span class="lineno"> 2203</span>&#160;    <span class="keywordflow">if</span> (<span class="keyword">present</span>(wts)) <span class="keywordflow">then</span></div><div class="line"><a name="l02204"></a><span class="lineno"> 2204</span>&#160;       <span class="keywordflow">if</span> (<span class="keyword">size</span>(wts) /= lsize) <span class="keywordflow">then</span></div><div class="line"><a name="l02205"></a><span class="lineno"> 2205</span>&#160;           <span class="keyword">WRITE</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,*) subname,<a class="code" href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">estr</a>,<span class="stringliteral">&#39;size wts ne size av&#39;</span></div><div class="line"><a name="l02206"></a><span class="lineno"> 2206</span>&#160;           <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">oasis_abort</a>(file=__file__,line=__line__)</div><div class="line"><a name="l02207"></a><span class="lineno"> 2207</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l02208"></a><span class="lineno"> 2208</span>&#160;       <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02209"></a><span class="lineno"> 2209</span>&#160;          lwts(n) = lwts(n) * wts(n)</div><div class="line"><a name="l02210"></a><span class="lineno"> 2210</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02211"></a><span class="lineno"> 2211</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02212"></a><span class="lineno"> 2212</span>&#160;</div><div class="line"><a name="l02213"></a><span class="lineno"> 2213</span>&#160;    lsum = 0.0_ip_r8_p</div><div class="line"><a name="l02214"></a><span class="lineno"> 2214</span>&#160;    lmin =  9.99e36    <span class="comment">! in case lsize is zero</span></div><div class="line"><a name="l02215"></a><span class="lineno"> 2215</span>&#160;    lmax = -9.99e36    <span class="comment">! in case lsize is zero</span></div><div class="line"><a name="l02216"></a><span class="lineno"> 2216</span>&#160;    <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l02217"></a><span class="lineno"> 2217</span>&#160;    first_call = .true.</div><div class="line"><a name="l02218"></a><span class="lineno"> 2218</span>&#160;    <span class="keywordflow">do</span> n = 1,lsize</div><div class="line"><a name="l02219"></a><span class="lineno"> 2219</span>&#160;       lval = av%rAttr(m,n)*lwts(n)</div><div class="line"><a name="l02220"></a><span class="lineno"> 2220</span>&#160;       lsum(m) = lsum(m) + lval</div><div class="line"><a name="l02221"></a><span class="lineno"> 2221</span>&#160;       <span class="keywordflow">if</span> (lwts(n) /= 0.0_ip_r8_p) <span class="keywordflow">then</span></div><div class="line"><a name="l02222"></a><span class="lineno"> 2222</span>&#160;          <span class="keywordflow">if</span> (first_call) <span class="keywordflow">then</span></div><div class="line"><a name="l02223"></a><span class="lineno"> 2223</span>&#160;             lmin(m) = lval</div><div class="line"><a name="l02224"></a><span class="lineno"> 2224</span>&#160;             lmax(m) = lval</div><div class="line"><a name="l02225"></a><span class="lineno"> 2225</span>&#160;             first_call = .false.</div><div class="line"><a name="l02226"></a><span class="lineno"> 2226</span>&#160;          <span class="keywordflow">else</span></div><div class="line"><a name="l02227"></a><span class="lineno"> 2227</span>&#160;             lmin(m) = min(lmin(m),lval)</div><div class="line"><a name="l02228"></a><span class="lineno"> 2228</span>&#160;             lmax(m) = max(lmax(m),lval)</div><div class="line"><a name="l02229"></a><span class="lineno"> 2229</span>&#160;<span class="keywordflow">          endif</span></div><div class="line"><a name="l02230"></a><span class="lineno"> 2230</span>&#160;<span class="keywordflow">       endif</span></div><div class="line"><a name="l02231"></a><span class="lineno"> 2231</span>&#160;<span class="keywordflow">    enddo</span></div><div class="line"><a name="l02232"></a><span class="lineno"> 2232</span>&#160;<span class="keywordflow">    enddo</span></div><div class="line"><a name="l02233"></a><span class="lineno"> 2233</span>&#160;</div><div class="line"><a name="l02234"></a><span class="lineno"> 2234</span>&#160;    mype = -1</div><div class="line"><a name="l02235"></a><span class="lineno"> 2235</span>&#160;    <span class="keyword">call </span>mpi_comm_rank(mpicom,mype,ierr)</div><div class="line"><a name="l02236"></a><span class="lineno"> 2236</span>&#160;    <span class="keyword">call </span><a class="code" href="interfacemod__oasis__mpi_1_1oasis__mpi__sum.html">oasis_mpi_sum</a>(lsum,gsum,mpicom,string=trim(subname)//<span class="stringliteral">&#39;:sum&#39;</span>,all=.false.)</div><div class="line"><a name="l02237"></a><span class="lineno"> 2237</span>&#160;    <span class="keyword">call </span><a class="code" href="interfacemod__oasis__mpi_1_1oasis__mpi__min.html">oasis_mpi_min</a>(lmin,gmin,mpicom,string=trim(subname)//<span class="stringliteral">&#39;:min&#39;</span>,all=.false.)</div><div class="line"><a name="l02238"></a><span class="lineno"> 2238</span>&#160;    <span class="keyword">call </span><a class="code" href="interfacemod__oasis__mpi_1_1oasis__mpi__max.html">oasis_mpi_max</a>(lmax,gmax,mpicom,string=trim(subname)//<span class="stringliteral">&#39;:max&#39;</span>,all=.false.)</div><div class="line"><a name="l02239"></a><span class="lineno"> 2239</span>&#160;</div><div class="line"><a name="l02240"></a><span class="lineno"> 2240</span>&#160;    <span class="keywordflow">if</span> (mype == 0) <span class="keywordflow">then</span></div><div class="line"><a name="l02241"></a><span class="lineno"> 2241</span>&#160;       <span class="keywordflow">do</span> m = 1,fsize</div><div class="line"><a name="l02242"></a><span class="lineno"> 2242</span>&#160;          <span class="keyword">call </span>mct_avect_getrlist(mstring,m,av)</div><div class="line"><a name="l02243"></a><span class="lineno"> 2243</span>&#160;          itemc = mct_string_tochar(mstring)</div><div class="line"><a name="l02244"></a><span class="lineno"> 2244</span>&#160;          <span class="keyword">call </span>mct_string_clean(mstring)</div><div class="line"><a name="l02245"></a><span class="lineno"> 2245</span>&#160;          <span class="keyword">write</span>(<a class="code" href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">nulprt</a>,<span class="stringliteral">&#39;(a,a16,3g21.12)&#39;</span>) <span class="stringliteral">&#39;   diags: &#39;</span>,trim(itemc),gmin(m),gmax(m),gsum(m)</div><div class="line"><a name="l02246"></a><span class="lineno"> 2246</span>&#160;<span class="keywordflow">       enddo</span></div><div class="line"><a name="l02247"></a><span class="lineno"> 2247</span>&#160;<span class="keywordflow">    endif</span></div><div class="line"><a name="l02248"></a><span class="lineno"> 2248</span>&#160;</div><div class="line"><a name="l02249"></a><span class="lineno"> 2249</span>&#160;    <span class="keyword">deallocate</span>(lsum,lmin,lmax)</div><div class="line"><a name="l02250"></a><span class="lineno"> 2250</span>&#160;    <span class="keyword">deallocate</span>(gsum,gmin,gmax)</div><div class="line"><a name="l02251"></a><span class="lineno"> 2251</span>&#160;    <span class="keyword">deallocate</span>(lwts)</div><div class="line"><a name="l02252"></a><span class="lineno"> 2252</span>&#160;</div><div class="line"><a name="l02253"></a><span class="lineno"> 2253</span>&#160;    <span class="keyword">call </span><a class="code" href="namespacemod__oasis__sys.html#a349f71cba2df935179d78f3858992c83">oasis_debug_exit</a>(subname)</div><div class="line"><a name="l02254"></a><span class="lineno"> 2254</span>&#160;</div><div class="line"><a name="l02255"></a><span class="lineno"> 2255</span>&#160;<span class="keyword">  END SUBROUTINE </span><a class="code" href="namespacemod__oasis__advance.html#af611b26fe4601ded488fd5d3c03b12a2">oasis_advance_avdiag</a></div><div class="line"><a name="l02256"></a><span class="lineno"> 2256</span>&#160;</div><div class="line"><a name="l02257"></a><span class="lineno"> 2257</span>&#160;<span class="comment">!-------------------------------------------------------------------</span></div><div class="line"><a name="l02258"></a><span class="lineno"> 2258</span>&#160;<span class="keyword">END MODULE </span><a class="code" href="namespacemod__oasis__advance.html">mod_oasis_advance</a></div><div class="line"><a name="l02259"></a><span class="lineno"> 2259</span>&#160;</div><div class="ttc" id="namespacemod__oasis__coupler_html_a47f4727f94719892d837f6a1545d3d08"><div class="ttname"><a href="namespacemod__oasis__coupler.html#a47f4727f94719892d837f6a1545d3d08">mod_oasis_coupler::lastseqtime</a></div><div class="ttdeci">integer(kind=ip_i4_p), public lastseqtime</div><div class="ttdoc">last coupler sequence time </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00105">mod_oasis_coupler.F90:105</a></div></div>
70<div class="ttc" id="namespacemod__oasis__parameters_html_ac7406e7f558491599acfbb6f4628f811"><div class="ttname"><a href="namespacemod__oasis__parameters.html#ac7406e7f558491599acfbb6f4628f811">mod_oasis_parameters::oasis_recvout</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_recvout</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00053">mod_oasis_parameters.F90:53</a></div></div>
71<div class="ttc" id="namespacemod__oasis__parameters_html_aec700ad0c6a11dd35e5d6c2afb745fd0"><div class="ttname"><a href="namespacemod__oasis__parameters.html#aec700ad0c6a11dd35e5d6c2afb745fd0">mod_oasis_parameters::ip_cglbpos</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_cglbpos</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00094">mod_oasis_parameters.F90:94</a></div></div>
72<div class="ttc" id="interfacemod__oasis__mpi_1_1oasis__mpi__sum_html"><div class="ttname"><a href="interfacemod__oasis__mpi_1_1oasis__mpi__sum.html">mod_oasis_mpi::oasis_mpi_sum</a></div><div class="ttdoc">Generic overloaded interface into MPI sum reduction. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__mpi_8_f90_source.html#l00088">mod_oasis_mpi.F90:88</a></div></div>
73<div class="ttc" id="namespacemod__oasis__sys_html"><div class="ttname"><a href="namespacemod__oasis__sys.html">mod_oasis_sys</a></div><div class="ttdoc">System type methods. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__sys_8_f90_source.html#l00004">mod_oasis_sys.F90:4</a></div></div>
74<div class="ttc" id="namespacemod__oasis__io_html_a8b604f89345d74c74c6bc3b4760b2e29"><div class="ttname"><a href="namespacemod__oasis__io.html#a8b604f89345d74c74c6bc3b4760b2e29">mod_oasis_io::oasis_io_read_array</a></div><div class="ttdeci">subroutine, public oasis_io_read_array(rstfile, mpicom, iarray, ivarname, rarray, rvarname, abort)</div><div class="ttdoc">Reads an integer or real field from a file into an array. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__io_8_f90_source.html#l00565">mod_oasis_io.F90:565</a></div></div>
75<div class="ttc" id="namespacemod__oasis__parameters_html_a1804e9b27d8d7ace38fd4c3f99ade6dd"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a1804e9b27d8d7ace38fd4c3f99ade6dd">mod_oasis_parameters::oasis_sentout</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_sentout</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00045">mod_oasis_parameters.F90:45</a></div></div>
76<div class="ttc" id="namespacemod__oasis__sys_html_a8e488f6a9a829762324519c6dd493912"><div class="ttname"><a href="namespacemod__oasis__sys.html#a8e488f6a9a829762324519c6dd493912">mod_oasis_sys::oasis_debug_note</a></div><div class="ttdeci">subroutine, public oasis_debug_note(string)</div><div class="ttdoc">Used to write information from a subroutine, write info to log file at some debug level...</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__sys_8_f90_source.html#l00263">mod_oasis_sys.F90:263</a></div></div>
77<div class="ttc" id="namespacemod__oasis__data_html"><div class="ttname"><a href="namespacemod__oasis__data.html">mod_oasis_data</a></div><div class="ttdoc">Provides a common location for several OASIS variables. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00004">mod_oasis_data.F90:4</a></div></div>
78<div class="ttc" id="namespacemod__oasis__reprosum_html_a398280c78cff126b7622dbd96af675e4"><div class="ttname"><a href="namespacemod__oasis__reprosum.html#a398280c78cff126b7622dbd96af675e4">mod_oasis_reprosum::oasis_reprosum_calc</a></div><div class="ttdeci">subroutine, public oasis_reprosum_calc(arr, arr_gsum, nsummands, dsummands, nflds, ddpdd_sum, arr_gbl_max, arr_gbl_max_out, arr_max_levels, arr_max_levels_out, gbl_max_nsummands, gbl_max_nsummands_out, gbl_count, repro_sum_validate, repro_sum_stats, rel_diff, commid)</div><div class="ttdoc">Compute the global sum of each field in &quot;arr&quot; using the indicated communicator with a reproducible ye...</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__reprosum_8_f90_source.html#l00267">mod_oasis_reprosum.F90:267</a></div></div>
79<div class="ttc" id="namespacemod__oasis__io_html"><div class="ttname"><a href="namespacemod__oasis__io.html">mod_oasis_io</a></div><div class="ttdoc">Provides reusable IO routines for OASIS. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__io_8_f90_source.html#l00004">mod_oasis_io.F90:4</a></div></div>
80<div class="ttc" id="namespacemod__oasis__parameters_html_a3ea125963822918ce37fd3cfd9658c9f"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a3ea125963822918ce37fd3cfd9658c9f">mod_oasis_parameters::oasis_ok</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_ok</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00021">mod_oasis_parameters.F90:21</a></div></div>
81<div class="ttc" id="namespacemod__oasis__io_html_ad8a48d6c36e3fac637a8191c20e514f2"><div class="ttname"><a href="namespacemod__oasis__io.html#ad8a48d6c36e3fac637a8191c20e514f2">mod_oasis_io::oasis_io_write_avfile</a></div><div class="ttdeci">subroutine, public oasis_io_write_avfile(rstfile, av, gsmap, mpicom, nx, ny, nampre)</div><div class="ttdoc">Writes all fields from an attribute vector to a file. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__io_8_f90_source.html#l00230">mod_oasis_io.F90:230</a></div></div>
82<div class="ttc" id="namespacemod__oasis__data_html_a7c427f27ff231565a1ecc0caeb30c67c"><div class="ttname"><a href="namespacemod__oasis__data.html#a7c427f27ff231565a1ecc0caeb30c67c">mod_oasis_data::lucia_debug</a></div><div class="ttdeci">integer(kind=ip_i4_p) lucia_debug</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00023">mod_oasis_data.F90:23</a></div></div>
83<div class="ttc" id="interfacemod__oasis__mpi_1_1oasis__mpi__max_html"><div class="ttname"><a href="interfacemod__oasis__mpi_1_1oasis__mpi__max.html">mod_oasis_mpi::oasis_mpi_max</a></div><div class="ttdoc">Generic overloaded interface into MPI max reduction. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__mpi_8_f90_source.html#l00114">mod_oasis_mpi.F90:114</a></div></div>
84<div class="ttc" id="namespacemod__oasis__parameters_html_a16809ad581bb609aa5b0661927478653"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a16809ad581bb609aa5b0661927478653">mod_oasis_parameters::oasis_in</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_in</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00031">mod_oasis_parameters.F90:31</a></div></div>
85<div class="ttc" id="namespacemod__oasis__part_html_a326ce52f630ba7e71905af864a6cb2dc"><div class="ttname"><a href="namespacemod__oasis__part.html#a326ce52f630ba7e71905af864a6cb2dc">mod_oasis_part::prism_part</a></div><div class="ttdeci">type(prism_part_type), dimension(mpart), public prism_part</div><div class="ttdoc">list of defined partitions </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__part_8_f90_source.html#l00047">mod_oasis_part.F90:47</a></div></div>
86<div class="ttc" id="namespacemod__oasis__data_html_af0f17b70f48598dac24f2e41ca0da4b2"><div class="ttname"><a href="namespacemod__oasis__data.html#af0f17b70f48598dac24f2e41ca0da4b2">mod_oasis_data::nulprt</a></div><div class="ttdeci">integer(kind=ip_intwp_p) nulprt</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00020">mod_oasis_data.F90:20</a></div></div>
87<div class="ttc" id="interfacemod__oasis__mpi_1_1oasis__mpi__bcast_html"><div class="ttname"><a href="interfacemod__oasis__mpi_1_1oasis__mpi__bcast.html">mod_oasis_mpi::oasis_mpi_bcast</a></div><div class="ttdoc">Generic overloaded interface into MPI broadcast. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__mpi_8_f90_source.html#l00058">mod_oasis_mpi.F90:58</a></div></div>
88<div class="ttc" id="namespacemod__oasis__parameters_html_a76a87a170e0c08863ae981693eb88fb8"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a76a87a170e0c08863ae981693eb88fb8">mod_oasis_parameters::oasis_fromrestout</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_fromrestout</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00055">mod_oasis_parameters.F90:55</a></div></div>
89<div class="ttc" id="namespacemod__oasis__data_html_a7f361db125e5554d0427e964b698f10c"><div class="ttname"><a href="namespacemod__oasis__data.html#a7f361db125e5554d0427e964b698f10c">mod_oasis_data::eradius</a></div><div class="ttdeci">real(ip_double_p), parameter eradius</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00071">mod_oasis_data.F90:71</a></div></div>
90<div class="ttc" id="namespacemod__oasis__coupler_html_a96df3ef2ec1b53597bb9beca43fe8349"><div class="ttname"><a href="namespacemod__oasis__coupler.html#a96df3ef2ec1b53597bb9beca43fe8349">mod_oasis_coupler::prism_coupler_get</a></div><div class="ttdeci">type(prism_coupler_type), dimension(:), pointer, public prism_coupler_get</div><div class="ttdoc">prism_coupler get array </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00102">mod_oasis_coupler.F90:102</a></div></div>
91<div class="ttc" id="namespacemod__oasis__parameters_html_a1028581caadcb9d7506b25c6cd3efd01"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a1028581caadcb9d7506b25c6cd3efd01">mod_oasis_parameters::ip_instant</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_instant</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00084">mod_oasis_parameters.F90:84</a></div></div>
92<div class="ttc" id="namespacemod__oasis__sys_html_af1943a0ce0c5765ba8a714379065464f"><div class="ttname"><a href="namespacemod__oasis__sys.html#af1943a0ce0c5765ba8a714379065464f">mod_oasis_sys::oasis_abort</a></div><div class="ttdeci">subroutine, public oasis_abort(id_compid, cd_routine, cd_message, file, line, rcode)</div><div class="ttdoc">OASIS abort method, publically available to users. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__sys_8_f90_source.html#l00044">mod_oasis_sys.F90:44</a></div></div>
93<div class="ttc" id="namespacemod__oasis__coupler_html_ae59d8823993d9ca8610efd9770393271"><div class="ttname"><a href="namespacemod__oasis__coupler.html#ae59d8823993d9ca8610efd9770393271">mod_oasis_coupler::prism_coupler_put</a></div><div class="ttdeci">type(prism_coupler_type), dimension(:), pointer, public prism_coupler_put</div><div class="ttdoc">prism_coupler put array </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00101">mod_oasis_coupler.F90:101</a></div></div>
94<div class="ttc" id="namespacemod__oasis__parameters_html_aa0584909970d34364b7ec319292b1682"><div class="ttname"><a href="namespacemod__oasis__parameters.html#aa0584909970d34364b7ec319292b1682">mod_oasis_parameters::oasis_fromrest</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_fromrest</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00049">mod_oasis_parameters.F90:49</a></div></div>
95<div class="ttc" id="namespacemod__oasis__parameters_html_af739945ec2da833423cdc6e220e1c847"><div class="ttname"><a href="namespacemod__oasis__parameters.html#af739945ec2da833423cdc6e220e1c847">mod_oasis_parameters::oasis_sent</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_sent</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00037">mod_oasis_parameters.F90:37</a></div></div>
96<div class="ttc" id="namespacemod__oasis__kinds_html_a6129e979d32b55cb020fb76068ce9808"><div class="ttname"><a href="namespacemod__oasis__kinds.html#a6129e979d32b55cb020fb76068ce9808">mod_oasis_kinds::ip_r8_p</a></div><div class="ttdeci">integer, parameter ip_r8_p</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__kinds_8_f90_source.html#l00043">mod_oasis_kinds.F90:43</a></div></div>
97<div class="ttc" id="namespacemod__oasis__parameters_html_a390018877602efede436bd0721add299"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a390018877602efede436bd0721add299">mod_oasis_parameters::oasis_torestout</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_torestout</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00047">mod_oasis_parameters.F90:47</a></div></div>
98<div class="ttc" id="namespacemod__oasis__advance_html_a932b0cbe5d1f5fa27c283c6472be7baf"><div class="ttname"><a href="namespacemod__oasis__advance.html#a932b0cbe5d1f5fa27c283c6472be7baf">mod_oasis_advance::oasis_advance_run</a></div><div class="ttdeci">subroutine, public oasis_advance_run(mop, varid, msec, kinfo, nff, namid, array1din, array1dout, array2dout, readrest, a2on, array2, a3on, array3, a4on, array4, a5on, array5, writrest, varnum)</div><div class="ttdoc">Advances the OASIS coupling. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__advance_8_f90_source.html#l00324">mod_oasis_advance.F90:324</a></div></div>
99<div class="ttc" id="namespacemod__oasis__data_html_acfb160b3d147e7cb667b0dc0f5bb2960"><div class="ttname"><a href="namespacemod__oasis__data.html#acfb160b3d147e7cb667b0dc0f5bb2960">mod_oasis_data::cspval</a></div><div class="ttdeci">character(len= *), parameter cspval</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00066">mod_oasis_data.F90:66</a></div></div>
100<div class="ttc" id="namespacemod__oasis__parameters_html_a194cfc3b7f2d515492e04fd6e8931c60"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a194cfc3b7f2d515492e04fd6e8931c60">mod_oasis_parameters::ip_min</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_min</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00087">mod_oasis_parameters.F90:87</a></div></div>
101<div class="ttc" id="namespacemod__oasis__parameters_html_a875abcc1cc679cb72f20d42d3dbfac97"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a875abcc1cc679cb72f20d42d3dbfac97">mod_oasis_parameters::oasis_torest</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_torest</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00041">mod_oasis_parameters.F90:41</a></div></div>
102<div class="ttc" id="namespacemod__oasis__coupler_html"><div class="ttname"><a href="namespacemod__oasis__coupler.html">mod_oasis_coupler</a></div><div class="ttdoc">Initialize the OASIS coupler infrastructure. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00004">mod_oasis_coupler.F90:4</a></div></div>
103<div class="ttc" id="namespacemod__oasis__parameters_html_adfaf98517b8396e4ba667f2f8bcd0ed5"><div class="ttname"><a href="namespacemod__oasis__parameters.html#adfaf98517b8396e4ba667f2f8bcd0ed5">mod_oasis_parameters::ip_accumul</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_accumul</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00086">mod_oasis_parameters.F90:86</a></div></div>
104<div class="ttc" id="namespacemod__oasis__kinds_html"><div class="ttname"><a href="namespacemod__oasis__kinds.html">mod_oasis_kinds</a></div><div class="ttdoc">Defines kinds for OASIS. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__kinds_8_f90_source.html#l00007">mod_oasis_kinds.F90:7</a></div></div>
105<div class="ttc" id="namespacemod__oasis__data_html_a46d81d5ac9efa619628264c5e45bac41"><div class="ttname"><a href="namespacemod__oasis__data.html#a46d81d5ac9efa619628264c5e45bac41">mod_oasis_data::nullucia</a></div><div class="ttdeci">integer(kind=ip_intwp_p) nullucia</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00020">mod_oasis_data.F90:20</a></div></div>
106<div class="ttc" id="namespacemod__oasis__mpi_html"><div class="ttname"><a href="namespacemod__oasis__mpi.html">mod_oasis_mpi</a></div><div class="ttdoc">Provides a generic and simpler interface into MPI calls for OASIS. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__mpi_8_f90_source.html#l00003">mod_oasis_mpi.F90:3</a></div></div>
107<div class="ttc" id="namespacemod__oasis__parameters_html_aaa7ead98ff7d53acfd539a32fca9e2c7"><div class="ttname"><a href="namespacemod__oasis__parameters.html#aaa7ead98ff7d53acfd539a32fca9e2c7">mod_oasis_parameters::ip_cbasbal</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_cbasbal</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00095">mod_oasis_parameters.F90:95</a></div></div>
108<div class="ttc" id="namespacemod__oasis__parameters_html_aa2ac99363b8f1aa7ff950fda3e3f5fff"><div class="ttname"><a href="namespacemod__oasis__parameters.html#aa2ac99363b8f1aa7ff950fda3e3f5fff">mod_oasis_parameters::oasis3_get</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis3_get</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00070">mod_oasis_parameters.F90:70</a></div></div>
109<div class="ttc" id="structmod__oasis__coupler_1_1prism__coupler__type_html"><div class="ttname"><a href="structmod__oasis__coupler_1_1prism__coupler__type.html">mod_oasis_coupler::prism_coupler_type</a></div><div class="ttdoc">Coupler data for managing all aspects of coupling in OASIS. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00047">mod_oasis_coupler.F90:47</a></div></div>
110<div class="ttc" id="namespacemod__oasis__sys_html_ab963e928a34a1521ec2c1921cc956cc5"><div class="ttname"><a href="namespacemod__oasis__sys.html#ab963e928a34a1521ec2c1921cc956cc5">mod_oasis_sys::oasis_debug_enter</a></div><div class="ttdeci">subroutine, public oasis_debug_enter(string)</div><div class="ttdoc">Used when a subroutine is entered, write info to log file at some debug level. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__sys_8_f90_source.html#l00209">mod_oasis_sys.F90:209</a></div></div>
111<div class="ttc" id="interfacemod__oasis__mpi_1_1oasis__mpi__min_html"><div class="ttname"><a href="interfacemod__oasis__mpi_1_1oasis__mpi__min.html">mod_oasis_mpi::oasis_mpi_min</a></div><div class="ttdoc">Generic overloaded interface into MPI min reduction. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__mpi_8_f90_source.html#l00106">mod_oasis_mpi.F90:106</a></div></div>
112<div class="ttc" id="namespacemod__oasis__advance_html_af611b26fe4601ded488fd5d3c03b12a2"><div class="ttname"><a href="namespacemod__oasis__advance.html#af611b26fe4601ded488fd5d3c03b12a2">mod_oasis_advance::oasis_advance_avdiag</a></div><div class="ttdeci">subroutine oasis_advance_avdiag(av, mpicom, mask, wts)</div><div class="ttdoc">A generic method for writing the global sums of fields in an attribute vector. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__advance_8_f90_source.html#l02150">mod_oasis_advance.F90:2150</a></div></div>
113<div class="ttc" id="namespacemod__oasis__part_html"><div class="ttname"><a href="namespacemod__oasis__part.html">mod_oasis_part</a></div><div class="ttdoc">OASIS partition data and methods. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__part_8_f90_source.html#l00004">mod_oasis_part.F90:4</a></div></div>
114<div class="ttc" id="namespacemod__oasis__coupler_html_a6f166f099a134dffba97a168d28a3c01"><div class="ttname"><a href="namespacemod__oasis__coupler.html#a6f166f099a134dffba97a168d28a3c01">mod_oasis_coupler::prism_coupler_avsmax</a></div><div class="ttdeci">integer(kind=ip_i4_p), parameter, public prism_coupler_avsmax</div><div class="ttdoc">maximum number of higher order terms in mapping </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00044">mod_oasis_coupler.F90:44</a></div></div>
115<div class="ttc" id="namespacemod__oasis__parameters_html_a50fc92036d81ca0ea23918e1feddfe75"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a50fc92036d81ca0ea23918e1feddfe75">mod_oasis_parameters::oasis_recvd</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_recvd</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00035">mod_oasis_parameters.F90:35</a></div></div>
116<div class="ttc" id="namespacemod__oasis__parameters_html_a325334a5e2f9d0c7846c1ef964f9f7e3"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a325334a5e2f9d0c7846c1ef964f9f7e3">mod_oasis_parameters::oasis3_put</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis3_put</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00068">mod_oasis_parameters.F90:68</a></div></div>
117<div class="ttc" id="namespacemod__oasis__parameters_html_a7f9f81f3b1f2c8b09a460aeca27ea859"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a7f9f81f3b1f2c8b09a460aeca27ea859">mod_oasis_parameters::oasis_output</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_output</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00043">mod_oasis_parameters.F90:43</a></div></div>
118<div class="ttc" id="namespacemod__oasis__advance_html_a0514c843d051b8ee16adfb349eaee6a7"><div class="ttname"><a href="namespacemod__oasis__advance.html#a0514c843d051b8ee16adfb349eaee6a7">mod_oasis_advance::oasis_advance_map</a></div><div class="ttdeci">subroutine oasis_advance_map(av1, avd, mapper, conserv, consopt, avon, av2, av3, av4, av5, tstrinp)</div><div class="ttdoc">Provides interpolation functionality. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__advance_8_f90_source.html#l01651">mod_oasis_advance.F90:1651</a></div></div>
119<div class="ttc" id="namespacemod__oasis__advance_html_a480bfe5b333300c1084af8f9c239a81d"><div class="ttname"><a href="namespacemod__oasis__advance.html#a480bfe5b333300c1084af8f9c239a81d">mod_oasis_advance::oasis_advance_init</a></div><div class="ttdeci">subroutine, public oasis_advance_init(kinfo)</div><div class="ttdoc">Initializes the OASIS fields. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__advance_8_f90_source.html#l00039">mod_oasis_advance.F90:39</a></div></div>
120<div class="ttc" id="namespacemod__oasis__advance_html_ac617024af9299c27eaeb9156f647b028"><div class="ttname"><a href="namespacemod__oasis__advance.html#ac617024af9299c27eaeb9156f647b028">mod_oasis_advance::map_barrier</a></div><div class="ttdeci">logical, parameter map_barrier</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__advance_8_f90_source.html#l00029">mod_oasis_advance.F90:29</a></div></div>
121<div class="ttc" id="namespacemod__oasis__parameters_html_a2cc23572d33c536d49a53587359b68f0"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a2cc23572d33c536d49a53587359b68f0">mod_oasis_parameters::oasis_waitgroup</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_waitgroup</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00057">mod_oasis_parameters.F90:57</a></div></div>
122<div class="ttc" id="namespacemod__oasis__coupler_html_a65adf0558cfd9a9d316bd22ad1f9dc23"><div class="ttname"><a href="namespacemod__oasis__coupler.html#a65adf0558cfd9a9d316bd22ad1f9dc23">mod_oasis_coupler::oasis_coupler_bldvarname</a></div><div class="ttdeci">subroutine, public oasis_coupler_bldvarname(varid, varnum, vname)</div><div class="ttdoc">Build a consistent variable name based on bundles. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l02012">mod_oasis_coupler.F90:2012</a></div></div>
123<div class="ttc" id="namespacemod__oasis__parameters_html_abe7b7d586b50bd7c7d77c7834efa2801"><div class="ttname"><a href="namespacemod__oasis__parameters.html#abe7b7d586b50bd7c7d77c7834efa2801">mod_oasis_parameters::ip_max</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_max</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00088">mod_oasis_parameters.F90:88</a></div></div>
124<div class="ttc" id="namespacemod__oasis__parameters_html_a8484e196ef7469adbeaef850787d7502"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a8484e196ef7469adbeaef850787d7502">mod_oasis_parameters::oasis_comm_ready</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_comm_ready</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00064">mod_oasis_parameters.F90:64</a></div></div>
125<div class="ttc" id="namespacemod__oasis__parameters_html"><div class="ttname"><a href="namespacemod__oasis__parameters.html">mod_oasis_parameters</a></div><div class="ttdoc">Defines parameters for OASIS. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00004">mod_oasis_parameters.F90:4</a></div></div>
126<div class="ttc" id="namespacemod__oasis__parameters_html_a8b206cc178182e3526d400ea7a6587b5"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a8b206cc178182e3526d400ea7a6587b5">mod_oasis_parameters::oasis_loctrans</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_loctrans</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00039">mod_oasis_parameters.F90:39</a></div></div>
127<div class="ttc" id="namespacemod__oasis__var_html"><div class="ttname"><a href="namespacemod__oasis__var.html">mod_oasis_var</a></div><div class="ttdoc">OASIS variable data and methods. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__var_8_f90_source.html#l00004">mod_oasis_var.F90:4</a></div></div>
128<div class="ttc" id="namespacemod__oasis__data_html_a8379835615758ccf7a4287dde5785681"><div class="ttname"><a href="namespacemod__oasis__data.html#a8379835615758ccf7a4287dde5785681">mod_oasis_data::compnm</a></div><div class="ttdeci">character(len=ic_lvar) compnm</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00040">mod_oasis_data.F90:40</a></div></div>
129<div class="ttc" id="namespacemod__oasis__timer_html_a13a16c07778911b45f3f42a542348019"><div class="ttname"><a href="namespacemod__oasis__timer.html#a13a16c07778911b45f3f42a542348019">mod_oasis_timer::oasis_timer_start</a></div><div class="ttdeci">subroutine, public oasis_timer_start(timer_label, barrier)</div><div class="ttdoc">Start a timer. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__timer_8_f90_source.html#l00134">mod_oasis_timer.F90:134</a></div></div>
130<div class="ttc" id="namespacemod__oasis__io_html_a42b325557a774b08d4cba24f387f8b01"><div class="ttname"><a href="namespacemod__oasis__io.html#a42b325557a774b08d4cba24f387f8b01">mod_oasis_io::oasis_io_write_avfbf</a></div><div class="ttdeci">subroutine, public oasis_io_write_avfbf(av, gsmap, mpicom, nx, ny, msec, f_string, filename)</div><div class="ttdoc">Write each field in an attribute vector to an individual files. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__io_8_f90_source.html#l00877">mod_oasis_io.F90:877</a></div></div>
131<div class="ttc" id="namespacemod__oasis__data_html_a51f2f4f66476cf893f2507722cd65958"><div class="ttname"><a href="namespacemod__oasis__data.html#a51f2f4f66476cf893f2507722cd65958">mod_oasis_data::oasis_debug</a></div><div class="ttdeci">integer(kind=ip_i4_p) oasis_debug</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00021">mod_oasis_data.F90:21</a></div></div>
132<div class="ttc" id="namespacemod__oasis__parameters_html_a76a150fa8ef6ed0b35183e627d757439"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a76a150fa8ef6ed0b35183e627d757439">mod_oasis_parameters::oasis_out</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_out</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00029">mod_oasis_parameters.F90:29</a></div></div>
133<div class="ttc" id="namespacemod__oasis__coupler_html_a33dbf692ad73f83f73fe083e252badd8"><div class="ttname"><a href="namespacemod__oasis__coupler.html#a33dbf692ad73f83f73fe083e252badd8">mod_oasis_coupler::prism_router</a></div><div class="ttdeci">type(prism_router_type), dimension(:), pointer, public prism_router</div><div class="ttdoc">prism_router array </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00098">mod_oasis_coupler.F90:98</a></div></div>
134<div class="ttc" id="namespacemod__oasis__timer_html_a01a76142a72cc6bc845736e79ad99bd3"><div class="ttname"><a href="namespacemod__oasis__timer.html#a01a76142a72cc6bc845736e79ad99bd3">mod_oasis_timer::oasis_timer_stop</a></div><div class="ttdeci">subroutine, public oasis_timer_stop(timer_label)</div><div class="ttdoc">Stop a timer. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__timer_8_f90_source.html#l00178">mod_oasis_timer.F90:178</a></div></div>
135<div class="ttc" id="namespacemod__oasis__sys_html_a0f6e0376585c6f39d653f5ab05e80e8f"><div class="ttname"><a href="namespacemod__oasis__sys.html#a0f6e0376585c6f39d653f5ab05e80e8f">mod_oasis_sys::estr</a></div><div class="ttdeci">character(len= *), parameter, public estr</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__sys_8_f90_source.html#l00012">mod_oasis_sys.F90:12</a></div></div>
136<div class="ttc" id="namespacemod__oasis__data_html_acd8801d4fab87a19c6f4f69a661d56c5"><div class="ttname"><a href="namespacemod__oasis__data.html#acd8801d4fab87a19c6f4f69a661d56c5">mod_oasis_data::mpi_comm_local</a></div><div class="ttdeci">integer(kind=ip_i4_p) mpi_comm_local</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00050">mod_oasis_data.F90:50</a></div></div>
137<div class="ttc" id="namespacemod__oasis__mpi_html_aaf477847380fbbbc1341520b0b3e66da"><div class="ttname"><a href="namespacemod__oasis__mpi.html#aaf477847380fbbbc1341520b0b3e66da">mod_oasis_mpi::oasis_mpi_barrier</a></div><div class="ttdeci">subroutine, public oasis_mpi_barrier(comm, string)</div><div class="ttdoc">Call MPI_BARRIER for a particular communicator. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__mpi_8_f90_source.html#l02697">mod_oasis_mpi.F90:2697</a></div></div>
138<div class="ttc" id="namespacemod__oasis__parameters_html_ae251e3ac1c9c82ae5db2a768d2d59d5f"><div class="ttname"><a href="namespacemod__oasis__parameters.html#ae251e3ac1c9c82ae5db2a768d2d59d5f">mod_oasis_parameters::ip_cglobal</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_cglobal</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00093">mod_oasis_parameters.F90:93</a></div></div>
139<div class="ttc" id="namespacemod__oasis__parameters_html_a5e40e91da22fca8f2b6a9d4f1c1ace5d"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a5e40e91da22fca8f2b6a9d4f1c1ace5d">mod_oasis_parameters::ip_average</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_average</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00085">mod_oasis_parameters.F90:85</a></div></div>
140<div class="ttc" id="namespacemod__oasis__map_html_a00ad53f61b6998938fca792455487f7e"><div class="ttname"><a href="namespacemod__oasis__map.html#a00ad53f61b6998938fca792455487f7e">mod_oasis_map::prism_mapper</a></div><div class="ttdeci">type(prism_mapper_type), dimension(:), pointer, public prism_mapper</div><div class="ttdoc">list of defined mappers </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__map_8_f90_source.html#l00055">mod_oasis_map.F90:55</a></div></div>
141<div class="ttc" id="namespacemod__oasis__parameters_html_ae65ca856d776de249fc624b2d76bc4e8"><div class="ttname"><a href="namespacemod__oasis__parameters.html#ae65ca856d776de249fc624b2d76bc4e8">mod_oasis_parameters::oasis_input</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_input</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00051">mod_oasis_parameters.F90:51</a></div></div>
142<div class="ttc" id="namespacemod__oasis__io_html_ac4a465a698824fb473074bfbd3d92f79"><div class="ttname"><a href="namespacemod__oasis__io.html#ac4a465a698824fb473074bfbd3d92f79">mod_oasis_io::oasis_io_read_avfbf</a></div><div class="ttdeci">subroutine, public oasis_io_read_avfbf(av, gsmap, mpicom, msec, f_string, filename)</div><div class="ttdoc">Read each field in an attribute vector from individual files. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__io_8_f90_source.html#l01091">mod_oasis_io.F90:1091</a></div></div>
143<div class="ttc" id="namespacemod__oasis__coupler_html_ab494fbbb8065f3a006892828f288e44a"><div class="ttname"><a href="namespacemod__oasis__coupler.html#ab494fbbb8065f3a006892828f288e44a">mod_oasis_coupler::allow_no_restart</a></div><div class="ttdeci">logical, public allow_no_restart</div><div class="ttdoc">flag to allow no restart files at startup </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00106">mod_oasis_coupler.F90:106</a></div></div>
144<div class="ttc" id="namespacemod__oasis__advance_html"><div class="ttname"><a href="namespacemod__oasis__advance.html">mod_oasis_advance</a></div><div class="ttdoc">Advances the OASIS coupling. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__advance_8_f90_source.html#l00004">mod_oasis_advance.F90:4</a></div></div>
145<div class="ttc" id="namespacemod__oasis__sys_html_ad152b6f737a7e06f8f1226af23d66361"><div class="ttname"><a href="namespacemod__oasis__sys.html#ad152b6f737a7e06f8f1226af23d66361">mod_oasis_sys::oasis_flush</a></div><div class="ttdeci">subroutine, public oasis_flush(nu)</div><div class="ttdoc">Flushes output to file. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__sys_8_f90_source.html#l00094">mod_oasis_sys.F90:94</a></div></div>
146<div class="ttc" id="namespacemod__oasis__advance_html_acf8f4a02082ba2d9f32f0835ad14e11d"><div class="ttname"><a href="namespacemod__oasis__advance.html#acf8f4a02082ba2d9f32f0835ad14e11d">mod_oasis_advance::oasis_advance_avsum</a></div><div class="ttdeci">subroutine oasis_advance_avsum(av, sum, gsmap, mpicom, mask, wts, consopt)</div><div class="ttdoc">A generic method for summing fields in an attribute vector. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__advance_8_f90_source.html#l02002">mod_oasis_advance.F90:2002</a></div></div>
147<div class="ttc" id="namespacemod__oasis__coupler_html_ad8c9a74a349ea4420ac38e2da2dc3cd2"><div class="ttname"><a href="namespacemod__oasis__coupler.html#ad8c9a74a349ea4420ac38e2da2dc3cd2">mod_oasis_coupler::oasis_coupler_unbldvarname</a></div><div class="ttdeci">subroutine, public oasis_coupler_unbldvarname(varid, vname, varnum)</div><div class="ttdoc">Deconstruct the varname based on oasis_coupler_bldvarname. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l02055">mod_oasis_coupler.F90:2055</a></div></div>
148<div class="ttc" id="namespacemod__oasis__io_html_a9ac8ce0ba3223fb59f7f003b50b229cf"><div class="ttname"><a href="namespacemod__oasis__io.html#a9ac8ce0ba3223fb59f7f003b50b229cf">mod_oasis_io::oasis_io_write_array</a></div><div class="ttdeci">subroutine, public oasis_io_write_array(rstfile, mpicom, iarray, ivarname, rarray, rvarname)</div><div class="ttdoc">Writes a real or integer array to a file. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__io_8_f90_source.html#l00730">mod_oasis_io.F90:730</a></div></div>
149<div class="ttc" id="namespacemod__oasis__var_html_a095f8ad84e6afbcbe1744d4a9f924e08"><div class="ttname"><a href="namespacemod__oasis__var.html#a095f8ad84e6afbcbe1744d4a9f924e08">mod_oasis_var::prism_nvar</a></div><div class="ttdeci">integer(kind=ip_intwp_p), public prism_nvar</div><div class="ttdoc">number of variables defined </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__var_8_f90_source.html#l00040">mod_oasis_var.F90:40</a></div></div>
150<div class="ttc" id="namespacemod__oasis__timer_html"><div class="ttname"><a href="namespacemod__oasis__timer.html">mod_oasis_timer</a></div><div class="ttdoc">Performance timer methods. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__timer_8_f90_source.html#l00039">mod_oasis_timer.F90:39</a></div></div>
151<div class="ttc" id="namespacemod__oasis__coupler_html_aaa019c39b0f657e7c37820697ecf354a"><div class="ttname"><a href="namespacemod__oasis__coupler.html#aaa019c39b0f657e7c37820697ecf354a">mod_oasis_coupler::prism_mcoupler</a></div><div class="ttdeci">integer(kind=ip_i4_p), public prism_mcoupler</div><div class="ttdoc">max couplers </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00100">mod_oasis_coupler.F90:100</a></div></div>
152<div class="ttc" id="namespacemod__oasis__var_html_ae66c490437c2960d795fbd3d2c773a0a"><div class="ttname"><a href="namespacemod__oasis__var.html#ae66c490437c2960d795fbd3d2c773a0a">mod_oasis_var::prism_var</a></div><div class="ttdeci">type(prism_var_type), dimension(:), pointer, public prism_var</div><div class="ttdoc">list of defined variables </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__var_8_f90_source.html#l00041">mod_oasis_var.F90:41</a></div></div>
153<div class="ttc" id="namespacemod__oasis__reprosum_html"><div class="ttname"><a href="namespacemod__oasis__reprosum.html">mod_oasis_reprosum</a></div><div class="ttdoc">OASIS reproducible sum method from P. Worley. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__reprosum_8_f90_source.html#l00004">mod_oasis_reprosum.F90:4</a></div></div>
154<div class="ttc" id="namespacemod__oasis__data_html_a66bd35eca1454b6d8c8ac0449f2ca475"><div class="ttname"><a href="namespacemod__oasis__data.html#a66bd35eca1454b6d8c8ac0449f2ca475">mod_oasis_data::ispval</a></div><div class="ttdeci">integer(ip_i4_p), parameter ispval</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__data_8_f90_source.html#l00068">mod_oasis_data.F90:68</a></div></div>
155<div class="ttc" id="structmod__oasis__map_1_1prism__mapper__type_html"><div class="ttname"><a href="structmod__oasis__map_1_1prism__mapper__type.html">mod_oasis_map::prism_mapper_type</a></div><div class="ttdoc">Mapper data for interpolating data between grids. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__map_8_f90_source.html#l00035">mod_oasis_map.F90:35</a></div></div>
156<div class="ttc" id="namespacemod__oasis__parameters_html_a9df795bd9123857642aae31661b6c13a"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a9df795bd9123857642aae31661b6c13a">mod_oasis_parameters::oasis_comm_wait</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter oasis_comm_wait</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00066">mod_oasis_parameters.F90:66</a></div></div>
157<div class="ttc" id="namespacemod__oasis__advance_html_aad8e5c2e16b0270a7da0800a14ae1e07"><div class="ttname"><a href="namespacemod__oasis__advance.html#aad8e5c2e16b0270a7da0800a14ae1e07">mod_oasis_advance::detailed_map_timing</a></div><div class="ttdeci">logical, parameter detailed_map_timing</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__advance_8_f90_source.html#l00030">mod_oasis_advance.F90:30</a></div></div>
158<div class="ttc" id="namespacemod__oasis__parameters_html_a3b96d31bbe142d84df2b93880498936f"><div class="ttname"><a href="namespacemod__oasis__parameters.html#a3b96d31bbe142d84df2b93880498936f">mod_oasis_parameters::ip_cbaspos</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_cbaspos</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00096">mod_oasis_parameters.F90:96</a></div></div>
159<div class="ttc" id="namespacemod__oasis__parameters_html_ae043e4e2c2b7f04fec7d8c061ef52934"><div class="ttname"><a href="namespacemod__oasis__parameters.html#ae043e4e2c2b7f04fec7d8c061ef52934">mod_oasis_parameters::ip_cnone</a></div><div class="ttdeci">integer(kind=ip_intwp_p), parameter ip_cnone</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__parameters_8_f90_source.html#l00092">mod_oasis_parameters.F90:92</a></div></div>
160<div class="ttc" id="namespacemod__oasis__coupler_html_a0cb9b8a96c10385d38fa244d920c7eaf"><div class="ttname"><a href="namespacemod__oasis__coupler.html#a0cb9b8a96c10385d38fa244d920c7eaf">mod_oasis_coupler::lastseq</a></div><div class="ttdeci">integer(kind=ip_i4_p), public lastseq</div><div class="ttdoc">last coupler sequence </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__coupler_8_f90_source.html#l00104">mod_oasis_coupler.F90:104</a></div></div>
161<div class="ttc" id="namespacemod__oasis__sys_html_a349f71cba2df935179d78f3858992c83"><div class="ttname"><a href="namespacemod__oasis__sys.html#a349f71cba2df935179d78f3858992c83">mod_oasis_sys::oasis_debug_exit</a></div><div class="ttdeci">subroutine, public oasis_debug_exit(string)</div><div class="ttdoc">Used when a subroutine is exited, write info to log file at some debug level. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__sys_8_f90_source.html#l00236">mod_oasis_sys.F90:236</a></div></div>
162<div class="ttc" id="namespacemod__oasis__map_html"><div class="ttname"><a href="namespacemod__oasis__map.html">mod_oasis_map</a></div><div class="ttdoc">OASIS map (interpolation) data and methods. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__map_8_f90_source.html#l00005">mod_oasis_map.F90:5</a></div></div>
163<div class="ttc" id="namespacemod__oasis__sys_html_a4e16ba69c68a3a39c8b8aa3b92234ce1"><div class="ttname"><a href="namespacemod__oasis__sys.html#a4e16ba69c68a3a39c8b8aa3b92234ce1">mod_oasis_sys::wstr</a></div><div class="ttdeci">character(len= *), parameter, public wstr</div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__sys_8_f90_source.html#l00013">mod_oasis_sys.F90:13</a></div></div>
164<div class="ttc" id="namespacemod__oasis__io_html_a65e17e4a065e8e4dea33754fb9c1d32c"><div class="ttname"><a href="namespacemod__oasis__io.html#a65e17e4a065e8e4dea33754fb9c1d32c">mod_oasis_io::oasis_io_read_avfile</a></div><div class="ttdeci">subroutine, public oasis_io_read_avfile(rstfile, av, gsmap, mpicom, abort, nampre, didread)</div><div class="ttdoc">Reads all fields for an attribute vector from a file. </div><div class="ttdef"><b>Definition:</b> <a href="mod__oasis__io_8_f90_source.html#l00406">mod_oasis_io.F90:406</a></div></div>
165</div><!-- fragment --></div><!-- contents -->
166<!-- start footer part -->
167<hr class="footer"/><address class="footer"><small>
168Generated on Fri Jun 29 2018 20:52:28 for Oasis3-MCT by &#160;<a href="http://www.doxygen.org/index.html">
169<img class="footer" src="doxygen.png" alt="doxygen"/>
170</a> 1.8.13
171</small></address>
172</body>
173</html>
Note: See TracBrowser for help on using the repository browser.