/[MITgcm]/MITgcm/pkg/ggl90/ggl90_output.F
ViewVC logotype

Annotation of /MITgcm/pkg/ggl90/ggl90_output.F

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


Revision 1.1 - (hide annotations) (download)
Wed Jun 17 14:15:34 2009 UTC (15 years ago) by jmc
Branch: MAIN
CVS Tags: checkpoint62, checkpoint61v, checkpoint61w, checkpoint61t, checkpoint61u, checkpoint61r, checkpoint61s, checkpoint61q, checkpoint61z, checkpoint61x, checkpoint61y
rename ggl90_do_diags.F --> ggl90_output.F & GGL90_DIAGS.h --> GGL90_TAVE.h
add a STOP if MULTIPLE_RECORD_GGL90_STATE_FILES is defined
(until it get fixed) ; remove PLOT_FIELD_XYZ calls.

1 jmc 1.1 C $Header: /u/gcmpack/MITgcm/pkg/ggl90/ggl90_do_diags.F,v 1.3 2005/05/15 03:04:56 jmc Exp $
2     C $Name: $
3    
4     #include "GGL90_OPTIONS.h"
5    
6     #undef MULTIPLE_RECORD_GGL90_STATE_FILES
7     CBOP
8     C !ROUTINE: GGL90_OUTPUT
9     C !INTERFACE:
10     SUBROUTINE GGL90_OUTPUT( myTime, myIter, myThid )
11     C !DESCRIPTION: \bv
12     C *==========================================================*
13     C | SUBROUTINE GGL90_OUTPUT
14     C | o Do GGL90 diagnostic output.
15     C *==========================================================
16     C | The following CPP flag (MULTIPLE_RECORD_GGL90_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     #include "GGL90.h"
48     #include "GGL90_TAVE.h"
49    
50     C !INPUT/OUTPUT PARAMETERS:
51     C == Routine arguments ==
52     C myTime :: my time in simulation ( s )
53     C myIter :: my Iteration number
54     C myThid :: my Thread Id number
55     _RL myTime
56     INTEGER myIter
57     INTEGER myThid
58    
59     #ifdef ALLOW_GGL90
60    
61     C !LOCAL VARIABLES:
62     C == Local variables ==
63     CHARACTER*(MAX_LEN_MBUF) suff
64     LOGICAL DIFFERENT_MULTIPLE
65     EXTERNAL DIFFERENT_MULTIPLE
66     INTEGER bi, bj, K
67     _RL DDTT
68     CEOP
69    
70     C----------------------------------------------------------------
71     C Dump snapshot of GGL90 variables.
72     C----------------------------------------------------------------
73    
74     IF (
75     & DIFFERENT_MULTIPLE(GGL90dumpFreq,myTime,deltaTClock)
76     & ) THEN
77    
78     IF (GGL90writeState) THEN
79     #ifdef MULTIPLE_RECORD_GGL90_STATE_FILES
80     C Write each snap-shot as a new record in one file per variable
81     C - creates relatively few files but these files can become huge
82     STOP 'un-initialised ggl90_drctrec'
83     CALL WRITE_REC_XYZ_RL('GGL90viscAr',GGL90viscAr,ggl90_drctrec,
84     & myIter,myThid)
85     CALL WRITE_REC_XYZ_RL('GGL90diffKr',GGL90diffKr,ggl90_drctrec,
86     & myIter,myThid)
87     CALL WRITE_REC_XYZ_RL('GGL90TKE' ,GGL90TKE ,ggl90_drctrec,
88     & myIter,myThid)
89     #else /* MULTIPLE_RECORD_GGL90_STATE_FILES */
90     C Write each snap-shot as a new file
91     C - creates many files but for large configurations is easier to
92     C transfer analyse a particular snap-shots
93     WRITE(suff,'(I10.10)') myIter
94     CALL WRITE_FLD_XYZ_RL('GGL90viscAr.',suff,GGL90viscAr,
95     & myIter,myThid)
96     CALL WRITE_FLD_XYZ_RL('GGL90diffKr.',suff,GGL90diffKr,
97     & myIter,myThid)
98     CALL WRITE_FLD_XYZ_RL('GGL90TKE.' ,suff,GGL90TKE,
99     & myIter,myThid)
100     #endif /* MULTIPLE_RECORD_GGL90_STATE_FILES */
101     ENDIF
102    
103     C-- Increment record counter
104     ggl90_drctrec = ggl90_drctrec + 1
105    
106     ENDIF
107    
108     C----------------------------------------------------------------
109     C Do GGL90 time averaging.
110     C----------------------------------------------------------------
111    
112     #ifdef ALLOW_TIMEAVE
113    
114     C Initialize averages to zero
115     IF ( myIter.EQ.nIter0 ) THEN
116     DO bj = myByLo(myThid), myByHi(myThid)
117     DO bi = myBxLo(myThid), myBxHi(myThid)
118     CALL TIMEAVE_RESET(GGL90viscArtave,Nr,bi,bj,myThid)
119     CALL TIMEAVE_RESET(GGL90diffKrtave,Nr,bi,bj,myThid)
120     CALL TIMEAVE_RESET(GGL90TKEtave, Nr,bi,bj,myThid)
121     DO k=1,Nr
122     ggl90_TimeAve(k,bi,bj)=0.
123     ENDDO
124     ENDDO
125     ENDDO
126     ENDIF
127    
128     C Time Average GGL90 fields
129     IF ( myIter .EQ. nIter0 .OR.
130     & DIFFERENT_MULTIPLE(GGL90taveFreq,myTime,deltaTClock)
131     & ) THEN
132     DDTT=0.5*deltaTclock
133     ELSE
134     DDTT=deltaTclock
135     ENDIF
136     DO bj = myByLo(myThid), myByHi(myThid)
137     DO bi = myBxLo(myThid), myBxHi(myThid)
138     CALL TIMEAVE_CUMULATE(
139     & GGL90viscArtave,GGL90viscAr,Nr,DDTT,bi,bj,myThid)
140     CALL TIMEAVE_CUMULATE(
141     & GGL90diffKrtave,GGL90diffKr,Nr,DDTT,bi,bj,myThid)
142     CALL TIMEAVE_CUMULATE(
143     & GGL90TKEtave, GGL90TKE, Nr,DDTT,bi,bj,myThid)
144     C Keep record of how much time has been integrated over
145     DO k=1,Nr
146     ggl90_TimeAve(k,bi,bj)=ggl90_TimeAve(k,bi,bj)+DDTT
147     ENDDO
148     ENDDO
149     ENDDO
150    
151     C Dump files and restart average computation if needed
152     IF ( myIter.NE.nIter0 .AND.
153     & DIFFERENT_MULTIPLE(GGL90taveFreq,myTime,deltaTClock)
154     & ) THEN
155    
156     C Normalize by integrated time
157     DO bj = myByLo(myThid), myByHi(myThid)
158     DO bi = myBxLo(myThid), myBxHi(myThid)
159     CALL TIMEAVE_NORMALIZ(GGL90viscArtave,ggl90_timeave,
160     & Nr, bi,bj,myThid)
161     CALL TIMEAVE_NORMALIZ(GGL90diffKrtave,ggl90_timeave,
162     & Nr, bi,bj,myThid)
163     CALL TIMEAVE_NORMALIZ(GGL90TKEtave ,ggl90_timeave,
164     & Nr, bi,bj,myThid)
165     ENDDO
166     ENDDO
167    
168     #ifdef MULTIPLE_RECORD_GGL90_STATE_FILES
169     C Write each snap-shot as a new record in one file per variable
170     C - creates relatively few files but these files can become huge
171     STOP 'un-initialised ggl90_drctrecTave'
172     CALL WRITE_REC_XYZ_RL('GGL90viscAr-T',GGL90viscArTave,
173     & ggl90_drctrecTave,myIter,myThid)
174     CALL WRITE_REC_XYZ_RL('GGL90diffKr-T',GGL90diffKrTave,
175     & ggl90_drctrecTave,myIter,myThid)
176     CALL WRITE_REC_XYZ_RL('GGL90TKE-T', GGL90TKETave,
177     & ggl90_drctrecTave,myIter,myThid)
178     C-- Increment record counter
179     ggl90_drctrecTave = ggl90_drctrecTave + 1
180    
181     #else /* MULTIPLE_RECORD_GGL90_STATE_FILES */
182    
183     C Write each snap-shot as a new file
184     C - creates many files but for large configurations is easier to
185     C transfer analyse a particular snap-shots
186     WRITE(suff,'(I10.10)') myIter
187     CALL WRITE_FLD_XYZ_RL('GGL90viscAr-T.',suff,GGL90viscArTave,
188     & myIter,myThid)
189     CALL WRITE_FLD_XYZ_RL('GGL90diffKr-T.',suff,GGL90diffKrTave,
190     & myIter,myThid)
191     CALL WRITE_FLD_XYZ_RL('GGL90TKE-T.', suff,GGL90TKETave,
192     & myIter,myThid)
193     #endif /* MULTIPLE_RECORD_GGL90_STATE_FILES */
194    
195     C Reset averages to zero
196     DO bj = myByLo(myThid), myByHi(myThid)
197     DO bi = myBxLo(myThid), myBxHi(myThid)
198     CALL TIMEAVE_RESET(GGL90viscArtave,Nr,bi,bj,myThid)
199     CALL TIMEAVE_RESET(GGL90diffKrtave,Nr,bi,bj,myThid)
200     CALL TIMEAVE_RESET(GGL90TKEtave, Nr,bi,bj,myThid)
201     DO k=1,Nr
202     ggl90_TimeAve(k,bi,bj)=0.
203     ENDDO
204     ENDDO
205     ENDDO
206    
207     C Time Average GGL90 fields
208     DDTT=0.5*deltaTclock
209     DO bj = myByLo(myThid), myByHi(myThid)
210     DO bi = myBxLo(myThid), myBxHi(myThid)
211     CALL TIMEAVE_CUMULATE(
212     & GGL90viscArtave,GGL90viscAr,Nr,DDTT,bi,bj,myThid)
213     CALL TIMEAVE_CUMULATE(
214     & GGL90diffKrtave,GGL90diffKr,Nr,DDTT,bi,bj,myThid)
215     CALL TIMEAVE_CUMULATE(
216     & GGL90TKEtave, GGL90TKE, Nr,DDTT,bi,bj,myThid)
217     C Keep record of how much time has been integrated over
218     DO k=1,Nr
219     ggl90_TimeAve(k,bi,bj)=ggl90_TimeAve(k,bi,bj)+DDTT
220     ENDDO
221     ENDDO
222     ENDDO
223     ENDIF
224    
225     #endif
226    
227     #endif
228    
229     RETURN
230     END

  ViewVC Help
Powered by ViewVC 1.1.22