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