1 | |
---|
2 | ! $Id: $ |
---|
3 | |
---|
4 | MODULE infotrac_phy |
---|
5 | |
---|
6 | ! Infotrac for physics; contains the same information as infotrac for |
---|
7 | ! the dynamics |
---|
8 | IMPLICIT NONE |
---|
9 | |
---|
10 | ! iflag_trac: ==1 if running with tracers |
---|
11 | INTEGER,SAVE :: iflag_trac |
---|
12 | !$OMP THREADPRIVATE(iflag_trac) |
---|
13 | |
---|
14 | ! nqtot : total number of tracers |
---|
15 | INTEGER,SAVE :: nqtot |
---|
16 | !$OMP THREADPRIVATE(nqtot) |
---|
17 | |
---|
18 | ! tracer names |
---|
19 | CHARACTER(len=30),ALLOCATABLE,DIMENSION(:),SAVE :: tname |
---|
20 | CHARACTER(len=33),ALLOCATABLE,DIMENSION(:),SAVE :: ttext ! tracer long name for diagnostics |
---|
21 | !$OMP THREADPRIVATE(tname,ttext) |
---|
22 | |
---|
23 | CONTAINS |
---|
24 | |
---|
25 | SUBROUTINE init_infotrac_phy(iflag_trac_,nqtot_,tname_,ttext_) |
---|
26 | ! Initialize module variables |
---|
27 | |
---|
28 | USE print_control_mod, ONLY: lunout |
---|
29 | IMPLICIT NONE |
---|
30 | |
---|
31 | INTEGER,INTENT(IN) :: iflag_trac_ ! ==1 if running with tracers |
---|
32 | INTEGER,INTENT(IN) :: nqtot_ ! total number of tracers |
---|
33 | CHARACTER(LEN=*),INTENT(IN) :: tname_(nqtot_) |
---|
34 | CHARACTER(LEN=*),INTENT(IN) :: ttext_(nqtot_) |
---|
35 | |
---|
36 | INTEGER :: iq |
---|
37 | CHARACTER(LEN=30) :: modname="init_infotrac_phy" |
---|
38 | CHARACTER(LEN=50) :: abort_message |
---|
39 | |
---|
40 | iflag_trac=iflag_trac_ |
---|
41 | nqtot=nqtot_ |
---|
42 | |
---|
43 | ALLOCATE(tname(nqtot)) |
---|
44 | ALLOCATE(ttext(nqtot)) |
---|
45 | DO iq=1,nqtot |
---|
46 | if (len_trim(tname_(iq)).gt.len(tname(iq))) then |
---|
47 | abort_message="init_infotrac_phy error; tname_() too long!" |
---|
48 | call abort_physic(modname,abort_message,1) |
---|
49 | endif |
---|
50 | tname(iq)=tname_(iq) |
---|
51 | ttext(iq)=ttext_(iq) |
---|
52 | ENDDO |
---|
53 | |
---|
54 | END SUBROUTINE init_infotrac_phy |
---|
55 | |
---|
56 | END MODULE infotrac_phy |
---|