/[MITgcm]/MITgcm/pkg/my82/my82_output.F
ViewVC logotype

Annotation of /MITgcm/pkg/my82/my82_output.F

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.4 - (hide annotations) (download)
Fri Mar 24 23:38:56 2017 UTC (7 years, 3 months ago) by jmc
Branch: MAIN
CVS Tags: checkpoint66g, checkpoint66f, checkpoint66o, checkpoint66n, checkpoint66m, checkpoint66l, checkpoint66k, checkpoint66j, checkpoint66i, checkpoint66h, HEAD
Changes since 1.3: +13 -5 lines
use new S/R RW_GET_SUFFIX to get file suffix (according to "rwSuffixType")

1 jmc 1.4 C $Header: /u/gcmpack/MITgcm/pkg/my82/my82_output.F,v 1.3 2013/08/12 00:05:44 jmc Exp $
2 jmc 1.1 C $Name: $
3    
4     #include "MY82_OPTIONS.h"
5    
6     CBOP
7     C !ROUTINE: MY82_OUTPUT
8     C !INTERFACE:
9     SUBROUTINE MY82_OUTPUT( myTime, myIter, myThid )
10 jmc 1.2
11 jmc 1.1 C !DESCRIPTION: \bv
12     C *==========================================================*
13     C | SUBROUTINE MY82_OUTPUT
14     C | o Do MY82 diagnostic output.
15     C *==========================================================
16     C | The following CPP flag (MULTIPLE_RECORD_MY82_STATE_FILES) is
17     C | #define/#undefed here since it is specific to this routine
18     C | and very user-preference specific.
19     C |
20     C | If #undefed (default) the state files are written as in all versions
21     C | prior to checkpoint32, where a file is created per variable, per time
22     C | and per tile. This *has* to be the default because most users use this
23     C | mode and all utilities and scripts (diagnostic) assume this form.
24     C | It is also robust, as explained below.
25     C |
26     C | If #defined, subsequent snap-shots are written as records in the
27     C | same file (no iteration number in filenames).
28     C | Advantages: - fewer files
29     C | - for small problems, is easy to copy the output around
30     C | Disadvantages:
31     C | - breaks a lot of diagnostic scripts
32     C | - for large or long problems this creates huge files
33     C | - is an unexpected, unsolicited change in behaviour which came
34     C | as a surprise (in c32) and inconvenience to several users
35     C | - can not accomodate changing the frequency of output
36     C | after a pickup (this is trivial in previous method
37     C | but needs new code and parameters in this new method)
38     C *==========================================================*
39     C \ev
40    
41     C !USES:
42     IMPLICIT NONE
43     C === Global variables ===
44     #include "SIZE.h"
45     #include "EEPARAMS.h"
46     #include "PARAMS.h"
47     #ifdef ALLOW_MNC
48     #include "MNC_PARAMS.h"
49     #endif
50     #include "MY82.h"
51     #include "MY82_TAVE.h"
52    
53     C !INPUT/OUTPUT PARAMETERS:
54     C == Routine arguments ==
55     C myTime :: my time in simulation ( s )
56     C myIter :: my Iteration number
57     C myThid :: my Thread Id number
58     _RL myTime
59     INTEGER myIter
60     INTEGER myThid
61    
62     #ifdef ALLOW_MY82
63    
64 jmc 1.2 C !FUNCTIONS:
65     LOGICAL DIFFERENT_MULTIPLE
66     EXTERNAL DIFFERENT_MULTIPLE
67    
68 jmc 1.1 C !LOCAL VARIABLES:
69     C == Local variables ==
70 jmc 1.4 CHARACTER*(10) suff
71 jmc 1.2 #ifdef ALLOW_TIMEAVE
72     INTEGER bi, bj
73 jmc 1.1 _RL DDTT
74 jmc 1.2 #endif
75     #ifdef ALLOW_MNC
76 jmc 1.1 CHARACTER*(1) pf
77 jmc 1.2 #endif
78 jmc 1.1 CEOP
79    
80 jmc 1.2 C---+----1----+----2----+----3----+----4----+----5----+----6----+----7-|--+----|
81 jmc 1.1
82     C----------------------------------------------------------------
83     C Dump snapshot of MY82 variables.
84     C----------------------------------------------------------------
85    
86 jmc 1.2 IF ( myIter.NE.nIter0 .AND.
87     & DIFFERENT_MULTIPLE( MYdumpFreq, myTime, deltaTClock )
88     & ) THEN
89 jmc 1.1
90     IF (MYwriteState .AND. snapshot_mdsio) THEN
91     C Write each snap-shot as a new file
92     C - creates many files but for large configurations is easier to
93     C transfer analyse a particular snap-shots
94 jmc 1.4 IF ( rwSuffixType.EQ.0 ) THEN
95     WRITE(suff,'(I10.10)') myIter
96     ELSE
97     CALL RW_GET_SUFFIX( suff, myTime, myIter, myThid )
98     ENDIF
99 jmc 1.1 CALL WRITE_FLD_XYZ_RL('MYviscAr.',suff,MYviscAr,
100     & myIter,myThid)
101     CALL WRITE_FLD_XYZ_RL('MYdiffKr.',suff,MYdiffKr,
102     & myIter,myThid)
103     CALL WRITE_FLD_XY_RL('MYhbl.',suff,MYhbl,
104     & myIter,myThid)
105     ENDIF
106    
107     #ifdef ALLOW_MNC
108     IF (MYwriteState .AND. useMNC .AND. snapshot_mnc ) THEN
109 jmc 1.2 IF ( writeBinaryPrec .EQ. precFloat64 ) THEN
110     pf(1:1) = 'D'
111     ELSE
112     pf(1:1) = 'R'
113     ENDIF
114 jmc 1.1 CALL MNC_CW_SET_UDIM('my_state', -1, myThid)
115     CALL MNC_CW_RL_W_S('D','my_state',0,0,'T',myTime,myThid)
116     CALL MNC_CW_SET_UDIM('my_state', 0, myThid)
117     CALL MNC_CW_I_W_S('I','my_state',0,0,'iter',myIter,myThid)
118     CALL MNC_CW_RL_W(pf,'my_state',0,0,
119     & 'MYviscAr', MYviscAr, myThid)
120     CALL MNC_CW_RL_W(pf,'my_state',0,0,
121     & 'MYdiffKr', MYdiffKr, myThid)
122     CALL MNC_CW_RL_W(pf,'my_state',0,0,
123     & 'MYhbl', MYhbl, myThid)
124     ENDIF
125     #endif /* ALLOW_MNC */
126    
127     ENDIF
128    
129     C----------------------------------------------------------------
130     C Do MY82 time averaging.
131     C----------------------------------------------------------------
132    
133     #ifdef ALLOW_TIMEAVE
134 jmc 1.2 IF ( MYtaveFreq.GT.0. _d 0 ) THEN
135 jmc 1.1
136 jmc 1.2 IF ( myIter.EQ.nIter0 ) THEN
137 jmc 1.1 C Initialize averages to zero
138 jmc 1.2 DO bj = myByLo(myThid), myByHi(myThid)
139     DO bi = myBxLo(myThid), myBxHi(myThid)
140     CALL TIMEAVE_RESET( MYviscArtave, Nr, bi, bj, myThid )
141     CALL TIMEAVE_RESET( MYdiffKrtave, Nr, bi, bj, myThid )
142     CALL TIMEAVE_RESET( MYhbltave, 1 , bi, bj, myThid )
143     MY_timeAve(bi,bj) = 0.
144 jmc 1.1 ENDDO
145     ENDDO
146    
147 jmc 1.2 ELSE
148     C Cumulate MY82 fields (for Time Average)
149 jmc 1.4 DDTT = deltaTClock
150 jmc 1.2 DO bj = myByLo(myThid), myByHi(myThid)
151     DO bi = myBxLo(myThid), myBxHi(myThid)
152     CALL TIMEAVE_CUMULATE( MYviscArtave, MYviscAr,
153     & Nr, DDTT, bi, bj, myThid )
154     CALL TIMEAVE_CUMULATE( MYdiffKrtave, MYdiffKr,
155     & Nr, DDTT, bi, bj, myThid )
156     CALL TIMEAVE_CUMULATE( MYhbltave, MYhbl,
157     & 1 , DDTT, bi, bj, myThid )
158 jmc 1.1 C Keep record of how much time has been integrated over
159 jmc 1.2 MY_timeAve(bi,bj) = MY_timeAve(bi,bj)+DDTT
160     ENDDO
161 jmc 1.1 ENDDO
162 jmc 1.2 ENDIF
163 jmc 1.1
164     C Dump files and restart average computation if needed
165 jmc 1.2 IF ( myIter.NE.nIter0 .AND.
166     & DIFFERENT_MULTIPLE( MYtaveFreq, myTime, deltaTClock )
167     & ) THEN
168 jmc 1.1
169     C Normalize by integrated time
170 jmc 1.2 DO bj = myByLo(myThid), myByHi(myThid)
171     DO bi = myBxLo(myThid), myBxHi(myThid)
172     CALL TIMEAVE_NORMALIZE( MYviscArtave,
173     & MY_timeAve, Nr, bi,bj,myThid)
174     CALL TIMEAVE_NORMALIZE( MYdiffKrtave,
175     & MY_timeAve, Nr, bi,bj,myThid)
176     CALL TIMEAVE_NORMALIZE( MYhbltave,
177     & MY_timeAve, 1 , bi,bj,myThid)
178     ENDDO
179 jmc 1.1 ENDDO
180    
181 jmc 1.2 IF (MYwriteState .AND. timeave_mdsio) THEN
182 jmc 1.1 C Write each snap-shot as a new file
183 jmc 1.4 IF ( rwSuffixType.EQ.0 ) THEN
184     WRITE(suff,'(I10.10)') myIter
185     ELSE
186     CALL RW_GET_SUFFIX( suff, myTime, myIter, myThid )
187     ENDIF
188 jmc 1.2 CALL WRITE_FLD_XYZ_RL('MYviscAr-T.', suff,
189     & MYviscArTave, myIter, myThid )
190     CALL WRITE_FLD_XYZ_RL('MYdiffKr-T.', suff,
191     & MYdiffKrTave, myIter, myThid )
192     CALL WRITE_FLD_XY_RL( 'MYhbl-T.', suff,
193     & MYhblTave, myIter, myThid )
194     ENDIF
195 jmc 1.1
196     #ifdef ALLOW_MNC
197 jmc 1.2 IF (MYwriteState .AND. useMNC .AND. timeave_mnc) THEN
198     IF ( writeBinaryPrec .EQ. precFloat64 ) THEN
199     pf(1:1) = 'D'
200     ELSE
201     pf(1:1) = 'R'
202     ENDIF
203     CALL MNC_CW_SET_UDIM('my_timeave', -1, myThid)
204     CALL MNC_CW_RL_W_S('D','my_timeave',0,0,'T',myTime,myThid)
205     CALL MNC_CW_SET_UDIM('my_timeave', 0, myThid)
206     CALL MNC_CW_I_W_S('I','my_timeave',0,0,'iter',myIter,myThid)
207     CALL MNC_CW_RL_W(pf,'my_timeave',0,0,
208     & 'MYviscAr', MYviscArTave, myThid)
209     CALL MNC_CW_RL_W(pf,'my_timeave',0,0,
210     & 'MYdiffKr', MYdiffKrTave, myThid)
211     CALL MNC_CW_RL_W(pf,'my_timeave',0,0,
212     & 'MYhbl', MYhblTave, myThid)
213     ENDIF
214 jmc 1.1 #endif /* ALLOW_MNC */
215    
216     C Reset averages to zero
217 jmc 1.2 DO bj = myByLo(myThid), myByHi(myThid)
218     DO bi = myBxLo(myThid), myBxHi(myThid)
219     CALL TIMEAVE_RESET( MYviscArtave, Nr, bi, bj, myThid )
220     CALL TIMEAVE_RESET( MYdiffKrtave, Nr, bi, bj, myThid )
221     CALL TIMEAVE_RESET( MYhbltave, 1 , bi, bj, myThid )
222     MY_timeAve(bi,bj) = 0.
223     ENDDO
224 jmc 1.1 ENDDO
225    
226 jmc 1.2 C- end dump-files block
227     ENDIF
228    
229     C- end if MYtaveFreq > 0
230 jmc 1.1 ENDIF
231     #endif /* ALLOW_TIMEAVE */
232    
233     #ifdef ALLOW_DIAGNOSTICS
234 jmc 1.3 C- note: should move this part to S/R MY82_CALC (like we do in pkg/ggl90)
235     C do not fill during call from INITIALISE_VARIA
236     IF ( useDiagnostics .AND. myIter.NE.nIter0 ) THEN
237 jmc 1.1 CALL DIAGNOSTICS_FILL(MYviscAr,'MYVISCAR',0,Nr,0,1,1,myThid)
238     CALL DIAGNOSTICS_FILL(MYdiffKr,'MYDIFFKR',0,Nr,0,1,1,myThid)
239     CALL DIAGNOSTICS_FILL(MYhbl ,'MYHBL ',0,1 ,0,1,1,myThid)
240     ENDIF
241     #endif /* ALLOW_DIAGNOSTICS */
242    
243     #endif /* ALLOW_MY82 */
244    
245     RETURN
246     END

  ViewVC Help
Powered by ViewVC 1.1.22