Changeset 538


Ignore:
Timestamp:
Feb 17, 2012, 11:54:16 PM (13 years ago)
Author:
rwordsworth
Message:

calc_cpp_mugaz changed to a check only in 3D

Location:
trunk/LMDZ.GENERIC/libf/phystd
Files:
5 edited

Legend:

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

    r471 r538  
    44!     Purpose
    55!     -------
    6 !     Compute the atmospheric specific heat capacity.
    7 !     Compute the atmospheric mean molar mass.
     6!     Check to see if the atmospheric specific heat capacity and
     7!     mean molar mass for the gas mixture defined in gases.def
     8!     corresponds to what we're using. If it doesn't, abort run
     9!     unless option 'check_cpp_match' is set to false in
     10!     callphys.def.
     11!     NOTE: for now, in 1D we do as before. Jeremy, if you're
     12!     re-writing rcm1d you may want to alter this.
    813!
    914!     Authors
     
    1621      implicit none
    1722
     23#include "dimensions.h"
     24#include "dimphys.h"
    1825#include "comcstfi.h"
    19 !#include "callkeys.h"
     26#include "callkeys.h"
     27
     28      real cpp_c
     29      real mugaz_c
    2030
    2131      integer igas
    2232
    23       cpp=0.0
    24       mugaz=0.0
     33      cpp_c   = 0.0
     34      mugaz_c = 0.0
    2535
    2636      do igas=1,ngasmx
     
    3141            ! all values at 300 K from Engineering Toolbox
    3242            if(gnom(igas).eq.'CO2')then
    33                cpp   = cpp   + 0.846*gfrac(igas)
    34                mugaz = mugaz + 44.01*gfrac(igas)
     43               cpp_c   = cpp_c   + 0.846*gfrac(igas)
     44               mugaz_c = mugaz_c + 44.01*gfrac(igas)
    3545            elseif(gnom(igas).eq.'N2_')then
    36                cpp   = cpp   + 1.040*gfrac(igas)
    37                mugaz = mugaz + 28.01*gfrac(igas)
     46               cpp_c   = cpp_c   + 1.040*gfrac(igas)
     47               mugaz_c = mugaz_c + 28.01*gfrac(igas)
    3848            elseif(gnom(igas).eq.'H2_')then
    39                cpp   = cpp   + 14.31*gfrac(igas)
    40                mugaz = mugaz + 2.01*gfrac(igas)
     49               cpp_c   = cpp_c   + 14.31*gfrac(igas)
     50               mugaz_c = mugaz_c + 2.01*gfrac(igas)
    4151            elseif(gnom(igas).eq.'H2O')then
    42                cpp   = cpp   + 1.864*gfrac(igas)
    43                mugaz = mugaz + 18.02*gfrac(igas)
     52               cpp_c   = cpp_c   + 1.864*gfrac(igas)
     53               mugaz_c = mugaz_c + 18.02*gfrac(igas)
    4454            elseif(gnom(igas).eq.'CH4')then
    45                cpp   = cpp   + 2.226*gfrac(igas)
    46                mugaz = mugaz + 16.04*gfrac(igas)
     55               cpp_c   = cpp_c   + 2.226*gfrac(igas)
     56               mugaz_c = mugaz_c + 16.04*gfrac(igas)
    4757            elseif(gnom(igas).eq.'NH3')then
    48                cpp   = cpp   + 2.175*gfrac(igas)
    49                mugaz = mugaz + 17.03*gfrac(igas)
     58               cpp_c   = cpp_c   + 2.175*gfrac(igas)
     59               mugaz_c = mugaz_c + 17.03*gfrac(igas)
    5060               print*,'WARNING, cpp for NH3 may be for liquid'
    5161            else
     
    5767      enddo
    5868
    59       cpp=1000.0*cpp
     69      cpp_c = 1000.0*cpp_c
    6070
    61       print*,'Cp in calc_cpp_mugaz is ',cpp,'J kg^-1 K^-1'
    62       print*,'Mg in calc_cpp_mugaz is ',mugaz,'amu'
     71      print*,'Cp in calc_cpp_mugaz is ',cpp_c,'J kg^-1 K^-1'
     72      print*,'Mg in calc_cpp_mugaz is ',mugaz_c,'amu'
     73      print*,'Predefined Cp in physics is ',cpp,'J kg^-1 K^-1'
     74      print*,'Predefined Mg in physics is ',mugaz,'amu'
    6375
    64       R = 8.314511E+0 *1000.E+0/mugaz
    65       rcp = R/cpp
     76      if(ngridmx.eq.1)then
     77         print*,'Automatically setting cpp & mugaz to calculated values in calc_cpp_mugaz'
     78         cpp   = cpp_c
     79         mugaz = mugaz_c
     80         R     = 8.314511E+0 *1000.E+0/mugaz
     81         rcp   = R/cpp
     82      elseif((cpp.ne.cpp_c) .or. (mugaz.ne.mugaz_c))then
     83         if(check_cpp_match)then
     84            print*,'Values do not match!'
     85            print*,'Either adjust cpp / mugaz via newstart to calculated values,'
     86            print*,'or set check_cpp_match to .false. in callphys.def.'
     87            stop
     88         endif
     89      endif
    6690
    6791      return
  • trunk/LMDZ.GENERIC/libf/phystd/callcorrk.F90

    r526 r538  
    44          dtlw,dtsw,fluxsurf_lw,                               &
    55          fluxsurf_sw,fluxtop_lw,fluxabs_sw,fluxtop_dn,        &
    6           OLR_nu,OSR_nu,                                       &
     6          OLR_nu,OSR_nu,                                       &
    77          reffrad,tau_col,cloudfrac,totcloudfrac,              &
    88          clearsky,firstcall,lastcall)
     
    195195      qsiaer(:,:,:)=0.0
    196196      giaer(:,:,:) =0.0
     197
    197198
    198199      if(firstcall) then
     
    264265            stop
    265266         endif
    266          
    267         OLR_nu=0.
    268         OSR_nu=0.
     267
     268        OLR_nu=0.
     269        OSR_nu=0.
    269270
    270271         firstcall=.false.   
     
    326327
    327328            do ig=1,ngrid
    328                if(tracer.and.igcm_co2_ice.gt.0)then
     329               if(tracer)then
     330               !if(tracer.and.igcm_co2_ice.gt.0)then
     331
     332                  if(igcm_co2_ice.lt.1)then
     333                     print*,'Tracers but no CO2 ice still seems to be a problem...'
     334                     print*,'Aborting in callcorrk.'
     335                     stop
     336                  endif
     337
    329338                  reffrad(ig,l,1) = CBRT( 3*pq(ig,l,igcm_co2_ice)/ &
    330339                       (4*Nmix_co2*pi*rho_co2) )
     
    556565         end do
    557566         qvar(1)=qvar(2)
    558 !         qvar(2*nlayermx+1)=qsurf(ig,i_var) !JL12 not very good to compare kg/kg and kg/m2???
    559567
    560568      elseif(varfixed)then
     
    585593         Ttemp = tsurf(ig)
    586594         call watersat(Ttemp,ptemp,qsat)
    587          
    588595
    589596         !qvar(2*nlayermx+1)=qsat      ! fully saturated everywhere
    590597         qvar(2*nlayermx+1)= RH * qsat ! ~realistic profile (e.g. 80% saturation at ground)
    591 
    592 
    593 !!!!!!!!!!!!!!!!!!!!!!!!  JL: for completely constant water profile uncoment the following line
    594 !        qvar=0.005
     598         !qvar=0.005                   ! completely constant profile (JL)
    595599
    596600      else
     
    600604      end if
    601605
     606      if(.not.kastprof)then
    602607      ! IMPORTANT: Now convert from kg/kg to mol/mol
    603608      do k=1,L_LEVELS
    604609         qvar(k) = qvar(k)/epsi
    605610      end do
     611      end if
    606612
    607613!-----------------------------------------------------------------------
     
    634640
    635641         print*,'Recalculating qvar with VARIABLE epsi for kastprof'
    636          i_var=igcm_h2o_vap
     642         print*,'Assumes that the variable gas is H2O!!!'
     643         print*,'Assumes that there is only one tracer'
     644         !i_var=igcm_h2o_vap
     645         i_var=1
     646         if(nqmx.gt.1)then
     647            print*,'Need 1 tracer only to run kcm1d.e'
     648            stop
     649         endif
    637650         do l=1,nlayer
    638651            vtmp(l)=pq(ig,l,i_var)*muvar(ig,l+1)/mH2O
     
    644657         end do
    645658         qvar(1)=qvar(2)
    646          qvar(2*nlayermx+1)=qsurf(ig,i_var)*muvar(ig,1)/mH2O
     659
     660         print*,'Warning: reducing qvar in callcorrk.'
     661         print*,'Temperature profile no longer consistent ', &
     662                            'with saturated H2O.'
     663         do k=1,L_LEVELS
     664            qvar(k) = qvar(k)*satval
     665         end do
    647666
    648667      endif
     
    766785              qxiaer,qsiaer,giaer,cosbi,wbari,tauaero,tmid,pmid,    &
    767786              taugsurfi,qvar,muvarrad)
    768              
     787
    769788         call sfluxi(plevrad,tlevrad,dtaui,taucumi,ubari,albi,      &
    770789              wnoi,dwni,cosbi,wbari,gweight,nfluxtopi,nfluxtopi_nu, &
     
    859878           close(116)
    860879
     880!          I am useful, please don`t remove me!
    861881!           if(specOLR)then
    862882!               open(117,file='OLRnu.out')
  • trunk/LMDZ.GENERIC/libf/phystd/callkeys.h

    r526 r538  
    2020     &   , Tstrat                                                       &
    2121     &   , newtonian                                                    &
     22     &   , check_cpp_match                                              &
    2223     &   , tau_relax                                                    &
    2324     &   , testradtimes                                                 &
     
    6162      logical kastprof
    6263      logical newtonian
     64      logical check_cpp_match
    6365      logical testradtimes
    6466      logical rayleigh
  • trunk/LMDZ.GENERIC/libf/phystd/inifis.F

    r526 r538  
    177177         write(*,*) " enertest = ",enertest
    178178
     179         write(*,*) "Check to see if cpp values used match gases.def ?"
     180         check_cpp_match=.true. ! default value
     181         call getin("check_cpp_match",check_cpp_match)
     182         write(*,*) " check_cpp_match = ",check_cpp_match
     183
     184
    179185         write(*,*) "call radiative transfer ?"
    180186         callrad=.true. ! default value
     
    192198         call getin("callgasvis",callgasvis)
    193199         write(*,*) " callgasvis = ",callgasvis
    194 
     200       
    195201         write(*,*) "call continuum opacities in radiative transfer ?",
    196202     &              "(matters only if callrad=T)"
    197          Continuum=.false. ! default value
     203         Continuum=.true. ! default value
    198204         call getin("Continuum",Continuum)
    199205         write(*,*) " Continuum = ",Continuum
    200          
     206
     207 
    201208         write(*,*) "call turbulent vertical diffusion ?"
    202209         calldifv=.true. ! default value
     
    310317         endif
    311318
    312 
    313319         write(*,*)"Use Newtonian cooling for radiative transfer?"
    314320         newtonian=.false.
     
    506512         endif
    507513
    508          mugaz=0.
    509          cpp=0.
     514         mugaz=8.314*1000./pr
    510515         call su_gases
    511516         call calc_cpp_mugaz
  • trunk/LMDZ.GENERIC/libf/phystd/physiq.F90

    r526 r538  
    440440!        read startfi (initial parameters)
    441441!        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    442           print*,'in physiqu i am in phyetat0'
    443442         call phyetat0("startfi.nc",0,0,nsoilmx,nq,           &
    444443               day_ini,time_phys,tsurf,tsoil,emis,q2,qsurf,   &
     
    712711                 call abort
    713712              endif
    714               muvar(:,:)=0.0 ! only used for climate evolution for now
    715              
    716              
     713              muvar(:,:)=0.0 ! only used for climate evolution studies (kcm1d) for now
     714     
    717715!             standard callcorrk
    718716              clearsky=.false.
    719               call callcorrk(ngrid,nlayer,pq,nq,qsurf,         &
     717              call callcorrk(ngrid,nlayer,pq,nq,qsurf,                   &
    720718                      albedo,emis,mu0,pplev,pplay,pt,                    &
    721719                      tsurf,fract,dist_star,aerosol,cpp3D,muvar,         &
    722720                      zdtlw,zdtsw,fluxsurf_lw,fluxsurf_sw,fluxtop_lw,    &
    723                       fluxabs_sw,fluxtop_dn,OLR_nu,OSR_nu,               &
     721                      fluxabs_sw,fluxtop_dn,OLR_nu,OSR_nu,               &
    724722                      reffrad,tau_col,cloudfrac,totcloudfrac,            &
    725723                      clearsky,firstcall,lastcall)     
    726              
    727724
    728725!             Option to call scheme once more for clear regions
     
    732729                 !!! (temporary solution in callcorrk: do not deallocate if CLFvarying ...)
    733730                 clearsky=.true.
    734                  call callcorrk(ngrid,nlayer,pq,nq,qsurf,           &
     731                 call callcorrk(ngrid,nlayer,pq,nq,qsurf,                  &
    735732                      albedo,emis,mu0,pplev,pplay,pt,                      &
    736733                      tsurf,fract,dist_star,aerosol,cpp3D,muvar,           &
     
    738735                      fluxabs_sw1,fluxtop_dn,OLR_nu1,OSR_nu1,              &
    739736                      reffrad,tau_col1,cloudfrac,totcloudfrac,             &
    740                       clearsky,firstcall,lastcall)
    741                 clearsky = .false.  !! just in case.     
     737                      clearsky,firstcall,lastcall)
     738                clearsky = .false.  !! just in case.     
    742739
    743740                 ! Sum the fluxes and heating rates from cloudy/clear cases
     
    757754                    enddo
    758755
    759                     do nw=1,L_NSPECTV
     756                    do nw=1,L_NSPECTV
    760757                       OSR_nu(ig,nw) = ntf*OSR_nu1(ig,nw) + tf*OSR_nu(ig,nw)                   
    761                     enddo
    762                     do nw=1,L_NSPECTI
     758                    enddo
     759                    do nw=1,L_NSPECTI
    763760                       OLR_nu(ig,nw) = ntf*OLR_nu1(ig,nw) + tf*OLR_nu(ig,nw)                   
    764                     enddo
     761                    enddo
    765762
    766763                 enddo
     
    19391936               enddo
    19401937
    1941 
    1942 
    19431938            endif
    19441939
     
    20972092                print*,'WARNING: tau_col=',tau_col(ig)
    20982093                print*,'at ig=',ig,'in PHYSIQ'
    2099                 !call abort
    21002094             endif
    21012095          end do
Note: See TracChangeset for help on using the changeset viewer.