forked from ESCOMP/CARMA_base
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcsolve.F90
57 lines (46 loc) · 1.88 KB
/
csolve.F90
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
#include "carma_globaer.h"
!! This routine calculates new particle concentrations from coagulation
!! microphysical processes.
!!
!! The basic form from which the solution is derived is:
!!
!! ( new_value - old_value ) / dtime = source_term - loss_rate*new_value
!!
!! This routine derived from psolve.f code, in which particle concentrations
!! due to coagulation were formerly included, before the relatively slow
!! coagulation calcs were separated from the other microphysical processes
!! so that time splitting could be applied to these fast & slow calcs.
!!
!! @author Bill McKie
!! @version Sep-1997
subroutine csolve(carma, cstate, ibin, ielem, rc)
! types
use carma_precision_mod
use carma_enums_mod
use carma_constants_mod
use carma_types_mod
use carmastate_mod
use carma_mod
implicit none
type(carma_type), intent(in) :: carma !! the carma object
type(carmastate_type), intent(inout) :: cstate !! the carma state object
integer, intent(in) :: ibin !! bin index
integer, intent(in) :: ielem !! element index
integer, intent(inout) :: rc !! return code, negative indicates failure
! Local Variables
integer :: igroup
real(kind=f) :: ppd(NZ)
real(kind=f) :: pls(NZ)
! Define current group & particle number concentration element indices
igroup = igelem(ielem) ! particle group
! Compute total production rate due to coagulation
ppd = coagpe(:,ibin,ielem) / zmet(:)
! Compute total loss rate due to coagulation
pls = coaglg(:,ibin,igroup) / zmet(:)
! Update net particle number concentration during current timestep
! due to production and loss rates for coagulation
pc(:,ibin,ielem) = ( pc(:,ibin,ielem) &
+ dtime * ppd(:) ) &
/ ( ONE + pls(:) * dtime )
return
end