forked from KuangLab-Harvard/SAM_SRCv6.11
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtask_boundaries.f90
118 lines (94 loc) · 3.41 KB
/
task_boundaries.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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
subroutine task_boundaries(flag)
! These routines exchanges overlaping information for various subdomains to
! be able to calculate various quantities in common /com3d/
! near the subdomain boundaries.
use vars
use microphysics
use sgs
use params, only: dotracers, dosgs, dowallx, dowally
use tracers
implicit none
integer i,j,k
integer flag
if(flag.eq.1) then
call task_exchange(u,dimx1_u,dimx2_u,dimy1_u,dimy2_u,nzm,2,3,2+NADV,2+NADV,1)
call task_exchange(v,dimx1_v,dimx2_v,dimy1_v,dimy2_v,nzm,2+NADV,2+NADV,2,3,2)
call task_exchange(w,dimx1_w,dimx2_w,dimy1_w,dimy2_w,nz,2+NADV,2+NADV,2+NADV,2+NADV,3)
if(dowallx) then
if(mod(rank,nsubdomains_x).eq.0) then
u(dimx1_u:1,:,1:nzm) = 0.
v(0,:,1:nzm) = v(1,:,1:nzm)
w(0,:,2:nzm) = w(1,:,2:nzm)
end if
if(mod(rank,nsubdomains_x).eq.nsubdomains_x-1) then
u(nx+1:dimx2_u,dimy1_u:dimy2_u,1:nzm) = 0.
v(nx+1,:,1:nzm) = v(nx,:,1:nzm)
w(nx+1,:,2:nzm) = w(nx,:,2:nzm)
end if
end if
if(dowally) then
if(rank.lt.nsubdomains_x) then
v(:,dimy1_v:1,1:nzm) = 0.
u(:,1-YES3D,1:nzm) = u(:,1,1:nzm)
w(:,1-YES3D,2:nzm) = w(:,1,2:nzm)
end if
if(rank.gt.nsubdomains-nsubdomains_x-1) then
v(:,ny+1:dimy2_v,1:nzm) = 0.
u(:,ny+YES3D,1:nzm) = u(:,ny,1:nzm)
w(:,ny+YES3D,2:nzm) = w(:,ny,2:nzm)
end if
end if
endif
if(flag.eq.2) then
call task_exchange(t,dimx1_s,dimx2_s,dimy1_s,dimy2_s,nzm,3+NADVS,3+NADVS,3+NADVS,3+NADVS,4)
do i = 1,nsgs_fields
if(dosgs.and.advect_sgs) &
call task_exchange(sgs_field(:,:,:,i),dimx1_s,dimx2_s,dimy1_s,dimy2_s,nzm, &
3+NADVS,3+NADVS,3+NADVS,3+NADVS,4+i)
end do
do i = 1,nmicro_fields
if( i.eq.index_water_vapor &
.or. docloud.and.flag_precip(i).ne.1 &
.or. doprecip.and.flag_precip(i).eq.1 ) then
if(flag_advect(i).eq.1) &
call task_exchange(micro_field(:,:,:,i),dimx1_s,dimx2_s,dimy1_s,dimy2_s,nzm, &
3+NADVS,3+NADVS,3+NADVS,3+NADVS,4+nsgs_fields+nsgs_fields_diag+i)
end if
end do
if(dotracers) then
do i=1,ntracers
call task_exchange(tracer(:,:,:,i),dimx1_s,dimx2_s,dimy1_s,dimy2_s,nzm, &
3+NADVS,3+NADVS,3+NADVS,3+NADVS,4+nsgs_fields+nsgs_fields_diag+nmicro_fields+i)
end do
end if
endif
if(flag.eq.3) then
call task_exchange(t,dimx1_s,dimx2_s,dimy1_s,dimy2_s,nzm,1,1,1,1,4)
do i = 1,nsgs_fields
if(dosgs.and.advect_sgs) &
call task_exchange(sgs_field(:,:,:,i),dimx1_s,dimx2_s,dimy1_s,dimy2_s,nzm,1,1,1,1,4+i)
end do
do i = 1,nmicro_fields
if( i.eq.index_water_vapor &
.or. docloud.and.flag_precip(i).ne.1 &
.or. doprecip.and.flag_precip(i).eq.1 ) then
if(flag_advect(i).eq.1) &
call task_exchange(micro_field(:,:,:,i),dimx1_s,dimx2_s,dimy1_s,dimy2_s,nzm, &
1,1,1,1,4+nsgs_fields+nsgs_fields_diag+i)
end if
end do
if(dotracers) then
do i=1,ntracers
call task_exchange(tracer(:,:,:,i),dimx1_s,dimx2_s,dimy1_s,dimy2_s,nzm, &
1,1,1,1,4+nsgs_fields+nsgs_fields_diag+nmicro_fields+i)
end do
end if
end if
if(flag.eq.4) then
do i = 1,nsgs_fields_diag
if(dosgs) &
call task_exchange(sgs_field_diag(:,:,:,i),dimx1_d,dimx2_d,dimy1_d,dimy2_d,nzm, &
1-dimx1_d,dimx2_d-nx,YES3D*(1-dimy1_d),1-YES3D+dimy2_d-ny,4+nsgs_fields+i)
end do
end if
end