72 & LBi, UBi, LBj, UBj, &
73 & IminS, ImaxS, JminS, JmaxS, &
77 & ad_Hz, ad_z_r, ad_z_w, &
78 & ad_rho, ad_u, ad_v, &
80 & ad_ubar, ad_vbar, ad_zeta)
97 integer,
intent(in) :: ng, tile
98 integer,
intent(in) :: LBi, UBi, LBj, UBj
99 integer,
intent(in) :: IminS, ImaxS, JminS, JmaxS
100 integer,
intent(in) :: nstp, kstp
103 real(r8),
intent(in) :: h(LBi:,LBj:)
104 real(r8),
intent(in) :: omn(LBi:,LBj:)
106 real(r8),
intent(in) :: ad_Hz(LBi:,LBj:,:)
107 real(r8),
intent(in) :: ad_z_r(LBi:,LBj:,:)
108 real(r8),
intent(in) :: ad_z_w(LBi:,LBj:,0:)
109 real(r8),
intent(in) :: ad_rho(LBi:,LBj:,:)
110 real(r8),
intent(in) :: ad_u(LBi:,LBj:,:,:)
111 real(r8),
intent(in) :: ad_v(LBi:,LBj:,:,:)
113 real(r8),
intent(in) :: ad_ubar(LBi:,LBj:,:)
114 real(r8),
intent(in) :: ad_vbar(LBi:,LBj:,:)
115 real(r8),
intent(in) :: ad_zeta(LBi:,LBj:,:)
117 real(r8),
intent(in) :: h(LBi:UBi,LBj:UBj)
118 real(r8),
intent(in) :: omn(LBi:UBi,LBj:UBj)
120 real(r8),
intent(in) :: ad_Hz(LBi:UBi,LBj:UBj,N(ng))
121 real(r8),
intent(in) :: ad_z_r(LBi:UBi,LBj:UBj,N(ng))
122 real(r8),
intent(in) :: ad_z_w(LBi:UBi,LBj:UBj,0:N(ng))
123 real(r8),
intent(in) :: ad_rho(LBi:UBi,LBj:UBj,N(ng))
124 real(r8),
intent(in) :: ad_u(LBi:UBi,LBj:UBj,N(ng),2)
125 real(r8),
intent(in) :: ad_v(LBi:UBi,LBj:UBj,N(ng),2)
127 real(r8),
intent(in) :: ad_ubar(LBi:UBi,LBj:UBj,:)
128 real(r8),
intent(in) :: ad_vbar(LBi:UBi,LBj:UBj,:)
129 real(r8),
intent(in) :: ad_zeta(LBi:UBi,LBj:UBj,:)
134 integer :: NSUB, i, j, k, trd
135 integer :: idia, istep
138 real(r8),
dimension(3) :: rbuffer
139 character (len=3),
dimension(3) :: op_handle
141 integer :: my_threadnum
144 real(r8) :: cff, my_avgke, my_avgpe, my_volume
146 real(r8),
dimension(IminS:ImaxS,JminS:JmaxS) :: ke2d
147 real(r8),
dimension(IminS:ImaxS,JminS:JmaxS) :: pe2d
149 character (len=8 ) :: kechar, pechar
150 character (len=22) :: DateTime
152# include "set_bounds.h"
156 ke2d(imins:imaxs,jmins:jmaxs)=0.0_r8
157 pe2d(imins:imaxs,jmins:jmaxs)=0.0_r8
168 istep=int(mod(real(
iic(ng)-1,r8),1.0e+10_r8))
178 IF (mod(istep,
ninfo(ng)).eq.0)
THEN
182 pe2d(i,j)=0.5_r8*
g*ad_z_w(i,j,n(ng))*ad_z_w(i,j,n(ng))
187 ke2d(i,j)=ke2d(i,j)+ &
189 & 0.25_r8*(ad_u(i ,j,k,idia)*ad_u(i ,j,k,idia)+ &
190 & ad_u(i+1,j,k,idia)*ad_u(i+1,j,k,idia)+ &
191 & ad_v(i,j ,k,idia)*ad_v(i,j ,k,idia)+ &
192 & ad_v(i,j+1,k,idia)*ad_v(i,j+1,k,idia))
193 pe2d(i,j)=pe2d(i,j)+ &
194 & cff*ad_hz(i,j,k)*(ad_rho(i,j,k)+1000.0_r8)* &
195 & (ad_z_r(i,j,k)-ad_z_w(i,j,0))
201 ke2d(i,j)=(ad_zeta(i,j,idia)+h(i,j))* &
202 & 0.25_r8*(ad_ubar(i ,j,idia)*ad_ubar(i ,j,idia)+ &
203 & ad_ubar(i+1,j,idia)*ad_ubar(i+1,j,idia)+ &
204 & ad_vbar(i,j ,idia)*ad_vbar(i,j ,idia)+ &
205 & ad_vbar(i,j+1,idia)*ad_vbar(i,j+1,idia))
206 pe2d(i,j)=cff*ad_zeta(i,j,idia)*ad_zeta(i,j,idia)
228 pe2d(i,jend+1)=pe2d(i,jend+1)+omn(i,j)*h(i,j)
229 pe2d(i,jstr-1)=pe2d(i,jstr-1)+omn(i,j)*pe2d(i,j)
230 ke2d(i,jstr-1)=ke2d(i,jstr-1)+omn(i,j)*ke2d(i,j)
237 my_volume=my_volume+pe2d(i,jend+1)
238 my_avgpe =my_avgpe +pe2d(i,jstr-1)
239 my_avgke =my_avgke +ke2d(i,jstr-1)
251 IF (
domain(ng)%SouthWest_Corner(tile).and. &
252 &
domain(ng)%NorthEast_Corner(tile))
THEN
293 IF (
master.and.(ng.eq.1))
THEN
294 WRITE (
stdout,10)
'TIME-STEP',
'YYYY-MM-DD hh:mm:ss.ss', &
295 &
'KINETIC_ENRG',
'POTEN_ENRG', &
297 &
'TOTAL_ENRG',
'NET_VOLUME',
'Grid'
299 &
'TOTAL_ENRG',
'NET_VOLUME'
302 10
FORMAT (/,1x,a,1x,a,2x,a,3x,a,4x,a,4x,a,2x,a)
304 10
FORMAT (/,1x,a,1x,a,2x,a,3x,a,4x,a,4x,a)
310 WRITE (
stdout,20) istep, datetime, &
317 20
FORMAT (i10,1x,a,4(1pe14.6),2x,i2.2)
319 20
FORMAT (i10,1x,a,4(1pe14.6))
326 WRITE (kechar,
'(1pe8.1)')
avgke
327 WRITE (pechar,
'(1pe8.1)')
avgpe
329 IF ((kechar(i:i).eq.
'N').or.(pechar(i:i).eq.
'N').or. &
330 & (kechar(i:i).eq.
'n').or.(pechar(i:i).eq.
'n').or. &
331 & (kechar(i:i).eq.
'*').or.(pechar(i:i).eq.
'*'))
THEN
subroutine ad_diag_tile(ng, tile, lbi, ubi, lbj, ubj, imins, imaxs, jmins, jmaxs, nstp, kstp, h, omn, ad_hz, ad_z_r, ad_z_w, ad_rho, ad_u, ad_v, ad_ubar, ad_vbar, ad_zeta)