1 |
adcroft |
1.1 |
<!doctype html public "-//w3c//dtd html 4.0 transitional//en"> |
2 |
|
|
<html> |
3 |
|
|
<head> |
4 |
|
|
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> |
5 |
|
|
<meta name="GENERATOR" content="Mozilla/4.5 [en] (X11; U; Linux 2.0.34 i586) [Netscape]"> |
6 |
|
|
</head> |
7 |
|
|
<body> |
8 |
|
|
|
9 |
|
|
<h1> |
10 |
|
|
Open Boundaries Implementation in MITgcmUV</h1> |
11 |
|
|
These are some quick explanatory notes regards implementation of open boundaries |
12 |
|
|
(OB) and the example configuration found in .../verification/exp4/ |
13 |
|
|
<br> |
14 |
|
|
<h2> |
15 |
|
|
Input and control of OBs</h2> |
16 |
|
|
|
17 |
|
|
<ul> |
18 |
|
|
<li> |
19 |
|
|
The open boundaries code is used only if the LOGICAL parameter openBondaries |
20 |
|
|
is .TRUE.</li> |
21 |
|
|
|
22 |
|
|
<li> |
23 |
|
|
Four 1-dimensional INTEGER arrays indicate the position of an OB: OB_Jnorth, |
24 |
|
|
OB_Jsouth, OB_Ieast and OB_Iwest.</li> |
25 |
|
|
</ul> |
26 |
|
|
The values of OB_* indicate the absolute computational coordinate of an |
27 |
|
|
open boundary. eg. OB_Jsouth(3)=4 |
28 |
|
|
<br>means that in the column I=3 there is a "southern" OB at tracer point |
29 |
|
|
J=4. Similarly OB_Iwest(2)=1 means that |
30 |
|
|
<br>the tracer point (2,1) is an OB point. This structure for specifying |
31 |
|
|
OBs assumes that there will be only one northern and southern OB per column |
32 |
|
|
and similar in the other direction. An entry of 0 (zero) means there is |
33 |
|
|
now OB in that column/row. |
34 |
|
|
<p>The reference to "tracer points" above introduces an important distinction |
35 |
|
|
between particular boundaries due to the C-grid staggering of variables. |
36 |
|
|
At a northern OB tracer point (i,j) the OB v-velocity point is at (i,j) |
37 |
|
|
while at a southern OB tracer point (i,j) the OB v-velocity point is at |
38 |
|
|
(i,j+1). This is all taken care of in the code but when specifying OB values |
39 |
|
|
it is important to remember the physical coordinates of T,S,U and V are |
40 |
|
|
not the same for a given computational index. |
41 |
|
|
<br> |
42 |
|
|
<h3> |
43 |
|
|
Changing the type of open boundary</h3> |
44 |
|
|
The supplied code simply specifies model variables at the appropriate points. |
45 |
|
|
The value to be specified can (and should) be determine using a radiative |
46 |
|
|
condition. A skeleton code is supplied set_obcs.F to illustrate how |
47 |
|
|
<br>this might be done. This is the only routine that needs to be edited. |
48 |
|
|
Edit others at your own peril! |
49 |
|
|
<br> |
50 |
|
|
<h3> |
51 |
|
|
The examples</h3> |
52 |
|
|
There are three examples in .../verification/exp4/ |
53 |
|
|
<ol> |
54 |
|
|
<li> |
55 |
|
|
A zonal channel (solid side walls) with open boundaries at either end: |
56 |
|
|
data.channel</li> |
57 |
|
|
|
58 |
|
|
<li> |
59 |
|
|
A zonal channel with a Gaussian bump and open boundaries at either end: |
60 |
|
|
data.bumpchannel</li> |
61 |
|
|
|
62 |
|
|
<li> |
63 |
|
|
An open domain (OBs on four sides) with a Gaussian bump: data.bump</li> |
64 |
|
|
</ol> |
65 |
|
|
Each data file has a corresponding topog.* file which is specified through |
66 |
|
|
the variable bathyFile in data.* |
67 |
|
|
<br>The physical problem has a flow of U=25 cm/s specified at all open |
68 |
|
|
boundaries. The details of the experiment can be found in Adcroft's thesis |
69 |
|
|
(Imperial College) and in Adcroft, Hill and Marshall, MWR 1997. |
70 |
|
|
<p>The differences between the supplied data.* files also show how to turn |
71 |
|
|
particular OBs on and off. |
72 |
|
|
<h3> |
73 |
|
|
Compiling and running the examples</h3> |
74 |
|
|
The examples supplied are the barotropic zonal flow over a Gaussian bump |
75 |
|
|
in a channel. |
76 |
|
|
<ul> |
77 |
|
|
<li> |
78 |
|
|
Header files: Copy or link SIZE.h, CPP_OPTIONS.h and CP_EEOPTIONS.h from |
79 |
adcroft |
1.2 |
.../verification/exp4/code/ to .../model/inc/, .../model/inc/ and .../eesupp.inc/ |
80 |
adcroft |
1.1 |
respectively</li> |
81 |
|
|
|
82 |
|
|
<li> |
83 |
|
|
Modified source: Copy set_obcs.F to .../model/src/</li> |
84 |
|
|
</ul> |
85 |
|
|
Now compile the code as usual: |
86 |
|
|
<ul> |
87 |
|
|
<li> |
88 |
|
|
cd bin</li> |
89 |
|
|
|
90 |
|
|
<li> |
91 |
|
|
../tools/genmake -makefile</li> |
92 |
|
|
|
93 |
|
|
<li> |
94 |
|
|
make depend</li> |
95 |
|
|
|
96 |
|
|
<li> |
97 |
|
|
make</li> |
98 |
|
|
</ul> |
99 |
|
|
To run the code you must first choose a data file to use: |
100 |
|
|
<ul> |
101 |
|
|
<li> |
102 |
adcroft |
1.2 |
cd ../verification/exp4/input/</li> |
103 |
adcroft |
1.1 |
|
104 |
|
|
<li> |
105 |
|
|
cp data.bump data</li> |
106 |
|
|
|
107 |
|
|
<li> |
108 |
|
|
../../exe/mitgcmuv</li> |
109 |
|
|
</ul> |
110 |
|
|
Happy Open Boundarying! |
111 |
|
|
</body> |
112 |
|
|
</html> |