/[MITgcm]/MITgcm/pkg/generic_advdiff/gad_init.F
ViewVC logotype

Contents of /MITgcm/pkg/generic_advdiff/gad_init.F

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


Revision 1.1 - (show annotations) (download)
Sat Jun 15 03:31:17 2002 UTC (21 years, 11 months ago) by jmc
Branch: MAIN
for each tracer, define an internal flag for multiDimAdvection & A-B

1 C $Header: $
2 C $Name: $
3
4 #include "GAD_OPTIONS.h"
5
6 CBOP
7 C !ROUTINE: GAD_INIT
8 C !INTERFACE:
9 SUBROUTINE GAD_INIT( myThid )
10 C !DESCRIPTION: \bv
11 C *==========================================================*
12 C | SUBROUTINE GAD_INIT
13 C | o Routine to initialize Generic Advection / Diffusion
14 C | variables and constants.
15 C *==========================================================*
16 C \ev
17
18 C !USES:
19 IMPLICIT NONE
20
21 C === Global variables ===
22 #include "SIZE.h"
23 #include "EEPARAMS.h"
24 #include "PARAMS.h"
25 #include "GAD.h"
26
27 C !INPUT/OUTPUT PARAMETERS:
28 C === Routine arguments ===
29 C myThid - Number of this instance of GAD_INIT
30 INTEGER myThid
31
32 CEOP
33
34 C === Local variables ===
35 C msgBuf - Informational/error meesage buffer
36 CHARACTER*(MAX_LEN_MBUF) msgBuf
37
38 C---+----1----+----2----+----3----+----4----+----5----+----6----+----7-|--+----|
39
40 C-- Set Temp & Salt muti-Dim Advec. flag according to advection scheme used
41 tempMultiDimAdvec = multiDimAdvection
42 saltMultiDimAdvec = multiDimAdvection
43 IF ( tempAdvScheme.EQ.ENUM_CENTERED_2ND
44 & .OR.tempAdvScheme.EQ.ENUM_UPWIND_3RD
45 & .OR.tempAdvScheme.EQ.ENUM_CENTERED_4TH ) THEN
46 tempMultiDimAdvec = .FALSE.
47 ENDIF
48 IF ( saltAdvScheme.EQ.ENUM_CENTERED_2ND
49 & .OR.saltAdvScheme.EQ.ENUM_UPWIND_3RD
50 & .OR.saltAdvScheme.EQ.ENUM_CENTERED_4TH ) THEN
51 saltMultiDimAdvec = .FALSE.
52 ENDIF
53
54 C-- Set Temp & Salt Adams-Bashforth flag according to advection scheme used
55 tempAdamsBashforth = .FALSE.
56 saltAdamsBashforth = .FALSE.
57 IF ( tempAdvScheme.EQ.ENUM_CENTERED_2ND
58 & .OR.tempAdvScheme.EQ.ENUM_UPWIND_3RD
59 & .OR.tempAdvScheme.EQ.ENUM_CENTERED_4TH ) THEN
60 tempAdamsBashforth = .TRUE.
61 ENDIF
62 IF ( saltAdvScheme.EQ.ENUM_CENTERED_2ND
63 & .OR.saltAdvScheme.EQ.ENUM_UPWIND_3RD
64 & .OR.saltAdvScheme.EQ.ENUM_CENTERED_4TH ) THEN
65 saltAdamsBashforth = .TRUE.
66 ENDIF
67
68 #ifdef ALLOW_PASSIVE_TRACER
69 tr1_MultiDimAdvec = multiDimAdvection
70 tr1_AdamsBashforth = .FALSE.
71 IF ( tracerAdvScheme.EQ.ENUM_CENTERED_2ND
72 & .OR.tracerAdvScheme.EQ.ENUM_UPWIND_3RD
73 & .OR.tracerAdvScheme.EQ.ENUM_CENTERED_4TH ) THEN
74 tr1_MultiDimAdvec = .FALSE.
75 tr1_AdamsBashforth = .TRUE.
76 ENDIF
77 #endif
78
79 C---+----1----+----2----+----3----+----4----+----5----+----6----+----7-|--+----|
80
81 C-- Print out GAD parameters :
82 _BARRIER
83 _BEGIN_MASTER(myThid)
84
85 WRITE(msgBuf,'(A)') ' '
86 CALL PRINT_MESSAGE(msgBuf,standardMessageUnit,SQUEEZE_RIGHT,1)
87 WRITE(msgBuf,'(A)') '// ==================================='
88 CALL PRINT_MESSAGE(msgBuf,standardMessageUnit,SQUEEZE_RIGHT,1)
89 WRITE(msgBuf,'(A)')'// GAD parameters :'
90 CALL PRINT_MESSAGE(msgBuf,standardMessageUnit,SQUEEZE_RIGHT,1)
91 WRITE(msgBuf,'(A)') '// ==================================='
92 CALL PRINT_MESSAGE(msgBuf,standardMessageUnit,SQUEEZE_RIGHT,1)
93
94 CALL WRITE_0D_I( tempAdvScheme, INDEX_NONE,
95 & 'tempAdvScheme =',
96 & ' /* Temp. advection scheme selector */')
97 CALL WRITE_0D_L( tempMultiDimAdvec, INDEX_NONE,
98 & 'tempMultiDimAdvec =',
99 & ' /* use Muti-Dim Advec method for Temp */')
100 CALL WRITE_0D_L( tempAdamsBashforth, INDEX_NONE,
101 & 'tempAdamsBashforth =',
102 & ' /* use Adams-Bashforth time-stepping for Temp */')
103
104 CALL WRITE_0D_I( saltAdvScheme, INDEX_NONE,
105 & 'saltAdvScheme =',
106 & ' /* Salt. advection scheme selector */')
107 CALL WRITE_0D_L( saltMultiDimAdvec, INDEX_NONE,
108 & 'saltMultiDimAdvec =',
109 & ' /* use Muti-Dim Advec method for Salt */')
110 CALL WRITE_0D_L( saltAdamsBashforth, INDEX_NONE,
111 & 'saltAdamsBashforth =',
112 & ' /* use Adams-Bashforth time-stepping for Salt */')
113
114 WRITE(msgBuf,'(A)') '// ==================================='
115 CALL PRINT_MESSAGE(msgBuf,standardMessageUnit,SQUEEZE_RIGHT,1)
116
117 _END_MASTER(myThid)
118 _BARRIER
119
120 RETURN
121 END

  ViewVC Help
Powered by ViewVC 1.1.22