-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathchemrxn.f
98 lines (93 loc) · 3 KB
/
chemrxn.f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
subroutine chemrxn(igrd)
c
c-----CAMx v4.02 030709
c
c CHEMRXN passes arrays from common decks to CHEMDRIV
c
c Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003
c ENVIRON International Corporation
c
c Modifications:
c none
c
c Input arguments:
c igrd grid index
c
c Output arguments:
c none
c
c Routines called:
c CHEMDRIV
c MASSUM
c
c Called by:
c CAMx
c NESTING
c
include 'camx.prm'
include 'camx.com'
include 'camxfld.com'
include 'grid.com'
include 'flags.com'
include 'filunit.com'
include 'chmstry.com'
real masschem(nspec), masspart(nspec)
c
c======================== Process Analysis Begin ====================================
c
include "procan.com"
c
c========================= Process Analysis End =====================================
c
c
c-----Entry point
c
call massum(igrd,nspec,ncol(igrd),nrow(igrd),nlay(igrd),
& deltax(1,igrd),deltay(igrd),depth(iptr3d(igrd)),
& conc(iptr4d(igrd)),xmstmp(1,igrd))
c
if (lchem) then
write(*,'(a20,$)') 'chemdriv ......'
write(iout,'(a20,$)') 'chemdriv ......'
do l = 1,nspec
masschem(l) = 0
masspart(l) = 0
enddo
call chemdriv(igrd,ncol(igrd),nrow(igrd),nlay(igrd),
& deltat(igrd),itzon,idfin(iptr2d(igrd)),
& fcloud(iptr3d(igrd)),cldtrns(iptr3d(igrd)),
& water(iptr3d(igrd)),tempk(iptr3d(igrd)),
& press(iptr3d(igrd)),height(iptr3d(igrd)),
& cwc(iptr3d(igrd)),
& conc(iptr4d(igrd)),cncrad(iptrad(igrd)),
& cellat(iptr2d(igrd)),cellon(iptr2d(igrd)),
& ldark(iptr2d(igrd)),l3davg,
$ iptr2d(igrd),
& ipsa3d(igrd),ipacl_3d(iptr3d(igrd)),
& masschem,masspart, deltax(1,igrd), !<- BNM 6/30/09
& deltay(igrd), depth(iptr3d(igrd)) ) !<- BNM 6/2/09
tcpu = dtime(tarray2)
write(*,'(a,f10.3)') ' CPU = ', tarray2(1)
write(iout,'(a,f10.3)') ' CPU = ', tarray2(1)
call flush(6)
call flush(iout)
endif
c
call massum(igrd,nspec,ncol(igrd),nrow(igrd),nlay(igrd),
& deltax(1,igrd),deltay(igrd),depth(iptr3d(igrd)),
& conc(iptr4d(igrd)),xmass(1,igrd))
c
do l = 1,nspec
xmschem(l,igrd) = xmschem(l,igrd) + xmass(l,igrd) -
& xmstmp(l,igrd)
xmsjustchem(l,igrd) = xmsjustchem(l,igrd) + masschem(l)
xmspart(l,igrd) = xmspart(l,igrd) + masspart(l)
CDEBUG
c print '(A9,I3,6(2x,E10.3),2x,4(2x,E10.3))','CHEMRXN: ',l,xmsjustchem(l,igrd),xmspart(l,igrd),
c & xmsjustchem(l,igrd)+xmspart(l,igrd),xmschem(l,igrd),
c & (xmsjustchem(l,igrd)+xmspart(l,igrd))/xmschem(l,igrd),xmspart(l,igrd)/xmschem(l,igrd),
c & masschem(l), masspart(l), masschem(l)+masspart(l),xmass(l,igrd)-xmstmp(l,igrd)
enddo
c
return
end