forked from ESCOMP/CARMA_base
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcoremasscheck.F90
89 lines (73 loc) · 3.1 KB
/
coremasscheck.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
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
! Include shortname defintions, so that the F77 code does not have to be modified to
! reference the CARMA structure.
#include "carma_globaer.h"
!! This routine checks if the coremass exceeds the total.
!!
!! NOTE: The fixer in this case is not mass conserving, and thus can have
!! the effect of creating mass of the concentration element (by removing
!! the negative values).
!!
!! NOTE: Errors will only be logged and runs aborted if they are greater
!! than roundoff error.
!!
!! @author Yunqian Zhu, Charles Bardeen
!! @version Apr-2021
subroutine coremasscheck(carma, cstate, iz, fixcoremass,logmsg,abort, packagename, 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(inout) :: carma !! the carma object
type(carmastate_type), intent(inout) :: cstate !! the carma state object
integer, intent(in) :: iz
logical, intent(in) :: fixcoremass !! if we fix the coremass if exceeds total
logical, intent(in) :: logmsg !! write message to log file if core mass check fails
logical, intent(in) :: abort !! set return code to ERROR and return if if core mass check fails
character(len=*), intent(in) :: packagename !! string to add to error message
integer, intent(inout) :: rc !! return code, negative
! Local declarations
integer :: igroup,ibin
integer :: iepart,i,icore
real(kind=f) :: coremass
real(kind=f) :: factor
real(kind=f),parameter :: roundoff = 1.e-14_f
! check the coremass exceeding the total mass
do igroup = 1,NGROUP
! Only check groups that have coremasses
if (ncore(igroup) > 0) then
iepart = ienconc(igroup)
do ibin = 1,NBIN
if (pc(iz, ibin, iepart) > 0._f) then
coremass = 0._f
do i = 1, ncore(igroup)
icore = icorelem(i,igroup)
coremass = coremass + pc(iz, ibin, icore)
end do ! i = 1, ncore(igroup)
if (coremass > pc(iz, ibin, iepart) * rmass(ibin, igroup)) then
if (((coremass - pc(iz, ibin, iepart) * rmass(ibin, igroup)) / coremass) .gt. roundoff) then
if (logmsg) then
write(LUNOPRT,*) "Error - coremass exceeds total: ",packagename
write(LUNOPRT,*) "coremass",coremass,"total",pc(iz, ibin, iepart) * rmass(ibin, igroup)
end if
if (abort) then
rc = RC_ERROR
return
end if
! Only fix large errors if requested.
if (fixcoremass) then
pc(iz, ibin, iepart) = coremass / rmass(ibin, igroup)
endif
! Automatically fix roundoff sized errors, regardless of settings.
else
pc(iz, ibin, iepart) = coremass / rmass(ibin, igroup)
end if
end if
end if
end do
end if
end do
end subroutine coremasscheck