Ignore:
Timestamp:
Aug 7, 2013, 4:21:01 PM (11 years ago)
Author:
jleconte
Message:

07/08/2013 == JL

  • Water cycle in double precision (largescale+moistadj)
  • Improved wate rayleigh.
  • First step for rayleigh with variable species. Now, just need to change optcv.
  • changed some interpolation indices in callcorrk to limit dependency of OLR on the number of layers
Location:
trunk/LMDZ.GENERIC/libf/phystd
Files:
12 edited

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.GENERIC/libf/phystd/calc_rayleigh.F90

    r995 r1016  
    1313!     -------
    1414!     Robin Wordsworth (2010)
     15!     Jeremy Leconte (2012): Added option for variable gas. Improved water rayleigh (Bucholtz 1995).
    1516!
    1617!     Called by
     
    2526
    2627      use radinc_h, only: L_NSPECTV
    27       use radcommon_h, only: WAVEV, BWNV, DWNV, tstellar, tauray, scalep
     28      use radcommon_h, only: WAVEV, BWNV, DWNV, tstellar, tauray, taurayvar, scalep
    2829      use gases_h
    2930
     
    3940
    4041      logical typeknown
    41       real*8 tauvar,tausum,tauwei,bwidth,bstart
     42      real*8 tauvar,tauvarvar,tausum,tausumvar,tauwei,tauweivar,bwidth,bstart
    4243      double precision df
    4344
     
    5455      do igas=1,ngasmx
    5556         if(igas.eq.vgas)then
    56             print*,'Ignoring ',trim(gnom(igas)),' in Rayleigh scattering '// &
    57             'as it is variable.'
    58          elseif(gfrac(igas).lt.5.e-2)then
     57            print*,'variable gas is ',trim(gnom(igas)),' in Rayleigh scattering '
     58         endif
     59         if((igas/=vgas).and.(gfrac(igas).lt.5.e-2))then
    5960            print*,'Ignoring ',trim(gnom(igas)),' in Rayleigh scattering '// &
    6061            'as its mixing ratio is less than 0.05.'
     
    6869               tauconsti(igas) = (9.81/g)*8.569E-3*scalep/(P0/93.0)
    6970            elseif(igas.eq.igas_H2O)then
    70                tauconsti(igas) = (10.0/g)*9.22E-3*scalep/101325.0
     71!               tauconsti(igas) = (10.0/g)*9.22E-3*scalep/101325.0
     72               tauconsti(igas) = 1.98017E-10/(g*mugaz*100.)
    7173            elseif(igas.eq.igas_H2)then
    7274               tauconsti(igas) = (10.0/g)*0.0241*scalep/101325.0
     
    8385            endif
    8486
    85             if(gfrac(igas).eq.1.0)then
     87            if((gfrac(igas).eq.1.0).and.(vgas.eq.0))then
    8688               print*,'Rayleigh scattering is for a pure ',trim(gnom(igas)),' atmosphere.'
    8789               typeknown=.true.
     
    101103         tausum = 0.0
    102104         tauwei = 0.0
     105         tausumvar = 0.0
     106         tauweivar = 0.0
    103107         bstart = 10000.0/BWNV(N+1)
    104108         bwidth = (10000.0/BWNV(N)) - (10000.0/BWNV(N+1))
     
    107111
    108112            tauvar=0.0
     113            tauvarvar=0.0
    109114            do igas=1,ngasmx
    110                if((igas.eq.vgas).or.(gfrac(igas).lt.5.e-2))then
     115               if((igas/=vgas).and.(gfrac(igas).lt.5.e-2))then
    111116                  ! ignore variable gas in Rayleigh calculation
    112117                  ! ignore gases of mixing ratio < 0.05 in Rayleigh calculation
     
    118123                     tauvari(igas) = (1.0+0.0113/wl**2+0.00013/wl**4)/wl**4
    119124                  elseif(igas.eq.igas_H2O)then
    120                      tauvari(igas) = 1.0/wl**4 ! to be improved...
     125!                     tauvari(igas) = 1.0/wl**4 ! to be improved...
     126                     tauvari(igas) = (5.7918E6/(2.38E2-1/wl**2)+1.679E5/(57.36E0-1/wl**2))**2/wl**4
    121127                  elseif(igas.eq.igas_H2)then
    122128                     tauvari(igas) = 1.0/wl**4
     
    130136               endif
    131137
    132                tauvar=tauvar+tauconsti(igas)*tauvari(igas)*gfrac(igas)
     138               if(igas.eq.vgas) then
     139                  tauvarvar=tauvarvar+tauconsti(igas)*tauvari(igas)
     140                  tauvar=tauvar+0.0*0.0*gfrac(igas)
     141               else
     142                  tauvar=tauvar+tauconsti(igas)*tauvari(igas)*gfrac(igas)
     143               endif
    133144
    134145            enddo
     
    138149            tauwei=tauwei+df
    139150            tausum=tausum+tauvar*df
     151            tauweivar=tauweivar+df
     152            tausumvar=tausumvar+tauvarvar*df
    140153         
    141154         enddo
    142155         TAURAY(N)=tausum/tauwei
     156         TAURAYVAR(N)=tausumvar/tauweivar
    143157         ! we multiply by scalep here (100) because plev, which is used in optcv,
    144158         ! is in units of mBar, so we need to convert.
  • trunk/LMDZ.GENERIC/libf/phystd/callcorrk.F90

    r962 r1016  
    460460      endif
    461461
     462!!! JL13: in the following, I changed some indices in the interpolations so that the model rsults are less dependent on the number of layers
     463!!!    the older verions are commented with the commetn !JL13index
     464
     465
    462466!-----------------------------------------------------------------------
    463467!     Water vapour (to be generalised for other gases eventually)
     
    468472         do l=1,nlayer
    469473            qvar(2*l)   = pq(ig,nlayer+1-l,i_var)
    470             qvar(2*l+1) = (pq(ig,nlayer+1-l,i_var)+pq(ig,max(nlayer-l,1),i_var))/2   
    471             ! Average approximation as for temperature...
     474            qvar(2*l+1) = pq(ig,nlayer+1-l,i_var)   
     475!JL13index            qvar(2*l+1) = (pq(ig,nlayer+1-l,i_var)+pq(ig,max(nlayer-l,1),i_var))/2   
     476!JL13index            ! Average approximation as for temperature...
    472477         end do
    473478         qvar(1)=qvar(2)
     
    497502         if(RH.lt.0.0) RH=0.0
    498503
    499          ptemp = pplev(ig,1)
    500          Ttemp = tsurf(ig)
    501          call watersat(Ttemp,ptemp,qsat)
    502 
    503          !qvar(2*nlayermx+1)=qsat      ! fully saturated everywhere
     504!         ptemp = pplev(ig,1)
     505!         Ttemp = tsurf(ig)
     506!         call watersat(Ttemp,ptemp,qsat)
     507
    504508         qvar(2*nlayermx+1)= RH * qsat ! ~realistic profile (e.g. 80% saturation at ground)
    505          !qvar=0.005                   ! completely constant profile (JL)
    506 
     509 
    507510      else
    508511         do k=1,L_LEVELS
     
    528531         END DO
    529532
    530          !do k=1,L_LEVELS
    531          !   qvar(k) = 0.0
    532          !end do
    533          !print*,'ASSUMING qH2O=0 EVERYWHERE IN CALLCORRK!'
    534       endif
    535 
    536 
    537       if(kastprof.and.(ngasmx.gt.1))then
    538 
     533         if(ngasmx.gt.1)then
     534
     535            DO l=1,nlayer
     536               muvarrad(2*l)   = muvar(ig,nlayer+2-l)
     537               muvarrad(2*l+1) = (muvar(ig,nlayer+2-l) + &
     538                                muvar(ig,max(nlayer+1-l,1)))/2
     539            END DO
     540     
     541            muvarrad(1) = muvarrad(2)
     542            muvarrad(2*nlayermx+1)=muvar(ig,1)
     543
     544            print*,'Recalculating qvar with VARIABLE epsi for kastprof'
     545            print*,'Assumes that the variable gas is H2O!!!'
     546            print*,'Assumes that there is only one tracer'
     547            !i_var=igcm_h2o_vap
     548            i_var=1
     549            if(nq.gt.1)then
     550               print*,'Need 1 tracer only to run kcm1d.e'
     551               stop
     552            endif
     553            do l=1,nlayer
     554               vtmp(l)=pq(ig,l,i_var)/(epsi+pq(ig,l,i_var)*(1.-epsi))
     555               !vtmp(l)=pq(ig,l,i_var)*muvar(ig,l+1)/mH2O !JL to be changed
     556            end do
     557
     558            do l=1,nlayer
     559               qvar(2*l)   = vtmp(nlayer+1-l)
     560               qvar(2*l+1) = vtmp(nlayer+1-l)
     561!               qvar(2*l+1) = ( vtmp(nlayer+1-l) + vtmp(max(nlayer-l,1)) )/2
     562            end do
     563            qvar(1)=qvar(2)
     564
     565            print*,'Warning: reducing qvar in callcorrk.'
     566            print*,'Temperature profile no longer consistent ', &
     567                            'with saturated H2O. qsat=',satval
     568            do k=1,L_LEVELS
     569               qvar(k) = qvar(k)*satval
     570            end do
     571
     572         endif
     573      else ! if kastprof
    539574         DO l=1,nlayer
    540575            muvarrad(2*l)   = muvar(ig,nlayer+2-l)
    541             muvarrad(2*l+1) = (muvar(ig,nlayer+2-l) + &
    542                                 muvar(ig,max(nlayer+1-l,1)))/2
     576            muvarrad(2*l+1) = (muvar(ig,nlayer+2-l)+muvar(ig,max(nlayer+1-l,1)))/2
    543577         END DO
    544578     
    545579         muvarrad(1) = muvarrad(2)
    546          muvarrad(2*nlayermx+1)=muvar(ig,1)
    547 
    548          print*,'Recalculating qvar with VARIABLE epsi for kastprof'
    549          print*,'Assumes that the variable gas is H2O!!!'
    550          print*,'Assumes that there is only one tracer'
    551          !i_var=igcm_h2o_vap
    552          i_var=1
    553          if(nq.gt.1)then
    554             print*,'Need 1 tracer only to run kcm1d.e'
    555             stop
    556          endif
    557          do l=1,nlayer
    558             vtmp(l)=pq(ig,l,i_var)*muvar(ig,l+1)/mH2O
    559          end do
    560 
    561          do l=1,nlayer
    562             qvar(2*l)   = vtmp(nlayer+1-l)
    563             qvar(2*l+1) = ( vtmp(nlayer+1-l) + vtmp(max(nlayer-l,1)) )/2
    564          end do
    565          qvar(1)=qvar(2)
    566 
    567          print*,'Warning: reducing qvar in callcorrk.'
    568          print*,'Temperature profile no longer consistent ', &
    569                             'with saturated H2O.'
    570          do k=1,L_LEVELS
    571             qvar(k) = qvar(k)*satval
    572          end do
    573 
     580         muvarrad(2*nlayermx+1)=muvar(ig,1)         
    574581      endif
    575 
     582     
    576583      ! Keep values inside limits for which we have radiative transfer coefficients
    577584      if(L_REFVAR.gt.1)then ! there was a bug here!
     
    607614     
    608615      DO l=1,L_NLAYRAD-1
    609          tmid(2*l+1) = tlevrad(2*l+1)
    610          tmid(2*l+2) = tlevrad(2*l+1)
    611          pmid(2*l+1) = plevrad(2*l+1)
    612          pmid(2*l+2) = plevrad(2*l+1)
     616         tmid(2*l+1) = tlevrad(2*l)
     617         tmid(2*l+2) = tlevrad(2*l)
     618         pmid(2*l+1) = plevrad(2*l)
     619         pmid(2*l+2) = plevrad(2*l)
     620!JL13index         tmid(2*l+1) = tlevrad(2*l+1)
     621!JL13index         tmid(2*l+2) = tlevrad(2*l+1)
     622!JL13index         pmid(2*l+1) = plevrad(2*l+1)
     623!JL13index         pmid(2*l+2) = plevrad(2*l+1)
    613624      END DO
    614       pmid(L_LEVELS) = plevrad(L_LEVELS)
    615       tmid(L_LEVELS) = tlevrad(L_LEVELS)
     625      pmid(L_LEVELS) = plevrad(L_LEVELS-1)
     626      tmid(L_LEVELS) = tlevrad(L_LEVELS-1)
     627!JL13index      pmid(L_LEVELS) = plevrad(L_LEVELS)
     628!JL13index      tmid(L_LEVELS) = tlevrad(L_LEVELS)
    616629
    617630      ! test for out-of-bounds pressure
     
    635648            !print*,'WARNING, OVERRIDING FOR TEST'
    636649            call abort
     650            !tlevrad(k)=tgasmin
    637651         elseif(tlevrad(k).gt.tgasmax)then
    638652            print*,'Maximum temperature is outside the radiative'
    639653            print*,'transfer kmatrix bounds, exiting.'
    640654            print*,'level,grid,T',k,ig,tlevrad(k)
    641             print*,'WARNING, OVERRIDING FOR TEST'
    642             !call abort
    643             tlevrad(k)=tgasmax
     655            !print*,'WARNING, OVERRIDING FOR TEST'
     656            call abort
     657            !tlevrad(k)=tgasmax
     658         endif
     659      enddo
     660      do k=1,L_NLAYRAD+1
     661         if(tmid(k).lt.tgasmin)then
     662            print*,'Minimum temperature is outside the radiative'
     663            print*,'transfer kmatrix bounds, exiting.'
     664            print*,"k=",k," tlevrad(k)=",tlevrad(k)
     665            print*,"tgasmin=",tgasmin
     666            !print*,'WARNING, OVERRIDING FOR TEST'
     667            call abort
     668            !tmid(k)=tgasmin
     669         elseif(tmid(k).gt.tgasmax)then
     670            print*,'Maximum temperature is outside the radiative'
     671            print*,'transfer kmatrix bounds, exiting.'
     672            print*,'level,grid,T',k,ig,tlevrad(k)
     673            !print*,'WARNING, OVERRIDING FOR TEST'
     674            call abort
     675            !tmid(k)=tgasmax
    644676         endif
    645677      enddo
  • trunk/LMDZ.GENERIC/libf/phystd/gfluxi.F

    r995 r1016  
    105105      ! -- and stabilizes integrations
    106106      NT    = int(TLEV(2*L+1)*NTfac) - NTstar+1
    107 
    108107      !! For deep, opaque, thick first layers (e.g. Saturn)
    109108      !! what is below works much better, not unstable, ...
  • trunk/LMDZ.GENERIC/libf/phystd/largescale.F90

    r875 r1016  
    22                        pdt, pdq, pdtlsc, pdqvaplsc, pdqliqlsc, rneb)
    33
     4
     5!     to use  'getin'
     6      use ioipsl_getincom
    47      use watercommon_h, only : RLVTT, RCPD, RVTMP2,  &
    5           T_h2O_ice_clouds,T_h2O_ice_liq,Psat_water,Lcpdqsat_water
     8          T_h2O_ice_clouds,T_h2O_ice_liq,Psat_waterDP,Lcpdqsat_waterDP
    69      USE tracer_h
    710      IMPLICIT none
     
    3336      REAL pplay(ngrid,nlayermx)   ! pression au milieu de couche
    3437      REAL pt(ngrid,nlayermx)      ! temperature (K)
    35       real pq(ngrid,nlayermx,nq) ! tracer mixing ratio (kg/kg)
     38      REAL pq(ngrid,nlayermx,nq) ! tracer mixing ratio (kg/kg)
    3639      REAL pdt(ngrid,nlayermx)     ! physical temperature tenedency (K/s)
    3740      REAL pdq(ngrid,nlayermx,nq)! physical tracer tenedency (K/s)
     
    4346
    4447!     Options du programme
    45       REAL ratqs   ! determine largeur de la distribution de vapeur
    46       PARAMETER (ratqs=0.2)
     48      REAL, SAVE :: ratqs   ! determine largeur de la distribution de vapeur
    4749
    4850!     Variables locales
     
    5052      EXTERNAL CBRT
    5153      INTEGER i, k , nn
    52       INTEGER,PARAMETER :: nitermax=2000
    53       REAL,PARAMETER :: alpha=.5,qthreshold=1.e-6
     54      INTEGER,PARAMETER :: nitermax=5000
     55      DOUBLE PRECISION,PARAMETER :: alpha=.1,qthreshold=1.d-8
    5456      ! JL13: if "careful, T<Tmin in psat water" appears often, you may want to stabilise the model by
    5557      !                   decreasing alpha and increasing nitermax accordingly
    56       REAL zt(ngrid), zq(ngrid)
    57       REAL zcond(ngrid),zcond_iter
    58       REAL zdelq(ngrid)
    59       REAL zqs(ngrid), zdqs(ngrid)
    60       REAL psat_tmp,dlnpsat_tmp
     58      DOUBLE PRECISION zt(ngrid), zq(ngrid)
     59      DOUBLE PRECISION zcond(ngrid),zcond_iter
     60      DOUBLE PRECISION zdelq(ngrid)
     61      DOUBLE PRECISION zqs(ngrid), zdqs(ngrid)
     62      DOUBLE PRECISION local_p,psat_tmp,dlnpsat_tmp,Lcp
    6163     
    6264! evaporation calculations
     
    6567      REAL tevap(ngrid,nlayermx)
    6668
    67       REAL zcor(ngrid), zdelta(ngrid), zcvm5(ngrid)
    68       REAL zx_q(ngrid)
    69       REAL Nmix_local,zfice
     69      DOUBLE PRECISION zx_q(ngrid)
     70      LOGICAL,SAVE :: firstcall=.true.
     71
     72
     73      IF (firstcall) THEN
     74
     75         write(*,*) "value for ratqs? "
     76         ratqs=0.2 ! default value
     77         call getin("ratqs",ratqs)
     78         write(*,*) " ratqs = ",ratqs
     79
     80         firstcall = .false.
     81      ENDIF
    7082
    7183!     GCM -----> subroutine variables, initialisation of outputs
     
    7587      pdqliqlsc(1:ngrid,1:nlayermx) = 0.0
    7688      rneb(1:ngrid,1:nlayermx) = 0.0
     89      Lcp=RLVTT/RCPD
    7790
    7891
     
    93106      DO i = 1, ngrid
    94107
     108         local_p=pplay(i,k)
    95109         if(zt(i).le.15.) then
    96110            print*,'in lsc',i,k,zt(i)
    97111!           zt(i)=15.   ! check too low temperatures
    98112         endif
    99          call Psat_water(zt(i),pplay(i,k),psat_tmp,zqs(i))
     113         call Psat_waterDP(zt(i),local_p,psat_tmp,zqs(i))
    100114 
    101          zdelq(i) = MAX(MIN(ratqs * zq(i),1.-zq(i)),1.e-12)
     115         zdelq(i) = MAX(MIN(ratqs * zq(i),1.-zq(i)),1.d-12)
    102116         rneb(i,k) = (zq(i)+zdelq(i)-zqs(i)) / (2.0*zdelq(i))
    103 !        print*,zq(i),zdelq(i),zqs(i),rneb(i,k)
    104117         if (rneb(i,k).lt.0.) then  !no clouds
    105118
     
    107120            zcond(i)=0.
    108121
    109          else if (rneb(i,k).gt.1.) then    !complete cloud cover, we start without evaporating
    110 
     122         else if ((rneb(i,k).gt.0.99).or.(ratqs.lt.1.e-6)) then    !complete cloud cover, we start without evaporating
    111123            rneb(i,k)=1.
    112124            zt(i)=pt(i,k)+pdt(i,k)*ptimestep
     
    114126            dqevap(i,k)=0.
    115127!           iterative process to stabilize the scheme when large water amounts JL12
    116             zcond(i) = 0.0
     128            zcond(i) = 0.0d0
    117129            Do nn=1,nitermax 
    118                call Psat_water(zt(i),pplay(i,k),psat_tmp,zqs(i))
    119                call Lcpdqsat_water(zt(i),pplay(i,k),psat_tmp,zqs(i),zdqs(i),dlnpsat_tmp)
    120                zcond_iter = alpha*(zx_q(i)-zqs(i))/(1.+zdqs(i))   
     130               call Psat_waterDP(zt(i),local_p,psat_tmp,zqs(i))
     131               call Lcpdqsat_waterDP(zt(i),local_p,psat_tmp,zqs(i),zdqs(i),dlnpsat_tmp)
     132               zcond_iter = alpha*(zx_q(i)-zqs(i))/(1.d0+zdqs(i))         
    121133                  !zcond can be negative here
    122134               zx_q(i) = zx_q(i) - zcond_iter
    123135               zcond(i) = zcond(i) + zcond_iter
    124                zt(i) = zt(i) + zcond_iter*RLVTT/RCPD
    125                if (ABS(zcond_iter/alpha).lt.qthreshold) exit
     136               zt(i) = zt(i) + zcond_iter*Lcp
     137               if (ABS(zcond_iter/alpha/zqs(i)).lt.qthreshold) exit
     138!              if (ABS(zcond_iter/alpha).lt.qthreshold) exit
     139               if (nn.eq.nitermax) print*,'itermax in largescale'
    126140            End do ! niter
    127141            zcond(i)=MAX(zcond(i),-(pq(i,k,igcm_h2o_ice)+pdq(i,k,igcm_h2o_ice)*ptimestep))
     
    129143         else   !standard case     
    130144
    131             zx_q(i) = (zq(i)+zdelq(i)+zqs(i))/2.0 !water vapor in cloudy sky
     145            zx_q(i) = (zq(i)+zdelq(i)+zqs(i))/2.0d0 !water vapor in cloudy sky
    132146!           iterative process to stabilize the scheme when large water amounts JL12
    133             zcond(i) = 0.0
     147            zcond(i) = 0.0d0
    134148            Do nn=1,nitermax 
    135                call Lcpdqsat_water(zt(i),pplay(i,k),psat_tmp,zqs(i),zdqs(i),dlnpsat_tmp)
    136                zcond_iter = MAX(0.0,alpha*(zx_q(i)-zqs(i))/(1.+zdqs(i)))           
     149               call Lcpdqsat_waterDP(zt(i),local_p,psat_tmp,zqs(i),zdqs(i),dlnpsat_tmp)
     150               zcond_iter = MAX(0.0d0,alpha*(zx_q(i)-zqs(i))/(1.d0+zdqs(i)))       
    137151                  !zcond always postive! cannot evaporate clouds!
    138152                  !this is why we must reevaporate before largescale
    139153               zx_q(i) = zx_q(i) - zcond_iter
    140154               zcond(i) = zcond(i) + zcond_iter
    141                if (ABS(zcond_iter/alpha).lt.qthreshold) exit
    142                zt(i) = zt(i) + zcond_iter*RLVTT/RCPD*rneb(i,k)
    143                call Psat_water(zt(i),pplay(i,k),psat_tmp,zqs(i))
     155               if (ABS(zcond_iter/alpha/zqs(i)).lt.qthreshold) exit
     156!              if (ABS(zcond_iter/alpha).lt.qthreshold) exit
     157               zt(i) = zt(i) + zcond_iter*Lcp*rneb(i,k)
     158               call Psat_waterDP(zt(i),local_p,psat_tmp,zqs(i))
     159               if (nn.eq.nitermax) print*,'itermax in largescale'
    144160            End do ! niter
    145161
     
    153169         pdqvaplsc(1:ngrid,k)  = dqevap(1:ngrid,k) - zcond(1:ngrid)
    154170         pdqliqlsc(1:ngrid,k) = - pdqvaplsc(1:ngrid,k)
    155          pdtlsc(1:ngrid,k)  = pdqliqlsc(1:ngrid,k)*RLVTT/RCPD
     171         pdtlsc(1:ngrid,k)  = pdqliqlsc(1:ngrid,k)*real(Lcp)
    156172
    157173   Enddo ! k= nlayermx, 1, -1
    158    
    159       !print*,'qsat=',zqs
    160       !print*,'q=',q
    161       !print*,'dq=',pdqvaplsc*ptimestep
    162       !print*,'dT in LS=',pdtlsc*ptimestep
    163 
    164       !print*,'rice=',rice
    165       !print*,'rneb=',rneb
     174 
    166175
    167176      return
  • trunk/LMDZ.GENERIC/libf/phystd/moistadj.F90

    r875 r1016  
    5656      LOGICAL itest(ngrid)
    5757      REAL delta_q(ngrid, nlayermx)
    58       REAL cp_new_t(nlayermx)
     58      DOUBLE PRECISION :: cp_new_t(nlayermx), v_cptt(ngrid,nlayermx)
    5959      REAL cp_delta_t(nlayermx)
    60       REAL v_cptj(nlayermx), v_cptjk1, v_ssig
    61       REAL v_cptt(ngrid,nlayermx), v_p, v_t, v_zqs,v_cptt2,v_pratio,v_dlnpsat
     60      DOUBLE PRECISION :: v_cptj(nlayermx), v_cptjk1, v_ssig
     61      REAL v_p, v_t, v_zqs,v_cptt2,v_pratio,v_dlnpsat
    6262      REAL zqs(ngrid,nlayermx), zdqs(ngrid,nlayermx),zpsat(ngrid,nlayermx),zdlnpsat(ngrid,nlayermx)
    6363      REAL zq1(ngrid), zq2(ngrid)
    64       REAL gamcpdz(ngrid,2:nlayermx)
    65       REAL zdp, zdpm
     64      DOUBLE PRECISION :: gamcpdz(ngrid,2:nlayermx)
     65      DOUBLE PRECISION :: zdp, zdpm
    6666
    6767      REAL zsat ! super-saturation
    6868      REAL zflo ! flotabilite
    6969
    70       REAL local_q(ngrid,nlayermx),local_t(ngrid,nlayermx)
     70      DOUBLE PRECISION :: local_q(ngrid,nlayermx),local_t(ngrid,nlayermx)
    7171
    7272      REAL zdelta, zcor, zcvm5
     
    139139            v_zqs     = (zqs(i,k-1)*zdpm + zqs(i,k)*zdp)/(zdpm+zdp)
    140140            v_cptt2   = (v_cptt(i,k-1)*zdpm + v_cptt(i,k)*zdp)/(zdpm+zdp)
    141             v_pratio  = ((1./(1.+zpsat(i,k-1)/pplay(i,k-1)))*zdpm + (1./(1.+zpsat(i,k)/pplay(i,k)))*zdp)/(zdpm+zdp)
     141            v_pratio  = ((1.-zpsat(i,k-1)/pplay(i,k-1))*zdpm + (1.-zpsat(i,k)/pplay(i,k))*zdp)/(zdpm+zdp)
    142142            v_dlnpsat = (zdlnpsat(i,k-1)*zdpm + zdlnpsat(i,k)*zdp)/(zdpm+zdp)
    143             gamcpdz(i,k) = v_pratio*( (R/RCPD*v_cptt2*(1.- v_zqs) + RLVTT*v_zqs) * (pplay(i,k-1)-pplay(i,k))/pplev(i,k) )  &
    144                 / ((1.- v_zqs) + v_zqs * RCPV/RCPD + v_zqs * v_pratio * v_dlnpsat)                   
     143            gamcpdz(i,k) = ( (R/RCPD*v_cptt2*(1.- v_zqs) + RLVTT*v_zqs) * (pplay(i,k-1)-pplay(i,k))/pplev(i,k) )  &
     144                / (((1.- v_zqs) + v_zqs * RCPV/RCPD)*v_pratio + v_zqs  * v_dlnpsat)               
    145145         ENDDO
    146146      ENDDO
     
    210210         call Lcpdqsat_water(v_t,v_p,zpsat(i,k),zqs(i,k),zdqs(i,k),zdlnpsat(i,k))
    211211
    212 
    213 
    214 !          print*,'i,k,zqs,cpdT=',i,k,zqs(i,k),cp_delta_t(k)
    215212      ENDDO
    216213    Enddo ! nn=1,niter
     
    240237         v_zqs     = (zqs(i,k-1)*zdpm + zqs(i,k)*zdp)/(zdpm+zdp)
    241238         v_cptt2   = (v_cptt(i,k-1)*zdpm + v_cptt(i,k)*zdp)/(zdpm+zdp)
    242          v_pratio  = ((1./(1.+zpsat(i,k-1)/pplay(i,k-1)))*zdpm + (1./(1.+zpsat(i,k)/pplay(i,k)))*zdp)/(zdpm+zdp)
     239         v_pratio  = ((1.-zpsat(i,k-1)/pplay(i,k-1))*zdpm + (1.-zpsat(i,k)/pplay(i,k))*zdp)/(zdpm+zdp)
    243240         v_dlnpsat = (zdlnpsat(i,k-1)*zdpm + zdlnpsat(i,k)*zdp)/(zdpm+zdp)
    244          gamcpdz(i,k) = v_pratio*( (R/RCPD*v_cptt2*(1.- v_zqs) + RLVTT*v_zqs) * (pplay(i,k-1)-pplay(i,k))/pplev(i,k) )  &
    245                 / ((1.- v_zqs) + v_zqs * RCPV/RCPD + v_zqs * v_pratio * v_dlnpsat)                   
     241         gamcpdz(i,k) = ( (R/RCPD*v_cptt2*(1.- v_zqs) + RLVTT*v_zqs) * (pplay(i,k-1)-pplay(i,k))/pplev(i,k) )  &
     242                / (((1.- v_zqs) + v_zqs * RCPV/RCPD)*v_pratio + v_zqs  * v_dlnpsat)               
    246243      ENDDO
    247244
     
    271268 9999 CONTINUE ! loop over all the points
    272269
    273 !      print*,'k1=',k1
    274 !      print*,'k2=',k2
    275 
    276 !      print*,'local_t=',local_t
    277 !      print*,'v_cptt=',v_cptt
    278 !      print*,'gamcpdz=',gamcpdz
    279 
    280270!-----------------------------------------------------------------------
    281271! Determine the cloud fraction (hypothese: la nebulosite a lieu
     
    317307      ENDDO
    318308      ENDDO
    319 
    320 !      print*,'local_q BEFORE=',local_q
    321309
    322310      DO k = 1, nlayermx
  • trunk/LMDZ.GENERIC/libf/phystd/optci.F90

    r961 r1016  
    121121     if(kastprof)then
    122122        dz(k) = dpr(k)*(1000.0d0*8.3145d0/muvar(k))*TMID(K)/(g*PMID(K))
    123         U(k)  = (Cmk*mugaz/(muvar(k)))*DPR(k)
     123        U(k)  = Cmk*DPR(k)*mugaz/muvar(k)
    124124     else
    125         dz(k) = dpr(k)*R*TMID(K)/(g*PMID(K))
    126         U(k)  = Cmk*DPR(k)    ! only Cmk line in optci.F
     125        dz(k) = dpr(k)*R*TMID(K)/(g*PMID(K))*mugaz/muvar(k)
     126        U(k)  = Cmk*DPR(k)*mugaz/muvar(k)     ! only Cmk line in optci.F 
     127            !JL13 the mugaz/muvar factor takes into account water meanmolecular weight if water is present
    127128     endif
    128129
  • trunk/LMDZ.GENERIC/libf/phystd/optcv.F90

    r919 r1016  
    108108     ! if we have continuum opacities, we need dz
    109109     if(kastprof)then
    110         dz(k) = dpr(k)*(1000.0*8.3145/muvar(k))*TMID(K)/(g*PMID(K))
    111         U(k)  = (Cmk*mugaz/(muvar(k)))*DPR(k)
     110        dz(k) = dpr(k)*(1000.0d0*8.3145d0/muvar(k))*TMID(K)/(g*PMID(K))
     111        U(k)  = Cmk*DPR(k)*mugaz/muvar(k)
    112112     else
    113         dz(k) = dpr(k)*R*TMID(K)/(g*PMID(K))
    114         U(k)  = Cmk*DPR(k)    ! only Cmk line in optci.F
     113        dz(k) = dpr(k)*R*TMID(K)/(g*PMID(K))*mugaz/muvar(k)
     114        U(k)  = Cmk*DPR(k)*mugaz/muvar(k)     ! only Cmk line in optci.F 
     115            !JL13 the mugaz/muvar factor takes into account water meanmolecular weight if water is present
    115116     endif
    116117
  • trunk/LMDZ.GENERIC/libf/phystd/physiq.F90

    r996 r1016  
    99 
    1010      use radinc_h, only : L_NSPECTI,L_NSPECTV,naerkind
    11       use watercommon_h, only : RLVTT, Psat_water
     11      use watercommon_h, only : RLVTT, Psat_water,epsi
    1212      use gases_h
    1313      use radcommon_h, only: sigma
     
    329329      real dEzRadsw(ngrid,nlayermx),dEzRadlw(ngrid,nlayermx),dEzdiff(ngrid,nlayermx)
    330330      real dEdiffs(ngrid),dEdiff(ngrid)
    331       real madjdE(ngrid), lscaledE(ngrid)
     331      real madjdE(ngrid), lscaledE(ngrid),madjdEz(ngrid,nlayermx), lscaledEz(ngrid,nlayermx)
    332332!JL12 conservation test for mean flow kinetic energy has been disabled temporarily
    333333     
     
    711711                 call abort
    712712              endif
    713               muvar(:,:)=0.0 ! only used for climate evolution studies (kcm1d) for now
     713              if(water) then
     714                  muvar(1:ngrid,1:nlayermx)=mugaz/(1.e0+(1.e0/epsi-1.e0)*pq(1:ngrid,1:nlayermx,igcm_h2o_vap))
     715                  muvar(1:ngrid,nlayermx+1)=mugaz/(1.e0+(1.e0/epsi-1.e0)*pq(1:ngrid,nlayermx,igcm_h2o_vap))
     716                  ! take into account water effect on mean molecular weight
     717              else
     718                  muvar(1:ngrid,1:nlayermx+1)=mugaz
     719              endif
    714720     
    715721!             standard callcorrk
     
    10591065               dtmoist(1:ngrid,1:nlayermx)=0.
    10601066
    1061                call moistadj(ngrid,nq,pt,pq,pdq,pplev,pplay,dtmoist,dqmoist,ptimestep,rneb_man)
     1067               call moistadj(ngrid,nq,pt,pq,pdq,pplev,pplay,dtmoist,dqmoist,ptimestep,rneb_man)
    10621068
    10631069               pdq(1:ngrid,1:nlayermx,igcm_h2o_vap) = pdq(1:ngrid,1:nlayermx,igcm_h2o_vap)   &
     
    10711077               if(enertest)then
    10721078                  dEtot=cpp*SUM(massarea(:,:)*dtmoist(:,:))/totarea
     1079                  madjdEz(:,:)=cpp*mass(:,:)*dtmoist(:,:)
    10731080                  do ig=1,ngrid
    10741081                     madjdE(ig) = cpp*SUM(mass(:,:)*dtmoist(:,:))
     
    10891096!        Large scale condensation/evaporation
    10901097!        --------------------------------
    1091 
    10921098               call largescale(ngrid,nq,ptimestep,pplev,pplay,pt,pq,pdt,pdq,dtlscale,dqvaplscale,dqcldlscale,rneb_lsc)
    10931099
     
    10991105               ! test energy conservation
    11001106               if(enertest)then
     1107                  lscaledEz(:,:) = cpp*mass(:,:)*dtlscale(:,:)
    11011108                  do ig=1,ngrid
    11021109                     lscaledE(ig) = cpp*SUM(mass(:,:)*dtlscale(:,:))
     
    15341541         do l = 1, nlayer
    15351542            do ig=1,ngrid
    1536 !               call watersat(pt(ig,l),pplay(ig,l),qsat(ig,l))
    15371543               call Psat_water(zt(ig,l),pplay(ig,l),psat_tmp,qsat(ig,l))
    1538 
    15391544               RH(ig,l) = zq(ig,l,igcm_h2o_vap) / qsat(ig,l)
    15401545            enddo
     
    16981703           call writediagfi(ngrid,"ASR","absorbed stellar rad.","W m-2",2,fluxabs_sw)
    16991704           call writediagfi(ngrid,"OLR","outgoing longwave rad.","W m-2",2,fluxtop_lw)
     1705!           call writediagfi(ngrid,"ASRcs","absorbed stellar rad (cs).","W m-2",2,fluxabs_sw1)
     1706!           call writediagfi(ngrid,"OLRcs","outgoing longwave rad (cs).","W m-2",2,fluxtop_lw1)
     1707!           call writediagfi(ngrid,"fluxsurfsw","sw surface flux.","W m-2",2,fluxsurf_sw)
     1708!           call writediagfi(ngrid,"fluxsurflw","lw back radiation.","W m-2",2,fluxsurf_lw)
     1709!           call writediagfi(ngrid,"fluxsurfswcs","sw surface flux (cs).","W m-2",2,fluxsurf_sw1)
     1710!           call writediagfi(ngrid,"fluxsurflwcs","lw back radiation (cs).","W m-2",2,fluxsurf_lw1)
    17001711           call writediagfi(ngrid,"GND","heat flux from ground","W m-2",2,fluxgrd)
    17011712           call writediagfi(ngrid,"DYN","dynamical heat input","W m-2",2,fluxdyn)
     
    17151726          endif
    17161727          if(watercond) then
     1728!            call writediagfi(ngrid,"lscaledEz","heat from largescale","W m-2",3,lscaledEz)
     1729!            call writediagfi(ngrid,"madjdEz","heat from moistadj","W m-2",3,madjdEz)
    17171730             call writediagfi(ngrid,"lscaledE","heat from largescale","W m-2",2,lscaledE)
    17181731             call writediagfi(ngrid,"madjdE","heat from moistadj","W m-2",2,madjdE)
    1719              call writediagfi(ngrid,"RH","relative humidity"," ",3,RH)
    1720 !            call writediagfi(ngrid,"qsatatm","atm qsat"," ",3,qsat)
     1732             call writediagfi(ngrid,"qsatatm","atm qsat"," ",3,qsat)
    17211733!            call writediagfi(ngrid,"h2o_max_col","maximum H2O column amount","kg.m^-2",2,H2Omaxcol)
    17221734          endif
     
    17591771             call writediagfi(ngrid,"CLF","H2O cloud fraction"," ",3,cloudfrac)
    17601772             call writediagfi(ngrid,"CLFt","H2O column cloud fraction"," ",2,totcloudfrac)
     1773             call writediagfi(ngrid,"RH","relative humidity"," ",3,RH)
    17611774          endif
    17621775
  • trunk/LMDZ.GENERIC/libf/phystd/radcommon_h.F90

    r959 r1016  
    3636!     TAURAY     - Array (NSPECTV elements) of the pressure-independent
    3737!                  part of Rayleigh scattering optical depth.
     38!     TAURAYVAR  - Array (NSPECTV elements) of the pressure-independent
     39!                  part of Rayleigh scattering optical depth for the variable gas.
    3840!     FZEROI     - Fraction of zeros in the IR CO2 k-coefficients, for
    3941!                  each temperature, pressure, and spectral interval
     
    6163      REAL*8 BWNI(L_NSPECTI+1), WNOI(L_NSPECTI), DWNI(L_NSPECTI), WAVEI(L_NSPECTI)
    6264      REAL*8 BWNV(L_NSPECTV+1), WNOV(L_NSPECTV), DWNV(L_NSPECTV), WAVEV(L_NSPECTV)
    63       REAL*8 STELLARF(L_NSPECTV), TAURAY(L_NSPECTV)
     65      REAL*8 STELLARF(L_NSPECTV), TAURAY(L_NSPECTV), TAURAYVAR(L_NSPECTV)
    6466
    6567      REAL*8 blami(L_NSPECTI+1)
  • trunk/LMDZ.GENERIC/libf/phystd/rain.F90

    r863 r1016  
    6666      INTEGER,PARAMETER :: ninter=5
    6767
    68       logical,parameter :: evap_prec=.true. ! Does the rain evaporate?
     68      logical,save :: evap_prec ! Does the rain evaporate?
    6969
    7070!     for simple scheme
     
    142142
    143143         endif
     144
     145         write(*,*) "re-evaporate precipitations?"
     146         evap_prec=.true. ! default value
     147         call getin("evap_prec",evap_prec)
     148         write(*,*) " evap_prec = ",evap_prec
    144149
    145150         firstcall = .false.
  • trunk/LMDZ.GENERIC/libf/phystd/turbdiff.F90

    r952 r1016  
    543543                  zcq0(ig) = qsat(ig)-dqsat(ig)*ptsrf(ig)
    544544
    545                   z1(ig) = pcapcal(ig)*ptsrf(ig) +cpp*zfluxq(ig,1)*zct(ig,1)*zovExner(ig,1)   &
     545                  z1(ig) = pcapcal(ig)*ptsrf(ig) +cpp*zfluxt(ig,1)*zct(ig,1)*zovExner(ig,1)   &
    546546                      + zdplanck(ig)*ptsrf(ig) + pfluxsrf(ig)*ptimestep                       &
    547547                      + zfluxq(ig,1)*dryness(ig)*RLVTT*((zdq(ig,1)-1.0)*zcq0(ig)+zcq(ig,1))
    548548
    549                   z2(ig) = pcapcal(ig) + cpp*zfluxq(ig,1)*(1.-zovExner(ig,1)*zdt(ig,1))       &
     549                  z2(ig) = pcapcal(ig) + cpp*zfluxt(ig,1)*(1.-zovExner(ig,1)*zdt(ig,1))       &
    550550                      + zdplanck(ig)+zfluxq(ig,1)*dryness(ig)*RLVTT*zdq0(ig)*(1.0-zdq(ig,1))
    551551
  • trunk/LMDZ.GENERIC/libf/phystd/watercommon_h.F90

    r989 r1016  
    175175      end subroutine Tsat_water
    176176
     177!==================================================================
     178      subroutine Psat_waterDP(T,p,psat,qsat)
     179
     180         implicit none
     181
     182!==================================================================
     183!     Purpose
     184!     -------
     185!     Compute the saturation vapor pressure and mass mixing ratio at saturation (kg/kg)
     186!     for a given pressure (Pa) and temperature (K)
     187!     DOUBLE PRECISION
     188!     Based on the Tetens formula from L.Li physical parametrization manual
     189!
     190!     Authors
     191!     -------
     192!     Jeremy Leconte (2012)
     193!
     194!==================================================================
     195
     196!        input
     197         double precision, intent(in) :: T, p
     198 
     199!        output
     200         double precision psat,qsat
     201
     202! JL12 variables for tetens formula
     203         double precision,parameter :: Pref_solid_liquid=611.14d0
     204         double precision,parameter :: Trefvaporization=35.86D0
     205         double precision,parameter :: Trefsublimation=7.66d0
     206         double precision,parameter :: Tmin=8.d0
     207         double precision,parameter :: r3vaporization=17.269d0
     208         double precision,parameter :: r3sublimation=21.875d0
     209
     210! checked vs. old watersat data 14/05/2012 by JL.
     211
     212         if (T.gt.T_h2O_ice_liq) then
     213            psat = Pref_solid_liquid*Exp(r3vaporization*(T-T_h2O_ice_liq)/(T-Trefvaporization)) ! liquid / vapour
     214         else if (T.lt.Tmin) then
     215            print*, "careful, T<Tmin in psat water"
     216            psat = Pref_solid_liquid*Exp(r3sublimation*(Tmin-T_h2O_ice_liq)/(Tmin-Trefsublimation)) ! min psat 
     217         else                 
     218            psat = Pref_solid_liquid*Exp(r3sublimation*(T-T_h2O_ice_liq)/(T-Trefsublimation)) ! solid / vapour
     219         endif
     220         if(psat.gt.p) then
     221            qsat=1.d0
     222         else
     223            qsat=epsi*psat/(p-(1.d0-epsi)*psat)
     224         endif
     225         return
     226      end subroutine Psat_waterDP
     227
     228
     229
     230
     231!==================================================================
     232      subroutine Lcpdqsat_waterDP(T,p,psat,qsat,dqsat,dlnpsat)
     233
     234         implicit none
     235
     236!==================================================================
     237!     Purpose
     238!     -------
     239!     Compute dqsat=L/cp*d (q_sat)/d T and dlnpsat=L/cp d(ln Psat)/d T
     240!     for a given temperature (K)!
     241!     Based on the Tetens formula from L.Li physical parametrization manual
     242!
     243!     Authors
     244!     -------
     245!     Jeremy Leconte (2012)
     246!
     247!==================================================================
     248
     249!        input
     250         double precision T, p, psat, qsat
     251 
     252!        output
     253         double precision dqsat,dlnpsat
     254
     255! JL12 variables for tetens formula
     256         double precision,parameter :: Pref_solid_liquid=611.14d0
     257         double precision,parameter :: Trefvaporization=35.86d0
     258         double precision,parameter :: Tmin=8.d0
     259         double precision,parameter :: Trefsublimation=7.66d0
     260         double precision,parameter :: r3vaporization=17.269d0
     261         double precision,parameter :: r3sublimation=21.875d0
     262
     263         double precision :: dummy
     264
     265         if (psat.gt.p) then
     266            dqsat=0.d0
     267            return
     268         endif
     269
     270         if (T.gt.T_h2O_ice_liq) then
     271            dummy = r3vaporization*(T_h2O_ice_liq-Trefvaporization)/(T-Trefvaporization)**2  ! liquid / vapour
     272         else if (T.lt.Tmin) then
     273            print*, "careful, T<Tmin in Lcp psat water"
     274            dummy = r3sublimation*(T_h2O_ice_liq-Trefsublimation)/(Tmin-Trefsublimation)**2  ! solid / vapour
     275         else               
     276            dummy = r3sublimation*(T_h2O_ice_liq-Trefsublimation)/(T-Trefsublimation)**2  ! solid / vapour
     277         endif
     278
     279         dqsat=RLVTT/RCPD*qsat*(p/(p-(1.d0-epsi)*psat))*dummy
     280         dlnpsat=RLVTT/RCPD*dummy
     281         return
     282      end subroutine Lcpdqsat_waterDP
     283
    177284
    178285end module watercommon_h
Note: See TracChangeset for help on using the changeset viewer.