80
81
84
85
86
87 integer, intent(in) :: ng, tile
88 integer, intent(in) :: LBi, UBi, LBj, UBj
89 integer, intent(in) :: IminS, ImaxS, JminS, JmaxS
90 integer, intent(in) :: nrhs, nnew
91
92# ifdef ASSUMED_SHAPE
93# ifdef MASKING
94 real(r8), intent(in) :: umask(LBi:,LBj:)
95 real(r8), intent(in) :: vmask(LBi:,LBj:)
96# endif
97 real(r8), intent(in) :: Hz(LBi:,LBj:,:)
98 real(r8), intent(in) :: pmon_u(LBi:,LBj:)
99 real(r8), intent(in) :: pnom_v(LBi:,LBj:)
100 real(r8), intent(in) :: pm(LBi:,LBj:)
101 real(r8), intent(in) :: pn(LBi:,LBj:)
102
103 real(r8), intent(inout) :: tl_t(LBi:,LBj:,:,:,:)
104# else
105# ifdef MASKING
106 real(r8), intent(in) :: umask(LBi:UBi,LBj:UBj)
107 real(r8), intent(in) :: vmask(LBi:UBi,LBj:UBj)
108# endif
109 real(r8), intent(in) :: Hz(LBi:UBi,LBj:UBj,N(ng))
110 real(r8), intent(in) :: pmon_u(LBi:UBi,LBj:UBj)
111 real(r8), intent(in) :: pnom_v(LBi:UBi,LBj:UBj)
112 real(r8), intent(in) :: pm(LBi:UBi,LBj:UBj)
113 real(r8), intent(in) :: pn(LBi:UBi,LBj:UBj)
114
115 real(r8), intent(inout) :: tl_t(LBi:UBi,LBj:UBj,N(ng),3,NT(ng))
116# endif
117
118
119
120 integer :: i, itrc, j, k
121
122 real(r8), dimension(IminS:ImaxS,JminS:JmaxS) :: FE
123 real(r8), dimension(IminS:ImaxS,JminS:JmaxS) :: FX
124
125# include "set_bounds.h"
126
127
128
129
130
131
132
133
134
135
136
137
139 IF (
tl_tdiff(itrc,ng).gt.0.0_r8)
THEN
141
142
143
144 DO j=jstr,jend
145 DO i=istr,iend+1
146 fx(i,j)=0.5_r8*
tl_tdiff(itrc,ng)*pmon_u(i,j)* &
147 & (hz(i,j,k)+hz(i-1,j,k))* &
148 & (tl_t(i ,j,k,nrhs,itrc)- &
149 & tl_t(i-1,j,k,nrhs,itrc))
150# ifdef MASKING
151 fx(i,j)=fx(i,j)*umask(i,j)
152# endif
153 END DO
154 END DO
155 DO j=jstr,jend+1
156 DO i=istr,iend
157 fe(i,j)=0.5_r8*
tl_tdiff(itrc,ng)*pnom_v(i,j)* &
158 & (hz(i,j,k)+hz(i,j-1,k))* &
159 & (tl_t(i,j ,k,nrhs,itrc)- &
160 & tl_t(i,j-1,k,nrhs,itrc))
161# ifdef MASKING
162 fe(i,j)=fe(i,j)*vmask(i,j)
163# endif
164 END DO
165 END DO
166
167
168
169 DO j=jstr,jend
170 DO i=istr,iend
171 tl_t(i,j,k,nnew,itrc)=tl_t(i,j,k,nnew,itrc)+ &
172 &
dt(ng)*pm(i,j)*pn(i,j)* &
173 & (fx(i+1,j)-fx(i,j)+ &
174 & fe(i,j+1)-fe(i,j))
175 END DO
176 END DO
177 END DO
178 END IF
179 END DO
180
181 RETURN
integer, dimension(:), allocatable n
integer, dimension(:), allocatable nt
real(r8), dimension(:,:), allocatable tl_tdiff
real(dp), dimension(:), allocatable dt