6 SUBROUTINE diagedyn(tit,iprt,idiag,idiag2,dtime
7 e , ucov , vcov , ps, p ,pk , teta , q, ql)
59 #include "dimensions.h"
71 REAL,
PARAMETER :: RCPD=
72 & 3.5*(1000.*(6.0221367e+23*1.380658e-23)/28.9644)
73 REAL,
PARAMETER :: RCPV=
74 & 4.*(1000.*(6.0221367e+23*1.380658e-23)/18.0153)
75 REAL,
PARAMETER :: RCS=rcpv
76 REAL,
PARAMETER :: RCW=rcpv
77 REAL,
PARAMETER :: RLSTT=2.8345e+6
78 REAL,
PARAMETER :: RLVTT=2.5008e+6
85 INTEGER iprt,idiag, idiag2
97 REAL d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec
101 REAL h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot
102 . , h_qs_tot, qw_tot, ql_tot, qs_tot , ec_tot
120 REAL zairm(imjmp1,
llm)
121 REAL zecin(imjmp1,
llm)
122 REAL zpaprs(imjmp1,
llm)
134 REAL zh_dair_col(imjmp1)
135 REAL zh_qw_col(imjmp1), zh_ql_col(imjmp1), zh_qs_col(imjmp1)
137 REAL d_h_dair, d_h_qw, d_h_ql, d_h_qs
139 REAL airetot, zcpvap, zcwat, zcice
141 INTEGER i, k, jj, ij , l ,ip1jjm1
149 REAL h_vcol_pre(ndiag), h_dair_pre(ndiag), h_qw_pre(ndiag)
150 $ , h_ql_pre(ndiag), h_qs_pre(ndiag), qw_pre(ndiag)
151 $ , ql_pre(ndiag), qs_pre(ndiag) , ec_pre(ndiag)
152 SAVE h_vcol_pre, h_dair_pre, h_qw_pre, h_ql_pre
153 $ , h_qs_pre, qw_pre, ql_pre, qs_pre , ec_pre
161 CALL covcont (
llm , ucov , vcov , ucont, vcont )
162 CALL enercin ( vcov , ucov , vcont , ucont , ecin )
167 print*,
'MAIS POURQUOI DONC DIAGEDYN NE MARCHE PAS ?'
174 zaire(i)=
aire(ij+ip1jjm1)
175 zps(i)=ps(ij+ip1jjm1)
184 zairm(i,l) = masse(ij+ip1jjm1,l)
185 zecin(i,l) = ecin(ij+ip1jjm1,l)
186 zpaprs(i,l) = p(ij+ip1jjm1,l)
187 zpk(i,l) = pk(ij+ip1jjm1,l)
188 zh(i,l) = teta(ij+ip1jjm1,l)
189 zqw(i,l) = q(ij+ip1jjm1,l)
190 zql(i,l) = ql(ij+ip1jjm1,l)
217 zqw_col(i) = zqw_col(i) + zqw(i,k)*zairm(i,k)
218 zql_col(i) = zql_col(i) + zql(i,k)*zairm(i,k)
219 zqs_col(i) = zqs_col(i) + zqs(i,k)*zairm(i,k)
221 zec_col(i) = zec_col(i)
222 $ +zecin(i,k)*zairm(i,k)
224 zt(i,k)= zh(i,k) * zpk(i,k) / rcpd
225 zh_dair_col(i) = zh_dair_col(i)
226 $ + rcpd*(1.-zqw(i,k)-zql(i,k)-zqs(i,k))*zairm(i,k)*zt(i,k)
227 zh_qw_col(i) = zh_qw_col(i)
228 $ + zcpvap*zqw(i,k)*zairm(i,k)*zt(i,k)
229 zh_ql_col(i) = zh_ql_col(i)
230 $ + zcwat*zql(i,k)*zairm(i,k)*zt(i,k)
231 $ - rlvtt*zql(i,k)*zairm(i,k)
232 zh_qs_col(i) = zh_qs_col(i)
233 $ + zcice*zqs(i,k)*zairm(i,k)*zt(i,k)
234 $ - rlstt*zqs(i,k)*zairm(i,k)
253 qw_tot = qw_tot + zqw_col(i)
254 ql_tot = ql_tot + zql_col(i)
255 qs_tot = qs_tot + zqs_col(i)
256 ec_tot = ec_tot + zec_col(i)
257 h_dair_tot = h_dair_tot + zh_dair_col(i)
258 h_qw_tot = h_qw_tot + zh_qw_col(i)
259 h_ql_tot = h_ql_tot + zh_ql_col(i)
260 h_qs_tot = h_qs_tot + zh_qs_col(i)
261 airetot=airetot+zaire(i)
264 qw_tot = qw_tot/airetot
265 ql_tot = ql_tot/airetot
266 qs_tot = qs_tot/airetot
267 ec_tot = ec_tot/airetot
268 h_dair_tot = h_dair_tot/airetot
269 h_qw_tot = h_qw_tot/airetot
270 h_ql_tot = h_ql_tot/airetot
271 h_qs_tot = h_qs_tot/airetot
273 h_vcol_tot = h_dair_tot+h_qw_tot+h_ql_tot+h_qs_tot
281 IF ( (idiag2.gt.0) .and. (pas(idiag2) .ne. 0) )
THEN
282 d_h_vcol = (h_vcol_tot - h_vcol_pre(idiag2) )/dtime
283 d_h_dair = (h_dair_tot- h_dair_pre(idiag2))/dtime
284 d_h_qw = (h_qw_tot - h_qw_pre(idiag2) )/dtime
285 d_h_ql = (h_ql_tot - h_ql_pre(idiag2) )/dtime
286 d_h_qs = (h_qs_tot - h_qs_pre(idiag2) )/dtime
287 d_qw = (qw_tot - qw_pre(idiag2) )/dtime
288 d_ql = (ql_tot - ql_pre(idiag2) )/dtime
289 d_qs = (qs_tot - qs_pre(idiag2) )/dtime
290 d_ec = (ec_tot - ec_pre(idiag2) )/dtime
291 d_qt = d_qw + d_ql + d_qs
306 WRITE(6,9000) tit,pas(idiag),d_qt,d_qw,d_ql,d_qs
307 9000
format(
'Dyn3d. Watter Mass Budget (kg/m2/s)',a15
309 WRITE(6,9001) tit,pas(idiag), d_h_vcol
310 9001
format(
'Dyn3d. Enthalpy Budget (W/m2) ',a15,1i6,10(f8.2))
311 WRITE(6,9002) tit,pas(idiag), d_ec
312 9002
format(
'Dyn3d. Cinetic Energy Budget (W/m2) ',a15,1i6,10(f8.2))
314 9003
format(
'Dyn3d. Cinetic Energy (W/m2) ',a15,1i6,10(e15.6))
315 WRITE(6,9004) tit,pas(idiag), d_h_vcol+d_ec
316 9004
format(
'Dyn3d. Total Energy Budget (W/m2) ',a15,1i6,10(f8.2))
321 pas(idiag)=pas(idiag)+1
322 h_vcol_pre(idiag) = h_vcol_tot
323 h_dair_pre(idiag) = h_dair_tot
324 h_qw_pre(idiag) = h_qw_tot
325 h_ql_pre(idiag) = h_ql_tot
326 h_qs_pre(idiag) = h_qs_tot
327 qw_pre(idiag) = qw_tot
328 ql_pre(idiag) = ql_tot
329 qs_pre(idiag) = qs_tot
330 ec_pre(idiag) = ec_tot
334 write(
lunout,*)
'diagedyn: set to function with Earth parameters'
subroutine diagedyn(tit, iprt, idiag, idiag2, dtime, ucov, vcov, ps, p, pk, teta, q, ql)
!$Header llmm1 INTEGER ip1jmp1
subroutine covcont(klevel, ucov, vcov, ucont, vcont)
character(len=10), save planet_type
!$Id Turb_fcg_gcssold get_uvd hqturb_gcssold endif!large scale llm day day1 day day1 *dt_toga endif!time annee_ref dt_toga u_toga vq_toga w_prof vq_prof llm day day1 day day1 *dt_dice endif!time annee_ref dt_dice swup_dice vg_dice omega_dice tg_prof vg_profd w_profd omega_profd!do llm!print llm l llm
!$Header!CDK comgeom COMMON comgeom aire
!$Header llmm1 INTEGER ip1jm
!$Header!integer nvarmx parameter(nfmx=10, imx=200, jmx=150, lmx=200, nvarmx=1000) real xd(imx
c c zjulian c cym CALL iim cym klev iim
subroutine massdair(p, masse)
subroutine enercin(vcov, ucov, vcont, ucont, ecin)
!$Header!gestion des impressions de sorties et de débogage la sortie standard prt_level COMMON comprint lunout