/[MITgcm]/MITgcm/pkg/ptracers/ptracers_readparms.F
ViewVC logotype

Annotation of /MITgcm/pkg/ptracers/ptracers_readparms.F

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


Revision 1.37 - (hide annotations) (download)
Tue Nov 16 17:46:00 2010 UTC (13 years, 6 months ago) by jmc
Branch: MAIN
CVS Tags: checkpoint62o
Changes since 1.36: +15 -10 lines
check for valid advection scheme in data.ptracers

1 jmc 1.37 C $Header: /u/gcmpack/MITgcm/pkg/ptracers/ptracers_readparms.F,v 1.36 2010/09/05 22:28:14 jmc Exp $
2 dimitri 1.2 C $Name: $
3 adcroft 1.1
4     #include "PTRACERS_OPTIONS.h"
5    
6 edhill 1.6 C---+----1----+----2----+----3----+----4----+----5----+----6----+----7-|--+----|
7 adcroft 1.1 CBOP
8 edhill 1.6 C !ROUTINE: PTRACERS_READPARMS
9 jmc 1.24
10 edhill 1.6 C !INTERFACE:
11 adcroft 1.1 SUBROUTINE PTRACERS_READPARMS( myThid )
12 jmc 1.24
13 edhill 1.6 C !DESCRIPTION:
14 adcroft 1.1 C Initialize PTRACERS parameters, read in data.ptracers
15    
16 edhill 1.6 C !USES:
17 adcroft 1.1 IMPLICIT NONE
18     #include "SIZE.h"
19     #include "EEPARAMS.h"
20 jahn 1.35 #ifdef ALLOW_LONGSTEP
21     #include "LONGSTEP_PARAMS.h"
22     #endif
23 jmc 1.5 #include "PTRACERS_SIZE.h"
24 jmc 1.27 #include "PTRACERS_PARAMS.h"
25 dimitri 1.2 #include "PARAMS.h"
26 edhill 1.20 #ifdef ALLOW_MNC
27     #include "MNC_PARAMS.h"
28     #endif
29 edhill 1.7
30 edhill 1.6 C !INPUT PARAMETERS:
31 adcroft 1.1 INTEGER myThid
32 edhill 1.6 CEOP
33 adcroft 1.1
34     #ifdef ALLOW_PTRACERS
35 jmc 1.37 C !FUNCTIONS
36     LOGICAL GAD_VALID_ADVSCHEME
37     EXTERNAL GAD_VALID_ADVSCHEME
38 adcroft 1.1
39 edhill 1.6 C !LOCAL VARIABLES:
40 jmc 1.11 C k,iTracer :: loop indices
41 edhill 1.6 C iUnit :: unit number for I/O
42     C msgBuf :: message buffer
43 jmc 1.11 INTEGER k, iTracer
44 adcroft 1.1 INTEGER iUnit
45 edhill 1.6 INTEGER ic
46 jmc 1.37 LOGICAL validNum
47 adcroft 1.1 CHARACTER*(MAX_LEN_MBUF) msgBuf
48 jmc 1.11 _RL PTRACERS_diffKr(PTRACERS_num)
49 jmc 1.30 _RL tauTr1ClimRelax
50 adcroft 1.1
51 jmc 1.5 C PTRACERS_taveFreq :: Frequency with which time-averaged PTRACERS
52     C are written to post-processing files.
53 jmc 1.30 C tauTr1ClimRelax :: old parameter (will be removed 1 day)
54 jmc 1.5 NAMELIST /PTRACERS_PARM01/
55 jmc 1.30 & tauTr1ClimRelax,
56 mlosch 1.14 & PTRACERS_dumpFreq,
57 edhill 1.6 & PTRACERS_taveFreq,
58 mlosch 1.13 & PTRACERS_monitorFreq,
59 edhill 1.6 & PTRACERS_advScheme,
60 jmc 1.15 & PTRACERS_ImplVertAdv,
61 edhill 1.6 & PTRACERS_diffKh,
62     & PTRACERS_diffK4,
63     & PTRACERS_diffKr,
64 jmc 1.11 & PTRACERS_diffKrNr,
65 mlosch 1.23 & PTRACERS_ref,
66 jmc 1.24 & PTRACERS_EvPrRn,
67 jmc 1.36 & PTRACERS_addSrelax2EmP,
68 edhill 1.6 & PTRACERS_useGMRedi,
69 jmc 1.32 & PTRACERS_useDWNSLP,
70 edhill 1.6 & PTRACERS_useKPP,
71 jmc 1.19 & PTRACERS_Iter0,
72 edhill 1.6 & PTRACERS_numInUse,
73     & PTRACERS_initialFile,
74     & PTRACERS_useRecords,
75     & PTRACERS_names,
76     & PTRACERS_long_names,
77     & PTRACERS_units,
78 jmc 1.24 & PTRACERS_timeave_mnc,
79 mlosch 1.22 & PTRACERS_snapshot_mnc,
80     & PTRACERS_monitor_mnc,
81 jmc 1.24 & PTRACERS_pickup_write_mnc,
82 mlosch 1.22 & PTRACERS_pickup_read_mnc
83 jmc 1.5
84 jmc 1.25 _BEGIN_MASTER(myThid)
85    
86 edhill 1.6 C This routine has been called by the main model so we set our
87     C internal flag to indicate we are in business
88 jmc 1.29 c PTRACERSisON=.TRUE.
89     C Note(jmc): remove this flag which is not really usefull (not set properly
90     C when usePTRACERS=F and always TRUE otherwise);
91     C much better to use "usePTRACERS" flag instead.
92 adcroft 1.1
93 jmc 1.28 C Set ptracer IO & diagnostics labels (2 characters long)
94     CALL PTRACERS_SET_IOLABEL(
95     O PTRACERS_ioLabel,
96     I PTRACERS_num, myThid )
97    
98 edhill 1.6 C Set defaults values for parameters in PTRACERS.h
99 mlosch 1.17 PTRACERS_dumpFreq = dumpFreq
100 mlosch 1.13 PTRACERS_taveFreq = taveFreq
101     PTRACERS_monitorFreq = monitorFreq
102 jmc 1.19 PTRACERS_Iter0 = 0
103 adcroft 1.1 PTRACERS_numInUse=-1
104     DO iTracer=1,PTRACERS_num
105 edhill 1.6 PTRACERS_advScheme(iTracer)=saltAdvScheme
106 jmc 1.15 PTRACERS_ImplVertAdv(iTracer) = .FALSE.
107 edhill 1.6 PTRACERS_diffKh(iTracer)=diffKhS
108     PTRACERS_diffK4(iTracer)=diffK4S
109 jmc 1.11 PTRACERS_diffKr(iTracer)=UNSET_RL
110     DO k=1,Nr
111     PTRACERS_diffKrNr(k,iTracer)=diffKrNrS(k)
112 mlosch 1.23 PTRACERS_ref (k,iTracer)=0. _d 0
113 jmc 1.11 ENDDO
114 jmc 1.24 PTRACERS_EvPrRn(iTracer)=UNSET_RL
115 edhill 1.6 PTRACERS_useGMRedi(iTracer)=useGMRedi
116 jmc 1.31 PTRACERS_useDWNSLP(iTracer)=useDOWN_SLOPE
117 jmc 1.33 PTRACERS_useKPP(iTracer) =useKPP
118 edhill 1.6 PTRACERS_initialFile(iTracer)=' '
119     DO ic = 1,MAX_LEN_FNAM
120     PTRACERS_names(iTracer)(ic:ic) = ' '
121     PTRACERS_long_names(iTracer)(ic:ic) = ' '
122     PTRACERS_units(iTracer)(ic:ic) = ' '
123     ENDDO
124 adcroft 1.1 ENDDO
125 jmc 1.36 PTRACERS_addSrelax2EmP = .FALSE.
126 edhill 1.20 PTRACERS_useRecords = .FALSE.
127     #ifdef ALLOW_MNC
128 jmc 1.25 PTRACERS_timeave_mnc = useMNC .AND. timeave_mnc
129     PTRACERS_snapshot_mnc = useMNC .AND. snapshot_mnc
130     PTRACERS_monitor_mnc = useMNC .AND. monitor_mnc
131     PTRACERS_pickup_write_mnc = useMNC .AND. pickup_write_mnc
132     PTRACERS_pickup_read_mnc = useMNC .AND. pickup_read_mnc
133 edhill 1.20 #else
134     PTRACERS_timeave_mnc = .FALSE.
135     PTRACERS_snapshot_mnc = .FALSE.
136 mlosch 1.22 PTRACERS_monitor_mnc = .FALSE.
137 edhill 1.20 PTRACERS_pickup_write_mnc = .FALSE.
138     PTRACERS_pickup_read_mnc = .FALSE.
139     #endif
140 jmc 1.30 tauTr1ClimRelax = 0.
141 jahn 1.35 DO k = 1,Nr
142     #ifdef ALLOW_LONGSTEP
143     PTRACERS_dTLev(k) = LS_nIter*dTtracerLev(k)
144     #else
145     PTRACERS_dTLev(k) = dTtracerLev(k)
146     #endif
147     ENDDO
148 adcroft 1.1
149 edhill 1.6 C Open and read the data.ptracers file
150 adcroft 1.1 WRITE(msgBuf,'(A)') ' PTRACERS_READPARMS: opening data.ptracers'
151 jmc 1.25 CALL PRINT_MESSAGE( msgBuf, standardMessageUnit,
152     & SQUEEZE_RIGHT , myThid )
153 adcroft 1.1 CALL OPEN_COPY_DATA_FILE(
154     I 'data.ptracers', 'PTRACERS_READPARMS',
155     O iUnit,
156     I myThid )
157     READ(UNIT=iUnit,NML=PTRACERS_PARM01)
158     WRITE(msgBuf,'(A)')
159     & ' PTRACERS_READPARMS: finished reading data.ptracers'
160 jmc 1.25 CALL PRINT_MESSAGE( msgBuf, standardMessageUnit,
161     & SQUEEZE_RIGHT , myThid )
162 adcroft 1.1
163 edhill 1.6 C Close the open data file
164 adcroft 1.1 CLOSE(iUnit)
165    
166 edhill 1.6 C Now set-up any remaining parameters that result from the input
167     C parameters
168 adcroft 1.1
169 jmc 1.30 C Tracer 1 climatology relaxation time scale (<- but the code is gone !)
170     IF ( tauTr1ClimRelax .EQ. 0. ) THEN
171     lambdaTr1ClimRelax = 0.
172     ELSE
173     lambdaTr1ClimRelax = 1./tauTr1ClimRelax
174     ENDIF
175    
176 edhill 1.6 C If PTRACERS_numInUse was not set in data.ptracers then we can
177     C assume that all PTRACERS fields will be in use
178 adcroft 1.1 IF (PTRACERS_numInUse.LT.0) THEN
179 edhill 1.6 PTRACERS_numInUse=PTRACERS_num
180 adcroft 1.1 ENDIF
181 edhill 1.6 C Check we are not trying to use more tracers than allowed
182 adcroft 1.1 IF (PTRACERS_numInUse.GT.PTRACERS_num) THEN
183 jmc 1.26 WRITE(msgBuf,'(A,I4,A,I4,A)')
184     & ' PTRACERS_READPARMS: You requested',PTRACERS_numInUse,
185     & ' tracers at run time when only',PTRACERS_num,
186 edhill 1.6 & ' were specified at compile time. Naughty! '
187 jmc 1.25 CALL PRINT_ERROR( msgBuf, myThid )
188 edhill 1.6 STOP 'ABNORMAL END: S/R PTRACERS_READPARMS'
189 adcroft 1.1 ENDIF
190 jmc 1.37 C Check for valid advection-scheme number
191 adcroft 1.1 DO iTracer=1,PTRACERS_numInUse
192 jmc 1.37 validNum = GAD_VALID_ADVSCHEME( PTRACERS_advScheme(iTracer) )
193     IF ( .NOT.validNum ) THEN
194     WRITE(msgBuf,'(2A,I6)') 'PTRACERS_READPARMS: ',
195     & 'invalid advection scheme number=',PTRACERS_advScheme(iTracer)
196     CALL PRINT_ERROR( msgBuf, myThid )
197     WRITE(msgBuf,'(2A,I6)') 'PTRACERS_READPARMS: ',
198     & 'for tracer #', iTracer
199     CALL PRINT_ERROR( msgBuf, myThid )
200     STOP 'ABNORMAL END: S/R PTRACERS_READPARMS'
201 edhill 1.6 ENDIF
202 adcroft 1.1 ENDDO
203 jmc 1.15 #ifndef INCLUDE_IMPLVERTADV_CODE
204     DO iTracer=1,PTRACERS_numInUse
205     IF ( PTRACERS_ImplVertAdv(iTracer) ) THEN
206     WRITE(msgBuf,'(A)')
207     & 'PTRACERS_READPARMS: #undef INCLUDE_IMPLVERTADV_CODE'
208 jmc 1.25 CALL PRINT_ERROR( msgBuf, myThid )
209 jmc 1.26 WRITE(msgBuf,'(2A,I3,A)') 'PTRACERS_READPARMS:',
210 jmc 1.15 & ' but pTracers_ImplVertAdv(',iTracer,' ) is TRUE'
211 jmc 1.25 CALL PRINT_ERROR( msgBuf, myThid )
212 jmc 1.15 STOP 'ABNORMAL END: S/R PTRACERS_READPARMS'
213     ENDIF
214     ENDDO
215 jahn 1.35 IF ( PTRACERS_dTLev(1).NE.PTRACERS_dTLev(Nr)
216     & .AND. implicitDiffusion ) THEN
217     WRITE(msgBuf,'(A)')
218     & 'PTRACERS_READPARMS: #undef INCLUDE_IMPLVERTADV_CODE'
219     CALL PRINT_ERROR( msgBuf , myThid)
220     WRITE(msgBuf,'(2A)') 'PTRACERS_READPARMS: ',
221     & 'but implicitDiffusion=T with non-uniform PTRACERS_dTLev'
222     CALL PRINT_ERROR( msgBuf , myThid)
223     STOP 'ABNORMAL END: S/R PTRACERS_READPARMS'
224     ENDIF
225 jmc 1.15 #endif
226 jmc 1.11 DO iTracer=1,PTRACERS_numInUse
227 jmc 1.26 IF ( PTRACERS_useGMRedi(iTracer) .AND. .NOT.useGMRedi ) THEN
228     WRITE(msgBuf,'(2A,I3,A)') 'PTRACERS_READPARMS:',
229     & ' pTracers_useGMRedi(',iTracer,' ) is TRUE'
230     CALL PRINT_ERROR( msgBuf, myThid )
231     WRITE(msgBuf,'(A,L5,A)')
232     & 'PTRACERS_READPARMS: But not useGMRedi (=',useGMRedi,')'
233     CALL PRINT_ERROR( msgBuf, myThid )
234     STOP 'ABNORMAL END: S/R PTRACERS_READPARMS'
235     ENDIF
236 jmc 1.31 IF ( PTRACERS_useDWNSLP(iTracer) .AND. .NOT.useDOWN_SLOPE ) THEN
237     WRITE(msgBuf,'(2A,I3,A)') 'PTRACERS_READPARMS:',
238     & ' pTracers_useDWNSLP(',iTracer,' ) is TRUE'
239     CALL PRINT_ERROR( msgBuf, myThid )
240     WRITE(msgBuf,'(2A,L5,A)') 'PTRACERS_READPARMS:',
241     & ' But not useDOWN_SLOPE (=', useDOWN_SLOPE, ')'
242     CALL PRINT_ERROR( msgBuf, myThid )
243     STOP 'ABNORMAL END: S/R PTRACERS_READPARMS'
244     ENDIF
245 jmc 1.26 IF ( PTRACERS_useKPP(iTracer) .AND. .NOT.useKPP ) THEN
246     WRITE(msgBuf,'(2A,I3,A)') 'PTRACERS_READPARMS:',
247     & ' pTracers_useKPP(',iTracer,' ) is TRUE'
248     CALL PRINT_ERROR( msgBuf, myThid )
249     WRITE(msgBuf,'(A,L5,A)')
250     & 'PTRACERS_READPARMS: But not useKPP (=',useKPP,')'
251     CALL PRINT_ERROR( msgBuf, myThid )
252     STOP 'ABNORMAL END: S/R PTRACERS_READPARMS'
253     ENDIF
254 jmc 1.11 IF ( PTRACERS_diffKr(iTracer).NE.UNSET_RL ) THEN
255     DO k=1,Nr
256     PTRACERS_diffKrNr(k,iTracer)=PTRACERS_diffKr(iTracer)
257     ENDDO
258     ENDIF
259     ENDDO
260 adcroft 1.1
261 edhill 1.6 #ifdef ALLOW_MNC
262 jmc 1.25 PTRACERS_timeave_mnc = useMNC .AND. PTRACERS_timeave_mnc
263     PTRACERS_snapshot_mnc = useMNC .AND. PTRACERS_snapshot_mnc
264     PTRACERS_monitor_mnc = useMNC .AND. PTRACERS_monitor_mnc
265     PTRACERS_pickup_write_mnc = useMNC .AND. PTRACERS_pickup_write_mnc
266     PTRACERS_pickup_read_mnc = useMNC .AND. PTRACERS_pickup_read_mnc
267 edhill 1.20
268     PTRACERS_timeave_mdsio = (.NOT. PTRACERS_timeave_mnc)
269     & .OR. outputTypesInclusive
270     PTRACERS_snapshot_mdsio = (.NOT. PTRACERS_snapshot_mnc)
271     & .OR. outputTypesInclusive
272 mlosch 1.22 PTRACERS_monitor_stdio = (.NOT. PTRACERS_monitor_mnc)
273     & .OR. outputTypesInclusive
274 edhill 1.20 PTRACERS_pickup_write_mdsio = (.NOT. PTRACERS_pickup_write_mnc)
275     & .OR. outputTypesInclusive
276     PTRACERS_pickup_read_mdsio = (.NOT. PTRACERS_pickup_read_mnc)
277     & .OR. outputTypesInclusive
278     #else
279     PTRACERS_timeave_mnc = .FALSE.
280     PTRACERS_snapshot_mnc = .FALSE.
281 mlosch 1.22 PTRACERS_monitor_mnc = .FALSE.
282 edhill 1.20 PTRACERS_pickup_write_mnc = .FALSE.
283     PTRACERS_pickup_read_mnc = .FALSE.
284     PTRACERS_timeave_mdsio = .TRUE.
285     PTRACERS_snapshot_mdsio = .TRUE.
286 mlosch 1.22 PTRACERS_monitor_stdio = .TRUE.
287 edhill 1.20 PTRACERS_pickup_write_mdsio = .TRUE.
288     PTRACERS_pickup_read_mdsio = .TRUE.
289     #endif
290 jmc 1.24
291 jmc 1.12 C-- Print a summary of pTracer parameter values:
292     iUnit = standardMessageUnit
293     WRITE(msgBuf,'(A)') '// ==================================='
294 jmc 1.25 CALL PRINT_MESSAGE( msgBuf, iUnit, SQUEEZE_RIGHT , myThid )
295 jmc 1.12 WRITE(msgBuf,'(A)') '// PTRACERS parameters '
296 jmc 1.25 CALL PRINT_MESSAGE( msgBuf, iUnit, SQUEEZE_RIGHT , myThid )
297 jmc 1.12 WRITE(msgBuf,'(A)') '// ==================================='
298 jmc 1.25 CALL PRINT_MESSAGE( msgBuf, iUnit, SQUEEZE_RIGHT , myThid )
299 jmc 1.12 CALL WRITE_0D_I( PTRACERS_numInUse, INDEX_NONE,
300     & 'PTRACERS_numInUse =',
301     & ' /* number of tracers */')
302 jmc 1.19 CALL WRITE_0D_I( PTRACERS_Iter0, INDEX_NONE,
303     & 'PTRACERS_Iter0 =',
304     & ' /* timestep number when tracers are initialized */')
305 jmc 1.36 CALL WRITE_0D_L( PTRACERS_addSrelax2EmP, INDEX_NONE,
306     & 'PTRACERS_addSrelax2EmP =','/* add Salt relaxation to EmP */')
307 jahn 1.35 CALL WRITE_1D_RL( PTRACERS_dTLev, Nr, INDEX_K,
308     & 'PTRACERS_dTLev =',
309     &' /* Ptracer timestep ( s ) */')
310 jmc 1.34 CALL WRITE_0D_RL(PTRACERS_dumpFreq, INDEX_NONE,
311 mlosch 1.14 & 'PTRACERS_dumpFreq =',
312     & ' /* Frequency^-1 for snapshot output (s) */')
313 jmc 1.34 CALL WRITE_0D_RL(PTRACERS_taveFreq, INDEX_NONE,
314 jmc 1.12 & 'PTRACERS_taveFreq =',
315     & ' /* Frequency^-1 for time-Aver. output (s) */')
316     CALL WRITE_0D_L( PTRACERS_useRecords, INDEX_NONE,
317     & 'PTRACERS_useRecords =', ' /* all tracers in 1 file */')
318 jmc 1.25
319 edhill 1.20 CALL WRITE_0D_L( PTRACERS_timeave_mnc, INDEX_NONE,
320     & 'PTRACERS_timeave_mnc =',
321     & ' /* use MNC for Tave output */')
322     CALL WRITE_0D_L( PTRACERS_snapshot_mnc, INDEX_NONE,
323     & 'PTRACERS_snapshot_mnc =',
324     & ' /* use MNC for snapshot output */')
325     CALL WRITE_0D_L( PTRACERS_pickup_write_mnc, INDEX_NONE,
326 jmc 1.25 & 'PTRACERS_pickup_write_mnc =',
327 edhill 1.20 & ' /* use MNC for writing pickups */')
328     CALL WRITE_0D_L( PTRACERS_pickup_read_mnc, INDEX_NONE,
329 jmc 1.25 & 'PTRACERS_pickup_read_mnc =',
330 edhill 1.20 & ' /* use MNC for reading pickups */')
331 jmc 1.12
332     DO iTracer=1,PTRACERS_numInUse
333     WRITE(msgBuf,'(A)') ' -----------------------------------'
334 jmc 1.25 CALL PRINT_MESSAGE( msgBuf, iUnit, SQUEEZE_RIGHT, myThid )
335 jmc 1.12 WRITE(msgBuf,'(A,I4)') ' tracer number : ',iTracer
336 jmc 1.25 CALL PRINT_MESSAGE( msgBuf, iUnit, SQUEEZE_RIGHT, myThid )
337 jmc 1.28 CALL WRITE_0D_C( PTRACERS_ioLabel(iTracer), 0, INDEX_NONE,
338     & 'PTRACERS_ioLabel =', ' /* tracer IO Label */')
339 jmc 1.12 CALL WRITE_0D_I( PTRACERS_advScheme(iTracer), INDEX_NONE,
340     & 'PTRACERS_advScheme =', ' /* Advection Scheme */')
341 jmc 1.15 CALL WRITE_0D_L( PTRACERS_ImplVertAdv(iTracer), INDEX_NONE,
342     & 'PTRACERS_ImplVertAdv =',
343     & ' /* implicit vert. advection flag */')
344 jmc 1.34 CALL WRITE_0D_RL( PTRACERS_diffKh(iTracer), INDEX_NONE,
345 jmc 1.12 & 'PTRACERS_diffKh =', ' /* Laplacian Diffusivity */')
346 jmc 1.34 CALL WRITE_0D_RL( PTRACERS_diffK4(iTracer), INDEX_NONE,
347 jmc 1.12 & 'PTRACERS_diffK4 =', ' /* Biharmonic Diffusivity */')
348 jmc 1.34 CALL WRITE_1D_RL( PTRACERS_diffKrNr(1,iTracer), Nr, INDEX_K,
349 jmc 1.12 & 'PTRACERS_diffKrNr =', ' /* Vertical Diffusivity */')
350     CALL WRITE_0D_L( PTRACERS_useGMRedi(iTracer), INDEX_NONE,
351     & 'PTRACERS_useGMRedi =', ' /* apply GM-Redi */')
352 jmc 1.31 CALL WRITE_0D_L( PTRACERS_useDWNSLP(iTracer), INDEX_NONE,
353     & 'PTRACERS_useDWNSLP =', ' /* apply DOWN-SLOPE Flow */')
354 jmc 1.12 CALL WRITE_0D_L( PTRACERS_useKPP(iTracer), INDEX_NONE,
355     & 'PTRACERS_useKPP =', ' /* apply KPP scheme */')
356 jmc 1.34 CALL WRITE_1D_RL( PTRACERS_ref(1,iTracer), Nr, INDEX_K,
357 jmc 1.24 & 'PTRACERS_ref =', ' /* Reference vertical profile */')
358 jmc 1.34 CALL WRITE_0D_RL( PTRACERS_EvPrRn(iTracer), INDEX_NONE,
359 jmc 1.24 & 'PTRACERS_EvPrRn =', '/* tracer conc. in Evap. & Rain */')
360 jmc 1.12
361     ENDDO
362     WRITE(msgBuf,'(A)') ' -----------------------------------'
363 jmc 1.25 CALL PRINT_MESSAGE( msgBuf, iUnit, SQUEEZE_RIGHT, myThid )
364    
365     _END_MASTER(myThid)
366     C Everyone else must wait for the parameters to be loaded
367     _BARRIER
368    
369 adcroft 1.1 #endif /* ALLOW_PTRACERS */
370    
371     RETURN
372     END

  ViewVC Help
Powered by ViewVC 1.1.22