Ignore:
Timestamp:
Jan 11, 2017, 3:33:51 PM (8 years ago)
Author:
jvatant
Message:

+ Major clean of the new LMDZ.TITAN from too-generic options and routines (water, co2, ocean, surface type ...)
+ From this revision LMDZ.TITAN begins to be really separated from LMDZ.GENERIC
+ Partial desactivation of aerosols, only the dummy case is still enabled to keep the code running ( new aerosol routines to come in followings commits )

JVO

Location:
trunk/LMDZ.TITAN/libf/phytitan
Files:
21 deleted
29 edited

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.TITAN/libf/phytitan/aeropacity.F90

    r1542 r1647  
    11      Subroutine aeropacity(ngrid,nlayer,nq,pplay,pplev,pq, &
    2          aerosol,reffrad,QREFvis3d,QREFir3d,tau_col,cloudfrac,totcloudfrac,clearsky)
     2         aerosol,reffrad,QREFvis3d,QREFir3d,tau_col)
    33
    44       use radinc_h, only : L_TAUMAX,naerkind
    55       use aerosol_mod
    6        USE tracer_h, only: noms,rho_co2,rho_ice
     6       USE tracer_h, only: noms
    77       use comcstfi_mod, only: g
    8        use callkeys_mod, only: aerofixco2,aerofixh2o,kastprof,cloudlvl, &
    9                 CLFvarying,CLFfixval,dusttau,                           &
    10                 pres_bottom_tropo,pres_top_tropo,obs_tau_col_tropo,     &
     8       use callkeys_mod, only: pres_bottom_tropo,pres_top_tropo,obs_tau_col_tropo,  &
    119                pres_bottom_strato,pres_top_strato,obs_tau_col_strato
    1210                 
     
    5553      REAL,INTENT(IN) :: QREFir3d(ngrid,nlayer,naerkind)
    5654      REAL,INTENT(OUT):: tau_col(ngrid) !column integrated visible optical depth
    57       ! BENJAMIN MODIFS
    58       real,intent(in) :: cloudfrac(ngrid,nlayer) ! cloud fraction
    59       real,intent(out) :: totcloudfrac(ngrid) ! total cloud fraction
    60       logical,intent(in) :: clearsky
    6155
    6256      real aerosol0
     
    6963      EXTERNAL CBRT
    7064
    71       INTEGER,SAVE :: i_co2ice=0      ! co2 ice
    72       INTEGER,SAVE :: i_h2oice=0      ! water ice
    73 !$OMP THREADPRIVATE(i_co2ice,i_h2oice)
    74       CHARACTER(LEN=20) :: tracername ! to temporarily store text
    75 
    7665      ! for fixed dust profiles
    77       real topdust, expfactor, zp
    78       REAL taudusttmp(ngrid) ! Temporary dust opacity used before scaling
    79       REAL tauh2so4tmp(ngrid) ! Temporary h2so4 opacity used before scaling
    80 
    81       real CLFtot
     66      real expfactor, zp
    8267
    8368      ! identify tracers
     
    8570
    8671        write(*,*) "Tracers found in aeropacity:"
    87         do iq=1,nq
    88           tracername=noms(iq)
    89           if (tracername.eq."co2_ice") then
    90             i_co2ice=iq
    91           write(*,*) "i_co2ice=",i_co2ice
    92 
    93           endif
    94           if (tracername.eq."h2o_ice") then
    95             i_h2oice=iq
    96             write(*,*) "i_h2oice=",i_h2oice
    97           endif
    98         enddo
    9972
    10073        if (noaero) then
     
    10780        endif
    10881
    109         if ((iaero_co2.ne.0).and.(.not.noaero)) then
    110           print*, 'iaero_co2=  ',iaero_co2
    111         endif
    112         if (iaero_h2o.ne.0) then
    113           print*,'iaero_h2o=  ',iaero_h2o   
    114         endif
    115         if (iaero_dust.ne.0) then
    116           print*,'iaero_dust= ',iaero_dust
    117         endif
    118         if (iaero_h2so4.ne.0) then
    119           print*,'iaero_h2so4= ',iaero_h2so4
    120         endif
    12182        if (iaero_back2lay.ne.0) then
    12283          print*,'iaero_back2lay= ',iaero_back2lay
     
    12788
    12889
    129 !     ---------------------------------------------------------
    130 !==================================================================
    131 !    CO2 ice aerosols
    132 !==================================================================
     90!     ---------------------------------------------------------   
    13391
    134       if (iaero_co2.ne.0) then
    135            iaer=iaero_co2
    136 !       1. Initialization
    137             aerosol(1:ngrid,1:nlayer,iaer)=0.0
    138 !       2. Opacity calculation
    139             if (noaero) then ! aerosol set to zero
    140              aerosol(1:ngrid,1:nlayer,iaer)=0.0
    141             elseif (aerofixco2.or.(i_co2ice.eq.0)) then !  CO2 ice cloud prescribed
    142                aerosol(1:ngrid,1:nlayer,iaer)=1.e-9
    143                !aerosol(1:ngrid,12,iaer)=4.0 ! single cloud layer option
    144             else
    145                DO ig=1, ngrid
    146                   DO l=1,nlayer-1 ! to stop the rad tran bug
    147 
    148                      aerosol0 =                         &
    149                           (  0.75 * QREFvis3d(ig,l,iaer) /        &
    150                           ( rho_co2 * reffrad(ig,l,iaer) )  ) *   &
    151                           ( pq(ig,l,i_co2ice) + 1.E-9 ) *         &
    152                           ( pplev(ig,l) - pplev(ig,l+1) ) / g
    153                      aerosol0           = max(aerosol0,1.e-9)
    154                      aerosol0           = min(aerosol0,L_TAUMAX)
    155                      aerosol(ig,l,iaer) = aerosol0
    156 !                     aerosol(ig,l,iaer) = 0.0
    157 !                     print*, aerosol(ig,l,iaer)
    158 !        using cloud fraction
    159 !                     aerosol(ig,l,iaer) = -log(1 - CLF + CLF*exp(-aerosol0/CLF))
    160 !                     aerosol(ig,l,iaer) = min(aerosol(ig,l,iaer),L_TAUMAX)
    161 
    162 
    163                   ENDDO
    164                ENDDO
    165             end if ! if fixed or varying
    166       end if ! if CO2 aerosols   
    167 !==================================================================
    168 !     Water ice / liquid
    169 !==================================================================
    170 
    171       if (iaero_h2o.ne.0) then
    172            iaer=iaero_h2o
    173 !       1. Initialization
    174             aerosol(1:ngrid,1:nlayer,iaer)=0.0
    175 !       2. Opacity calculation
    176             if (aerofixh2o.or.(i_h2oice.eq.0).or.clearsky) then
    177                aerosol(1:ngrid,1:nlayer,iaer) =1.e-9
    178 
    179                ! put cloud at cloudlvl
    180                if(kastprof.and.(cloudlvl.ne.0.0))then
    181                   ig=1
    182                   do l=1,nlayer
    183                      if(int(cloudlvl).eq.l)then
    184                      !if(cloudlvl.gt.(pplay(ig,l)/pplev(ig,1)))then
    185                         print*,'Inserting cloud at level ',l
    186                         !aerosol(ig,l,iaer)=10.0
    187 
    188                         rho_ice=920.0
    189 
    190                         ! the Kasting approximation
    191                         aerosol(ig,l,iaer) =                      &
    192                           (  0.75 * QREFvis3d(ig,l,iaer) /        &
    193                           ( rho_ice * reffrad(ig,l,iaer) )  ) *   &
    194                           !( pq(ig,l,i_h2oice) + 1.E-9 ) *         &
    195                           ( 4.0e-4 + 1.E-9 ) *         &
    196                           ( pplev(ig,l) - pplev(ig,l+1) ) / g
    197 
    198 
    199                         open(115,file='clouds.out',form='formatted')
    200                         write(115,*) l,aerosol(ig,l,iaer)
    201                         close(115)
    202 
    203                         return
    204                      endif
    205                   end do
    206 
    207                   call abort
    208                endif
    209 
    210             else
    211 
    212                do ig=1, ngrid
    213                   do l=1,nlayer-1 ! to stop the rad tran bug
    214 
    215                      aerosol(ig,l,iaer) =                                    & !modification by BC
    216                           (  0.75 * QREFvis3d(ig,l,iaer) /        &
    217                           ( rho_ice * reffrad(ig,l,iaer) )  ) *   &
    218                           !  pq(ig,l,i_h2oice) *                   & !JL I dropped the +1e-9 here to have the same
    219                           !( pplev(ig,l) - pplev(ig,l+1) ) / g       !   opacity in the clearsky=true and the
    220                                                                      !   clear=false/pq=0 case
    221                           ( pq(ig,l,i_h2oice) + 1.E-9 ) *         & ! Doing this makes the code unstable, so I have restored it (RW)
    222                           ( pplev(ig,l) - pplev(ig,l+1) ) / g
    223 
    224                   enddo
    225                enddo
    226 
    227                if(CLFvarying)then
    228                   call totalcloudfrac(ngrid,nlayer,nq,cloudfrac,totcloudfrac,pplev,pq,aerosol(1,1,iaer))
    229                   do ig=1, ngrid
    230                      do l=1,nlayer-1 ! to stop the rad tran bug
    231                         CLFtot  = max(totcloudfrac(ig),0.01)
    232                         aerosol(ig,l,iaer)=aerosol(ig,l,iaer)/CLFtot
    233                         aerosol(ig,l,iaer) = max(aerosol(ig,l,iaer),1.e-9)
    234                      enddo
    235                   enddo
    236                else
    237                   do ig=1, ngrid
    238                      do l=1,nlayer-1 ! to stop the rad tran bug
    239                         CLFtot  = CLFfixval
    240                         aerosol(ig,l,iaer)=aerosol(ig,l,iaer)/CLFtot
    241                         aerosol(ig,l,iaer) = max(aerosol(ig,l,iaer),1.e-9)
    242                      enddo
    243                   enddo
    244               end if!(CLFvarying)
    245             endif !(aerofixed.or.(i_h2oice.eq.0).or.clearsky)
    246              
    247       end if ! End if h2o aerosol
    248 
    249 !==================================================================
    250 !             Dust
    251 !==================================================================
    252       if (iaero_dust.ne.0) then
    253           iaer=iaero_dust
    254 !         1. Initialization
    255           aerosol(1:ngrid,1:nlayer,iaer)=0.0
    256          
    257           topdust=30.0 ! km  (used to be 10.0 km) LK
    258 
    259 !       2. Opacity calculation
    260 
    261 !           expfactor=0.
    262            DO l=1,nlayer-1
    263              DO ig=1,ngrid
    264 !             Typical mixing ratio profile
    265 
    266                  zp=(pplev(ig,1)/pplay(ig,l))**(70./topdust)
    267                  expfactor=max(exp(0.007*(1.-max(zp,1.))),1.e-3)
    268 
    269 !             Vertical scaling function
    270               aerosol(ig,l,iaer)= (pplev(ig,l)-pplev(ig,l+1)) &
    271                *expfactor
    272 
    273 
    274              ENDDO
    275            ENDDO
    276 
    277 !          Rescaling each layer to reproduce the choosen (or assimilated)
    278 !          dust extinction opacity at visible reference wavelength, which
    279 !          is scaled to the surface pressure pplev(ig,1)
    280 
    281             taudusttmp(1:ngrid)=0.
    282               DO l=1,nlayer
    283                 DO ig=1,ngrid
    284                    taudusttmp(ig) = taudusttmp(ig) &
    285                           +  aerosol(ig,l,iaer)
    286                 ENDDO
    287               ENDDO
    288             DO l=1,nlayer-1
    289                DO ig=1,ngrid
    290                   aerosol(ig,l,iaer) = max(1E-20, &
    291                           dusttau &
    292                        *  pplev(ig,1) / pplev(ig,1) &
    293                        *  aerosol(ig,l,iaer) &
    294                        /  taudusttmp(ig))
    295 
    296               ENDDO
    297             ENDDO
    298       end if ! If dust aerosol   
    299 
    300 !==================================================================
    301 !           H2SO4
    302 !==================================================================
    303 ! added by LK
    304       if (iaero_h2so4.ne.0) then
    305          iaer=iaero_h2so4
    306 
    307 !       1. Initialization
    308          aerosol(1:ngrid,1:nlayer,iaer)=0.0
    309 
    310 
    311 !       2. Opacity calculation
    312 
    313 !           expfactor=0.
    314          DO l=1,nlayer-1
    315             DO ig=1,ngrid
    316 !              Typical mixing ratio profile
    317 
    318                zp=(pplev(ig,1)/pplay(ig,l))**(70./30) !emulating topdust
    319                expfactor=max(exp(0.007*(1.-max(zp,1.))),1.e-3)
    320 
    321 !             Vertical scaling function
    322                aerosol(ig,l,iaer)= (pplev(ig,l)-pplev(ig,l+1))*expfactor
    323 
    324             ENDDO
    325          ENDDO
    326          tauh2so4tmp(1:ngrid)=0.
    327          DO l=1,nlayer
    328             DO ig=1,ngrid
    329                tauh2so4tmp(ig) = tauh2so4tmp(ig) + aerosol(ig,l,iaer)
    330             ENDDO
    331          ENDDO
    332          DO l=1,nlayer-1
    333             DO ig=1,ngrid
    334                aerosol(ig,l,iaer) = max(1E-20, &
    335                           1 &
    336                        *  pplev(ig,1) / pplev(ig,1) &
    337                        *  aerosol(ig,l,iaer) &
    338                        /  tauh2so4tmp(ig))
    339 
    340             ENDDO
    341          ENDDO
    342 
    343 ! 1/700. is assuming a "sulfurtau" of 1
    344 ! Sulfur aerosol routine to be improved.
    345 !                     aerosol0 =                         &
    346 !                          (  0.75 * QREFvis3d(ig,l,iaer) /        &
    347 !                          ( rho_h2so4 * reffrad(ig,l,iaer) )  ) *   &
    348 !                          ( pq(ig,l,i_h2so4) + 1.E-9 ) *         &
    349 !                          ( pplev(ig,l) - pplev(ig,l+1) ) / g
    350 !                     aerosol0           = max(aerosol0,1.e-9)
    351 !                     aerosol0           = min(aerosol0,L_TAUMAX)
    352 !                     aerosol(ig,l,iaer) = aerosol0
    353 
    354 !                  ENDDO
    355 !               ENDDO
    356       end if
    357  
    358            
    359 !     ---------------------------------------------------------
    36092!==================================================================
    36193!    Two-layer aerosols (unknown composition)
  • trunk/LMDZ.TITAN/libf/phytitan/aerosol_mod.F90

    r1315 r1647  
    88!                 corresponding aerosol was not activated in callphys.def
    99!                 -- otherwise a value is given in iniaerosol
    10       integer :: iaero_co2 = 0
    11       integer :: iaero_h2o = 0
    12       integer :: iaero_dust = 0
    13       integer :: iaero_h2so4 = 0
    1410      logical :: noaero = .false.
    1511
    1612! two-layer simple aerosol model
    1713      integer :: iaero_back2lay = 0
    18 !$OMP THREADPRIVATE(iaero_co2,iaero_h2o,iaero_dust,iaero_h2so4,noaero,iaero_back2lay)
     14!$OMP THREADPRIVATE(noaero,iaero_back2lay)
    1915     
    2016!==================================================================
  • trunk/LMDZ.TITAN/libf/phytitan/calc_cpp_mugaz.F90

    r1397 r1647  
    3838         else
    3939            ! all values at 300 K from Engineering Toolbox
    40             if(igas.eq.igas_CO2)then
    41                mugaz_c = mugaz_c + 44.01*gfrac(igas)
    42             elseif(igas.eq.igas_N2)then
     40            if(igas.eq.igas_N2)then
    4341               mugaz_c = mugaz_c + 28.01*gfrac(igas)
    4442            elseif(igas.eq.igas_H2)then
    4543               mugaz_c = mugaz_c + 2.01*gfrac(igas)
    46             elseif(igas.eq.igas_He)then
    47                mugaz_c = mugaz_c + 4.003*gfrac(igas)
    48             elseif(igas.eq.igas_H2O)then
    49                mugaz_c = mugaz_c + 18.02*gfrac(igas)
    50             elseif(igas.eq.igas_SO2)then
    51                mugaz_c = mugaz_c + 64.066*gfrac(igas)
    52             elseif(igas.eq.igas_H2S)then
    53                mugaz_c = mugaz_c + 34.08*gfrac(igas)
    5444            elseif(igas.eq.igas_CH4)then
    5545               mugaz_c = mugaz_c + 16.04*gfrac(igas)
    56             elseif(igas.eq.igas_NH3)then
    57                mugaz_c = mugaz_c + 17.03*gfrac(igas)
    5846            elseif(igas.eq.igas_C2H6)then
    5947               ! C2H6 http://encyclopedia.airliquide.com/Encyclopedia.asp?GasID=28
     
    7765         else
    7866            ! all values at 300 K from Engineering Toolbox
    79             if(igas.eq.igas_CO2)then
    80                !cpp_c   = cpp_c   + 0.744*gfrac(igas) ! @ ~210 K (better for
    81                !Mars conditions)
    82                cpp_c   = cpp_c   + 0.846*gfrac(igas)*44.01/mugaz_c
    83             elseif(igas.eq.igas_N2)then
     67            if(igas.eq.igas_N2)then
    8468               cpp_c   = cpp_c   + 1.040*gfrac(igas)*28.01/mugaz_c
    8569            elseif(igas.eq.igas_H2)then
    8670               cpp_c   = cpp_c   + 14.31*gfrac(igas)*2.01/mugaz_c
    87             elseif(igas.eq.igas_He)then
    88                cpp_c   = cpp_c   + 5.19*gfrac(igas)*4.003/mugaz_c
    89             elseif(igas.eq.igas_H2O)then
    90                cpp_c   = cpp_c   + 1.864*gfrac(igas)*18.02/mugaz_c
    91             elseif(igas.eq.igas_SO2)then
    92                cpp_c   = cpp_c   + 0.64*gfrac(igas)*64.066/mugaz_c
    93             elseif(igas.eq.igas_H2S)then
    94                cpp_c   = cpp_c   + 1.003*gfrac(igas)*34.08/mugaz_c ! from wikipedia...
    9571            elseif(igas.eq.igas_CH4)then
    9672               cpp_c   = cpp_c   + 2.226*gfrac(igas)*16.04/mugaz_c
    97             elseif(igas.eq.igas_NH3)then
    98                cpp_c   = cpp_c   + 2.175*gfrac(igas)*17.03/mugaz_c
    99                print*,'WARNING, cpp for NH3 may be for liquid'
    10073            elseif(igas.eq.igas_C2H6)then
    10174               ! C2H6
  • trunk/LMDZ.TITAN/libf/phytitan/calc_rayleigh.F90

    r1397 r1647  
    6262            tauconsti(igas) = 0.0
    6363         else
    64             if(igas.eq.igas_CO2) then
    65                tauconsti(igas) = (8.7/g)*1.527*scalep/P0
    66             elseif(igas.eq.igas_N2)then
     64            if(igas.eq.igas_N2)then
    6765               tauconsti(igas) = (9.81/g)*8.569E-3*scalep/(P0/93.0)
    68             elseif(igas.eq.igas_H2O)then
    69 !               tauconsti(igas) = (10.0/g)*9.22E-3*scalep/101325.0
    70                tauconsti(igas) = 1.98017E-10/(g*mugaz*100.)
    7166            elseif(igas.eq.igas_H2)then
    7267               tauconsti(igas) = (10.0/g)*0.0241*scalep/101325.0
     
    7469               ! uses n=1.000132 from Optics, Fourth Edition.
    7570               ! was out by a factor 2!
    76             elseif(igas.eq.igas_He)then
    77                tauconsti(igas) = (10.0/g)*0.00086*scalep/101325.0
    7871            else
    7972               print*,'Error in calc_rayleigh: Gas species not recognised!'
     
    114107                  tauvari(igas)   = 0.0
    115108               else
    116                   if(igas.eq.igas_CO2)then
    117                      tauvari(igas) = (1.0+0.013/wl**2)/wl**4
    118                   elseif(igas.eq.igas_N2)then
     109                  if(igas.eq.igas_N2)then
    119110                     tauvari(igas) = (1.0+0.0113/wl**2+0.00013/wl**4)/wl**4
    120                   elseif(igas.eq.igas_H2O)then
    121 !                     tauvari(igas) = 1.0/wl**4 ! to be improved...
    122                      tauvari(igas) = (5.7918E6/(2.38E2-1/wl**2)+1.679E5/(57.36E0-1/wl**2))**2/wl**4
    123111                  elseif(igas.eq.igas_H2)then
    124                      tauvari(igas) = 1.0/wl**4
    125                   elseif(igas.eq.igas_He)then
    126112                     tauvari(igas) = 1.0/wl**4
    127113                  else
  • trunk/LMDZ.TITAN/libf/phytitan/callcorrk.F90

    r1529 r1647  
    66          fluxabs_sw,fluxtop_dn,                               &
    77          OLR_nu,OSR_nu,                                       &
    8           tau_col,cloudfrac,totcloudfrac,                      &
    9           clearsky,firstcall,lastcall)
     8          tau_col,firstcall,lastcall)
    109
    1110      use radinc_h
    1211      use radcommon_h
    13       use watercommon_h
    1412      use datafile_mod, only: datadir
    1513      use ioipsl_getin_p_mod, only: getin_p
    1614      use gases_h
    17       use radii_mod, only : su_aer_radii,co2_reffrad,h2o_reffrad,dust_reffrad,h2so4_reffrad,back2lay_reffrad
    18       use aerosol_mod, only : iaero_co2,iaero_h2o,iaero_dust,iaero_h2so4, iaero_back2lay
     15      use radii_mod, only : su_aer_radii,back2lay_reffrad
     16      use aerosol_mod, only : iaero_back2lay
    1917      USE tracer_h
    2018      use comcstfi_mod, only: pi, mugaz, cpp
    21       use callkeys_mod, only: varactive,diurnal,tracer,water,nosurf,varfixed,satval,        &
    22                               kastprof,strictboundcorrk,specOLR,CLFvarying
     19      use callkeys_mod, only: diurnal,tracer,nosurf,satval,        &
     20                              strictboundcorrk,specOLR
    2321
    2422      implicit none
     
    6260      REAL,INTENT(IN) :: dist_star                 ! Distance star-planet (AU).
    6361      REAL,INTENT(IN) :: muvar(ngrid,nlayer+1)
    64       REAL,INTENT(IN) :: cloudfrac(ngrid,nlayer)   ! Fraction of clouds (%).
    65       logical,intent(in) :: clearsky
    6662      logical,intent(in) :: firstcall              ! Signals first call to physics.
    6763      logical,intent(in) :: lastcall               ! Signals last call to physics.
     
    8076      REAL,INTENT(OUT) :: OSR_nu(ngrid,L_NSPECTV)        ! Outgoing SW radition in each band (Normalized to the band width (W/m2/cm-1).
    8177      REAL,INTENT(OUT) :: tau_col(ngrid)                 ! Diagnostic from aeropacity.
    82       REAL,INTENT(OUT) :: albedo_equivalent(ngrid)       ! Spectrally Integrated Albedo. For Diagnostic. By MT2015
    83       REAL,INTENT(OUT) :: totcloudfrac(ngrid)            ! Column Fraction of clouds (%).
     78      REAL,INTENT(OUT) :: albedo_equivalent(ngrid)       ! Spectrally Integrated Albedo. For Diagnostic. By MT2015 
    8479     
    8580     
    86      
    87      
    88 
    8981      ! Globally varying aerosol optical properties on GCM grid ; not needed everywhere so not in radcommon_h.   
    9082      REAL :: QVISsQREF3d(ngrid,nlayer,L_NSPECTV,naerkind)
     
    230222       
    231223
    232          if((igcm_h2o_vap.eq.0) .and. varactive)then
    233             print*,'varactive in callcorrk but no h2o_vap tracer.'
    234             stop
    235          endif
    236 
    237224         OLR_nu(:,:) = 0.
    238225         OSR_nu(:,:) = 0.
     
    278265
    279266      do iaer=1,naerkind
    280 
    281          if ((iaer.eq.iaero_co2).and.tracer.and.(igcm_co2_ice.gt.0)) then ! Treat condensed co2 particles.
    282             call co2_reffrad(ngrid,nlayer,nq,pq,reffrad(1,1,iaero_co2))
    283             print*,'Max. CO2 ice particle size = ',maxval(reffrad(1:ngrid,1:nlayer,iaer))/1.e-6,' um'
    284             print*,'Min. CO2 ice particle size = ',minval(reffrad(1:ngrid,1:nlayer,iaer))/1.e-6,' um'
    285          end if
    286          
    287          if ((iaer.eq.iaero_h2o).and.water) then ! Treat condensed water particles. To be generalized for other aerosols ...
    288             call h2o_reffrad(ngrid,nlayer,pq(1,1,igcm_h2o_ice),pt, &
    289                              reffrad(1,1,iaero_h2o),nueffrad(1,1,iaero_h2o))
    290             print*,'Max. H2O cloud particle size = ',maxval(reffrad(1:ngrid,1:nlayer,iaer))/1.e-6,' um'
    291             print*,'Min. H2O cloud particle size = ',minval(reffrad(1:ngrid,1:nlayer,iaer))/1.e-6,' um'
    292          endif
    293          
    294          if(iaer.eq.iaero_dust)then
    295             call dust_reffrad(ngrid,nlayer,reffrad(1,1,iaero_dust))
    296             print*,'Dust particle size = ',reffrad(1,1,iaer)/1.e-6,' um'
    297          endif
    298          
    299          if(iaer.eq.iaero_h2so4)then
    300             call h2so4_reffrad(ngrid,nlayer,reffrad(1,1,iaero_h2so4))
    301             print*,'H2SO4 particle size =',reffrad(1,1,iaer)/1.e-6,' um'
    302          endif
    303          
     267     
    304268          if(iaer.eq.iaero_back2lay)then
    305269            call back2lay_reffrad(ngrid,reffrad(1,1,iaero_back2lay),nlayer,pplev)
     
    323287      call aeropacity(ngrid,nlayer,nq,pplay,pplev,pq,aerosol,      &
    324288           reffrad,QREFvis3d,QREFir3d,                             &
    325            tau_col,cloudfrac,totcloudfrac,clearsky)               
     289           tau_col)               
    326290         
    327291
     
    506470
    507471
    508 !-----------------------------------------------------------------------
    509 !     Water vapour (to be generalised for other gases eventually ...)
    510 !-----------------------------------------------------------------------
     472     do k=1,L_LEVELS
     473         qvar(k) = 1.0D-7
     474     end do
     475
     476
     477       ! IMPORTANT: Now convert from kg/kg to mol/mol.
     478!       do k=1,L_LEVELS
     479!          qvar(k) = qvar(k)/(epsi+qvar(k)*(1.-epsi))
     480!       end do
     481
     482       DO l=1,nlayer
     483          muvarrad(2*l)   = muvar(ig,nlayer+2-l)
     484          muvarrad(2*l+1) = (muvar(ig,nlayer+2-l)+muvar(ig,max(nlayer+1-l,1)))/2
     485       END DO
    511486     
    512       if(varactive)then
    513 
    514          i_var=igcm_h2o_vap
    515          do l=1,nlayer
    516             qvar(2*l)   = pq(ig,nlayer+1-l,i_var)
    517             qvar(2*l+1) = pq(ig,nlayer+1-l,i_var)   
    518 !JL13index            qvar(2*l+1) = (pq(ig,nlayer+1-l,i_var)+pq(ig,max(nlayer-l,1),i_var))/2   
    519 !JL13index            ! Average approximation as for temperature...
    520          end do
    521          qvar(1)=qvar(2)
    522 
    523       elseif(varfixed)then
    524 
    525          do l=1,nlayer ! Here we will assign fixed water vapour profiles globally.
    526             RH = satval * ((pplay(ig,l)/pplev(ig,1) - 0.02) / 0.98)
    527             if(RH.lt.0.0) RH=0.0
    528            
    529             ptemp=pplay(ig,l)
    530             Ttemp=pt(ig,l)
    531             call watersat(Ttemp,ptemp,qsat)
    532 
    533             !pq_temp(l) = qsat      ! fully saturated everywhere
    534             pq_temp(l) = RH * qsat ! ~realistic profile (e.g. 80% saturation at ground)
    535          end do
    536          
    537          do l=1,nlayer
    538             qvar(2*l)   = pq_temp(nlayer+1-l)
    539             qvar(2*l+1) = (pq_temp(nlayer+1-l)+pq_temp(max(nlayer-l,1)))/2
    540          end do
    541          
    542          qvar(1)=qvar(2)
    543 
    544          ! Lowest layer of atmosphere
    545          RH = satval * (1 - 0.02) / 0.98
    546          if(RH.lt.0.0) RH=0.0
    547 
    548 !         ptemp = pplev(ig,1)
    549 !         Ttemp = tsurf(ig)
    550 !         call watersat(Ttemp,ptemp,qsat)
    551 
    552          qvar(2*nlayer+1)= RH * qsat ! ~realistic profile (e.g. 80% saturation at ground)
    553  
    554       else
    555          do k=1,L_LEVELS
    556             qvar(k) = 1.0D-7
    557          end do
    558       end if ! varactive/varfixed
    559 
    560       if(.not.kastprof)then
    561          ! IMPORTANT: Now convert from kg/kg to mol/mol.
    562          do k=1,L_LEVELS
    563             qvar(k) = qvar(k)/(epsi+qvar(k)*(1.-epsi))
    564          end do
    565       end if
    566 
    567 !-----------------------------------------------------------------------
    568 !     kcm mode only !
    569 !-----------------------------------------------------------------------
    570 
    571       if(kastprof)then
    572 
    573          ! Initial values equivalent to mugaz.
    574          DO l=1,nlayer
    575             muvarrad(2*l)   = mugaz
    576             muvarrad(2*l+1) = mugaz
    577          END DO
    578 
    579          if(ngasmx.gt.1)then
    580 
    581             DO l=1,nlayer
    582                muvarrad(2*l)   =  muvar(ig,nlayer+2-l)
    583                muvarrad(2*l+1) = (muvar(ig,nlayer+2-l) + &
    584                                   muvar(ig,max(nlayer+1-l,1)))/2
    585             END DO
    586      
    587             muvarrad(1) = muvarrad(2)
    588             muvarrad(2*nlayer+1) = muvar(ig,1)
    589 
    590             print*,'Recalculating qvar with VARIABLE epsi for kastprof'
    591             print*,'Assumes that the variable gas is H2O!!!'
    592             print*,'Assumes that there is only one tracer'
    593            
    594             !i_var=igcm_h2o_vap
    595             i_var=1
    596            
    597             if(nq.gt.1)then
    598                print*,'Need 1 tracer only to run kcm1d.e'
    599                stop
    600             endif
    601            
    602             do l=1,nlayer
    603                vtmp(l)=pq(ig,l,i_var)/(epsi+pq(ig,l,i_var)*(1.-epsi))
    604                !vtmp(l)=pq(ig,l,i_var)*muvar(ig,l+1)/mH2O !JL to be changed
    605             end do
    606 
    607             do l=1,nlayer
    608                qvar(2*l)   = vtmp(nlayer+1-l)
    609                qvar(2*l+1) = vtmp(nlayer+1-l)
    610 !               qvar(2*l+1) = ( vtmp(nlayer+1-l) + vtmp(max(nlayer-l,1)) )/2
    611             end do
    612             qvar(1)=qvar(2)
    613 
    614             print*,'Warning: reducing qvar in callcorrk.'
    615             print*,'Temperature profile no longer consistent ', &
    616                    'with saturated H2O. qsat=',satval
    617                    
    618             do k=1,L_LEVELS
    619                qvar(k) = qvar(k)*satval
    620             end do
    621 
    622          endif
    623       else ! if kastprof
    624          DO l=1,nlayer
    625             muvarrad(2*l)   = muvar(ig,nlayer+2-l)
    626             muvarrad(2*l+1) = (muvar(ig,nlayer+2-l)+muvar(ig,max(nlayer+1-l,1)))/2
    627          END DO
    628      
    629          muvarrad(1) = muvarrad(2)
    630          muvarrad(2*nlayer+1)=muvar(ig,1)         
    631       endif ! if kastprof
     487       muvarrad(1) = muvarrad(2)
     488       muvarrad(2*nlayer+1)=muvar(ig,1)         
    632489     
    633490      ! Keep values inside limits for which we have radiative transfer coefficients !!!
     
    949806
    950807      ! See physiq.F for explanations about CLFvarying. This is temporary.
    951       if (lastcall .and. .not.CLFvarying) then
     808      if (lastcall) then
    952809        IF( ALLOCATED( gasi ) ) DEALLOCATE( gasi )
    953810        IF( ALLOCATED( gasv ) ) DEALLOCATE( gasv )
  • trunk/LMDZ.TITAN/libf/phytitan/callkeys_mod.F90

    r1520 r1647  
    44      logical,save :: callrad,corrk,calldifv,UseTurbDiff
    55!$OMP THREADPRIVATE(callrad,corrk,calldifv,UseTurbDiff)
    6       logical,save :: calladj,co2cond,callsoil
    7 !$OMP THREADPRIVATE(calladj,co2cond,callsoil)
     6      logical,save :: calladj,callsoil
     7!$OMP THREADPRIVATE(calladj,callsoil)
    88      logical,save :: season,diurnal,tlocked,rings_shadow,lwrite
    99!$OMP THREADPRIVATE(season,diurnal,tlocked,rings_shadow,lwrite)
    1010      logical,save :: callstats,calleofdump
    1111!$OMP THREADPRIVATE(callstats,calleofdump)
    12       logical,save :: callgasvis,continuum,H2Ocont_simple,graybody
    13 !$OMP THREADPRIVATE(callgasvis,continuum,H2Ocont_simple,graybody)
     12      logical,save :: callgasvis,continuum,graybody
     13!$OMP THREADPRIVATE(callgasvis,continuum,graybody)
    1414      logical,save :: strictboundcorrk                                     
    1515!$OMP THREADPRIVATE(strictboundcorrk)
     
    1919      logical,save :: meanOLR
    2020      logical,save :: specOLR
    21       logical,save :: kastprof
    22 !$OMP THREADPRIVATE(enertest,nonideal,meanOLR,kastprof)
     21!$OMP THREADPRIVATE(enertest,nonideal,meanOLR)
    2322      logical,save :: newtonian
    2423      logical,save :: check_cpp_match
     
    2928      logical,save :: stelbbody
    3029      logical,save :: ozone
    31       logical,save :: nearco2cond
    3230      logical,save :: tracer
    3331      logical,save :: mass_redistrib
    34 !$OMP THREADPRIVATE(stelbbody,ozone,nearco2cond,tracer,mass_redistrib)
    35       logical,save :: varactive
    36       logical,save :: varfixed
    37       logical,save :: radfixed
     32!$OMP THREADPRIVATE(stelbbody,ozone,tracer,mass_redistrib)
    3833      logical,save :: sedimentation
    39 !$OMP THREADPRIVATE(varactive,varfixed,radfixed,sedimentation)
    40       logical,save :: water,watercond,waterrain
    41 !$OMP THREADPRIVATE(water,watercond,waterrain)
    42       logical,save :: aeroco2,aeroh2o,aeroh2so4,aeroback2lay
    43 !$OMP THREADPRIVATE(aeroco2,aeroh2o,aeroh2so4,aeroback2lay)
    44       logical,save :: aerofixco2,aerofixh2o
    45 !$OMP THREADPRIVATE(aerofixco2,aerofixh2o)
    46       logical,save :: hydrology
    47       logical,save :: sourceevol
    48       logical,save :: CLFvarying
     34!$OMP THREADPRIVATE(sedimentation)
     35      logical,save :: aeroback2lay
     36!$OMP THREADPRIVATE(aeroback2lay)
    4937      logical,save :: nosurf
    5038      logical,save :: oblate
    51 !$OMP THREADPRIVATE(hydrology,sourceevol,CLFvarying,nosurf,oblate)
    52       logical,save :: ok_slab_ocean
    53       logical,save :: ok_slab_sic
    54       logical,save :: ok_slab_heat_transp
    55       logical,save :: albedo_spectral_mode
    56 !$OMP THREADPRIVATE(ok_slab_ocean,ok_slab_sic,ok_slab_heat_transp,albedo_spectral_mode)
     39!$OMP THREADPRIVATE(nosurf,oblate)
    5740
    5841      integer,save :: iddist
     
    6346
    6447      real,save :: topdustref
    65       real,save :: Nmix_co2
    66       real,save :: dusttau
    6748      real,save :: Fat1AU
    6849      real,save :: stelTbb
    69 !$OMP THREADPRIVATE(topdustref,Nmix_co2,dusttau,Fat1AU,stelTbb)
    70       real,save :: Tstrat
     50!$OMP THREADPRIVATE(topdustref,Fat1AU,stelTbb)
    7151      real,save :: tplanet
    7252      real,save :: obs_tau_col_tropo
    7353      real,save :: obs_tau_col_strato
    74 !$OMP THREADPRIVATE(Tstrat,tplanet,obs_tau_col_tropo,obs_tau_col_strato)
     54!$OMP THREADPRIVATE(tplanet,obs_tau_col_tropo,obs_tau_col_strato)
    7555      real,save :: pres_bottom_tropo
    7656      real,save :: pres_top_tropo
     
    8161      real,save :: size_strato
    8262      real,save :: satval
    83       real,save :: CLFfixval
    84       real,save :: n2mixratio
    85 !$OMP THREADPRIVATE(size_tropo,size_strato,satval,CLFfixval,n2mixratio)
    86       real,save :: co2supsat
     63!$OMP THREADPRIVATE(size_tropo,size_strato,satval)
    8764      real,save :: pceil
    88       real,save :: albedosnow
    89       real,save :: albedoco2ice
    90       real,save :: maxicethick
    91 !$OMP THREADPRIVATE(co2supsat,pceil,albedosnow,albedoco2ice,maxicethick)
    92       real,save :: Tsaldiff
     65!$OMP THREADPRIVATE(pceil)
    9366      real,save :: tau_relax
    94       real,save :: cloudlvl
    95       real,save :: icetstep
    9667      real,save :: intheat
    97 !$OMP THREADPRIVATE(Tsaldiff,tau_relax,cloudlvl,icetstep,intheat)
     68!$OMP THREADPRIVATE(tau_relax,intheat)
    9869      real,save :: flatten
    9970      real,save :: Rmean
  • trunk/LMDZ.TITAN/libf/phytitan/callsedim.F

    r1477 r1647  
    44
    55      use radinc_h, only : naerkind
    6       use radii_mod, only: h2o_reffrad
    7       use aerosol_mod, only : iaero_h2o
    8       USE tracer_h, only : igcm_co2_ice,igcm_h2o_ice,radius,rho_q
     6      USE tracer_h, only : radius, rho_q
    97      use comcstfi_mod, only: g
    10       use callkeys_mod, only : water
    118
    129      IMPLICIT NONE
     
    6259      real epaisseur (ngrid,nlay) ! Layer thickness (m)
    6360      real wq(ngrid,nlay+1) ! displaced tracer mass (kg.m-2)
    64 c      real dens(ngrid,nlay) ! Mean density of the ice part. accounting for dust core
    6561
    6662
     
    7369      IF (firstcall) THEN
    7470        firstcall=.false.
    75         ! add some tests on presence of required tracers/aerosols:
    76         if (water) then
    77           if (igcm_h2o_ice.eq.0) then
    78             write(*,*) "callsedim error: water=.true.",
    79      &                 " but igcm_h2o_ice=0"
    80           stop
    81           endif
    82           if (iaero_h2o.eq.0) then
    83             write(*,*) "callsedim error: water=.true.",
    84      &                 " but iaero_ho2=0"
    85           stop
    86           endif
    87         endif
    8871      ENDIF ! of IF (firstcall)
    8972     
     
    10689 
    10790      do iq=1,nq
    108        if((radius(iq).gt.1.e-9).and.(iq.ne.igcm_co2_ice)) then   
    109 !         (no sedim for gases, and co2_ice sedim is done in condense_co2)     
     91       if(radius(iq).gt.1.e-9) then   
     92!         (no sedim for gases)     
    11093
    11194! store locally updated tracers
     
    120103! Sedimentation
    121104!======================================================================
    122 ! Water         
    123           if (water.and.(iq.eq.igcm_h2o_ice)) then
    124             ! compute radii for h2o_ice
    125              call h2o_reffrad(ngrid,nlay,zqi(1,1,igcm_h2o_ice),zt,
    126      &                reffrad(1,1,iaero_h2o),nueffrad(1,1,iaero_h2o))
    127             ! call sedimentation for h2o_ice
    128              call newsedim(ngrid,nlay,ngrid*nlay,ptimestep,
    129      &            pplev,masse,epaisseur,zt,reffrad(1,1,iaero_h2o),
    130      &            rho_q(iq),zqi(1,1,igcm_h2o_ice),wq)
    131 
    132105! General Case
    133           else
    134106             call newsedim(ngrid,nlay,1,ptimestep,
    135107     &            pplev,masse,epaisseur,zt,radius(iq),rho_q(iq),
    136108     &            zqi(1,1,iq),wq)
    137           endif
    138109
    139110!=======================================================================
     
    152123            ENDDO
    153124          ENDDO
    154        endif ! of no gases no co2_ice
     125       endif ! of no gases
    155126      enddo ! of do iq=1,nq
    156127      return
  • trunk/LMDZ.TITAN/libf/phytitan/comsoil_h.F90

    r1538 r1647  
    88! Full soil layer depths are set as: layer(k)=lay1_soil*alpha_soil**(k-1) , k=1,nsoil
    99! Mid soil layer depths are set as: mlayer(k)=lay1_soil*alpha_soil**(k-1/2) , k=0,nsoil-1
    10   real,save :: lay1_soil=2.e-4 ! depth (m) of first full soil layer (may be set in callphys.def)
     10  real,save :: lay1_soil=2.e-3 ! depth (m) of first full soil layer (may be set in callphys.def)
    1111  real,save :: alpha_soil=2 ! coefficient for soil layer thickness (may be set in callphys.def)
    1212!$OMP THREADPRIVATE(nsoilmx,lay1_soil,alpha_soil)
  • trunk/LMDZ.TITAN/libf/phytitan/convadj.F

    r1397 r1647  
    88      USE tracer_h
    99      use comcstfi_mod, only: g
    10       use callkeys_mod, only: tracer,water
     10      use callkeys_mod, only: tracer
    1111
    1212      implicit none
     
    1616!     Purpose
    1717!     -------
    18 !     Calculates dry convective adjustment. If one tracer is CO2,
    19 !     we take into account the molecular mass variation (e.g. when
    20 !     CO2 condenses) to trigger convection (F. Forget 01/2005)
     18!     Calculates dry convective adjustment.
    2119!
    2220!     Authors
     
    6260
    6361!     Tracers
    64       INTEGER iq,ico2
    65       save ico2
    66 !$OMP THREADPRIVATE(ico2)
     62      INTEGER iq
    6763      REAL zq(ngrid,nlay,nq), zq2(ngrid,nlay,nq)
    68       REAL zqm(nq),zqco2m
    69       real m_co2, m_noco2, A , B
     64      REAL zqm(nq)
     65      real A , B
    7066      save A, B
    7167!$OMP THREADPRIVATE(A,B)
     
    7369      real mtot1, mtot2 , mm1, mm2
    7470       integer l1ref, l2ref
    75       LOGICAL vtest(ngrid),down,firstcall
     71      LOGICAL vtest(ngrid),down, firstcall
    7672      save firstcall
    7773      data firstcall/.true./
     
    8884
    8985      IF (firstcall) THEN
    90         ico2=0
    91         if (tracer) then
    92 !     Prepare Special treatment if one of the tracers is CO2 gas
    93            do iq=1,nq
    94              if (noms(iq).eq."co2") then
    95                 print*,'dont go there'
    96                 stop
    97                 ico2=iq
    98                 m_co2 = 44.01E-3  ! CO2 molecular mass (kg/mol)   
    99                 m_noco2 = 33.37E-3  ! Non condensible mol mass (kg/mol)   
    100 !               Compute A and B coefficient use to compute
    101 !               mean molecular mass Mair defined by
    102 !               1/Mair = q(ico2)/m_co2 + (1-q(ico2))/m_noco2
    103 !               1/Mair = A*q(ico2) + B
    104                 A =(1/m_co2 - 1/m_noco2)
    105                 B=1/m_noco2
    106              end if
    107            enddo
    108         endif
    10986        firstcall=.false.
    11087      ENDIF ! of IF (firstcall)
    111 
     88     
    11289      DO l=1,nlay
    11390         DO ig=1,ngrid
     
    142119      ENDDO
    143120
    144       if (ico2.ne.0) then
    145 !     Special case if one of the tracers is CO2 gas
    146          DO l=1,nlay
    147            DO ig=1,ngrid
    148              zhc(ig,l) = zh2(ig,l)*(A*zq2(ig,l,ico2)+B)
    149            ENDDO
    150          ENDDO
    151        else
    152           CALL scopy(ngrid*nlay,zh2,1,zhc,1)
    153        end if
     121      CALL scopy(ngrid*nlay,zh2,1,zhc,1)
    154122
    155123!     Find out which grid points are convectively unstable
     
    203171              zdsm = dsig(l2)
    204172              zhm = zh2(i, l2)
    205               if(ico2.ne.0) zqco2m = zq2(i,l2,ico2)
    206173
    207174!     Test loop downwards
     
    211178                zdsm = zdsm + dsig(l)
    212179                zhm = zhm + sdsig(l) * (zh2(i, l) - zhm) / zsm
    213                 if(ico2.ne.0) then
    214                   zqco2m =
    215      &            zqco2m + dsig(l) * (zq2(i,l,ico2) - zqco2m) / zdsm
    216                   zhmc = zhm*(A*zqco2m+B)
    217                 else
    218                   zhmc = zhm
    219                 end if
     180                zhmc = zhm
    220181 
    221182!     do we have to extend the column downwards?
     
    260221              end do
    261222              DO l = l1, l2
    262                 if(ico2.ne.0) then
    263                   zalpha=zalpha+
    264      &            ABS(zhc(i,l)/(A+B*zqco2m) -zhm)*dsig(l)
    265                 else
    266                   zalpha=zalpha+ABS(zh2(i,l)-zhm)*dsig(l)
    267                 endif
     223                zalpha=zalpha+ABS(zh2(i,l)-zhm)*dsig(l)
    268224                zh2(i, l) = zhm
    269225!     modifs by RDW !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
     
    306262                 end do
    307263              ENDDO
    308               if (ico2.ne.0) then
    309                 DO l=l1, l2
    310                   zhc(i,l) = zh2(i,l)*(A*zq2(i,l,ico2)+B)
    311                 ENDDO
    312               end if
    313264
    314265
     
    324275!     check conservation
    325276         cadjncons=0.0
    326          if(water)then
    327          do l = 1, nlay
    328             masse = (pplev(i,l) - pplev(i,l+1))/g
    329             iq    = igcm_h2o_vap
    330             cadjncons = cadjncons +
    331      &           masse*(zq2(i,l,iq)-zq(i,l,iq))/ptimestep
    332          end do
    333          endif
    334277
    335278         if(cadjncons.lt.-1.e-6)then
     
    369312            print*,'zh2(ig,:)        = ',zh2(i,l)
    370313         end do
    371          do l = 1, nlay
    372             print*,'zq(ig,:,vap)     = ',zq(i,l,igcm_h2o_vap)
    373          end do
    374          do l = 1, nlay
    375             print*,'zq2(ig,:,vap)    = ',zq2(i,l,igcm_h2o_vap)
    376          end do
    377             print*,'zqm(vap)         = ',zqm(igcm_h2o_vap)
     314!         do l = 1, nlay
     315!            print*,'zq(ig,:,vap)     = ',zq(i,l,igcm_h2o_vap)
     316!         end do
     317!         do l = 1, nlay
     318!            print*,'zq2(ig,:,vap)    = ',zq2(i,l,igcm_h2o_vap)
     319!         end do
     320!            print*,'zqm(vap)         = ',zqm(igcm_h2o_vap)
    378321            print*,'jadrs=',jadrs
    379322
  • trunk/LMDZ.TITAN/libf/phytitan/gases_h.F90

    r1315 r1647  
    1919      ! in analogy with tracer.h ...
    2020      integer :: igas_H2
    21       integer :: igas_He
    22       integer :: igas_H2O
    23       integer :: igas_CO2
    24       integer :: igas_CO
    2521      integer :: igas_N2
    26       integer :: igas_O2
    27       integer :: igas_SO2
    28       integer :: igas_H2S
    2922      integer :: igas_CH4
    30       integer :: igas_NH3
    3123      integer :: igas_C2H2
    3224      integer :: igas_C2H6
    3325!!$OMP THREADPRIVATE(ngasmx,vgas,gnom,gfrac,&
    34 !       !$OMP igas_H2,igas_He,igas_H2O,igas_CO2,igas_CO,igas_N2,&
    35 !       !$OMP igas_O2,igas_SO2,igas_H2S,igas_CH4,igas_NH3,igas_C2H2,igas_C2H6)
     26!       !$OMP igas_H2,igas_N2,igas_CH4,igas_C2H2,igas_C2H6)
    3627
    3728      end module gases_h
  • trunk/LMDZ.TITAN/libf/phytitan/iniaerosol.F

    r1397 r1647  
    44      use radinc_h, only: naerkind
    55      use aerosol_mod
    6       use callkeys_mod, only: aeroco2,aeroh2o,dusttau,aeroh2so4,
    7      &          aeroback2lay
     6      use callkeys_mod, only: aeroback2lay
    87
    98      IMPLICIT NONE
     
    2221
    2322      ia=0
    24       if (aeroco2) then
    25          ia=ia+1
    26          iaero_co2=ia
    27       endif
    28       write(*,*) '--- CO2 aerosol = ', iaero_co2
    29  
    30       if (aeroh2o) then
    31          ia=ia+1
    32          iaero_h2o=ia
    33       endif
    34       write(*,*) '--- H2O aerosol = ', iaero_h2o
    35 
    36       if (dusttau.gt.0) then
    37          ia=ia+1
    38          iaero_dust=ia
    39       endif
    40       write(*,*) '--- Dust aerosol = ', iaero_dust
    41 
    42       if (aeroh2so4) then
    43          ia=ia+1
    44          iaero_h2so4=ia
    45       endif
    46       write(*,*) '--- H2SO4 aerosol = ', iaero_h2so4
    47      
     23       
    4824      if (aeroback2lay) then
    4925         ia=ia+1
     
    5935
    6036      if (ia.eq.0) then  !For the zero aerosol case.
     37         noaero = .true.
    6138         ia = 1
    62          noaero = .true.
    63          iaero_co2=ia
    6439      endif
    6540
  • trunk/LMDZ.TITAN/libf/phytitan/inifis_mod.F90

    r1542 r1647  
    235235     call getin_p("continuum",continuum)
    236236     write(*,*) " continuum = ",continuum
    237 
    238      write(*,*) "use analytic function for H2O continuum ?"
    239      H2Ocont_simple=.false. ! default value
    240      call getin_p("H2Ocont_simple",H2Ocont_simple)
    241      write(*,*) " H2Ocont_simple = ",H2Ocont_simple
    242237 
    243238     write(*,*) "call turbulent vertical diffusion ?"
     
    255250     call getin_p("calladj",calladj)
    256251     write(*,*) " calladj = ",calladj
    257 
    258      write(*,*) "call CO2 condensation ?"
    259      co2cond=.false. ! default value
    260      call getin_p("co2cond",co2cond)
    261      write(*,*) " co2cond = ",co2cond
    262 ! Test of incompatibility
    263      if (co2cond.and.(.not.tracer)) then
    264         print*,'We need a CO2 ice tracer to condense CO2'
    265         call abort
    266      endif
    267  
    268      write(*,*) "CO2 supersaturation level ?"
    269      co2supsat=1.0 ! default value
    270      call getin_p("co2supsat",co2supsat)
    271      write(*,*) " co2supsat = ",co2supsat
    272252
    273253     write(*,*) "Radiative timescale for Newtonian cooling ?"
     
    313293     write(*,*)" specOLR = ",specOLR
    314294
    315      write(*,*)"Operate in kastprof mode?"
    316      kastprof=.false.
    317      call getin_p("kastprof",kastprof)
    318      write(*,*)" kastprof = ",kastprof
    319 
    320295     write(*,*)"Uniform absorption in radiative transfer?"
    321296     graybody=.false.
     
    339314     write(*,*)" alpha_soil = ",alpha_soil
    340315
    341 ! Slab Ocean
    342      write(*,*) "Use slab-ocean ?"
    343      ok_slab_ocean=.false.         ! default value
    344      call getin_p("ok_slab_ocean",ok_slab_ocean)
    345      write(*,*) "ok_slab_ocean = ",ok_slab_ocean
    346      ! Sanity check: for now slab oncean only works in serial mode
    347      if (ok_slab_ocean.and.is_parallel) then
    348        write(*,*) " Error: slab ocean should only be used in serial mode!"
    349        call abort
    350      endif
    351 
    352      write(*,*) "Use slab-sea-ice ?"
    353      ok_slab_sic=.true.         ! default value
    354      call getin_p("ok_slab_sic",ok_slab_sic)
    355      write(*,*) "ok_slab_sic = ",ok_slab_sic
    356 
    357      write(*,*) "Use heat transport for the ocean ?"
    358      ok_slab_heat_transp=.true.   ! default value
    359      call getin_p("ok_slab_heat_transp",ok_slab_heat_transp)
    360      write(*,*) "ok_slab_heat_transp = ",ok_slab_heat_transp
    361 
    362 
    363 
    364 ! Test of incompatibility:
    365 ! if kastprof used, we must be in 1D
    366      if (kastprof.and.(ngrid.gt.1)) then
    367        print*,'kastprof can only be used in 1D!'
    368        call abort
    369      endif
    370 
    371      write(*,*)"Stratospheric temperature for kastprof mode?"
    372      Tstrat=167.0
    373      call getin_p("Tstrat",Tstrat)
    374      write(*,*)" Tstrat = ",Tstrat
    375 
    376316     write(*,*)"Remove lower boundary?"
    377317     nosurf=.false.
     
    441381! TRACERS:
    442382
    443      write(*,*)"Varying H2O cloud fraction?"
    444      CLFvarying=.false.     ! default value
    445      call getin_p("CLFvarying",CLFvarying)
    446      write(*,*)" CLFvarying = ",CLFvarying
    447 
    448      write(*,*)"Value of fixed H2O cloud fraction?"
    449      CLFfixval=1.0                ! default value
    450      call getin_p("CLFfixval",CLFfixval)
    451      write(*,*)" CLFfixval = ",CLFfixval
    452 
    453      write(*,*)"fixed radii for Cloud particles?"
    454      radfixed=.false. ! default value
    455      call getin_p("radfixed",radfixed)
    456      write(*,*)" radfixed = ",radfixed
    457 
    458      if(kastprof)then
    459         radfixed=.true.
    460      endif 
    461 
    462      write(*,*)"Number mixing ratio of CO2 ice particles:"
    463      Nmix_co2=1.e6 ! default value
    464      call getin_p("Nmix_co2",Nmix_co2)
    465      write(*,*)" Nmix_co2 = ",Nmix_co2
    466 
    467383!         write(*,*)"Number of radiatively active aerosols:"
    468384!         naerkind=0. ! default value
     
    470386!         write(*,*)" naerkind = ",naerkind
    471387
    472      write(*,*)"Opacity of dust (if used):"
    473      dusttau=0. ! default value
    474      call getin_p("dusttau",dusttau)
    475      write(*,*)" dusttau = ",dusttau
    476 
    477      write(*,*)"Radiatively active CO2 aerosols?"
    478      aeroco2=.false.     ! default value
    479      call getin_p("aeroco2",aeroco2)
    480      write(*,*)" aeroco2 = ",aeroco2
    481 
    482      write(*,*)"Fixed CO2 aerosol distribution?"
    483      aerofixco2=.false.     ! default value
    484      call getin_p("aerofixco2",aerofixco2)
    485      write(*,*)" aerofixco2 = ",aerofixco2
    486 
    487      write(*,*)"Radiatively active water ice?"
    488      aeroh2o=.false.     ! default value
    489      call getin_p("aeroh2o",aeroh2o)
    490      write(*,*)" aeroh2o = ",aeroh2o
    491 
    492      write(*,*)"Fixed H2O aerosol distribution?"
    493      aerofixh2o=.false.     ! default value
    494      call getin_p("aerofixh2o",aerofixh2o)
    495      write(*,*)" aerofixh2o = ",aerofixh2o
    496 
    497      write(*,*)"Radiatively active sulfuric acid aersols?"
    498      aeroh2so4=.false.     ! default value
    499      call getin_p("aeroh2so4",aeroh2so4)
    500      write(*,*)" aeroh2so4 = ",aeroh2so4
    501          
     388 
    502389!=================================
    503390
     
    553440!=================================
    554441
    555      write(*,*)"Cloud pressure level (with kastprof only):"
    556      cloudlvl=0. ! default value
    557      call getin_p("cloudlvl",cloudlvl)
    558      write(*,*)" cloudlvl = ",cloudlvl
    559 
    560      write(*,*)"Is the variable gas species radiatively active?"
    561      Tstrat=167.0
    562      varactive=.false.
    563      call getin_p("varactive",varactive)
    564      write(*,*)" varactive = ",varactive
    565 
    566      write(*,*)"Is the variable gas species distribution set?"
    567      varfixed=.false.
    568      call getin_p("varfixed",varfixed)
    569      write(*,*)" varfixed = ",varfixed
    570 
    571442     write(*,*)"What is the saturation % of the variable species?"
    572443     satval=0.8
     
    574445     write(*,*)" satval = ",satval
    575446
    576 
    577 ! Test of incompatibility:
    578 ! if varactive, then varfixed should be false
    579      if (varactive.and.varfixed) then
    580        print*,'if varactive, varfixed must be OFF!'
    581        stop
    582      endif
    583 
    584447     write(*,*) "Gravitationnal sedimentation ?"
    585448     sedimentation=.false. ! default value
    586449     call getin_p("sedimentation",sedimentation)
    587      write(*,*) " sedimentation = ",sedimentation
    588 
    589      write(*,*) "Compute water cycle ?"
    590      water=.false. ! default value
    591      call getin_p("water",water)
    592      write(*,*) " water = ",water
    593          
    594 ! Test of incompatibility:
    595 ! if water is true, there should be at least a tracer
    596      if (water.and.(.not.tracer)) then
    597         print*,'if water is ON, tracer must be ON too!'
    598         stop
    599      endif
    600 
    601      write(*,*) "Include water condensation ?"
    602      watercond=.false. ! default value
    603      call getin_p("watercond",watercond)
    604      write(*,*) " watercond = ",watercond
    605 
    606 ! Test of incompatibility:
    607 ! if watercond is used, then water should be used too
    608      if (watercond.and.(.not.water)) then
    609         print*,'if watercond is used, water should be used too'
    610         stop
    611      endif
    612 
    613      write(*,*) "Include water precipitation ?"
    614      waterrain=.false. ! default value
    615      call getin_p("waterrain",waterrain)
    616      write(*,*) " waterrain = ",waterrain
    617 
    618      write(*,*) "Include surface hydrology ?"
    619      hydrology=.false. ! default value
    620      call getin_p("hydrology",hydrology)
    621      write(*,*) " hydrology = ",hydrology
    622 
    623      write(*,*) "Evolve surface water sources ?"
    624      sourceevol=.false. ! default value
    625      call getin_p("sourceevol",sourceevol)
    626      write(*,*) " sourceevol = ",sourceevol
    627 
    628      write(*,*) "Ice evolution timestep ?"
    629      icetstep=100.0 ! default value
    630      call getin_p("icetstep",icetstep)
    631      write(*,*) " icetstep = ",icetstep
    632          
    633      write(*,*) "Spectral Dependant albedo ?"
    634      albedo_spectral_mode=.false. ! default value
    635      call getin_p("albedo_spectral_mode",albedo_spectral_mode)
    636      write(*,*) " albedo_spectral_mode = ",albedo_spectral_mode
    637 
    638      write(*,*) "Snow albedo ?"
    639      write(*,*) "If albedo_spectral_mode=.true., then this "
    640      write(*,*) "corresponds to the 0.5 microns snow albedo."
    641      albedosnow=0.5         ! default value
    642      call getin_p("albedosnow",albedosnow)
    643      write(*,*) " albedosnow = ",albedosnow
    644          
    645      write(*,*) "CO2 ice albedo ?"
    646      albedoco2ice=0.5       ! default value
    647      call getin_p("albedoco2ice",albedoco2ice)
    648      write(*,*) " albedoco2ice = ",albedoco2ice
    649 
    650      write(*,*) "Maximum ice thickness ?"
    651      maxicethick=2.0         ! default value
    652      call getin_p("maxicethick",maxicethick)
    653      write(*,*) " maxicethick = ",maxicethick
    654 
    655      write(*,*) "Freezing point of seawater ?"
    656      Tsaldiff=-1.8          ! default value
    657      call getin_p("Tsaldiff",Tsaldiff)
    658      write(*,*) " Tsaldiff = ",Tsaldiff
     450     write(*,*) " sedimentation = ",sedimentation       
    659451
    660452     write(*,*) "Does user want to force cpp and mugaz?"
  • trunk/LMDZ.TITAN/libf/phytitan/initracer.F

    r1621 r1647  
    33      use surfdat_h
    44      USE tracer_h
    5       USE callkeys_mod, only: water
    65      IMPLICIT NONE
    76c=======================================================================
     
    2524
    2625!      real qsurf(ngrid,nq)       ! tracer on surface (e.g.  kg.m-2)
    27 !      real co2ice(ngrid)           ! co2 ice mass on surface (e.g.  kg.m-2)
    2826      character(len=20) :: txt ! to store some text
    2927      integer iq,ig,count
     
    4038c  alpha_lift(nq)  ! saltation vertical flux/horiz flux ratio (m-1)
    4139c  alpha_devil(nq) ! lifting coeeficient by dust devil
    42 c  rho_dust          ! Mars dust density
    43 c  rho_ice           ! Water ice density
    4440c  doubleq           ! if method with mass (iq=1) and number(iq=2) mixing ratio
    4541c  varian            ! Characteristic variance of log-normal distribution
     
    7672      ! 0. initialize tracer indexes to zero:
    7773      ! NB: igcm_* indexes are commons in 'tracer.h'
    78       do iq=1,nq
    79         igcm_dustbin(iq)=0
    80       enddo
    81       igcm_dust_mass=0
    82       igcm_dust_number=0
    83       igcm_h2o_vap=0
    84       igcm_h2o_ice=0
    85       igcm_co2=0
    8674      igcm_co=0
    8775      igcm_o=0
     
    9785      igcm_ar=0
    9886      igcm_ar_n2=0
    99       igcm_co2_ice=0
    10087
    10188      write(*,*) 'initracer: noms() ', noms
     
    133120!      endif ! of if (doubleq)
    134121      ! 2. find chemistry and water tracers
    135       do iq=1,nq
    136         if (noms(iq).eq."co2") then
    137           igcm_co2=iq
    138           mmol(igcm_co2)=44.
    139           count=count+1
    140 !          write(*,*) 'co2: count=',count
    141         endif
    142         if (noms(iq).eq."co2_ice") then
    143           igcm_co2_ice=iq
    144           mmol(igcm_co2_ice)=44.
    145           count=count+1
    146 !          write(*,*) 'co2_ice: count=',count
    147         endif
    148         if (noms(iq).eq."h2o_vap") then
    149           igcm_h2o_vap=iq
    150           mmol(igcm_h2o_vap)=18.
    151           count=count+1
    152 !          write(*,*) 'h2o_vap: count=',count
    153         endif
    154         if (noms(iq).eq."h2o_ice") then
    155           igcm_h2o_ice=iq
    156           mmol(igcm_h2o_ice)=18.
    157           count=count+1
    158 !          write(*,*) 'h2o_ice: count=',count
    159         endif
    160       enddo ! of do iq=1,nq
    161      
     122     
    162123      ! check that we identified all tracers:
    163124      if (count.ne.nq) then
     
    181142      call zerophys(nq,rho_q)
    182143
    183       rho_dust=2500.  ! Mars dust density (kg.m-3)
    184       rho_ice=920.    ! Water ice density (kg.m-3)
    185       rho_co2=1620.   ! CO2 ice density (kg.m-3)
    186 
    187 
    188 
    189 c$$$      if (doubleq) then
    190 c$$$c       "doubleq" technique
    191 c$$$c       -------------------
    192 c$$$c      (transport of mass and number mixing ratio)
    193 c$$$c       iq=1: Q mass mixing ratio, iq=2: N number mixing ratio
    194 c$$$
    195 c$$$        if( (nq.lt.2).or.(water.and.(nq.lt.3)) ) then
    196 c$$$          write(*,*)'initracer: nq is too low : nq=', nq
    197 c$$$          write(*,*)'water= ',water,' doubleq= ',doubleq   
    198 c$$$        end if
    199 c$$$
    200 c$$$        varian=0.637    ! Characteristic variance   
    201 c$$$        qext(igcm_dust_mass)=3.04   ! reference extinction at 0.67 um for ref dust
    202 c$$$        qext(igcm_dust_number)=3.04 ! reference extinction at 0.67 um for ref dust
    203 c$$$        rho_q(igcm_dust_mass)=rho_dust
    204 c$$$        rho_q(igcm_dust_number)=rho_dust
    205 c$$$
    206 c$$$c       Intermediate calcul for computing geometric mean radius r0
    207 c$$$c       as a function of mass and number mixing ratio Q and N
    208 c$$$c       (r0 = (r3n_q * Q/ N)
    209 c$$$        r3n_q = exp(-4.5*varian**2)*(3./4.)/(pi*rho_dust)
    210 c$$$
    211 c$$$c       Intermediate calcul for computing effective radius reff
    212 c$$$c       from geometric mean radius r0
    213 c$$$c       (reff = ref_r0 * r0)
    214 c$$$        ref_r0 = exp(2.5*varian**2)
    215 c$$$       
    216 c$$$c       lifted dust :
    217 c$$$c       '''''''''''
    218 c$$$        reff_lift = 3.e-6      !  Effective radius of lifted dust (m)
    219 c$$$        alpha_devil(igcm_dust_mass)=9.e-9   !  dust devil lift mass coeff
    220 c$$$        alpha_lift(igcm_dust_mass)=3.0e-15  !  Lifted mass coeff
    221 c$$$
    222 c$$$        r0_lift = reff_lift/ref_r0
    223 c$$$        alpha_devil(igcm_dust_number)=r3n_q*
    224 c$$$     &                        alpha_devil(igcm_dust_mass)/r0_lift**3
    225 c$$$        alpha_lift(igcm_dust_number)=r3n_q*
    226 c$$$     &                        alpha_lift(igcm_dust_mass)/r0_lift**3
    227 c$$$
    228 c$$$c       Not used:
    229 c$$$        radius(igcm_dust_mass) = 0.
    230 c$$$        radius(igcm_dust_number) = 0.
    231 c$$$
    232 c$$$      else
    233 
    234 
    235 c$$$       if (dustbin.gt.1) then
    236 c$$$        print*,'ATTENTION:',
    237 c$$$     $   ' properties of dust need input in initracer !!!'
    238 c$$$        stop
    239 c$$$
    240 c$$$       else if (dustbin.eq.1) then
    241 c$$$
    242 c$$$c       This will be used for 1 dust particle size:
    243 c$$$c       ------------------------------------------
    244 c$$$        radius(igcm_dustbin(1))=3.e-6
    245 c$$$        Qext(igcm_dustbin(1))=3.04
    246 c$$$        alpha_lift(igcm_dustbin(1))=0.0e-6
    247 c$$$        alpha_devil(igcm_dustbin(1))=7.65e-9
    248 c$$$        qextrhor(igcm_dustbin(1))=(3./4.)*Qext(igcm_dustbin(1))
    249 c$$$     &                         /(rho_dust*radius(igcm_dustbin(1)))
    250 c$$$        rho_q(igcm_dustbin(1))=rho_dust
    251 c$$$
    252 c$$$       endif
    253 c$$$!      end if    ! (doubleq)
    254 
    255 c     Initialization for water vapor
    256 c     ------------------------------
    257       if(water) then
    258          radius(igcm_h2o_vap)=0.
    259          Qext(igcm_h2o_vap)=0.
    260          alpha_lift(igcm_h2o_vap) =0.
    261          alpha_devil(igcm_h2o_vap)=0.
    262          qextrhor(igcm_h2o_vap)= 0.
    263 
    264 c       "Dryness coefficient" controlling the evaporation and
    265 c        sublimation from the ground water ice (close to 1)
    266 c        HERE, the goal is to correct for the fact
    267 c        that the simulated permanent water ice polar caps
    268 c        is larger than the actual cap and the atmospheric
    269 c        opacity not always realistic.
    270 
    271 
    272 !         if(ngrid.eq.1)
    273 
    274 
    275 !     to be modified for BC+ version?
    276 
    277          !! this is defined in surfdat_h.F90
    278          IF (.not.ALLOCATED(dryness)) ALLOCATE(dryness(ngrid))
    279          IF (.not.ALLOCATED(watercaptag)) ALLOCATE(watercaptag(ngrid))
    280 
    281          do ig=1,ngrid
    282            if (ngrid.ne.1) watercaptag(ig)=.false.
    283            dryness(ig) = 1.
    284          enddo
    285 
    286 
    287 
    288 
    289 !         IF (caps) THEN
    290 c Perennial H20 north cap defined by watercaptag=true (allows surface to be
    291 c hollowed by sublimation in vdifc).
    292 !         do ig=1,ngrid
    293 !           if (lati(ig)*180./pi.gt.84) then
    294 !             if (ngrid.ne.1) watercaptag(ig)=.true.
    295 !             dryness(ig) = 1.
    296 c Use the following cap definition for high spatial resolution (latitudinal bin <= 5 deg)
    297 c             if (lati(ig)*180./pi.lt.85.and.long(ig).ge.0) then
    298 c               if (ngrid.ne.1) watercaptag(ig)=.true.
    299 c               dryness(ig) = 1.
    300 c             endif
    301 c             if (lati(ig)*180./pi.ge.85) then
    302 c               if (ngrid.ne.1) watercaptag(ig)=.true.
    303 c               dryness(ig) = 1.
    304 c             endif
    305 !           endif  ! (lati>80 deg)
    306 !         end do ! (ngrid)
    307 !        ENDIF ! (caps)
    308 
    309 !         if(iceparty.and.(nq.ge.2)) then
    310 
    311            radius(igcm_h2o_ice)=3.e-6
    312            rho_q(igcm_h2o_ice)=rho_ice
    313            Qext(igcm_h2o_ice)=0.
    314 !           alpha_lift(igcm_h2o_ice) =0.
    315 !           alpha_devil(igcm_h2o_ice)=0.
    316            qextrhor(igcm_h2o_ice)= (3./4.)*Qext(igcm_h2o_ice)
    317      $       / (rho_ice*radius(igcm_h2o_ice))
    318 
    319 
    320 
    321 !         elseif(iceparty.and.(nq.lt.2)) then
    322 !            write(*,*) 'nq is too low : nq=', nq
    323 !            write(*,*) 'water= ',water,' iceparty= ',iceparty
    324 !         endif
    325 
    326       end if  ! (water)
    327144
    328145c     Output for records:
  • trunk/LMDZ.TITAN/libf/phytitan/iostart.F90

    r1621 r1647  
    1515    INTEGER,SAVE :: idim6 ! "nlayer" dimension
    1616    INTEGER,SAVE :: idim7 ! "Time" dimension
    17     INTEGER,SAVE :: idim8 ! "ocean_layers" dimension
    1817    INTEGER,SAVE :: timeindex ! current time index (for time-dependent fields)
    1918!$OMP THREADPRIVATE(idim1,idim2,idim3,idim4,idim5,idim6,idim7,timeindex)
     
    469468  USE tracer_h, only: nqtot
    470469  USE comsoil_h, only: nsoilmx
    471   USE slab_ice_h, only: noceanmx
    472470
    473471  IMPLICIT NONE
     
    558556      ENDIF
    559557
    560       ierr=NF90_DEF_DIM(nid_restart,"ocean_layers",noceanmx,idim8)
    561       IF (ierr/=NF90_NOERR) THEN
    562         write(*,*)'open_restartphy: problem defining oceanic layer dimension '
    563         write(*,*)trim(nf90_strerror(ierr))
    564         CALL ABORT
    565       ENDIF
    566 
    567 
    568558      ierr=NF90_ENDDEF(nid_restart)
    569559      IF (ierr/=NF90_NOERR) THEN
     
    646636  USE mod_grid_phy_lmdz
    647637  USE mod_phys_lmdz_para
    648   USE slab_ice_h, only: noceanmx
    649638  IMPLICIT NONE
    650639  CHARACTER(LEN=*),INTENT(IN)    :: field_name
     
    832821        endif ! of if (.not.present(time))
    833822
    834       ELSE IF (field_size==noceanmx) THEN
    835         ! input is a 2D "oceanic field" array
    836         if (.not.present(time)) then ! for a time-independent field
    837           ierr = NF90_REDEF(nid_restart)
    838 #ifdef NC_DOUBLE
    839           ierr=NF90_DEF_VAR(nid_restart,field_name,NF90_DOUBLE,&
    840                             (/idim2,idim8/),nvarid)
    841 #else
    842           ierr=NF90_DEF_VAR(nid_restart,field_name,NF90_FLOAT,&
    843                             (/idim2,idim8/),nvarid)
    844 #endif
    845           if (ierr.ne.NF90_NOERR) then
    846             write(*,*)"put_field_rgen error: failed to define "//trim(field_name)
    847             write(*,*)trim(nf90_strerror(ierr))
    848           endif
    849           IF (LEN_TRIM(title) > 0) ierr=NF90_PUT_ATT(nid_restart,nvarid,"title",title)
    850           ierr = NF90_ENDDEF(nid_restart)
    851           ierr = NF90_PUT_VAR(nid_restart,nvarid,field_glo)
    852         else
    853           ! check if the variable has already been defined:
    854           ierr=NF90_INQ_VARID(nid_restart,field_name,nvarid)
    855           if (ierr/=NF90_NOERR) then ! variable not found, define it
    856             ierr=NF90_REDEF(nid_restart)
    857 #ifdef NC_DOUBLE
    858             ierr=NF90_DEF_VAR(nid_restart,field_name,NF90_DOUBLE,&
    859                               (/idim2,idim8,idim7/),nvarid)
    860 #else
    861             ierr=NF90_DEF_VAR(nid_restart,field_name,NF90_FLOAT,&
    862                               (/idim2,idim8,idim7/),nvarid)
    863 #endif
    864            if (ierr.ne.NF90_NOERR) then
    865               write(*,*)"put_field_rgen error: failed to define "//trim(field_name)
    866               write(*,*)trim(nf90_strerror(ierr))
    867             endif
    868             IF (LEN_TRIM(title) > 0) ierr=NF90_PUT_ATT(nid_restart,nvarid,"title",title)
    869             ierr=NF90_ENDDEF(nid_restart)
    870           endif
    871           ! Write the variable
    872           ierr=NF90_PUT_VAR(nid_restart,nvarid,field_glo,&
    873                             start=(/1,1,timeindex/))
    874 
    875         endif ! of if (.not.present(time))
    876 
    877 
    878823      ELSE
    879824        PRINT *, "Error phyredem(put_field_rgen) : wrong dimension for ",trim(field_name)
     
    948893  USE comsoil_h, only: nsoilmx
    949894  USE mod_phys_lmdz_para, only: is_master
    950   USE slab_ice_h, only: noceanmx
    951895  IMPLICIT NONE
    952896     CHARACTER(LEN=*),INTENT(IN) :: var_name
     
    1000944        ! We know it is an  "mlayer" kind of 1D array
    1001945        idim1d=idim3
    1002       ELSEIF (var_size==noceanmx) THEN
    1003         ! We know it is an  "mlayer" kind of 1D array
    1004         idim1d=idim8
    1005946      ELSE
    1006947        PRINT *, "put_var_rgen error : wrong dimension"
  • trunk/LMDZ.TITAN/libf/phytitan/mass_redistribution.F90

    r1542 r1647  
    11SUBROUTINE mass_redistribution(ngrid,nlayer,nq,ptimestep,   &
    2                        rnat,pcapcal,pplay,pplev,pt,ptsrf,pq,pqs,     &
     2                       pcapcal,pplay,pplev,pt,ptsrf,pq,pqs,     &
    33                       pu,pv,pdt,pdtsrf,pdq,pdu,pdv,pdmassmr,  &
    44                       pdtmr,pdtsrfmr,pdpsrfmr,pdumr,pdvmr,pdqmr,pdqsmr)
    55                                                   
    6        USE watercommon_h, Only: Tsat_water,RLVTT
    76       use surfdat_h
    87       use radcommon_h, only: glat
     
    109       USE planete_mod, only: bp
    1110       use comcstfi_mod, only: g
    12        USE callkeys_mod, ONLY: water
    1311       
    1412       IMPLICIT NONE
     
    5755      INTEGER ngrid, nlayer, nq   
    5856      REAL ptimestep
    59       REAL pcapcal(ngrid)
    60       INTEGER rnat(ngrid)     
     57      REAL pcapcal(ngrid)   
    6158      REAL pplay(ngrid,nlayer),pplev(ngrid,nlayer+1)
    6259      REAL pt(ngrid,nlayer),pdt(ngrid,nlayer)
     
    7673
    7774!    Boiling/sublimation
    78       REAL Tsat(ngrid),zmassboil(ngrid)
     75      REAL zmassboil(ngrid)
    7976
    8077!    vertical reorganization of sigma levels
     
    132129
    133130
    134       if (water) then
    135          do ig=1,ngrid
    136             call Tsat_water(pplev(ig,1)+zdmass_sum(ig,1)*g*ptimestep,Tsat(ig))
    137          enddo
    138                call writediagfi(ngrid,'Tsat','saturation temperature at surface','',2,Tsat)
    139          
    140          do ig=1,ngrid
    141             if (ztsrf(ig).gt.Tsat(ig)) then
    142                zmassboil(ig)=(ptsrf(ig)-Tsat(ig))*pcapcal(ig)/RLVTT/ptimestep
    143                if ((zmassboil(ig)*ptimestep.gt.pqs(ig,igcm_h2o_vap)).and.(rnat(ig).eq.1)) then
    144                   zmassboil(ig)=pqs(ig,igcm_h2o_vap)/ptimestep
    145                endif
    146                zmassboil(ig)=zmassboil(ig)*0.0 !momentary, should be 1. JL12
    147                pdqsmr(ig,igcm_h2o_vap)=-zmassboil(ig)
    148                pdtsrfmr(ig)=-zmassboil(ig)*RLVTT/pcapcal(ig)
    149                ztsrf(ig)=ptsrf(ig)+pdtsrfmr(ig)*ptimestep
    150             else
    151                zmassboil(ig)=0.
    152                pdtsrfmr(ig)=0.
    153             endif
    154          enddo
    155       endif
    156 
    157131!     *************************
    158132!           UPDATE SURFACE
     
    219193         zvm(1) = 0. 
    220194         zqm(1,1:nq)=0. ! most tracer do not condense !
    221          if (water) zqm(1,igcm_h2o_vap)=1. ! flux is 100% h2o at surface
    222195         
    223196!        Van Leer scheme:
  • trunk/LMDZ.TITAN/libf/phytitan/optci.F90

    r1397 r1647  
    77  use gases_h
    88  use comcstfi_mod, only: g, r, mugaz
    9   use callkeys_mod, only: kastprof,continuum,graybody,H2Ocont_simple
     9  use callkeys_mod, only: continuum,graybody
    1010  implicit none
    1111
     
    7777  integer interm
    7878
    79   !--- Kasting's CIA ----------------------------------------
    80   !real*8, parameter :: Ci(L_NSPECTI)=[                         &
    81   !     3.8E-5, 1.2E-5, 2.8E-6, 7.6E-7, 4.5E-7, 2.3E-7,    &
    82   !     5.4E-7, 1.6E-6, 0.0,                               &
    83   !     0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0,            &
    84   !     0.0, 4.0E-7, 4.0E-6, 1.4E-5,    &
    85   !     1.0E-5, 1.2E-6, 2.0E-7, 5.0E-8, 3.0E-8, 0.0 ]
    86   !real*8, parameter :: Ti(L_NSPECTI)=[ -2.2, -1.9,             &
    87   !     -1.7, -1.7, -1.7, -1.7, -1.7, -1.7,                &
    88   !     0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, &
    89   !     -1.7,-1.7,-1.7,-1.7,-1.7,-1.7,-1.7, -1.7,0.0 ]
    90   !----------------------------------------------------------
    91 
    9279  !! AS: to save time in computing continuum (see bilinearbig)
    9380  IF (.not.ALLOCATED(indi)) THEN
     
    10794     DPR(k) = PLEV(K)-PLEV(K-1)
    10895
    109      !--- Kasting's CIA ----------------------------------------
    110      !dz(k)=dpr(k)*189.02*TMID(K)/(0.03720*PMID(K))
    111      ! this is CO2 path length (in cm) as written by Francois
    112      ! delta_z = delta_p * R_specific * T / (g * P)
    113      ! But Kasting states that W is in units of _atmosphere_ cm
    114      ! So we do
    115      !dz(k)=dz(k)*(PMID(K)/1013.25)
    116      !dz(k)=dz(k)/100.0 ! in m for SI calc
    117      !----------------------------------------------------------
    118 
    11996     ! if we have continuum opacities, we need dz
    120      if(kastprof)then
    121         dz(k) = dpr(k)*(1000.0d0*8.3145d0/muvar(k))*TMID(K)/(g*PMID(K))
    122         U(k)  = Cmk*DPR(k)*mugaz/muvar(k)
    123      else
    124         dz(k) = dpr(k)*R*TMID(K)/(glat_ig*PMID(K))*mugaz/muvar(k)
    125         U(k)  = Cmk*DPR(k)*mugaz/muvar(k)     ! only Cmk line in optci.F 
     97      dz(k) = dpr(k)*R*TMID(K)/(glat_ig*PMID(K))*mugaz/muvar(k)
     98      U(k)  = Cmk*DPR(k)*mugaz/muvar(k)     ! only Cmk line in optci.F 
    12699            !JL13 the mugaz/muvar factor takes into account water meanmolecular weight if water is present
    127      endif
    128100
    129101     call tpindex(PMID(K),TMID(K),QVAR(K),pfgasref,tgasref,WREFVAR, &
     
    185157                       call interpolateN2H2(wn_cont,T_cont,p_cross,p_cont,dtempc,.false.,interm)
    186158                       indi(nw,igas,jgas) = interm
    187                     elseif(jgas.eq.igas_He)then
    188                        interm = indi(nw,igas,jgas)
    189                        call interpolateH2He(wn_cont,T_cont,p_cross,p_cont,dtempc,.false.,interm)
    190                        indi(nw,igas,jgas) = interm
    191159                    endif
    192160                    dtemp = dtemp + dtempc
    193161                 enddo
    194 
    195               elseif(igas.eq.igas_H2O.and.T_cont.gt.200.0)then
    196 
    197                  p_air = dble(PMID(k)*scalep) - p_cont ! note assumes background is air!
    198                  if(H2Ocont_simple)then
    199                     call interpolateH2Ocont_PPC(wn_cont,T_cont,p_cont,p_air,dtemp,.false.)
    200                  else
    201                     interm = indi(nw,igas,igas)
    202                     call interpolateH2Ocont_CKD(wn_cont,T_cont,p_cont,p_air,dtemp,.false.,interm)
    203                     indi(nw,igas,igas) = interm
    204                  endif
    205162
    206163              endif
  • trunk/LMDZ.TITAN/libf/phytitan/optcv.F90

    r1397 r1647  
    77  use gases_h
    88  use comcstfi_mod, only: g, r, mugaz
    9   use callkeys_mod, only: kastprof,continuum,graybody,H2Ocont_simple,callgasvis
     9  use callkeys_mod, only: continuum,graybody,callgasvis
    1010
    1111  implicit none
     
    106106
    107107     ! if we have continuum opacities, we need dz
    108      if(kastprof)then
    109         dz(k) = dpr(k)*(1000.0d0*8.3145d0/muvar(k))*TMID(K)/(g*PMID(K))
    110         U(k)  = Cmk*DPR(k)*mugaz/muvar(k)
    111      else
    112         dz(k) = dpr(k)*R*TMID(K)/(glat_ig*PMID(K))*mugaz/muvar(k)
    113         U(k)  = Cmk*DPR(k)*mugaz/muvar(k)     ! only Cmk line in optci.F 
    114             !JL13 the mugaz/muvar factor takes into account water meanmolecular weight if water is present
    115      endif
     108
     109      dz(k) = dpr(k)*R*TMID(K)/(glat_ig*PMID(K))*mugaz/muvar(k)
     110      U(k)  = Cmk*DPR(k)*mugaz/muvar(k)     ! only Cmk line in optci.F 
     111          !JL13 the mugaz/muvar factor takes into account water meanmolecular weight if water is present
     112     
    116113
    117114     call tpindex(PMID(K),TMID(K),QVAR(K),pfgasref,tgasref,WREFVAR, &
     
    186183                       indv(nw,igas,jgas) = interm
    187184                       ! should be irrelevant in the visible
    188                     elseif(jgas.eq.igas_He)then
    189                        interm = indv(nw,igas,jgas)
    190                        call interpolateH2He(wn_cont,T_cont,p_cross,p_cont,dtempc,.false.,interm)
    191                        indv(nw,igas,jgas) = interm
    192185                    endif
    193186                    dtemp = dtemp + dtempc
    194187                 enddo
    195 
    196               elseif(igas.eq.igas_H2O.and.T_cont.gt.200.0)then
    197 
    198                  p_air = dble(PMID(k)*scalep) - p_cont ! note assumes background is air!
    199                  if(H2Ocont_simple)then
    200                     call interpolateH2Ocont_PPC(wn_cont,T_cont,p_cont,p_air,dtemp,.false.)
    201                  else
    202                     interm = indv(nw,igas,igas)
    203                     call interpolateH2Ocont_CKD(wn_cont,T_cont,p_cont,p_air,dtemp,.false.,interm)
    204                     indv(nw,igas,igas) = interm
    205                  endif
    206188
    207189              endif
  • trunk/LMDZ.TITAN/libf/phytitan/phyetat0.F90

    r1621 r1647  
    11subroutine phyetat0 (ngrid,nlayer,fichnom,tab0,Lmodif,nsoil,nq, &
    22                     day_ini,time,tsurf,tsoil, &
    3                      emis,q2,qsurf,cloudfrac,totcloudfrac,hice, &
    4                      rnat,pctsrf_sic,tslab,tsea_ice,sea_ice)
     3                     emis,q2,qsurf)
    54
    65
     
    109                     get_field, get_var, inquire_field, &
    1110                     inquire_dimension, inquire_dimension_length
    12   use slab_ice_h, only: noceanmx
    13   use callkeys_mod, only: CLFvarying
    1411
    1512  implicit none
     
    4542  real,intent(out) :: q2(ngrid,nlayer+1) !
    4643  real,intent(out) :: qsurf(ngrid,nq) ! tracers on surface
    47 ! real co2ice(ngrid) ! co2 ice cover
    48   real,intent(out) :: cloudfrac(ngrid,nlayer)
    49   real,intent(out) :: hice(ngrid), totcloudfrac(ngrid)
    50   real,intent(out) :: pctsrf_sic(ngrid),tslab(ngrid,noceanmx) 
    51   real,intent(out) :: tsea_ice(ngrid),sea_ice(ngrid)
    52   real,intent(out) :: rnat(ngrid)
    5344
    5445!======================================================================
     
    5647
    5748!      INTEGER radpas
    58 !      REAL co2_ppm
    5949!      REAL solaire
    6050
     
    250240             minval(emis), maxval(emis)
    251241endif
    252 
    253 ! Cloud fraction (added by BC 2010)
    254 if (CLFvarying) then
    255 call get_field("cloudfrac",cloudfrac,found,indextime)
    256 if (.not.found) then
    257   write(*,*) "phyetat0: Failed loading <cloudfrac>"
    258   call abort
    259 else
    260   write(*,*) "phyetat0: Cloud fraction <cloudfrac> range:", &
    261              minval(cloudfrac), maxval(cloudfrac)
    262 endif
    263 else
    264 cloudfrac(:,:)=0.0
    265 endif
    266 
    267 ! Total cloud fraction (added by BC 2010)
    268 if (CLFvarying) then
    269 call get_field("totcloudfrac",totcloudfrac,found,indextime)
    270 if (.not.found) then
    271   write(*,*) "phyetat0: Failed loading <totcloudfrac>"
    272   call abort
    273 else
    274   write(*,*) "phyetat0: Total cloud fraction <totcloudfrac> range:", &
    275              minval(totcloudfrac), maxval(totcloudfrac)
    276 endif
    277 else
    278 totcloudfrac(:)=0.0
    279 endif
    280 
    281 ! Height of oceanic ice (added by BC 2010)
    282 call get_field("hice",hice,found,indextime)
    283 if (.not.found) then
    284   write(*,*) "phyetat0: Failed loading <hice>"
    285 !  call abort
    286       do ig=1,ngrid
    287       hice(ig)=0.
    288       enddo
    289 else
    290   write(*,*) "phyetat0: Height of oceanic ice <hice> range:", &
    291              minval(hice), maxval(hice)
    292 endif
    293 
    294 ! SLAB OCEAN (added by BC 2014)
    295 ! nature of the surface
    296 call get_field("rnat",rnat,found,indextime)
    297 if (.not.found) then
    298   write(*,*) "phyetat0: Failed loading <rnat>"
    299       do ig=1,ngrid
    300         rnat(ig)=1.
    301       enddo
    302 else
    303       do ig=1,ngrid
    304         if((nint(rnat(ig)).eq.2).or.(nint(rnat(ig)).eq.0))then
    305           rnat(ig)=0.
    306         else
    307           rnat(ig)=1.
    308         endif     
    309       enddo
    310 
    311   write(*,*) "phyetat0: Nature of surface <rnat> range:", &
    312              minval(rnat), maxval(rnat)
    313 endif
    314 ! Pourcentage of sea ice cover
    315 call get_field("pctsrf_sic",pctsrf_sic,found,indextime)
    316 if (.not.found) then
    317   write(*,*) "phyetat0: Failed loading <pctsrf_sic>"
    318       do ig=1,ngrid
    319       pctsrf_sic(ig)=0.
    320       enddo
    321 else
    322   write(*,*) "phyetat0: Pourcentage of sea ice cover <pctsrf_sic> range:", &
    323              minval(pctsrf_sic), maxval(pctsrf_sic)
    324 endif
    325 ! Slab ocean temperature (2 layers)
    326 call get_field("tslab",tslab,found,indextime)
    327 if (.not.found) then
    328   write(*,*) "phyetat0: Failed loading <tslab>"
    329       do ig=1,ngrid
    330       do iq=1,noceanmx
    331       tslab(ig,iq)=tsurf(ig)
    332       enddo
    333       enddo
    334 else
    335   write(*,*) "phyetat0: Slab ocean temperature <tslab> range:", &
    336              minval(tslab), maxval(tslab)
    337 endif
    338 ! Oceanic ice temperature
    339 call get_field("tsea_ice",tsea_ice,found,indextime)
    340 if (.not.found) then
    341   write(*,*) "phyetat0: Failed loading <tsea_ice>"
    342       do ig=1,ngrid
    343       tsea_ice(ig)=273.15-1.8
    344       enddo
    345 else
    346   write(*,*) "phyetat0: Oceanic ice temperature <tsea_ice> range:", &
    347              minval(tsea_ice), maxval(tsea_ice)
    348 endif
    349 !  Oceanic ice quantity (kg/m^2)
    350 call get_field("sea_ice",sea_ice,found,indextime)
    351 if (.not.found) then
    352   write(*,*) "phyetat0: Failed loading <sea_ice>"
    353       do ig=1,ngrid
    354       tsea_ice(ig)=0.
    355       enddo
    356 else
    357   write(*,*) "phyetat0: Oceanic ice quantity <sea_ice> range:", &
    358              minval(sea_ice), maxval(sea_ice)
    359 endif
    360 
    361 
    362 
    363242
    364243! pbl wind variance
  • trunk/LMDZ.TITAN/libf/phytitan/phyredem.F90

    r1621 r1647  
    135135
    136136subroutine physdem1(filename,nsoil,ngrid,nlay,nq, &
    137                     phystep,time,tsurf,tsoil,emis,q2,qsurf, &
    138                     cloudfrac,totcloudfrac,hice, &
    139                     rnat,pctsrf_sic,tslab,tsea_ice,sea_ice)
     137                    phystep,time,tsurf,tsoil,emis,q2,qsurf)
    140138  ! write time-dependent variable to restart file
    141139  use iostart, only : open_restartphy, close_restartphy, &
    142140                      put_var, put_field
    143141  use tracer_h, only: noms
    144   use slab_ice_h, only: noceanmx
    145   use callkeys_mod, only: ok_slab_ocean
    146142
    147143  implicit none
     
    159155  real,intent(in) :: q2(ngrid,nlay+1)
    160156  real,intent(in) :: qsurf(ngrid,nq)
    161   real,intent(in) :: cloudfrac(ngrid,nlay)
    162   real,intent(in) :: totcloudfrac(ngrid)
    163   real,intent(in) :: hice(ngrid)
    164   real,intent(in) :: rnat(ngrid)
    165   real,intent(in) :: pctsrf_sic(ngrid)
    166   real,intent(in) :: tslab(ngrid,noceanmx)
    167   real,intent(in) :: tsea_ice(ngrid)
    168   real,intent(in) :: sea_ice(ngrid)
    169157
    170158  integer :: iq
     
    189177  call put_field("q2","pbl wind variance",q2)
    190178 
    191 ! cloud fraction and sea ice (NB: these should be optional... to be improved)
    192   call put_field("cloudfrac","Cloud fraction",cloudfrac)
    193   call put_field("totcloudfrac","Total fraction",totcloudfrac)
    194   call put_field("hice","Height of oceanic ice",hice)
    195 
    196  !Slab ocean
    197  if(ok_slab_ocean) then
    198    call put_field("rnat","Nature of surface",rnat)
    199    call put_field("pctsrf_sic","Pourcentage sea ice",pctsrf_sic)
    200    call put_field("tslab","Temperature slab ocean",tslab)
    201    call put_field("tsea_ice","Temperature sea ice",tsea_ice)
    202    call put_field("sea_ice","Sea ice mass",sea_ice)
    203  endif!(ok_slab_ocean)
    204 
    205 
    206179! tracers
    207180  if (nq>0) then
  • trunk/LMDZ.TITAN/libf/phytitan/physiq_mod.F90

    r1637 r1647  
    1515 
    1616      use radinc_h, only : L_NSPECTI,L_NSPECTV,naerkind
    17       use watercommon_h, only : RLVTT, Psat_water,epsi
    1817      use gases_h, only: gnom, gfrac
    1918      use radcommon_h, only: sigma, glat, grav, BWNV
    20       use radii_mod, only: h2o_reffrad, co2_reffrad
    21       use aerosol_mod, only: iaero_co2, iaero_h2o
    22       use surfdat_h, only: phisfi, zmea, zstd, zsig, zgam, zthe, &
    23                            dryness, watercaptag
     19      use surfdat_h, only: phisfi, zmea, zstd, zsig, zgam, zthe
    2420      use comdiurn_h, only: coslat, sinlat, coslon, sinlon
    2521      use comsaison_h, only: mu0, fract, dist_star, declin, right_ascen
     
    2925      USE tracer_h, only: noms, mmol, radius, rho_q, qext, &
    3026                          alpha_lift, alpha_devil, qextrhor, &
    31                           igcm_h2o_ice, igcm_h2o_vap, igcm_dustbin, &
    32                           igcm_co2_ice
     27                          igcm_dustbin
    3328      use time_phylmdz_mod, only: ecritphy, iphysiq, nday
    3429      use phyredem, only: physdem0, physdem1
    35       use slab_ice_h, only: capcalocean, capcalseaice,capcalsno, &
    36                             noceanmx
    37       use ocean_slab_mod, only :ocean_slab_init, ocean_slab_ice, &
    38                                 ini_surf_heat_transp_mod, &
    39                                 ocean_slab_get_vars,ocean_slab_final
    40       use surf_heat_transp_mod,only :init_masquv
    4130      use planetwide_mod, only: planetwide_minval,planetwide_maxval,planetwide_sumval
    4231      use mod_phys_lmdz_para, only : is_master
     
    8170!      IV. Dry Convective adjustment :
    8271!
    83 !      V. Condensation and sublimation of gases (currently just CO2).
    84 !
    85 !      VI. Tracers
    86 !         VI.1. Water and water ice.
    87 !         VI.2. Aerosols and particles.
    88 !         VI.3. Updates (pressure variations, surface budget).
    89 !         VI.4. Slab Ocean.
    90 !         VI.5. Surface Tracer Update.
    91 !
    92 !      VII. Surface and sub-surface soil temperature.
    93 !
    94 !      VIII. Perform diagnostics and write output files.
     72!      V. Tracers
     73!         V.1. Aerosols and particles.
     74!         V.2. Updates (pressure variations, surface budget).
     75!         V.3. Surface Tracer Update.
     76!
     77!      VI. Surface and sub-surface soil temperature.
     78!
     79!      VII. Perform diagnostics and write output files.
    9580!
    9681!
     
    156141!           No more ngridmx/nqmx, F90 commons and adaptation to parallel: A. Spiga (2012)
    157142!           Purge of the code : M. Turbet (2015)
    158 !==================================================================
     143!           Fork for Titan and clean of all too-generic (ocean, water, co2 ...) routines : J. Vatant d'Ollone (2017)
     144!============================================================================================
    159145
    160146
     
    212198      real, dimension(:,:),allocatable,save :: albedo              ! Surface Spectral albedo. By MT2015.
    213199      real, dimension(:),allocatable,save :: albedo_equivalent     ! Spectral Mean albedo.
    214       real, dimension(:),allocatable,save :: albedo_snow_SPECTV    ! Snow Spectral albedo.
    215       real, dimension(:),allocatable,save :: albedo_co2_ice_SPECTV ! CO2 ice Spectral albedo.
    216      
    217 !$OMP THREADPRIVATE(tsurf,tsoil,albedo,albedo_equivalent,albedo_snow_SPECTV,albedo_co2_ice_SPECTV)
     200     
     201!$OMP THREADPRIVATE(tsurf,tsoil,albedo,albedo_equivalent)
    218202
    219203      real,dimension(:),allocatable,save :: albedo_bareground ! Bare Ground Albedo. By MT 2015.
    220       real,dimension(:),allocatable,save :: rnat              ! Defines the type of the grid (ocean,continent,...). By BC.
    221      
    222 !$OMP THREADPRIVATE(albedo_bareground,rnat)
     204     
     205!$OMP THREADPRIVATE(albedo_bareground)
    223206
    224207      real,dimension(:),allocatable,save :: emis        ! Thermal IR surface emissivity.
     
    276259      real zdtsurf(ngrid)     ! Cumulated tendencies.
    277260      real zdtsurfmr(ngrid)   ! Mass_redistribution routine.
    278       real zdtsurfc(ngrid)    ! Condense_co2 routine.
    279261      real zdtsdif(ngrid)     ! Turbdiff/vdifc routines.
    280       real zdtsurf_hyd(ngrid) ! Hydrol routine.
    281262           
    282263      ! For Atmospheric Temperatures : (K/s)   
    283       real dtlscale(ngrid,nlayer)                             ! Largescale routine.
    284       real zdtc(ngrid,nlayer)                                 ! Condense_co2 routine.
    285       real zdtdif(ngrid,nlayer)                                      ! Turbdiff/vdifc routines.
     264      real zdtdif(ngrid,nlayer)                               ! Turbdiff/vdifc routines.
    286265      real zdtmr(ngrid,nlayer)                                ! Mass_redistribution routine.
    287       real zdtrain(ngrid,nlayer)                              ! Rain routine.
    288       real dtmoist(ngrid,nlayer)                              ! Moistadj routine.
    289       real dt_ekman(ngrid,noceanmx), dt_hdiff(ngrid,noceanmx) ! Slab_ocean routine.
    290266      real zdtsw1(ngrid,nlayer), zdtlw1(ngrid,nlayer)         ! Callcorrk routine.
    291267                             
    292268      ! For Surface Tracers : (kg/m2/s)
    293269      real dqsurf(ngrid,nq)                 ! Cumulated tendencies.
    294       real zdqsurfc(ngrid)                  ! Condense_co2 routine.
    295270      real zdqsdif(ngrid,nq)                ! Turbdiff/vdifc routines.
    296271      real zdqssed(ngrid,nq)                ! Callsedim routine.
    297272      real zdqsurfmr(ngrid,nq)              ! Mass_redistribution routine.
    298       real zdqsrain(ngrid), zdqssnow(ngrid) ! Rain routine.
    299       real dqs_hyd(ngrid,nq)                ! Hydrol routine.
    300273                 
    301274      ! For Tracers : (kg/kg_of_air/s)
    302       real zdqc(ngrid,nlayer,nq)      ! Condense_co2 routine.
    303275      real zdqadj(ngrid,nlayer,nq)    ! Convadj routine.
    304276      real zdqdif(ngrid,nlayer,nq)    ! Turbdiff/vdifc routines.
     
    306278      real zdqsed(ngrid,nlayer,nq)    ! Callsedim routine.
    307279      real zdqmr(ngrid,nlayer,nq)     ! Mass_redistribution routine.
    308       real zdqrain(ngrid,nlayer,nq)   ! Rain routine.
    309       real dqmoist(ngrid,nlayer,nq)   ! Moistadj routine.
    310       real dqvaplscale(ngrid,nlayer)  ! Largescale routine.
    311       real dqcldlscale(ngrid,nlayer)  ! Largescale routine.
    312280                       
    313281      ! For Winds : (m/s/s)
     
    359327      real qcol(ngrid,nq) ! Tracer Column Mass (kg/m2).
    360328
    361 !     included by RW for H2O Manabe scheme
    362       real rneb_man(ngrid,nlayer) ! H2O cloud fraction (moistadj).
    363       real rneb_lsc(ngrid,nlayer) ! H2O cloud fraction (large scale).
    364 
    365 
    366329!     to test energy conservation (RW+JL)
    367330      real mass(ngrid,nlayer),massarea(ngrid,nlayer)
     
    371334      real dEzRadsw(ngrid,nlayer),dEzRadlw(ngrid,nlayer),dEzdiff(ngrid,nlayer)
    372335      real dEdiffs(ngrid),dEdiff(ngrid)
    373       real madjdE(ngrid), lscaledE(ngrid),madjdEz(ngrid,nlayer), lscaledEz(ngrid,nlayer)
    374336     
    375337!JL12 conservation test for mean flow kinetic energy has been disabled temporarily
    376338
    377       real dtmoist_max,dtmoist_min     
    378339      real dItot, dItot_tmp, dVtot, dVtot_tmp
    379 
    380       real,allocatable,save :: hice(:) ! Oceanic Ice height. by BC
    381  !$OMP THREADPRIVATE(hice)     
    382 
    383       real h2otot                      ! Total Amount of water. For diagnostic.
    384       real icesrf,liqsrf,icecol,vapcol ! Total Amounts of water (ice,liq,vap). For diagnostic.
     340     
    385341      real dWtot, dWtot_tmp, dWtots, dWtots_tmp
    386       logical,save :: watertest
    387 !$OMP THREADPRIVATE(watertest)
    388 
    389       real qsat(ngrid,nlayer) ! Water Vapor Volume Mixing Ratio at saturation (kg/kg_of_air).
    390       real RH(ngrid,nlayer)   ! Relative humidity.
    391       real H2Omaxcol(ngrid)   ! Maximum possible H2O column amount (at 100% saturation) (kg/m2).
    392       real psat_tmp
    393      
    394       logical clearsky ! For double radiative transfer call. By BC
     342     
    395343     
    396344      ! For Clear Sky Case.
     
    400348      real tau_col1(ngrid)                                                   ! For aerosol optical depth diagnostic.
    401349      real OLR_nu1(ngrid,L_NSPECTI), OSR_nu1(ngrid,L_NSPECTV)                ! For Outgoing Radiation diagnostics.
    402       real tf, ntf
    403 
    404       real,allocatable,dimension(:,:),save :: cloudfrac  ! Fraction of clouds (%).
    405       real,allocatable,dimension(:),save :: totcloudfrac ! Column fraction of clouds (%).
    406 !$OMP THREADPRIVATE(cloudfrac,totcloudfrac)
    407 
    408       real nconsMAX, vdifcncons(ngrid), cadjncons(ngrid) ! Vdfic water conservation test. By RW
     350      real tf, ntf   
    409351
    410352      real,allocatable,dimension(:,:),save :: qsurf_hist
     
    418360
    419361      real reffcol(ngrid,naerkind)
    420 
    421 !     Sourceevol for 'accelerated ice evolution'. By RW
    422       real,allocatable,dimension(:),save :: ice_initial
    423       real delta_ice,ice_tot
    424       real,allocatable,dimension(:),save :: ice_min     
    425       integer num_run
    426       logical,save :: ice_update
    427 !$OMP THREADPRIVATE(ice_initial,ice_min,ice_update)
    428 
    429 !     For slab ocean. By BC
    430       real, dimension(:),allocatable,save ::  pctsrf_sic
    431       real, dimension(:,:),allocatable,save :: tslab
    432       real, dimension(:),allocatable,save ::  tsea_ice
    433       real, dimension(:),allocatable,save :: sea_ice
    434       real, dimension(:),allocatable,save :: zmasq
    435       integer, dimension(:),allocatable,save ::knindex
    436 !$OMP THREADPRIVATE(pctsrf_sic,tslab,tsea_ice,sea_ice,zmasq,knindex)
    437 
    438       real :: tsurf2(ngrid)
    439       real :: flux_o(ngrid),flux_g(ngrid),fluxgrdocean(ngrid)
    440       real :: flux_sens_lat(ngrid)
    441       real :: qsurfint(ngrid,nq)
    442362
    443363
     
    457377        ALLOCATE(tsoil(ngrid,nsoilmx))   
    458378        ALLOCATE(albedo(ngrid,L_NSPECTV))
    459          ALLOCATE(albedo_equivalent(ngrid))       
    460          ALLOCATE(albedo_snow_SPECTV(L_NSPECTV))
    461          ALLOCATE(albedo_co2_ice_SPECTV(L_NSPECTV))
    462          ALLOCATE(albedo_bareground(ngrid))           
    463         ALLOCATE(rnat(ngrid))         
     379        ALLOCATE(albedo_equivalent(ngrid))       
     380        ALLOCATE(albedo_bareground(ngrid))               
    464381        ALLOCATE(emis(ngrid))   
    465382        ALLOCATE(dtrad(ngrid,nlayer))
     
    472389        ALLOCATE(ztprevious(ngrid,nlayer))
    473390        ALLOCATE(zuprevious(ngrid,nlayer))
    474         ALLOCATE(cloudfrac(ngrid,nlayer))
    475         ALLOCATE(totcloudfrac(ngrid))
    476         ALLOCATE(hice(ngrid))
    477391        ALLOCATE(qsurf_hist(ngrid,nq))
    478392        ALLOCATE(reffrad(ngrid,nlayer,naerkind))
    479393        ALLOCATE(nueffrad(ngrid,nlayer,naerkind))
    480         ALLOCATE(ice_initial(ngrid))
    481         ALLOCATE(ice_min(ngrid))
    482394        ALLOCATE(fluxsurf_lw(ngrid))
    483395        ALLOCATE(fluxsurf_sw(ngrid))
     
    493405        ALLOCATE(zdtsw(ngrid,nlayer))
    494406        ALLOCATE(tau_col(ngrid))
    495         ALLOCATE(pctsrf_sic(ngrid))
    496         ALLOCATE(tslab(ngrid,noceanmx))
    497         ALLOCATE(tsea_ice(ngrid))
    498         ALLOCATE(sea_ice(ngrid))
    499         ALLOCATE(zmasq(ngrid))
    500         ALLOCATE(knindex(ngrid))
    501407
    502408        ! This is defined in comsaison_h
     
    532438!        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    533439         call phyetat0(ngrid,nlayer,"startfi.nc",0,0,nsoilmx,nq,      &
    534                        day_ini,time_phys,tsurf,tsoil,emis,q2,qsurf,   &
    535                        cloudfrac,totcloudfrac,hice,                   &
    536                        rnat,pctsrf_sic,tslab, tsea_ice,sea_ice)
     440                       day_ini,time_phys,tsurf,tsoil,emis,q2,qsurf)
    537441
    538442         if (pday.ne.day_ini) then
     
    550454         albedo(:,:)=0.0
    551455          albedo_bareground(:)=0.0
    552           albedo_snow_SPECTV(:)=0.0
    553           albedo_co2_ice_SPECTV(:)=0.0
    554          call surfini(ngrid,nq,qsurf,albedo,albedo_bareground,albedo_snow_SPECTV,albedo_co2_ice_SPECTV)
     456         call surfini(ngrid,nq,qsurf,albedo,albedo_bareground)
    555457         
    556458!        Initialize orbital calculation.
     
    564466         endif
    565467
    566 !        Initialize oceanic variables.
    567 !        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    568 
    569          if (ok_slab_ocean)then
    570 
    571            call ocean_slab_init(ngrid,ptimestep, tslab, &
    572                                 sea_ice, pctsrf_sic)
    573 
    574            call ini_surf_heat_transp_mod()
    575            
    576            knindex(:) = 0
    577 
    578            do ig=1,ngrid
    579               zmasq(ig)=1
    580               knindex(ig) = ig
    581               if (nint(rnat(ig)).eq.0) then
    582                  zmasq(ig)=0
    583               endif
    584            enddo
    585 
    586            CALL init_masquv(ngrid,zmasq)
    587 
    588          endif ! end of 'ok_slab_ocean'.
    589 
    590468
    591469!        Initialize soil.
     
    595473            call soil(ngrid,nsoilmx,firstcall,lastcall,inertiedat, &
    596474                      ptimestep,tsurf,tsoil,capcal,fluxgrd)
    597 
    598             if (ok_slab_ocean) then
    599                do ig=1,ngrid
    600                   if (nint(rnat(ig)).eq.2) then
    601                      capcal(ig)=capcalocean
    602                      if (pctsrf_sic(ig).gt.0.5) then
    603                         capcal(ig)=capcalseaice
    604                         if (qsurf(ig,igcm_h2o_ice).gt.0.) then
    605                            capcal(ig)=capcalsno
    606                         endif
    607                      endif
    608                   endif
    609                enddo
    610             endif ! end of 'ok_slab_ocean'.
    611475
    612476         else ! else of 'callsoil'.
     
    620484         
    621485         icount=1
    622 
    623 !        Decide whether to update ice at end of run.
    624 !        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    625          ice_update=.false.
    626          if(sourceevol)then
    627 !$OMP MASTER
    628             open(128,file='num_run',form='formatted', &
    629                      status="old",iostat=ierr)
    630             if (ierr.ne.0) then
    631                write(*,*) "physiq: Error! No num_run file!"
    632                write(*,*) " (which is needed for sourceevol option)"
    633                stop
    634             endif
    635             read(128,*) num_run
    636             close(128)
    637 !$OMP END MASTER
    638 !$OMP BARRIER
    639        
    640             if(num_run.ne.0.and.mod(num_run,2).eq.0)then
    641                print*,'Updating ice at end of this year!'
    642                ice_update=.true.
    643                ice_min(:)=1.e4
    644             endif
    645            
    646          endif ! end of 'sourceevol'.
    647 
    648 
    649          ! Here is defined the type of the surface : Continent or Ocean.
    650          ! BC2014 : This is now already done in newstart.
    651          ! ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    652          if (.not.ok_slab_ocean) then
    653          
    654            rnat(:)=1.
    655            do ig=1,ngrid
    656               if(inertiedat(ig,1).gt.1.E4)then
    657                  rnat(ig)=0
    658               endif
    659            enddo
    660 
    661            print*,'WARNING! Surface type currently decided by surface inertia'
    662            print*,'This should be improved e.g. in newstart.F'
    663486           
    664          endif ! end of 'ok_slab_ocean'.
    665 
    666487
    667488!        Initialize surface history variable.
     
    674495         zuprevious(:,:)=pu(:,:)
    675496
    676 !        Set temperature just above condensation temperature (for Early Mars)
    677 !        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    678          if(nearco2cond) then
    679             write(*,*)' WARNING! Starting at Tcond+1K'
    680             do l=1, nlayer
    681                do ig=1,ngrid
    682                   pdt(ig,l)= ((-3167.8)/(log(.01*pplay(ig,l))-23.23)+4     &
    683                       -pt(ig,l)) / ptimestep
    684                enddo
    685             enddo
    686          endif
    687497
    688498         if(meanOLR)then         
     
    691501            call system('rm -f h2o_bal.out') ! to record global hydrological balance.
    692502         endif
    693 
    694 
    695          watertest=.false.       
    696          if(water)then ! Initialize variables for water cycle
    697            
    698             if(enertest)then
    699                watertest = .true.
    700             endif
    701 
    702             if(ice_update)then
    703                ice_initial(:)=qsurf(:,igcm_h2o_ice)
    704             endif
    705 
    706          endif
    707          
    708          call su_watercycle ! even if we don't have a water cycle, we might
    709                             ! need epsi for the wvp definitions in callcorrk.F
    710503
    711504         if (ngrid.ne.1) then ! Note : no need to create a restart file in 1d.
     
    735528      ! Initialize various variables
    736529      ! ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    737      
    738       if ( .not.nearco2cond ) then
    739          pdt(1:ngrid,1:nlayer) = 0.0
    740       endif     
     530
     531      pdt(1:ngrid,1:nlayer) = 0.0     
    741532      zdtsurf(1:ngrid)      = 0.0
    742533      pdq(1:ngrid,1:nlayer,1:nq) = 0.0
     
    746537      pdpsrf(1:ngrid)       = 0.0
    747538      zflubid(1:ngrid)      = 0.0     
    748       flux_sens_lat(1:ngrid) = 0.0
    749539      taux(1:ngrid) = 0.0
    750540      tauy(1:ngrid) = 0.0
     
    870660! II.a Call correlated-k radiative transfer scheme
    871661! ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    872                if(kastprof)then
    873                   print*,'kastprof should not = true here'
    874                   call abort
    875                endif
    876                if(water) then
    877                   muvar(1:ngrid,1:nlayer)=mugaz/(1.e0+(1.e0/epsi-1.e0)*pq(1:ngrid,1:nlayer,igcm_h2o_vap))
    878                   muvar(1:ngrid,nlayer+1)=mugaz/(1.e0+(1.e0/epsi-1.e0)*pq(1:ngrid,nlayer,igcm_h2o_vap))
    879                   ! take into account water effect on mean molecular weight
    880                else
    881                   muvar(1:ngrid,1:nlayer+1)=mugaz
    882                endif
    883      
    884 
    885                if(ok_slab_ocean) then
    886                   tsurf2(:)=tsurf(:)
    887                   do ig=1,ngrid
    888                      if (nint(rnat(ig))==0) then
    889                         tsurf(ig)=((1.-pctsrf_sic(ig))*tslab(ig,1)**4+pctsrf_sic(ig)*tsea_ice(ig)**4)**0.25
    890                      endif
    891                   enddo
    892                endif !(ok_slab_ocean)
    893                
     662 
     663               muvar(1:ngrid,1:nlayer+1)=mugaz
     664
    894665               ! standard callcorrk
    895                clearsky=.false.
    896666               call callcorrk(ngrid,nlayer,pq,nq,qsurf,                           &
    897667                              albedo,albedo_equivalent,emis,mu0,pplev,pplay,pt,   &
     
    900670                              fluxsurfabs_sw,fluxtop_lw,                          &
    901671                              fluxabs_sw,fluxtop_dn,OLR_nu,OSR_nu,                &
    902                               tau_col,cloudfrac,totcloudfrac,                     &
    903                               clearsky,firstcall,lastcall)     
    904 
    905                 ! Option to call scheme once more for clear regions 
    906                if(CLFvarying)then
    907 
    908                   ! ---> PROBLEMS WITH ALLOCATED ARRAYS : temporary solution in callcorrk: do not deallocate if CLFvarying ...
    909                   clearsky=.true.
    910                   call callcorrk(ngrid,nlayer,pq,nq,qsurf,                           &
    911                                  albedo,albedo_equivalent1,emis,mu0,pplev,pplay,pt,   &
    912                                  tsurf,fract,dist_star,aerosol,muvar,                &
    913                                  zdtlw1,zdtsw1,fluxsurf_lw1,fluxsurf_sw1,            &
    914                                  fluxsurfabs_sw1,fluxtop_lw1,                        &
    915                                  fluxabs_sw1,fluxtop_dn,OLR_nu1,OSR_nu1,             &
    916                                  tau_col1,cloudfrac,totcloudfrac,                    &
    917                                  clearsky,firstcall,lastcall)
    918                   clearsky = .false.  ! just in case.     
    919 
    920                   ! Sum the fluxes and heating rates from cloudy/clear cases
    921                   do ig=1,ngrid
    922                      tf=totcloudfrac(ig)
    923                      ntf=1.-tf                   
    924                      fluxsurf_lw(ig)       = ntf*fluxsurf_lw1(ig)       + tf*fluxsurf_lw(ig)
    925                      fluxsurf_sw(ig)       = ntf*fluxsurf_sw1(ig)       + tf*fluxsurf_sw(ig)
    926                      albedo_equivalent(ig) = ntf*albedo_equivalent1(ig) + tf*albedo_equivalent(ig)
    927                      fluxsurfabs_sw(ig)    = ntf*fluxsurfabs_sw1(ig)    + tf*fluxsurfabs_sw(ig)
    928                      fluxtop_lw(ig)        = ntf*fluxtop_lw1(ig)        + tf*fluxtop_lw(ig)
    929                      fluxabs_sw(ig)        = ntf*fluxabs_sw1(ig)        + tf*fluxabs_sw(ig)
    930                      tau_col(ig)           = ntf*tau_col1(ig)           + tf*tau_col(ig)
    931                    
    932                      zdtlw(ig,1:nlayer) = ntf*zdtlw1(ig,1:nlayer) + tf*zdtlw(ig,1:nlayer)
    933                      zdtsw(ig,1:nlayer) = ntf*zdtsw1(ig,1:nlayer) + tf*zdtsw(ig,1:nlayer)
    934 
    935                      OSR_nu(ig,1:L_NSPECTV) = ntf*OSR_nu1(ig,1:L_NSPECTV) + tf*OSR_nu(ig,1:L_NSPECTV)                       
    936                      OLR_nu(ig,1:L_NSPECTI) = ntf*OLR_nu1(ig,1:L_NSPECTI) + tf*OLR_nu(ig,1:L_NSPECTI)                       
    937                   enddo                               
    938 
    939                endif ! end of CLFvarying.
    940 
    941                if(ok_slab_ocean) then
    942                   tsurf(:)=tsurf2(:)
    943                endif
    944 
     672                              tau_col,firstcall,lastcall)
    945673
    946674               ! Radiative flux from the sky absorbed by the surface (W.m-2).
     
    957685               dtrad(1:ngrid,1:nlayer)=zdtsw(1:ngrid,1:nlayer)+zdtlw(1:ngrid,1:nlayer)
    958686               
    959                ! Late initialization of the Ice Spectral Albedo. We needed the visible bands to do that !
    960                if (firstcall .and. albedo_spectral_mode) then
    961                   call spectral_albedo_calc(albedo_snow_SPECTV)
    962                endif
    963 
    964687            elseif(newtonian)then
    965688           
     
    1040763         if (UseTurbDiff) then
    1041764         
    1042             call turbdiff(ngrid,nlayer,nq,rnat,                  &
     765            call turbdiff(ngrid,nlayer,nq,                       &
    1043766                          ptimestep,capcal,lwrite,               &
    1044767                          pplay,pplev,zzlay,zzlev,z0,            &
     
    1046769                          pdt,pdq,zflubid,                       &
    1047770                          zdudif,zdvdif,zdtdif,zdtsdif,          &
    1048                           sensibFlux,q2,zdqdif,zdqevap,zdqsdif,  &
     771                          sensibFlux,q2,zdqdif,zdqsdif,          &
    1049772                          taux,tauy,lastcall)
    1050773
     
    1053776            zdh(1:ngrid,1:nlayer)=pdt(1:ngrid,1:nlayer)/zpopsk(1:ngrid,1:nlayer)
    1054777 
    1055             call vdifc(ngrid,nlayer,nq,rnat,zpopsk,           &
     778            call vdifc(ngrid,nlayer,nq,zpopsk,                &
    1056779                       ptimestep,capcal,lwrite,               &
    1057780                       pplay,pplev,zzlay,zzlev,z0,            &
     
    1072795         pdt(1:ngrid,1:nlayer)=pdt(1:ngrid,1:nlayer)+zdtdif(1:ngrid,1:nlayer)
    1073796         zdtsurf(1:ngrid)=zdtsurf(1:ngrid)+zdtsdif(1:ngrid)
    1074 
    1075 
    1076          if(ok_slab_ocean)then
    1077             flux_sens_lat(1:ngrid)=(zdtsdif(1:ngrid)*capcal(1:ngrid)-fluxrad(1:ngrid))
    1078          endif
    1079 
    1080797
    1081798         if (tracer) then
     
    1116833         endif ! end of 'enertest'
    1117834
    1118 
    1119          ! Test water conservation.
    1120          if(watertest.and.water)then
    1121          
    1122             call planetwide_sumval(massarea(:,:)*zdqdif(:,:,igcm_h2o_vap)*ptimestep/totarea_planet,dWtot_tmp)
    1123             call planetwide_sumval(zdqsdif(:,igcm_h2o_vap)*cell_area(:)*ptimestep/totarea_planet,dWtots_tmp)
    1124             do ig = 1, ngrid
    1125                vdifcncons(ig)=SUM(mass(ig,:)*zdqdif(ig,:,igcm_h2o_vap))
    1126             enddo
    1127             call planetwide_sumval(massarea(:,:)*zdqdif(:,:,igcm_h2o_ice)*ptimestep/totarea_planet,dWtot)
    1128             call planetwide_sumval(zdqsdif(:,igcm_h2o_ice)*cell_area(:)*ptimestep/totarea_planet,dWtots)
    1129             dWtot = dWtot + dWtot_tmp
    1130             dWtots = dWtots + dWtots_tmp
    1131             do ig = 1, ngrid
    1132                vdifcncons(ig)=vdifcncons(ig) + SUM(mass(ig,:)*zdqdif(ig,:,igcm_h2o_ice))
    1133             enddo           
    1134             call planetwide_maxval(vdifcncons(:),nconsMAX)
    1135 
    1136             if (is_master) then
    1137                print*,'---------------------------------------------------------------'
    1138                print*,'In difv atmospheric water change        =',dWtot,' kg m-2'
    1139                print*,'In difv surface water change            =',dWtots,' kg m-2'
    1140                print*,'In difv non-cons factor                 =',dWtot+dWtots,' kg m-2'
    1141                print*,'In difv MAX non-cons factor             =',nconsMAX,' kg m-2 s-1'
    1142             endif
    1143 
    1144          endif ! end of 'watertest'
    1145          !-------------------------
    1146 
    1147835      else ! calldifv
    1148836
     
    1190878         endif
    1191879
    1192          ! Test water conservation
    1193          if(watertest)then
    1194             call planetwide_sumval(massarea(:,:)*zdqadj(:,:,igcm_h2o_vap)*ptimestep/totarea_planet,dWtot_tmp)
    1195             do ig = 1, ngrid
    1196                cadjncons(ig)=SUM(mass(ig,:)*zdqadj(ig,:,igcm_h2o_vap))
    1197             enddo
    1198             call planetwide_sumval(massarea(:,:)*zdqadj(:,:,igcm_h2o_ice)*ptimestep/totarea_planet,dWtot)
    1199             dWtot = dWtot + dWtot_tmp
    1200             do ig = 1, ngrid
    1201                cadjncons(ig)=cadjncons(ig) + SUM(mass(ig,:)*zdqadj(ig,:,igcm_h2o_ice))
    1202             enddo           
    1203             call planetwide_maxval(cadjncons(:),nconsMAX)
    1204 
    1205             if (is_master) then
    1206                print*,'In convadj atmospheric water change     =',dWtot,' kg m-2'
    1207                print*,'In convadj MAX non-cons factor          =',nconsMAX,' kg m-2 s-1'
    1208             endif
    1209            
    1210          endif ! end of 'watertest'
    1211880         
    1212881      endif ! end of 'calladj'
    1213 
    1214 !-----------------------------------------------
    1215 !   V. Carbon dioxide condensation-sublimation :
    1216 !-----------------------------------------------
    1217 
    1218       if (co2cond) then
    1219      
    1220          if (.not.tracer) then
    1221             print*,'We need a CO2 ice tracer to condense CO2'
    1222             call abort
    1223          endif
    1224          call condense_co2(ngrid,nlayer,nq,ptimestep,                    &
    1225                            capcal,pplay,pplev,tsurf,pt,                  &
    1226                            pdt,zdtsurf,pq,pdq,                           &
    1227                            qsurf,zdqsurfc,albedo,emis,                   &
    1228                            albedo_bareground,albedo_co2_ice_SPECTV,      &
    1229                            zdtc,zdtsurfc,pdpsrf,zdqc)
    1230 
    1231          pdt(1:ngrid,1:nlayer) = pdt(1:ngrid,1:nlayer)+zdtc(1:ngrid,1:nlayer)
    1232          zdtsurf(1:ngrid)      = zdtsurf(1:ngrid) + zdtsurfc(1:ngrid)
    1233 
    1234          pdq(1:ngrid,1:nlayer,1:nq)   = pdq(1:ngrid,1:nlayer,1:nq)+ zdqc(1:ngrid,1:nlayer,1:nq)
    1235          dqsurf(1:ngrid,igcm_co2_ice) = dqsurf(1:ngrid,igcm_co2_ice) + zdqsurfc(1:ngrid)
    1236 
    1237          ! test energy conservation
    1238          if(enertest)then
    1239             call planetwide_sumval(cpp*massarea(:,:)*zdtc(:,:)/totarea_planet,dEtot)
    1240             call planetwide_sumval(capcal(:)*zdtsurfc(:)*cell_area(:)/totarea_planet,dEtots)
    1241             if (is_master) then
    1242                print*,'In co2cloud atmospheric energy change   =',dEtot,' W m-2'
    1243                print*,'In co2cloud surface energy change       =',dEtots,' W m-2'
    1244             endif
    1245          endif
    1246 
    1247       endif  ! end of 'co2cond'
    1248 
     882     
    1249883
    1250884!---------------------------------------------
    1251 !   VI. Specific parameterizations for tracers
     885!   V. Specific parameterizations for tracers
    1252886!---------------------------------------------
    1253887
    1254888      if (tracer) then
    1255889     
    1256   ! ---------------------
    1257   !   VI.1. Water and ice
    1258   ! ---------------------
    1259          if (water) then
    1260 
    1261             ! Water ice condensation in the atmosphere
    1262             if(watercond.and.(RLVTT.gt.1.e-8))then
    1263 
    1264                dqmoist(1:ngrid,1:nlayer,1:nq)=0.
    1265                dtmoist(1:ngrid,1:nlayer)=0.
    1266                
    1267                ! Moist Convective Adjustment.
    1268                ! ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    1269                call moistadj(ngrid,nlayer,nq,pt,pq,pdq,pplev,pplay,dtmoist,dqmoist,ptimestep,rneb_man)
    1270 
    1271                pdq(1:ngrid,1:nlayer,igcm_h2o_vap) = pdq(1:ngrid,1:nlayer,igcm_h2o_vap)     &
    1272                                                   + dqmoist(1:ngrid,1:nlayer,igcm_h2o_vap)
    1273                pdq(1:ngrid,1:nlayer,igcm_h2o_ice) = pdq(1:ngrid,1:nlayer,igcm_h2o_ice)     &
    1274                                                   + dqmoist(1:ngrid,1:nlayer,igcm_h2o_ice)
    1275                pdt(1:ngrid,1:nlayer) = pdt(1:ngrid,1:nlayer)+dtmoist(1:ngrid,1:nlayer)
    1276 
    1277                ! Test energy conservation.
    1278                if(enertest)then
    1279                
    1280                   call planetwide_sumval(cpp*massarea(:,:)*dtmoist(:,:)/totarea_planet,dEtot)
    1281                   call planetwide_maxval(dtmoist(:,:),dtmoist_max)
    1282                   call planetwide_minval(dtmoist(:,:),dtmoist_min)
    1283                   madjdEz(:,:)=cpp*mass(:,:)*dtmoist(:,:)
    1284                   do ig=1,ngrid
    1285                      madjdE(ig) = cpp*SUM(mass(:,:)*dtmoist(:,:))
    1286                   enddo
    1287                  
    1288                   if (is_master) then
    1289                      print*,'In moistadj atmospheric energy change   =',dEtot,' W m-2'
    1290                      print*,'In moistadj MAX atmospheric energy change   =',dtmoist_max*ptimestep,'K/step'
    1291                      print*,'In moistadj MIN atmospheric energy change   =',dtmoist_min*ptimestep,'K/step'
    1292                   endif
    1293                  
    1294                   call planetwide_sumval(massarea(:,:)*dqmoist(:,:,igcm_h2o_vap)*ptimestep/totarea_planet+        &
    1295                                            massarea(:,:)*dqmoist(:,:,igcm_h2o_ice)*ptimestep/totarea_planet,dWtot)
    1296                   if (is_master) print*,'In moistadj atmospheric water change    =',dWtot,' kg m-2'
    1297                  
    1298                endif ! end of 'enertest'
    1299                
    1300 
    1301                ! Large scale condensation/evaporation.
    1302                ! ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    1303                call largescale(ngrid,nlayer,nq,ptimestep,pplev,pplay,pt,pq,pdt,pdq,dtlscale,dqvaplscale,dqcldlscale,rneb_lsc)
    1304 
    1305                pdt(1:ngrid,1:nlayer) = pdt(1:ngrid,1:nlayer)+dtlscale(1:ngrid,1:nlayer)
    1306                pdq(1:ngrid,1:nlayer,igcm_h2o_vap) = pdq(1:ngrid,1:nlayer,igcm_h2o_vap)+dqvaplscale(1:ngrid,1:nlayer)
    1307                pdq(1:ngrid,1:nlayer,igcm_h2o_ice) = pdq(1:ngrid,1:nlayer,igcm_h2o_ice)+dqcldlscale(1:ngrid,1:nlayer)
    1308 
    1309                ! Test energy conservation.
    1310                if(enertest)then
    1311                   lscaledEz(:,:) = cpp*mass(:,:)*dtlscale(:,:)
    1312                   do ig=1,ngrid
    1313                      lscaledE(ig) = cpp*SUM(mass(:,:)*dtlscale(:,:))
    1314                   enddo
    1315                   call planetwide_sumval(cpp*massarea(:,:)*dtlscale(:,:)/totarea_planet,dEtot)
    1316 
    1317                   if (is_master) print*,'In largescale atmospheric energy change =',dEtot,' W m-2'
    1318 
    1319                   ! Test water conservation.
    1320                   call planetwide_sumval(massarea(:,:)*dqvaplscale(:,:)*ptimestep/totarea_planet+        &
    1321                                            SUM(massarea(:,:)*dqcldlscale(:,:))*ptimestep/totarea_planet,dWtot)
    1322                        
    1323                   if (is_master) print*,'In largescale atmospheric water change  =',dWtot,' kg m-2'
    1324                endif ! end of 'enertest'
    1325 
    1326                ! Compute cloud fraction.
    1327                do l = 1, nlayer
    1328                   do ig=1,ngrid
    1329                      cloudfrac(ig,l)=MAX(rneb_lsc(ig,l),rneb_man(ig,l))
    1330                   enddo
    1331                enddo
    1332 
    1333             endif ! end of 'watercond'
    1334            
    1335             ! Water ice / liquid precipitation.
    1336             ! ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    1337             if(waterrain)then
    1338 
    1339                zdqrain(1:ngrid,1:nlayer,1:nq) = 0.0
    1340                zdqsrain(1:ngrid)    = 0.0
    1341                zdqssnow(1:ngrid)    = 0.0
    1342 
    1343                call rain(ngrid,nlayer,nq,ptimestep,pplev,pplay,pt,pdt,pq,pdq,            &
    1344                          zdtrain,zdqrain,zdqsrain,zdqssnow,cloudfrac)
    1345 
    1346                pdq(1:ngrid,1:nlayer,igcm_h2o_vap) = pdq(1:ngrid,1:nlayer,igcm_h2o_vap) &
    1347                                                   + zdqrain(1:ngrid,1:nlayer,igcm_h2o_vap)
    1348                pdq(1:ngrid,1:nlayer,igcm_h2o_ice) = pdq(1:ngrid,1:nlayer,igcm_h2o_ice) &
    1349                                                   + zdqrain(1:ngrid,1:nlayer,igcm_h2o_ice)
    1350                pdt(1:ngrid,1:nlayer) = pdt(1:ngrid,1:nlayer)+zdtrain(1:ngrid,1:nlayer)
    1351                
    1352                dqsurf(1:ngrid,igcm_h2o_vap) = dqsurf(1:ngrid,igcm_h2o_vap)+zdqsrain(1:ngrid)
    1353                dqsurf(1:ngrid,igcm_h2o_ice) = dqsurf(1:ngrid,igcm_h2o_ice)+zdqssnow(1:ngrid)
    1354 
    1355                ! Test energy conservation.
    1356                if(enertest)then
    1357                
    1358                   call planetwide_sumval(cpp*massarea(:,:)*zdtrain(:,:)/totarea_planet,dEtot)
    1359                   if (is_master) print*,'In rain atmospheric T energy change       =',dEtot,' W m-2'
    1360                   call planetwide_sumval(massarea(:,:)*zdqrain(:,:,igcm_h2o_ice)/totarea_planet*RLVTT/cpp,dItot_tmp)
    1361                   call planetwide_sumval(cell_area(:)*zdqssnow(:)/totarea_planet*RLVTT/cpp,dItot)
    1362                   dItot = dItot + dItot_tmp
    1363                   call planetwide_sumval(massarea(:,:)*zdqrain(:,:,igcm_h2o_vap)*ptimestep/totarea_planet,dVtot_tmp)
    1364                   call planetwide_sumval(cell_area(:)*zdqsrain(:)/totarea_planet*RLVTT/cpp,dVtot)
    1365                   dVtot = dVtot + dVtot_tmp
    1366                   dEtot = dItot + dVtot
    1367                  
    1368                   if (is_master) then
    1369                      print*,'In rain dItot =',dItot,' W m-2'
    1370                      print*,'In rain dVtot =',dVtot,' W m-2'
    1371                      print*,'In rain atmospheric L energy change       =',dEtot,' W m-2'
    1372                   endif
    1373 
    1374                   ! Test water conservation
    1375                   call planetwide_sumval(massarea(:,:)*zdqrain(:,:,igcm_h2o_vap)*ptimestep/totarea_planet+        &
    1376                           massarea(:,:)*zdqrain(:,:,igcm_h2o_ice)*ptimestep/totarea_planet,dWtot)
    1377                   call planetwide_sumval((zdqsrain(:)+zdqssnow(:))*cell_area(:)*ptimestep/totarea_planet,dWtots)
    1378                  
    1379                   if (is_master) then
    1380                           print*,'In rain atmospheric water change        =',dWtot,' kg m-2'
    1381                           print*,'In rain surface water change            =',dWtots,' kg m-2'
    1382                           print*,'In rain non-cons factor                 =',dWtot+dWtots,' kg m-2'
    1383                   endif
    1384                  
    1385                endif ! end of 'enertest'
    1386 
    1387             end if ! enf of 'waterrain'
    1388            
    1389          end if ! end of 'water'
    1390 
     890     
    1391891  ! -------------------------
    1392   !   VI.2. Aerosol particles
     892  !   V.1. Aerosol particles
    1393893  ! -------------------------
    1394894
     
    1398898            zdqsed(1:ngrid,1:nlayer,1:nq) = 0.0
    1399899            zdqssed(1:ngrid,1:nq)  = 0.0
    1400 
    1401             if(watertest)then
    1402            
    1403                iq=igcm_h2o_ice
    1404                call planetwide_sumval(massarea(:,:)*pq(:,:,iq)*ptimestep/totarea_planet,dWtot)
    1405                call planetwide_sumval(massarea(:,:)*pdq(:,:,iq)*ptimestep/totarea_planet,dWtots)
    1406                if (is_master) then
    1407                         print*,'Before sedim pq  =',dWtot,' kg m-2'
    1408                   print*,'Before sedim pdq =',dWtots,' kg m-2'
    1409                endif
    1410             endif
    1411900           
    1412901            call callsedim(ngrid,nlayer,ptimestep,           &
     
    1414903                          zdqsed,zdqssed,nq)
    1415904
    1416             if(watertest)then
    1417                iq=igcm_h2o_ice
    1418                call planetwide_sumval(massarea(:,:)*pq(:,:,iq)*ptimestep/totarea_planet,dWtot)
    1419                call planetwide_sumval(massarea(:,:)*pdq(:,:,iq)*ptimestep/totarea_planet,dWtots)
    1420                if (is_master) then
    1421                         print*,'After sedim pq  =',dWtot,' kg m-2'
    1422                         print*,'After sedim pdq =',dWtots,' kg m-2'
    1423                  endif
    1424             endif
    1425 
    1426905            ! Whether it falls as rain or snow depends only on the surface temperature
    1427906            pdq(1:ngrid,1:nlayer,1:nq) = pdq(1:ngrid,1:nlayer,1:nq) + zdqsed(1:ngrid,1:nlayer,1:nq)
    1428907            dqsurf(1:ngrid,1:nq) = dqsurf(1:ngrid,1:nq) + zdqssed(1:ngrid,1:nq)
    1429908
    1430             ! Test water conservation
    1431             if(watertest)then
    1432                call planetwide_sumval(massarea(:,:)*(zdqsed(:,:,igcm_h2o_vap)+zdqsed(:,:,igcm_h2o_ice))*ptimestep/totarea_planet,dWtot)
    1433                call planetwide_sumval((zdqssed(:,igcm_h2o_vap)+zdqssed(:,igcm_h2o_ice))*cell_area(:)*ptimestep/totarea_planet,dWtots)
    1434                if (is_master) then
    1435                         print*,'In sedim atmospheric ice change         =',dWtot,' kg m-2'
    1436                         print*,'In sedim surface ice change             =',dWtots,' kg m-2'
    1437                         print*,'In sedim non-cons factor                =',dWtot+dWtots,' kg m-2'
    1438                endif
    1439             endif
    1440 
    1441909         end if ! end of 'sedimentation'
    1442910
    1443911
    1444912  ! ---------------
    1445   !   VI.3. Updates
     913  !   V.2. Updates
    1446914  ! ---------------
    1447915
     
    1449917         if(mass_redistrib) then
    1450918
    1451             zdmassmr(1:ngrid,1:nlayer) = mass(1:ngrid,1:nlayer) *     &
    1452                (   zdqevap(1:ngrid,1:nlayer)                          &
    1453                  + zdqrain(1:ngrid,1:nlayer,igcm_h2o_vap)             &
    1454                  + dqmoist(1:ngrid,1:nlayer,igcm_h2o_vap)             &
    1455                  + dqvaplscale(1:ngrid,1:nlayer) )
     919            zdmassmr(1:ngrid,1:nlayer) = mass(1:ngrid,1:nlayer) * zdqevap(1:ngrid,1:nlayer)
    1456920
    1457921            do ig = 1, ngrid
     
    1464928
    1465929            call mass_redistribution(ngrid,nlayer,nq,ptimestep,                     &
    1466                                      rnat,capcal,pplay,pplev,pt,tsurf,pq,qsurf,     &
     930                                     capcal,pplay,pplev,pt,tsurf,pq,qsurf,          &
    1467931                                     pu,pv,pdt,zdtsurf,pdq,pdu,pdv,zdmassmr,        &
    1468932                                     zdtmr,zdtsurfmr,zdpsrfmr,zdumr,zdvmr,zdqmr,zdqsurfmr)
     
    1478942         endif
    1479943
    1480   ! ------------------
    1481   !   VI.4. Slab Ocean
    1482   ! ------------------
    1483 
    1484          if (ok_slab_ocean)then
    1485 
    1486             do ig=1,ngrid
    1487                qsurfint(:,igcm_h2o_ice)=qsurf(:,igcm_h2o_ice)
    1488             enddo
    1489 
    1490             call ocean_slab_ice(ptimestep,                          &
    1491                                 ngrid, knindex, tsea_ice, fluxrad,  &
    1492                                 zdqssnow, qsurf(:,igcm_h2o_ice),    &
    1493                               - zdqsdif(:,igcm_h2o_vap),            &
    1494                                 flux_sens_lat,tsea_ice, pctsrf_sic, &
    1495                                 taux,tauy,icount)
    1496 
    1497 
    1498             call ocean_slab_get_vars(ngrid,tslab,      &
    1499                                      sea_ice, flux_o,  &
    1500                                      flux_g, dt_hdiff, &
    1501                                      dt_ekman)
    1502    
    1503             do ig=1,ngrid
    1504                if (nint(rnat(ig)).eq.1)then
    1505                   tslab(ig,1) = 0.
    1506                   tslab(ig,2) = 0.
    1507                   tsea_ice(ig) = 0.
    1508                   sea_ice(ig) = 0.
    1509                   pctsrf_sic(ig) = 0.
    1510                   qsurf(ig,igcm_h2o_ice) = qsurfint(ig,igcm_h2o_ice)
    1511                endif
    1512             enddo
    1513 
    1514          endif ! end of 'ok_slab_ocean'
    1515 
    1516944  ! -----------------------------
    1517   !   VI.5. Surface Tracer Update
     945  !   V.3. Surface Tracer Update
    1518946  ! -----------------------------
    1519947
    1520          if(hydrology)then
    1521            
    1522             call hydrol(ngrid,nq,ptimestep,rnat,tsurf,qsurf,dqsurf,dqs_hyd, &
    1523                         capcal,albedo,albedo_bareground,                    &
    1524                         albedo_snow_SPECTV,albedo_co2_ice_SPECTV,           &
    1525                         mu0,zdtsurf,zdtsurf_hyd,hice,pctsrf_sic,            &
    1526                         sea_ice)
    1527 
    1528             zdtsurf(1:ngrid)     = zdtsurf(1:ngrid) + zdtsurf_hyd(1:ngrid)
    1529             dqsurf(1:ngrid,1:nq) = dqsurf(1:ngrid,1:nq) + dqs_hyd(1:ngrid,1:nq)
    1530            
    1531             qsurf(1:ngrid,1:nq) = qsurf(1:ngrid,1:nq) + ptimestep*dqsurf(1:ngrid,1:nq)
    1532 
    1533             ! Test energy conservation
    1534             if(enertest)then
    1535                call planetwide_sumval(cell_area(:)*capcal(:)*zdtsurf_hyd(:)/totarea_planet,dEtots)
    1536                if (is_master) print*,'In hydrol surface energy change     =',dEtots,' W m-2'
    1537             endif
    1538 
    1539             ! test water conservation
    1540             if(watertest)then
    1541                call planetwide_sumval(dqs_hyd(:,igcm_h2o_ice)*cell_area(:)*ptimestep/totarea_planet,dWtots)
    1542                if (is_master) print*,'In hydrol surface ice change            =',dWtots,' kg m-2'
    1543                   call planetwide_sumval(dqs_hyd(:,igcm_h2o_vap)*cell_area(:)*ptimestep/totarea_planet,dWtots)
    1544                if (is_master) then
    1545                   print*,'In hydrol surface water change          =',dWtots,' kg m-2'
    1546                   print*,'---------------------------------------------------------------'
    1547                endif
    1548             endif
    1549 
    1550          else ! of if (hydrology)
    1551 
    1552             qsurf(1:ngrid,1:nq) = qsurf(1:ngrid,1:nq) + ptimestep*dqsurf(1:ngrid,1:nq)
    1553 
    1554          end if ! of if (hydrology)
     948        qsurf(1:ngrid,1:nq) = qsurf(1:ngrid,1:nq) + ptimestep*dqsurf(1:ngrid,1:nq)
    1555949
    1556950         ! Add qsurf to qsurf_hist, which is what we save in diagfi.nc. At the same time, we set the water
     
    1558952         qsurf_hist(:,:) = qsurf(:,:)
    1559953
    1560          if(ice_update)then
    1561             ice_min(1:ngrid)=min(ice_min(1:ngrid),qsurf(1:ngrid,igcm_h2o_ice))
    1562          endif
    1563 
    1564954      endif! end of if 'tracer'
    1565955
    1566956
    1567957!------------------------------------------------
    1568 !   VII. Surface and sub-surface soil temperature
     958!   VI. Surface and sub-surface soil temperature
    1569959!------------------------------------------------
    1570960
    1571961
    1572962      ! Increment surface temperature
    1573       if(ok_slab_ocean)then
    1574          do ig=1,ngrid
    1575            if (nint(rnat(ig)).eq.0)then
    1576              zdtsurf(ig)= (tslab(ig,1)              &
    1577              + pctsrf_sic(ig)*(tsea_ice(ig)-tslab(ig,1))-tsurf(ig))/ptimestep
    1578            endif
    1579            tsurf(ig)=tsurf(ig)+ptimestep*zdtsurf(ig)
    1580          enddo
    1581    
    1582       else
    1583         tsurf(1:ngrid)=tsurf(1:ngrid)+ptimestep*zdtsurf(1:ngrid)
    1584       endif ! end of 'ok_slab_ocean'
    1585 
     963
     964      tsurf(1:ngrid)=tsurf(1:ngrid)+ptimestep*zdtsurf(1:ngrid)
    1586965
    1587966      ! Compute soil temperatures and subsurface heat flux.
     
    1592971
    1593972
    1594       if (ok_slab_ocean) then
    1595      
    1596          do ig=1,ngrid
    1597          
    1598             fluxgrdocean(ig)=fluxgrd(ig)
    1599             if (nint(rnat(ig)).eq.0) then
    1600                capcal(ig)=capcalocean
    1601                fluxgrd(ig)=0.
    1602                fluxgrdocean(ig)=pctsrf_sic(ig)*flux_g(ig)+(1-pctsrf_sic(ig))*(dt_hdiff(ig,1)+dt_ekman(ig,1))
    1603                do iq=1,nsoilmx
    1604                   tsoil(ig,iq)=tsurf(ig)
    1605                enddo
    1606                if (pctsrf_sic(ig).gt.0.5) then
    1607                   capcal(ig)=capcalseaice
    1608                   if (qsurf(ig,igcm_h2o_ice).gt.0.) then
    1609                      capcal(ig)=capcalsno
    1610                   endif
    1611                endif               
    1612             endif
    1613            
    1614          enddo
    1615          
    1616       endif !end of 'ok_slab_ocean'
    1617 
    1618 
    1619973      ! Test energy conservation
    1620974      if(enertest)then
     
    1625979
    1626980!---------------------------------------------------
    1627 !   VIII. Perform diagnostics and write output files
     981!   VII. Perform diagnostics and write output files
    1628982!---------------------------------------------------
    1629983
     
    17571111         ! Generalised for arbitrary aerosols now. By LK
    17581112         reffcol(1:ngrid,1:naerkind)=0.0
    1759          if(co2cond.and.(iaero_co2.ne.0))then
    1760             call co2_reffrad(ngrid,nlayer,nq,zq,reffrad(1,1,iaero_co2))
    1761             do ig=1,ngrid
    1762                reffcol(ig,iaero_co2) = SUM(zq(ig,1:nlayer,igcm_co2_ice)*reffrad(ig,1:nlayer,iaero_co2)*mass(ig,1:nlayer))
    1763             enddo
    1764          endif
    1765          if(water.and.(iaero_h2o.ne.0))then
    1766             call h2o_reffrad(ngrid,nlayer,zq(1,1,igcm_h2o_ice),zt, &
    1767                              reffrad(1,1,iaero_h2o),nueffrad(1,1,iaero_h2o))
    1768             do ig=1,ngrid
    1769                reffcol(ig,iaero_h2o) = SUM(zq(ig,1:nlayer,igcm_h2o_ice)*reffrad(ig,1:nlayer,iaero_h2o)*mass(ig,1:nlayer))
    1770             enddo
    1771          endif
    17721113
    17731114      endif ! end of 'tracer'
    1774 
    1775 
    1776       ! Test for water conservation.
    1777       if(water)then
    1778 
    1779          call planetwide_sumval(cell_area(:)*qsurf_hist(:,igcm_h2o_ice)/totarea_planet,icesrf)
    1780          call planetwide_sumval(cell_area(:)*qsurf_hist(:,igcm_h2o_vap)/totarea_planet,liqsrf)
    1781          call planetwide_sumval(cell_area(:)*qcol(:,igcm_h2o_ice)/totarea_planet,icecol)
    1782          call planetwide_sumval(cell_area(:)*qcol(:,igcm_h2o_vap)/totarea_planet,vapcol)
    1783 
    1784          h2otot = icesrf + liqsrf + icecol + vapcol
    1785          
    1786          if (is_master) then
    1787             print*,' Total water amount [kg m^-2]: ',h2otot
    1788             print*,' Surface ice    Surface liq.   Atmos. con.     Atmos. vap. [kg m^-2] '
    1789             print*, icesrf,liqsrf,icecol,vapcol
    1790          endif
    1791 
    1792          if(meanOLR .and. is_master)then
    1793             if((ngrid.gt.1) .or. (mod(icount-1,ecritphy).eq.0))then
    1794                ! to record global water balance
    1795                open(98,file="h2o_bal.out",form='formatted',position='append')
    1796                write(98,*) zday,icesrf,liqsrf,icecol,vapcol
    1797                close(98)
    1798             endif
    1799          endif
    1800 
    1801       endif
    1802 
    1803 
    1804       ! Calculate RH (Relative Humidity) for diagnostic.
    1805       if(water)then
    1806      
    1807          do l = 1, nlayer
    1808             do ig=1,ngrid
    1809                call Psat_water(zt(ig,l),pplay(ig,l),psat_tmp,qsat(ig,l))
    1810                RH(ig,l) = zq(ig,l,igcm_h2o_vap) / qsat(ig,l)
    1811             enddo
    1812          enddo
    1813 
    1814          ! Compute maximum possible H2O column amount (100% saturation).
    1815          do ig=1,ngrid
    1816             H2Omaxcol(ig) = SUM( qsat(ig,:) * mass(ig,:))
    1817          enddo
    1818 
    1819       endif ! end of 'water'
    18201115
    18211116
     
    18381133         ztime_fin = ptime + ptimestep/(float(iphysiq)*daysec)
    18391134
    1840          ! Update surface ice distribution to iterate to steady state if requested
    1841          if(ice_update)then
    1842 
    1843             do ig=1,ngrid
    1844 
    1845                delta_ice = (qsurf(ig,igcm_h2o_ice)-ice_initial(ig))
    1846                
    1847                ! add multiple years of evolution
    1848                qsurf_hist(ig,igcm_h2o_ice) = qsurf_hist(ig,igcm_h2o_ice) + delta_ice*icetstep
    1849 
    1850                ! if ice has gone -ve, set to zero
    1851                if(qsurf_hist(ig,igcm_h2o_ice).lt.0.0)then
    1852                   qsurf_hist(ig,igcm_h2o_ice) = 0.0
    1853                endif
    1854 
    1855                ! if ice is seasonal, set to zero (NEW)
    1856                if(ice_min(ig).lt.0.01)then
    1857                   qsurf_hist(ig,igcm_h2o_ice) = 0.0
    1858                endif
    1859 
    1860             enddo
    1861 
    1862             ! enforce ice conservation
    1863             ice_tot= SUM(qsurf_hist(:,igcm_h2o_ice)*cell_area(:) )/SUM(cell_area(:))
    1864             qsurf_hist(:,igcm_h2o_ice) = qsurf_hist(:,igcm_h2o_ice)*(icesrf/ice_tot)
    1865 
    1866          endif
    1867 
    18681135         if (ngrid.ne.1) then
    18691136            write(*,*)'PHYSIQ: for physdem ztime_fin =',ztime_fin
     
    18711138            call physdem1("restartfi.nc",nsoilmx,ngrid,nlayer,nq, &
    18721139                          ptimestep,ztime_fin,                    &
    1873                           tsurf,tsoil,emis,q2,qsurf_hist,         &
    1874                           cloudfrac,totcloudfrac,hice,            &
    1875                           rnat,pctsrf_sic,tslab,tsea_ice,sea_ice)
    1876          endif
    1877 
    1878          if(ok_slab_ocean) then
    1879             call ocean_slab_final!(tslab, seaice)
    1880          end if
    1881 
     1140                          tsurf,tsoil,emis,q2,qsurf_hist)
     1141         endif
    18821142         
    18831143      endif ! end of 'lastcall'
     
    19371197
    19381198            end do
    1939            
    1940             if (water) then
    1941                vmr=zq(1:ngrid,1:nlayer,igcm_h2o_vap)*mugaz/mmol(igcm_h2o_vap)
    1942                call wstats(ngrid,"vmr_h2ovapor",                             &
    1943                            "H2O vapour volume mixing ratio","mol/mol",       &
    1944                            3,vmr)
    1945             endif
    19461199
    19471200         endif ! end of 'tracer'
    1948 
    1949          if(watercond.and.CLFvarying)then
    1950             call wstats(ngrid,"rneb_man","H2O cloud fraction (conv)"," ",3,rneb_man)
    1951             call wstats(ngrid,"rneb_lsc","H2O cloud fraction (large scale)"," ",3,rneb_lsc)
    1952             call wstats(ngrid,"CLF","H2O cloud fraction"," ",3,cloudfrac)
    1953             call wstats(ngrid,"CLFt","H2O column cloud fraction"," ",2,totcloudfrac)
    1954             call wstats(ngrid,"RH","relative humidity"," ",3,RH)
    1955          endif
    1956 
    1957          if (ok_slab_ocean) then
    1958             call wstats(ngrid,"dt_hdiff1","dt_hdiff1","K/s",2,dt_hdiff(:,1))
    1959             call wstats(ngrid,"dt_hdiff2","dt_hdiff2","K/s",2,dt_hdiff(:,2))
    1960             call wstats(ngrid,"dt_ekman1","dt_ekman1","K/s",2,dt_ekman(:,1))
    1961             call wstats(ngrid,"dt_ekman2","dt_ekman2","K/s",2,dt_ekman(:,2))
    1962             call wstats(ngrid,"tslab1","tslab1","K",2,tslab(:,1))
    1963             call wstats(ngrid,"tslab2","tslab2","K",2,tslab(:,2))
    1964             call wstats(ngrid,"pctsrf_sic","pct ice/sea","",2,pctsrf_sic)
    1965             call wstats(ngrid,"tsea_ice","tsea_ice","K",2,tsea_ice)
    1966             call wstats(ngrid,"sea_ice","sea ice","kg/m2",2,sea_ice)
    1967             call wstats(ngrid,"rnat","nature of the surface","",2,rnat)
    1968          endif
    19691201
    19701202         if(lastcall) then
     
    20031235!        call writediagsoil(ngrid,"temp","temperature","K",3,tsoil)
    20041236
    2005       ! Oceanic layers
    2006       if(ok_slab_ocean) then
    2007          call writediagfi(ngrid,"pctsrf_sic","pct ice/sea","",2,pctsrf_sic)
    2008          call writediagfi(ngrid,"tsea_ice","tsea_ice","K",2,tsea_ice)
    2009          call writediagfi(ngrid,"sea_ice","sea ice","kg/m2",2,sea_ice)
    2010          call writediagfi(ngrid,"tslab1","tslab1","K",2,tslab(:,1))
    2011          call writediagfi(ngrid,"tslab2","tslab2","K",2,tslab(:,2))
    2012          call writediagfi(ngrid,"dt_hdiff1","dt_hdiff1","K/s",2,dt_hdiff(:,1))
    2013          call writediagfi(ngrid,"dt_hdiff2","dt_hdiff2","K/s",2,dt_hdiff(:,2))
    2014          call writediagfi(ngrid,"dt_ekman1","dt_ekman1","K/s",2,dt_ekman(:,1))
    2015          call writediagfi(ngrid,"dt_ekman2","dt_ekman2","K/s",2,dt_ekman(:,2))
    2016          call writediagfi(ngrid,"rnat","nature of the surface","",2,rnat)
    2017          call writediagfi(ngrid,"sensibFlux","sensible heat flux","w.m^-2",2,sensibFlux)
    2018          call writediagfi(ngrid,"latentFlux","latent heat flux","w.m^-2",2,zdqsdif(:,igcm_h2o_vap)*RLVTT)
    2019       endif
    20201237     
    20211238
     
    20371254!           call writediagfi(ngrid,"fluxsurflwcs","lw back radiation (cs).","W m-2",2,fluxsurf_lw1)
    20381255
    2039          if(ok_slab_ocean) then
    2040             call writediagfi(ngrid,"GND","heat flux from ground","W m-2",2,fluxgrdocean)
    2041          else
    2042             call writediagfi(ngrid,"GND","heat flux from ground","W m-2",2,fluxgrd)
    2043          endif
     1256
     1257         call writediagfi(ngrid,"GND","heat flux from ground","W m-2",2,fluxgrd)
    20441258         
    20451259         call writediagfi(ngrid,"DYN","dynamical heat input","W m-2",2,fluxdyn)
     
    20651279         endif
    20661280         
    2067          if(watercond) then
    2068 
    2069             call writediagfi(ngrid,"lscaledE","heat from largescale","W m-2",2,lscaledE)
    2070             call writediagfi(ngrid,"madjdE","heat from moistadj","W m-2",2,madjdE)
    2071             call writediagfi(ngrid,"qsatatm","atm qsat"," ",3,qsat)
    2072              
    2073 !             call writediagfi(ngrid,"lscaledEz","heat from largescale","W m-2",3,lscaledEz)
    2074 !             call writediagfi(ngrid,"madjdEz","heat from moistadj","W m-2",3,madjdEz)             
    2075 !             call writediagfi(ngrid,"h2o_max_col","maximum H2O column amount","kg.m^-2",2,H2Omaxcol)
    2076 
    2077          endif
    2078          
    20791281      endif ! end of 'enertest'
    20801282
     
    20871289       
    20881290        ! For Debugging.
    2089         !call writediagfi(ngrid,'rnat','Terrain type',' ',2,real(rnat))
    20901291        !call writediagfi(ngrid,'pphi','Geopotential',' ',3,pphi)
    20911292       
    2092 
    2093       ! Output aerosols.
    2094       if (igcm_co2_ice.ne.0.and.iaero_co2.ne.0) &
    2095          call writediagfi(ngrid,'CO2ice_reff','CO2ice_reff','m',3,reffrad(1,1,iaero_co2))
    2096       if (igcm_h2o_ice.ne.0.and.iaero_h2o.ne.0) &
    2097          call writediagfi(ngrid,'H2Oice_reff','H2Oice_reff','m',3,reffrad(:,:,iaero_h2o))
    2098       if (igcm_co2_ice.ne.0.and.iaero_co2.ne.0) &
    2099          call writediagfi(ngrid,'CO2ice_reffcol','CO2ice_reffcol','um kg m^-2',2,reffcol(1,iaero_co2))
    2100       if (igcm_h2o_ice.ne.0.and.iaero_h2o.ne.0) &
    2101          call writediagfi(ngrid,'H2Oice_reffcol','H2Oice_reffcol','um kg m^-2',2,reffcol(1,iaero_h2o))
    21021293
    21031294      ! Output tracers.
     
    21141305!                          'kg m^-2',2,qsurf(1,iq) )                         
    21151306
    2116             if(watercond.or.CLFvarying)then
    2117                call writediagfi(ngrid,"rneb_man","H2O cloud fraction (conv)"," ",3,rneb_man)
    2118                call writediagfi(ngrid,"rneb_lsc","H2O cloud fraction (large scale)"," ",3,rneb_lsc)
    2119                call writediagfi(ngrid,"CLF","H2O cloud fraction"," ",3,cloudfrac)
    2120                call writediagfi(ngrid,"CLFt","H2O column cloud fraction"," ",2,totcloudfrac)
    2121                call writediagfi(ngrid,"RH","relative humidity"," ",3,RH)
    2122             endif
    2123 
    2124             if(waterrain)then
    2125                call writediagfi(ngrid,"rain","rainfall","kg m-2 s-1",2,zdqsrain)
    2126                call writediagfi(ngrid,"snow","snowfall","kg m-2 s-1",2,zdqssnow)
    2127             endif
    2128 
    2129             if((hydrology).and.(.not.ok_slab_ocean))then
    2130                call writediagfi(ngrid,"hice","oceanic ice height","m",2,hice)
    2131             endif
    2132 
    2133             if(ice_update)then
    2134                call writediagfi(ngrid,"ice_min","min annual ice","m",2,ice_min)
    2135                call writediagfi(ngrid,"ice_ini","initial annual ice","m",2,ice_initial)
    2136             endif
    2137 
    21381307            do ig=1,ngrid
    21391308               if(tau_col(ig).gt.1.e3)then
  • trunk/LMDZ.TITAN/libf/phytitan/radii_mod.F90

    r1529 r1647  
    33!==================================================================
    44!  module to centralize the radii calculations for aerosols
    5 ! OK for water but should be extended to other aerosols (CO2,...)
    65!==================================================================
    76     
    8 !     water cloud optical properties
    9 
    10       use callkeys_mod, only: radfixed,Nmix_co2,                    &
    11                 pres_bottom_tropo,pres_top_tropo,size_tropo,        &
    12                 pres_bottom_strato,size_strato
    13      
    14       real, save ::  rad_h2o
    15       real, save ::  rad_h2o_ice
    16       real, save ::  Nmix_h2o
    17       real, save ::  Nmix_h2o_ice
    18 !$OMP THREADPRIVATE(rad_h2o,rad_h2o_ice,Nmix_h2o,Nmix_h2o_ice)
    19       real, parameter ::  coef_chaud=0.13
    20       real, parameter ::  coef_froid=0.09
    21 
     7      use callkeys_mod, only: pres_bottom_tropo,pres_top_tropo, &
     8                size_tropo,pres_bottom_strato,size_strato
    229
    2310contains
     
    3825      use ioipsl_getin_p_mod, only: getin_p
    3926      use radinc_h, only: naerkind
    40       use aerosol_mod, only: iaero_back2lay, iaero_co2, iaero_dust, &
    41                              iaero_h2o, iaero_h2so4
     27      use aerosol_mod, only: iaero_back2lay
    4228      Implicit none
    4329
     
    5945!     .def file. To be improved!
    6046
    61             if(iaer.eq.iaero_co2)then ! CO2 ice
     47
     48!     WARNING : Titan adapt. (J. Vatant d'Ollone, 2017)
     49!            - ONLY THE NO AEROSOL CASE FOR NOW SINCE WE COMPUTE THEM ANOTHER WAY !
     50!            - This routine is just here to keep the code running without unplugging all (yet)
     51!            - There's only the dummy aerosol case on iaer = 1     
     52            if(iaer.eq.1)then
    6253               reffrad(1:ngrid,1:nlayer,iaer) = 1.e-4
    63                nueffrad(1:ngrid,1:nlayer,iaer) = 0.1
    64             endif
    65 
    66             if(iaer.eq.iaero_h2o)then ! H2O ice
    67                reffrad(1:ngrid,1:nlayer,iaer) = 1.e-5
    68                nueffrad(1:ngrid,1:nlayer,iaer) = 0.1
    69             endif
    70 
    71             if(iaer.eq.iaero_dust)then ! dust
    72                reffrad(1:ngrid,1:nlayer,iaer) = 1.e-5
    73                nueffrad(1:ngrid,1:nlayer,iaer) = 0.1
    74             endif
    75  
    76             if(iaer.eq.iaero_h2so4)then ! H2O ice
    77                reffrad(1:ngrid,1:nlayer,iaer) = 1.e-6
    7854               nueffrad(1:ngrid,1:nlayer,iaer) = 0.1
    7955            endif
     
    8359               nueffrad(1:ngrid,1:nlayer,iaer) = 0.1
    8460            endif
    85 
    86 
    8761
    8862            if(iaer.gt.5)then
     
    9569         enddo
    9670
    97 
    98          if (radfixed) then
    99 
    100             write(*,*)"radius of H2O water particles:"
    101             rad_h2o=13. ! default value
    102             call getin_p("rad_h2o",rad_h2o)
    103             write(*,*)" rad_h2o = ",rad_h2o
    104 
    105             write(*,*)"radius of H2O ice particles:"
    106             rad_h2o_ice=35. ! default value
    107             call getin_p("rad_h2o_ice",rad_h2o_ice)
    108             write(*,*)" rad_h2o_ice = ",rad_h2o_ice
    109 
    110          else
    111 
    112             write(*,*)"Number mixing ratio of H2O water particles:"
    113             Nmix_h2o=1.e6 ! default value
    114             call getin_p("Nmix_h2o",Nmix_h2o)
    115             write(*,*)" Nmix_h2o = ",Nmix_h2o
    116 
    117             write(*,*)"Number mixing ratio of H2O ice particles:"
    118             Nmix_h2o_ice=Nmix_h2o ! default value
    119             call getin_p("Nmix_h2o_ice",Nmix_h2o_ice)
    120             write(*,*)" Nmix_h2o_ice = ",Nmix_h2o_ice
    121          endif
    122 
    12371      print*,'exit su_aer_radii'
    12472
     
    12674!==================================================================
    12775
    128 
    129 !==================================================================
    130    subroutine h2o_reffrad(ngrid,nlayer,pq,pt,reffrad,nueffrad)
    131 !==================================================================
    132 !     Purpose
    133 !     -------
    134 !     Compute the effective radii of liquid and icy water particles
    135 !
    136 !     Authors
    137 !     -------
    138 !     Jeremy Leconte (2012)
    139 !
    140 !==================================================================
    141       use watercommon_h, Only: T_h2O_ice_liq,T_h2O_ice_clouds,rhowater,rhowaterice
    142       use comcstfi_mod, only: pi
    143       Implicit none
    144 
    145       integer,intent(in) :: ngrid
    146       integer,intent(in) :: nlayer
    147 
    148       real, intent(in) :: pq(ngrid,nlayer) !water ice mixing ratios (kg/kg)
    149       real, intent(in) :: pt(ngrid,nlayer) !temperature (K)
    150       real, intent(out) :: reffrad(ngrid,nlayer)      !aerosol radii
    151       real, intent(out) :: nueffrad(ngrid,nlayer) ! dispersion     
    152 
    153       integer :: ig,l
    154       real zfice ,zrad,zrad_liq,zrad_ice
    155       real,external :: CBRT           
    156      
    157 
    158       if (radfixed) then
    159          do l=1,nlayer
    160             do ig=1,ngrid
    161                zfice = 1.0 - (pt(ig,l)-T_h2O_ice_clouds) / (T_h2O_ice_liq-T_h2O_ice_clouds)
    162                zfice = MIN(MAX(zfice,0.0),1.0)
    163                reffrad(ig,l)= rad_h2o * (1.-zfice) + rad_h2o_ice * zfice
    164                nueffrad(ig,l) = coef_chaud * (1.-zfice) + coef_froid * zfice
    165             enddo
    166          enddo
    167       else
    168          do l=1,nlayer
    169             do ig=1,ngrid
    170                zfice = 1.0 - (pt(ig,l)-T_h2O_ice_clouds) / (T_h2O_ice_liq-T_h2O_ice_clouds)
    171                zfice = MIN(MAX(zfice,0.0),1.0)
    172                zrad_liq  = CBRT( 3*pq(ig,l)/(4*Nmix_h2o*pi*rhowater) )
    173                zrad_ice  = CBRT( 3*pq(ig,l)/(4*Nmix_h2o_ice*pi*rhowaterice) )
    174                nueffrad(ig,l) = coef_chaud * (1.-zfice) + coef_froid * zfice
    175                zrad = zrad_liq * (1.-zfice) + zrad_ice * zfice
    176 
    177                reffrad(ig,l) = min(max(zrad,1.e-6),1000.e-6)
    178                enddo
    179             enddo     
    180       end if
    181 
    182    end subroutine h2o_reffrad
    183 !==================================================================
    184 
    185 
    186 !==================================================================
    187    subroutine h2o_cloudrad(ngrid,nlayer,pql,reffliq,reffice)
    188 !==================================================================
    189 !     Purpose
    190 !     -------
    191 !     Compute the effective radii of liquid and icy water particles
    192 !
    193 !     Authors
    194 !     -------
    195 !     Jeremy Leconte (2012)
    196 !
    197 !==================================================================
    198       use watercommon_h, Only: rhowater,rhowaterice
    199       use comcstfi_mod, only: pi
    200       Implicit none
    201 
    202       integer,intent(in) :: ngrid
    203       integer,intent(in) :: nlayer
    204 
    205       real, intent(in) :: pql(ngrid,nlayer) !condensed water mixing ratios (kg/kg)
    206       real, intent(out) :: reffliq(ngrid,nlayer),reffice(ngrid,nlayer)     !liquid and ice water particle radii (m)
    207 
    208       real,external :: CBRT           
    209       integer :: i,k
    210 
    211       if (radfixed) then
    212          reffliq(1:ngrid,1:nlayer)= rad_h2o
    213          reffice(1:ngrid,1:nlayer)= rad_h2o_ice
    214       else
    215          do k=1,nlayer
    216            do i=1,ngrid
    217              reffliq(i,k) = CBRT(3*pql(i,k)/(4*Nmix_h2o*pi*rhowater))
    218              reffliq(i,k) = min(max(reffliq(i,k),1.e-6),1000.e-6)
    219            
    220              reffice(i,k) = CBRT(3*pql(i,k)/(4*Nmix_h2o_ice*pi*rhowaterice))
    221              reffice(i,k) = min(max(reffice(i,k),1.e-6),1000.e-6)
    222            enddo
    223          enddo
    224       endif
    225 
    226    end subroutine h2o_cloudrad
    227 !==================================================================
    228 
    229 
    230 
    231 !==================================================================
    232    subroutine co2_reffrad(ngrid,nlayer,nq,pq,reffrad)
    233 !==================================================================
    234 !     Purpose
    235 !     -------
    236 !     Compute the effective radii of co2 ice particles
    237 !
    238 !     Authors
    239 !     -------
    240 !     Jeremy Leconte (2012)
    241 !
    242 !==================================================================
    243       USE tracer_h, only:igcm_co2_ice,rho_co2
    244       use comcstfi_mod, only: pi
    245       Implicit none
    246 
    247       integer,intent(in) :: ngrid,nlayer,nq
    248 
    249       real, intent(in) :: pq(ngrid,nlayer,nq) !tracer mixing ratios (kg/kg)
    250       real, intent(out) :: reffrad(ngrid,nlayer)      !co2 ice particles radii (m)
    251 
    252       integer :: ig,l
    253       real :: zrad   
    254       real,external :: CBRT           
    255            
    256      
    257 
    258       if (radfixed) then
    259          reffrad(1:ngrid,1:nlayer) = 5.e-5 ! CO2 ice
    260       else
    261          do l=1,nlayer
    262             do ig=1,ngrid
    263                zrad = CBRT( 3*pq(ig,l,igcm_co2_ice)/(4*Nmix_co2*pi*rho_co2) )
    264                reffrad(ig,l) = min(max(zrad,1.e-6),100.e-6)
    265             enddo
    266          enddo     
    267       end if
    268 
    269    end subroutine co2_reffrad
    270 !==================================================================
    271 
    272 
    273 
    274 !==================================================================
    275    subroutine dust_reffrad(ngrid,nlayer,reffrad)
    276 !==================================================================
    277 !     Purpose
    278 !     -------
    279 !     Compute the effective radii of dust particles
    280 !
    281 !     Authors
    282 !     -------
    283 !     Jeremy Leconte (2012)
    284 !
    285 !==================================================================
    286       Implicit none
    287 
    288       integer,intent(in) :: ngrid
    289       integer,intent(in) :: nlayer
    290 
    291       real, intent(out) :: reffrad(ngrid,nlayer)      !dust particles radii (m)
    292            
    293       reffrad(1:ngrid,1:nlayer) = 2.e-6 ! dust
    294 
    295    end subroutine dust_reffrad
    296 !==================================================================
    297 
    298 
    299 !==================================================================
    300    subroutine h2so4_reffrad(ngrid,nlayer,reffrad)
    301 !==================================================================
    302 !     Purpose
    303 !     -------
    304 !     Compute the effective radii of h2so4 particles
    305 !
    306 !     Authors
    307 !     -------
    308 !     Jeremy Leconte (2012)
    309 !
    310 !==================================================================
    311       Implicit none
    312 
    313       integer,intent(in) :: ngrid
    314       integer,intent(in) :: nlayer
    315 
    316       real, intent(out) :: reffrad(ngrid,nlayer)      !h2so4 particle radii (m)
    317                
    318       reffrad(1:ngrid,1:nlayer) = 1.e-6 ! h2so4
    319 
    320    end subroutine h2so4_reffrad
    321 !==================================================================
    32276
    32377!==================================================================
  • trunk/LMDZ.TITAN/libf/phytitan/su_gases.F90

    r1315 r1647  
    7373           igas_H2=igas
    7474           count=count+1
    75         elseif (trim(gnom(igas)).eq."He_" .or. trim(gnom(igas)).eq."He") then
    76            igas_He=igas
    77            count=count+1
    78         elseif (trim(gnom(igas)).eq."H2O") then
    79            igas_H2O=igas
    80            count=count+1
    81         elseif (trim(gnom(igas)).eq."CO2") then
    82            igas_CO2=igas
    83            count=count+1
    84         elseif (trim(gnom(igas)).eq."CO_" .or. trim(gnom(igas)).eq."CO") then
    85            igas_CO=igas
    86            count=count+1
    8775        elseif (trim(gnom(igas)).eq."N2_" .or. trim(gnom(igas)).eq."N2") then
    8876           igas_N2=igas
    8977           count=count+1
    90         elseif (trim(gnom(igas)).eq."O2_" .or. trim(gnom(igas)).eq."O2") then
    91            igas_O2=igas
    92            count=count+1
    93         elseif (trim(gnom(igas)).eq."SO2") then
    94            igas_SO2=igas
    95            count=count+1
    96         elseif (trim(gnom(igas)).eq."H2S") then
    97            igas_H2S=igas
    98            count=count+1
    9978        elseif (trim(gnom(igas)).eq."CH4") then
    10079           igas_CH4=igas
    101            count=count+1
    102         elseif (trim(gnom(igas)).eq."NH3") then
    103            igas_NH3=igas
    10480           count=count+1
    10581        elseif (trim(gnom(igas)).eq."C2H6") then
  • trunk/LMDZ.TITAN/libf/phytitan/suaer_corrk.F90

    r1529 r1647  
    4242!     MODIF R. Wordsworth (2009)
    4343!     - generalisation to arbitrary spectral bands
    44 !
    45 !==================================================================
     44!     
     45!     WARNING : Titan adapt. (J. Vatant d'Ollone, 2017)
     46!            - ONLY THE NO AEROSOL CASE FOR NOW SINCE WE COMPUTE THEM ANOTHER WAY !
     47!            - This routine is just here to keep the code running without unplugging all (yet)                           
     48!================================================================================================
    4649
    4750!     Optical properties (read in external ASCII files)
     
    106109      endif
    107110      do iaer=1,naerkind
    108        if (iaer.eq.iaero_co2) then
     111       if (iaer.eq.1) then ! JVO 2017 : Now iaer = 1 is always dummy co2 for noaero case, since we don't use aerosols
    109112        forgetit=.true.
    110           if (.not.noaero) then
    111               print*, 'naerkind= co2', iaer
    112           end if
    113113!     visible
    114114        if(forgetit)then
     
    130130! JB thinks this shouldn't matter too much, but it needs to be
    131131! fixed / decided for the final version.
    132 
    133        if (iaer.eq.iaero_h2o) then
    134         print*, 'naerkind= h2o', iaer
    135 
    136 !     visible
    137          file_id(iaer,1) = 'optprop_icevis_n50.dat'
    138          lamrefvis(iaer)=1.5E-6   ! 1.5um OMEGA/MEx
    139 !     infrared
    140          file_id(iaer,2) = 'optprop_iceir_n50.dat'
    141          lamrefir(iaer)=12.1E-6   ! 825cm-1 TES/MGS
    142        endif
    143 
    144        if (iaer.eq.iaero_dust) then
    145         print*, 'naerkind= dust', iaer
    146 
    147 !     visible
    148          file_id(iaer,1) = 'optprop_dustvis_n50.dat'
    149          !lamrefvis(iaer)=1.5E-6   ! 1.5um OMEGA/MEx
    150          lamrefvis(iaer)=0.67e-6
    151 !     infrared
    152          file_id(iaer,2) = 'optprop_dustir_n50.dat'
    153          !lamrefir(iaer)=12.1E-6   ! 825cm-1 TES/MGS
    154          lamrefir(iaer)=9.3E-6
    155        endif
    156 
    157        if (iaer.eq.iaero_h2so4) then
    158          print*, 'naerkind= h2so4', iaer
    159 
    160 !     visible
    161          file_id(iaer,1) = 'optprop_h2so4vis_n20.dat'
    162          !lamrefir(iaer)=  doesn't exist?
    163          lamrefvis(iaer)=1.5E-6   ! no idea, must find
    164 !     infrared
    165          file_id(iaer,2) = 'optprop_h2so4ir_n20.dat'
    166          !lamrefir(iaer)=12.1E-6   ! 825cm-1 TES/MGS
    167          lamrefir(iaer)=9.3E-6 ! no idea, must find
    168 ! added by LK
    169        endif
    170132
    171133       if (iaer.eq.iaero_back2lay) then
     
    328290
    329291      jfile = jfile+1
    330       IF ((idomain.NE.iaero_co2).OR.(iaer.NE.iaero_co2)) THEN
     292      IF ((idomain.NE.1).OR.(iaer.NE.1)) THEN
    331293         endwhile = .true.
    332294      ENDIF
     
    346308
    347309!     1.5 If Francois' data, convert wvl to metres
    348        if(iaer.eq.iaero_co2)then
     310       if(iaer.eq.1)then
    349311         if(forgetit)then
    350312         !   print*,'please sort out forgetit for naerkind>1'
  • trunk/LMDZ.TITAN/libf/phytitan/sugas_corrk.F90

    r1521 r1647  
    2929      use gases_h
    3030      use ioipsl_getin_p_mod, only: getin_p
    31       use callkeys_mod, only: varactive,varfixed,graybody,callgasvis,&
    32                 continuum,H2Ocont_simple
     31      use callkeys_mod, only: graybody,callgasvis, continuum
    3332      implicit none
    3433
     
    8685      endif
    8786
    88       if(ngas.eq.1 .and. (varactive.or.varfixed))then
    89          print*,'You have varactive/fixed=.true. but the database [',  &
    90                      corrkdir(1:LEN_TRIM(corrkdir)),           &
    91                 '] has no variable species, exiting.'
    92          call abort
    93       elseif(ngas.gt.5 .or. ngas.lt.1)then
     87      if(ngas.gt.5 .or. ngas.lt.1)then
    9488         print*,ngas,' species in database [',               &
    9589                     corrkdir(1:LEN_TRIM(corrkdir)),           &
     
    112106      read(111,*) wrefvar
    113107      close(111)
    114 
    115       if(L_REFVAR.gt.1 .and. (.not.varactive) .and. (.not.varfixed))then
    116          print*,'You have varactive and varfixed=.false. and the database [', &
    117                      corrkdir(1:LEN_TRIM(corrkdir)),           &
    118                 '] has a variable species.'
    119          call abort
    120       endif
    121108
    122109      ! Check that gastype and gnom match
     
    638625                  dummy = -9999
    639626                  call interpolateN2H2(592.D+0,278.15D+0,200000.D+0,10000.D+0,testcont,.true.,dummy)
    640                elseif (jgas .eq. igas_He) then
    641                   dummy = -9999
    642                   call interpolateH2He(500.D+0,250.D+0,200000.D+0,10000.D+0,testcont,.true.,dummy)
    643627               endif
    644628            enddo
    645 
    646          elseif (igas .eq. igas_H2O) then
    647 
    648             ! H2O is special
    649             if(H2Ocont_simple)then
    650                call interpolateH2Ocont_PPC(990.D+0,296.D+0,683.2D+0*2,0.D+0,testcont,.true.)
    651             else
    652                dummy = -9999
    653                call interpolateH2Ocont_CKD(990.D+0,296.D+0,683.2D+0*2,0.D+0,testcont,.true.,dummy)
    654             endif
    655629
    656630         endif
  • trunk/LMDZ.TITAN/libf/phytitan/surfdat_h.F90

    r1482 r1647  
    1717!$OMP THREADPRIVATE(zmea,zstd,zsig,zgam,zthe)
    1818
    19        real,allocatable,dimension(:) :: dryness  !"Dryness coefficient" for grnd water ice sublimation
    20                                                  ! AS: previously in tracer.h. it is more logical here.
    21 
    22        logical,allocatable,dimension(:) :: watercaptag !! was in watercap.h
    23 !$OMP THREADPRIVATE(dryness,watercaptag)
    24 
    2519       end module surfdat_h
    2620
  • trunk/LMDZ.TITAN/libf/phytitan/surfini.F

    r1482 r1647  
    1       SUBROUTINE surfini(ngrid,nq,qsurf,albedo,albedo_bareground,
    2      &                   albedo_snow_SPECTV,albedo_co2_ice_SPECTV)
     1      SUBROUTINE surfini(ngrid,nq,qsurf,albedo,albedo_bareground)
    32
    43      USE surfdat_h, only: albedodat
    5       USE tracer_h, only: igcm_co2_ice
    64      use planetwide_mod, only: planetwide_maxval, planetwide_minval
    75      use radinc_h, only : L_NSPECTV
    8       use callkeys_mod, only : albedosnow, albedoco2ice
    96
    107      IMPLICIT NONE
     
    2623      REAL,INTENT(OUT) :: albedo(ngrid,L_NSPECTV)
    2724      REAL,INTENT(OUT) :: albedo_bareground(ngrid)
    28       REAL,INTENT(OUT) :: albedo_snow_SPECTV(L_NSPECTV)
    29       REAL,INTENT(OUT) :: albedo_co2_ice_SPECTV(L_NSPECTV)
    3025      REAL,INTENT(IN) :: qsurf(ngrid,nq) ! tracer on surface (kg/m2)
    3126
     
    3530c=======================================================================
    3631
    37       ! Step 1 : Initialisation of the Spectral Albedos.
    38       DO nw=1,L_NSPECTV
    39          albedo_snow_SPECTV(nw)=albedosnow
    40          albedo_co2_ice_SPECTV(nw)=albedoco2ice
    41       ENDDO
    42 
    43 
    44       ! Step 2 : We get the bare ground albedo from the start files.
     32      ! We get the bare ground albedo from the start files.
    4533      DO ig=1,ngrid
    4634         albedo_bareground(ig)=albedodat(ig)
     
    5442      write(*,*) 'surfini: maximum bare ground albedo',max_albedo
    5543
    56 
    57       ! Step 3 : We modify the albedo considering some CO2 at the surface. We dont take into account water ice (this is made in hydrol after the first timestep) ...
    58       if (igcm_co2_ice.ne.0) then
    59          DO ig=1,ngrid
    60             IF (qsurf(ig,igcm_co2_ice) .GT. 1.) THEN ! This was changed by MT2015. Condition for ~1mm of CO2 ice deposit.
    61                DO nw=1,L_NSPECTV
    62                   albedo(ig,nw)=albedo_co2_ice_SPECTV(nw)
    63                ENDDO
    64             END IF   
    65          ENDDO   
    66       else
    67          write(*,*) "surfini: No CO2 ice tracer on surface  ..."
    68          write(*,*) "         and therefore no albedo change."
    69       endif     
     44   
    7045      call planetwide_minval(albedo,min_albedo)
    7146      call planetwide_maxval(albedo,max_albedo)
  • trunk/LMDZ.TITAN/libf/phytitan/tracer_h.F90

    r1621 r1647  
    2020      real r3n_q     ! used to compute r0 from number and mass mixing ratio
    2121      real rho_dust     ! Mars dust density (kg.m-3)
    22       real rho_ice     ! Water ice density (kg.m-3)
    23       real rho_co2     ! CO2 ice density (kg.m-3)
    2422      real ref_r0        ! for computing reff=ref_r0*r0 (in log.n. distribution)
    2523!$OMP THREADPRIVATE(noms,mmol,radius,rho_q,qext,alpha_lift,alpha_devil,qextrhor, &
    26         !$OMP varian,r3n_q,rho_dust,rho_ice,rho_co2,ref_r0)
     24        !$OMP varian,r3n_q,rho_dust,rho_ice,ref_r0)
    2725
    2826! tracer indexes: these are initialized in initracer and should be 0 if the
     
    3331      integer :: igcm_dust_mass   ! dust mass mixing ratio (for transported dust)
    3432      integer :: igcm_dust_number ! dust number mixing ratio (transported dust)
    35       ! water
    36       integer :: igcm_h2o_vap ! water vapour
    37       integer :: igcm_h2o_ice ! water ice
    3833      ! chemistry:
    39       integer :: igcm_co2
    4034      integer :: igcm_co
    4135      integer :: igcm_o
     
    5246      ! other tracers
    5347      integer :: igcm_ar_n2 ! for simulations using co2 +neutral gaz
    54       integer :: igcm_co2_ice ! CO2 ice
    55 !$OMP THREADPRIVATE(igcm_dustbin,igcm_dust_mass,igcm_dust_number,igcm_h2o_vap,igcm_h2o_ice, &
    56         !$OMP igcm_co2,igcm_co,igcm_o,igcm_o1d,igcm_o2,igcm_o3,igcm_h,igcm_h2,igcm_oh,      &
    57         !$OMP igcm_ho2,igcm_h2o2,igcm_n2,igcm_ar,igcm_ar_n2,igcm_co2_ice)
     48!$OMP THREADPRIVATE(igcm_dustbin,igcm_dust_mass,igcm_dust_number, &
     49        !$OMP igcm_co,igcm_o,igcm_o1d,igcm_o2,igcm_o3,igcm_h,igcm_h2,igcm_oh,       &
     50        !$OMP igcm_ho2,igcm_h2o2,igcm_n2,igcm_ar,igcm_ar_n2)
    5851
    5952       end module tracer_h
  • trunk/LMDZ.TITAN/libf/phytitan/turbdiff.F90

    r1477 r1647  
    1       subroutine turbdiff(ngrid,nlay,nq,rnat,          &
     1      subroutine turbdiff(ngrid,nlay,nq,               &
    22          ptimestep,pcapcal,lecrit,                    &   
    33          pplay,pplev,pzlay,pzlev,pz0,                 &
     
    55          pdtfi,pdqfi,pfluxsrf,            &
    66          Pdudif,pdvdif,pdtdif,pdtsrf,sensibFlux,pq2,  &
    7           pdqdif,pdqevap,pdqsdif,flux_u,flux_v,lastcall)
    8 
    9       use watercommon_h, only : RLVTT, T_h2O_ice_liq, RCPD, mx_eau_sol,Psat_water
     7          pdqdif,pdqsdif,flux_u,flux_v,lastcall)
     8
    109      use radcommon_h, only : sigma, glat
    11       use surfdat_h, only: dryness
    12       use tracer_h, only: igcm_h2o_vap, igcm_h2o_ice
    1310      use comcstfi_mod, only: rcp, g, r, cpp
    14       use callkeys_mod, only: water,tracer,nosurf
     11      use callkeys_mod, only: tracer,nosurf
    1512
    1613      implicit none
     
    6259      REAL,INTENT(IN) :: pcapcal(ngrid)
    6360      REAL,INTENT(INOUT) :: pq2(ngrid,nlay+1)
    64       REAL,INTENT(OUT) :: flux_u(ngrid),flux_v(ngrid)
    65       REAL,INTENT(IN) :: rnat(ngrid)     
     61      REAL,INTENT(OUT) :: flux_u(ngrid),flux_v(ngrid) 
    6662      LOGICAL,INTENT(IN) :: lastcall ! not used
    6763
     
    109105      INTEGER iq
    110106      REAL zq(ngrid,nlay,nq)
    111       REAL zqnoevap(ngrid,nlay) !special for water case to compute where evaporated water goes.
    112       REAL pdqevap(ngrid,nlay) !special for water case to compute where evaporated water goes.
    113107      REAL zdmassevap(ngrid)
    114108      REAL rho(ngrid)         ! near-surface air density
    115       REAL qsat(ngrid),psat(ngrid)
    116109      REAL kmixmin
    117110
    118 !     Variables added for implicit latent heat inclusion
    119 !     --------------------------------------------------
    120       real dqsat(ngrid), qsat_temp1, qsat_temp2,psat_temp
    121 
    122       integer, save :: ivap, iliq, iliq_surf,iice_surf ! also make liq for clarity on surface...
    123 !$OMP THREADPRIVATE(ivap,iliq,iliq_surf,iice_surf)
    124111
    125112      real, parameter :: karman=0.4
     
    133120!     --------------
    134121
    135       IF (firstcall) THEN
    136 
    137          if(water)then
    138              ivap=igcm_h2o_vap
    139              iliq=igcm_h2o_ice
    140              iliq_surf=igcm_h2o_vap
    141              iice_surf=igcm_h2o_ice ! simply to make the code legible               
    142                                   ! to be generalised
    143          else
    144              ivap=0
    145              iliq=0
    146              iliq_surf=0
    147              iice_surf=0 ! simply to make the code legible                       
    148          endif
     122      IF (firstcall) THEN         
     123
    149124         sensibFlux(:)=0.
    150125
     
    202177            ENDDO
    203178         ENDDO
    204          if (water) then
    205             DO ilev=1,nlay
    206                DO ig=1,ngrid
    207                   zqnoevap(ig,ilev)=pq(ig,ilev,ivap) + pdqfi(ig,ilev,ivap)*ptimestep
    208                ENDDO
    209             ENDDO
    210          Endif
    211179      end if
    212180
     
    405373!       flux (if any) from subsurface
    406374
    407       if(.not.water) then
    408375
    409376         DO ig=1,ngrid
     
    427394         ENDDO
    428395
    429       endif                     ! not water
    430396
    431397!-----------------------------------------------------------------------
     
    446412!     -----------------------
    447413         do iq=1,nq
    448 
    449             if (iq.ne.ivap) then
    450414
    451415               DO ig=1,ngrid
     
    462426                  ENDDO
    463427               ENDDO
    464 
    465                if ((water).and.(iq.eq.iliq)) then
    466                   ! special case for condensed water tracer: do not include
    467                   ! h2o ice tracer from surface (which is set when handling
    468                   ! h2o vapour case (see further down).
    469                   ! zb(ig,1)=0 if iq ne ivap
    470                   DO ig=1,ngrid
    471                      z1(ig)=1./(zmass(ig,1)+zfluxq(ig,2)*(1.-zdq(ig,2)))
    472                      zcq(ig,1)=(zmass(ig,1)*zq(ig,1,iq)+zfluxq(ig,2)*zcq(ig,2))*z1(ig)
    473                   ENDDO
    474                else             ! general case
    475                   do ig=1,ngrid
    476                      z1(ig)=1./(zmass(ig,1)+zfluxq(ig,2)*(1.-zdq(ig,2)))
    477                      zcq(ig,1)=(zmass(ig,1)*zq(ig,1,iq)+zfluxq(ig,2)*zcq(ig,2)+(-pdqsdif(ig,iq))*ptimestep)*z1(ig)
    478                           ! tracer flux from surface
    479                           ! currently pdqsdif always zero here,
    480                           ! so last line is superfluous
    481                   enddo
    482                endif            ! of if (water.and.(iq.eq.igcm_h2o_ice))
    483 
     428               
     429               do ig=1,ngrid
     430                  z1(ig)=1./(zmass(ig,1)+zfluxq(ig,2)*(1.-zdq(ig,2)))
     431                  zcq(ig,1)=(zmass(ig,1)*zq(ig,1,iq)+zfluxq(ig,2)*zcq(ig,2)+(-pdqsdif(ig,iq))*ptimestep)*z1(ig)
     432                  ! tracer flux from surface
     433                  ! currently pdqsdif always zero here,
     434                  ! so last line is superfluous
     435               enddo
    484436
    485437!     Starting upward calculations for simple tracer mixing (e.g., dust)
     
    493445                  end do
    494446               end do
    495 
    496             endif               ! if (iq.ne.ivap)
    497 
    498 !     Calculate temperature tendency including latent heat term
    499 !     and assuming an infinite source of water on the ground
    500 !     ------------------------------------------------------------------
    501 
    502             if (water.and.(iq.eq.ivap)) then
    503            
    504                ! compute evaporation efficiency
    505                do ig=1,ngrid
    506                   if(nint(rnat(ig)).eq.1)then
    507                      dryness(ig)=pqsurf(ig,iliq_surf)+pqsurf(ig,iice_surf)
    508                      dryness(ig)=MIN(1.,2*dryness(ig)/mx_eau_sol)
    509                      dryness(ig)=MAX(0.,dryness(ig))
    510                   endif
    511                enddo
    512 
    513                do ig=1,ngrid
    514                 ! Calculate the value of qsat at the surface (water)
    515                 call Psat_water(ptsrf(ig),pplev(ig,1),psat(ig),qsat(ig))
    516                 call Psat_water(ptsrf(ig)-0.0001,pplev(ig,1),psat_temp,qsat_temp1)
    517                 call Psat_water(ptsrf(ig)+0.0001,pplev(ig,1),psat_temp,qsat_temp2)
    518                 dqsat(ig)=(qsat_temp2-qsat_temp1)/0.0002
    519                 ! calculate dQsat / dT by finite differences
    520                 ! we cannot use the updated temperature value yet...
    521                enddo
    522 
    523 ! coefficients for q
    524 
    525                do ig=1,ngrid
    526                   z1(ig)=1./(zmass(ig,nlay)+zfluxq(ig,nlay))
    527                   zcq(ig,nlay)=zmass(ig,nlay)*zq(ig,nlay,iq)*z1(ig)
    528                   zdq(ig,nlay)=zfluxq(ig,nlay)*z1(ig)
    529                enddo
    530          
    531                do ilay=nlay-1,2,-1
    532                   do ig=1,ngrid
    533                      z1(ig)=1./(zmass(ig,ilay)+zfluxq(ig,ilay)+zfluxq(ig,ilay+1)*(1.-zdq(ig,ilay+1)))
    534                      zcq(ig,ilay)=(zmass(ig,ilay)*zq(ig,ilay,iq)+zfluxq(ig,ilay+1)*zcq(ig,ilay+1))*z1(ig)
    535                      zdq(ig,ilay)=zfluxq(ig,ilay)*z1(ig)
    536                   enddo
    537                enddo
    538 
    539                do ig=1,ngrid
    540                   z1(ig)=1./(zmass(ig,1)+zfluxq(ig,1)*dryness(ig)+zfluxq(ig,2)*(1.-zdq(ig,2)))
    541                   zcq(ig,1)=(zmass(ig,1)*zq(ig,1,iq)+zfluxq(ig,2)*zcq(ig,2))*z1(ig)
    542                   zdq(ig,1)=dryness(ig)*zfluxq(ig,1)*z1(ig)
    543                enddo
    544 
    545               do ig=1,ngrid
    546 !calculation of surface temperature
    547                   zdq0(ig) = dqsat(ig)
    548                   zcq0(ig) = qsat(ig)-dqsat(ig)*ptsrf(ig)
    549 
    550                   z1(ig) = pcapcal(ig)*ptsrf(ig) +cpp*zfluxt(ig,1)*zct(ig,1)*zovExner(ig,1)   &
    551                       + zdplanck(ig)*ptsrf(ig) + pfluxsrf(ig)*ptimestep                       &
    552                       + zfluxq(ig,1)*dryness(ig)*RLVTT*((zdq(ig,1)-1.0)*zcq0(ig)+zcq(ig,1))
    553 
    554                   z2(ig) = pcapcal(ig) + cpp*zfluxt(ig,1)*(1.-zovExner(ig,1)*zdt(ig,1))       &
    555                       + zdplanck(ig)+zfluxq(ig,1)*dryness(ig)*RLVTT*zdq0(ig)*(1.0-zdq(ig,1))
    556 
    557                   ztsrf(ig) = z1(ig) / z2(ig)
    558 
    559 ! calculation of qs and q1
    560                   zq0(ig)     = zcq0(ig)+zdq0(ig)*ztsrf(ig)
    561                   zq(ig,1,iq) = zcq(ig,1)+zdq(ig,1)*zq0(ig)
    562 
    563 ! calculation of evaporation             
    564                   dqsdif_total(ig)=zfluxq(ig,1)*dryness(ig)*(zq(ig,1,ivap)-zq0(ig))
    565 
    566 !     --------------------------------------------------------
    567 !     Now check if we've taken too much water from the surface
    568 !     This can only occur on the continent
    569 !     If we do, we recompute Tsurf, T1 and q1 accordingly
    570                   if((-dqsdif_total(ig).gt.(pqsurf(ig,iice_surf)+pqsurf(ig,iliq_surf))).and.rnat(ig).eq.1)then
    571                       !water flux * ptimestep
    572                       dqsdif_total(ig)=-(pqsurf(ig,iice_surf)+pqsurf(ig,iliq_surf))
    573 
    574                       !recompute surface temperature 
    575                       z1(ig) = pcapcal(ig)*ptsrf(ig) +cpp*zfluxq(ig,1)*zct(ig,1)*zovExner(ig,1)   &
    576                         + zdplanck(ig)*ptsrf(ig) + pfluxsrf(ig)*ptimestep                       &
    577                         + RLVTT*dqsdif_total(ig)
    578                       z2(ig) = pcapcal(ig) + cpp*zfluxq(ig,1)*(1.-zovExner(ig,1)*zdt(ig,1))       &
    579                         + zdplanck(ig)
    580                       ztsrf(ig) = z1(ig) / z2(ig)
    581 
    582                       !recompute q1 with new water flux from surface 
    583                       zq(ig,1,iq) = (zmass(ig,1)*(pq(ig,1,iq)+ptimestep*pdqfi(ig,1,iq))  &
    584                                             +zfluxq(ig,2)*zcq(ig,2)-dqsdif_total(ig))     &
    585                                  / (zmass(ig,1)+(1.-zdq(ig,2))*zfluxq(ig,2))                 
    586                   end if
    587                  
    588 ! calculation surface T tendency  and T(1)           
    589                   pdtsrf(ig) = (ztsrf(ig) - ptsrf(ig))/ptimestep
    590                   zt(ig,1)   = zct(ig,1) + zdt(ig,1)*ztsrf(ig)               
    591                enddo
    592 
    593 
    594 ! recalculate temperature and q(vap) to top of atmosphere, starting from ground
    595                do ilay=2,nlay
    596                   do ig=1,ngrid
    597                      zq(ig,ilay,iq)=zcq(ig,ilay)+zdq(ig,ilay)*zq(ig,ilay-1,iq)
    598                      zt(ig,ilay)=zct(ig,ilay)+zdt(ig,ilay)*zt(ig,ilay-1)
    599                   end do
    600                end do
    601 
    602 
    603                do ig=1,ngrid
    604 !     --------------------------------------------------------------------------
    605 !     On the ocean, if T > 0 C then the vapour tendency must replace the ice one
    606 !     The surface vapour tracer is actually liquid. To make things difficult.
    607 
    608                   if (nint(rnat(ig)).eq.0) then ! unfrozen ocean
    609                      
    610                      pdqsdif(ig,iliq_surf)=dqsdif_total(ig)/ptimestep
    611                      pdqsdif(ig,iice_surf)=0.0
    612 
    613                   elseif (nint(rnat(ig)).eq.1) then ! (continent)
    614 !     If water is evaporating / subliming, we take it from ice before liquid
    615 !     -- is this valid??
    616                      if(dqsdif_total(ig).lt.0)then
    617                         if (-dqsdif_total(ig).gt.pqsurf(ig,iice_surf))then
    618                            pdqsdif(ig,iice_surf) = -pqsurf(ig,iice_surf)/ptimestep ! removes all the ice!
    619                            pdqsdif(ig,iliq_surf) = dqsdif_total(ig)/ptimestep- pdqsdif(ig,iice_surf) ! take the remainder from the liquid instead
    620                         else               
    621                            pdqsdif(ig,iice_surf)=dqsdif_total(ig)/ptimestep
    622                            pdqsdif(ig,iliq_surf)=0.
    623                         end if
    624                      else !dqsdif_total(ig).ge.0
    625                         !If water vapour is condensing, we must decide whether it forms ice or liquid.
    626                         if(ztsrf(ig).gt.T_h2O_ice_liq)then
    627                            pdqsdif(ig,iice_surf)=0.0
    628                            pdqsdif(ig,iliq_surf)=dqsdif_total(ig)/ptimestep
    629                         else
    630                            pdqsdif(ig,iice_surf)=dqsdif_total(ig)/ptimestep
    631                            pdqsdif(ig,iliq_surf)=0.0
    632                         endif               
    633                      endif
    634 
    635                   elseif (nint(rnat(ig)).eq.2) then ! (continental glaciers)
    636                      pdqsdif(ig,iliq_surf)=0.0
    637                      pdqsdif(ig,iice_surf)=dqsdif_total(ig)/ptimestep
    638 
    639                   endif !rnat
    640                end do            ! of DO ig=1,ngrid
    641 
    642            endif                ! if (water et iq=ivap)
    643447        end do                  ! of do iq=1,nq
    644 
    645         if (water) then  ! special case where we recompute water mixing without any evaporation.
    646                          !    The difference with the first calculation then tells us where evaporated water has gone
    647 
    648             DO ig=1,ngrid
    649                z1(ig)=1./(zmass(ig,nlay)+zfluxq(ig,nlay))
    650                zcq(ig,nlay)=zmass(ig,nlay)*zqnoevap(ig,nlay)*z1(ig)
    651                zdq(ig,nlay)=zfluxq(ig,nlay)*z1(ig)
    652             ENDDO
    653            
    654             DO ilay=nlay-1,2,-1
    655                DO ig=1,ngrid
    656                   z1(ig)=1./(zmass(ig,ilay)+zfluxq(ig,ilay)+zfluxq(ig,ilay+1)*(1.-zdq(ig,ilay+1)))
    657                   zcq(ig,ilay)=(zmass(ig,ilay)*zqnoevap(ig,ilay)+zfluxq(ig,ilay+1)*zcq(ig,ilay+1))*z1(ig)
    658                   zdq(ig,ilay)=zfluxq(ig,ilay)*z1(ig)
    659                ENDDO
    660             ENDDO
    661 
    662             do ig=1,ngrid
    663                z1(ig)=1./(zmass(ig,1)+zfluxq(ig,2)*(1.-zdq(ig,2)))
    664                zcq(ig,1)=(zmass(ig,1)*zqnoevap(ig,1)+zfluxq(ig,2)*zcq(ig,2))*z1(ig)
    665             enddo
    666 
    667 !     Starting upward calculations for simple tracer mixing (e.g., dust)
    668             do ig=1,ngrid
    669                zqnoevap(ig,1)=zcq(ig,1)
    670             end do
    671 
    672             do ilay=2,nlay
    673                do ig=1,ngrid
    674                   zqnoevap(ig,ilay)=zcq(ig,ilay)+zdq(ig,ilay)*zqnoevap(ig,ilay-1)
    675                end do
    676             end do
    677 
    678          endif               ! if water
    679        
    680        
     448                       
    681449      endif                     ! tracer
    682450
     
    706474            enddo
    707475         enddo
    708          if (water) then
    709             do ilev = 1, nlay
    710                do ig=1,ngrid
    711                   pdqevap(ig,ilev)=(zq(ig,ilev,ivap)-zqnoevap(ig,ilev))/ptimestep
    712                enddo
    713             enddo
    714             do ig=1,ngrid
    715                zdmassevap(ig)=SUM(pdqevap(ig,:)*zmass(ig,:))*ptimestep
    716             end do         
    717          endif
    718476      endif
    719 
    720       if(water)then
    721          call writediagfi(ngrid,'beta','Dryness coefficient',' ',2,dryness)
    722          if (tracer) then
    723             call writediagfi(ngrid,'dqevap','evaporated water vapor specific concentration','s-1',3,pdqevap)
    724          endif
    725       endif
    726477
    727478!      if(lastcall)then
  • trunk/LMDZ.TITAN/libf/phytitan/vdifc.F

    r1542 r1647  
    1       subroutine vdifc(ngrid,nlay,nq,rnat,ppopsk,         
     1      subroutine vdifc(ngrid,nlay,nq,ppopsk,         
    22     &     ptimestep,pcapcal,lecrit,                       
    33     &     pplay,pplev,pzlay,pzlev,pz0,
     
    77     &     pdqdif,pdqsdif,lastcall)
    88
    9       use watercommon_h, only : RLVTT, T_h2O_ice_liq, RCPD, mx_eau_sol
    109      use radcommon_h, only : sigma
    1110      USE surfdat_h
    1211      USE tracer_h
    1312      use comcstfi_mod, only: g, r, cpp, rcp
    14       use callkeys_mod, only: water,tracer,nosurf
     13      use callkeys_mod, only: tracer,nosurf
    1514
    1615      implicit none
     
    5352      REAL pdtsrf(ngrid),sensibFlux(ngrid),pcapcal(ngrid)
    5453      REAL pq2(ngrid,nlay+1)
    55      
    56       real rnat(ngrid)     
     54           
    5755
    5856!     Arguments added for condensation
     
    116114      REAL kmixmin
    117115
    118 !     Variables added for implicit latent heat inclusion
    119 !     --------------------------------------------------
    120       real latconst, dqsat(ngrid), qsat_temp1, qsat_temp2
    121       real z1_Tdry(ngrid), z2_Tdry(ngrid)
    122       real z1_T(ngrid), z2_T(ngrid)
    123       real zb_T(ngrid)
    124       real zc_T(ngrid,nlay)
    125       real zd_T(ngrid,nlay)
    126       real lat1(ngrid), lat2(ngrid)
    127       real surfh2otot
    128       logical surffluxdiag
    129       integer isub ! sub-loop for precision
    130 
    131       integer ivap, iice ! also make liq for clarity on surface...
    132       save ivap, iice
    133 !$OMP THREADPRIVATE(ivap,iice)
    134 
    135116      real, parameter :: karman=0.4
    136117      real cd0, roughratio
    137118
    138       logical forceWC
    139119      real masse, Wtot, Wdiff
    140120
    141121      real dqsdif_total(ngrid)
    142122      real zq0(ngrid)
    143 
    144       forceWC=.true.
    145 !      forceWC=.false.
    146123
    147124
     
    155132!     PRINT*,'In vdifc: Tcond(P=1mb)=',tcond1mb,' Lcond=',latcond
    156133!     PRINT*,'          acond,bcond',acond,bcond
    157 
    158          if(water)then
    159 !                iliq=igcm_h2o_vap
    160                 ivap=igcm_h2o_vap
    161                 iice=igcm_h2o_ice ! simply to make the code legible               
    162                                   ! to be generalised later
    163          endif
    164134
    165135         firstcall=.false.
     
    404374!       flux (if any) from subsurface
    405375
    406       if(.not.water) then
    407376
    408377         DO ig=1,ngrid
     
    427396         ENDDO
    428397
    429       endif                     ! not water
    430398
    431399!-----------------------------------------------------------------------
     
    446414!     -----------------------
    447415         do iq=1,nq
    448 
    449             if (iq.ne.igcm_h2o_vap) then
    450416
    451417               DO ig=1,ngrid
     
    465431               ENDDO
    466432
    467                if ((water).and.(iq.eq.iice)) then
    468                   ! special case for water ice tracer: do not include
    469                   ! h2o ice tracer from surface (which is set when handling
    470                   ! h2o vapour case (see further down).
    471                   ! zb(ig,1)=0 if iq ne ivap
    472                   DO ig=1,ngrid
    473                      z1(ig)=1./(za(ig,1)+
    474      &                    zb(ig,2)*(1.-zdq(ig,2)))
    475                      zcq(ig,1)=(za(ig,1)*zq(ig,1,iq)+
    476      &                    zb(ig,2)*zcq(ig,2))*z1(ig)
    477                   ENDDO
    478                else             ! general case
     433
     434
    479435                  DO ig=1,ngrid
    480436                     z1(ig)=1./(za(ig,1)+
     
    487443                          ! so last line is superfluous
    488444                  enddo
    489                endif            ! of if (water.and.(iq.eq.igcm_h2o_ice))
    490445
    491446
     
    502457               end do
    503458
    504             endif               ! if (iq.ne.igcm_h2o_vap)
    505 
    506 !     Calculate temperature tendency including latent heat term
    507 !     and assuming an infinite source of water on the ground
    508 !     ------------------------------------------------------------------
    509 
    510             if (water.and.(iq.eq.igcm_h2o_vap)) then
    511            
    512                ! compute evaporation efficiency
    513                do ig = 1, ngrid
    514                   if(nint(rnat(ig)).eq.1)then
    515                      dryness(ig)=pqsurf(ig,ivap)+pqsurf(ig,iice)
    516                      dryness(ig)=MIN(1.,2*dryness(ig)/mx_eau_sol)
    517                      dryness(ig)=MAX(0.,dryness(ig))
    518                   endif
    519                enddo
    520 
    521                do ig=1,ngrid
    522 
    523                 ! Calculate the value of qsat at the surface (water)
    524                 call watersat(ptsrf(ig),pplev(ig,1),qsat(ig))
    525                 call watersat(ptsrf(ig)-0.0001,pplev(ig,1),qsat_temp1)
    526                 call watersat(ptsrf(ig)+0.0001,pplev(ig,1),qsat_temp2)
    527                 dqsat(ig)=(qsat_temp2-qsat_temp1)/0.0002
    528                 ! calculate dQsat / dT by finite differences
    529                 ! we cannot use the updated temperature value yet...
    530  
    531                enddo
    532 
    533 ! coefficients for q
    534 
    535                do ig=1,ngrid
    536                   z1(ig)=1./(za(ig,nlay)+zb(ig,nlay))
    537                   zcq(ig,nlay)=za(ig,nlay)*zq(ig,nlay,iq)*z1(ig)
    538                   zdq(ig,nlay)=zb(ig,nlay)*z1(ig)
    539                enddo
    540            
    541                do ilay=nlay-1,2,-1
    542                   do ig=1,ngrid
    543                      z1(ig)=1./(za(ig,ilay)+zb(ig,ilay)+
    544      $                    zb(ig,ilay+1)*(1.-zdq(ig,ilay+1)))
    545                      zcq(ig,ilay)=(za(ig,ilay)*zq(ig,ilay,iq)+
    546      $                    zb(ig,ilay+1)*zcq(ig,ilay+1))*z1(ig)
    547                      zdq(ig,ilay)=zb(ig,ilay)*z1(ig)
    548                   enddo
    549                enddo
    550 
    551                do ig=1,ngrid
    552                   z1(ig)=1./(za(ig,1)+zb(ig,1)*dryness(ig)+
    553      $                 zb(ig,2)*(1.-zdq(ig,2)))
    554                   zcq(ig,1)=(za(ig,1)*zq(ig,1,iq)+
    555      $                 zb(ig,2)*zcq(ig,2))*z1(ig)
    556                   zdq(ig,1)=dryness(ig)*zb(ig,1)*z1(ig)
    557                enddo
    558 
    559 ! calculation of h0 and h1
    560                do ig=1,ngrid
    561                   zdq0(ig) = dqsat(ig)
    562                   zcq0(ig) = qsat(ig)-dqsat(ig)*ptsrf(ig)
    563 
    564                   z1(ig) = pcapcal(ig)*ptsrf(ig) +cpp*zb(ig,1)*zc(ig,1)
    565      &                 + zdplanck(ig)*ptsrf(ig) + pfluxsrf(ig)*ptimestep
    566      &                 +  zb(ig,1)*dryness(ig)*RLVTT*
    567      &                 ((zdq(ig,1)-1.0)*zcq0(ig)+zcq(ig,1))
    568 
    569                   z2(ig) = pcapcal(ig) + cpp*zb(ig,1)*(1.-zd(ig,1))
    570      &                 +zdplanck(ig)
    571      &                 +zb(ig,1)*dryness(ig)*RLVTT*zdq0(ig)*
    572      &                 (1.0-zdq(ig,1))
    573 
    574                   ztsrf2(ig) = z1(ig) / z2(ig)
    575                   pdtsrf(ig) = (ztsrf2(ig) - ptsrf(ig))/ptimestep
    576                   zh(ig,1)   = zc(ig,1) + zd(ig,1)*ztsrf2(ig)
    577                enddo
    578 
    579 ! calculation of qs and q1
    580                do ig=1,ngrid
    581                   zq0(ig)     = zcq0(ig)+zdq0(ig)*ztsrf2(ig)
    582                   zq(ig,1,iq) = zcq(ig,1)+zdq(ig,1)*zq0(ig)
    583                enddo
    584 
    585 ! calculation of evaporation             
    586                do ig=1,ngrid
    587                   evap(ig)= zb(ig,1)*dryness(ig)*(zq(ig,1,ivap)-zq0(ig))
    588                   dqsdif_total(ig)=evap(ig)
    589                enddo
    590 
    591 ! recalculate temperature and q(vap) to top of atmosphere, starting from ground
    592                do ilay=2,nlay
    593                   do ig=1,ngrid
    594                      zq(ig,ilay,iq)=zcq(ig,ilay)
    595      &                    +zdq(ig,ilay)*zq(ig,ilay-1,iq)
    596                      zh(ig,ilay)=zc(ig,ilay)+zd(ig,ilay)*zh(ig,ilay-1)
    597                   end do
    598                end do
    599 
    600                do ig=1,ngrid
    601 
    602 !     --------------------------------------------------------------------------
    603 !     On the ocean, if T > 0 C then the vapour tendency must replace the ice one
    604 !     The surface vapour tracer is actually liquid. To make things difficult.
    605 
    606                   if (nint(rnat(ig)).eq.0) then ! unfrozen ocean
    607                      
    608                      pdqsdif(ig,ivap)=dqsdif_total(ig)/ptimestep
    609                      pdqsdif(ig,iice)=0.0
    610 
    611 
    612                   elseif (nint(rnat(ig)).eq.1) then ! (continent)
    613 
    614 !     --------------------------------------------------------
    615 !     Now check if we've taken too much water from the surface
    616 !     This can only occur on the continent
    617 
    618 !     If water is evaporating / subliming, we take it from ice before liquid
    619 !     -- is this valid??
    620                      if(dqsdif_total(ig).lt.0)then
    621                         pdqsdif(ig,iice)=dqsdif_total(ig)/ptimestep
    622                         pdqsdif(ig,iice)=max(-pqsurf(ig,iice)/ptimestep
    623      &                       ,pdqsdif(ig,iice))
    624                      endif
    625                      ! sublimation only greater than qsurf(ice)
    626                      ! ----------------------------------------
    627                      ! we just convert some liquid to vapour too
    628                      ! if latent heats are the same, no big deal
    629                      if (-dqsdif_total(ig).gt.pqsurf(ig,iice))then           
    630                        pdqsdif(ig,iice) = -pqsurf(ig,iice)/ptimestep ! removes all the ice!
    631                        pdqsdif(ig,ivap) = dqsdif_total(ig)/ptimestep
    632      &                       - pdqsdif(ig,iice) ! take the remainder from the liquid instead
    633                        pdqsdif(ig,ivap) = max(-pqsurf(ig,ivap)/ptimestep
    634      &                       ,pdqsdif(ig,ivap))
    635                     endif
    636 
    637                  endif          ! if (rnat.ne.1)
    638 
    639 !     If water vapour is condensing, we must decide whether it forms ice or liquid.
    640                  if(dqsdif_total(ig).gt.0)then ! a bug was here!
    641                     if(ztsrf2(ig).gt.T_h2O_ice_liq)then
    642                        pdqsdif(ig,iice)=0.0
    643                        pdqsdif(ig,ivap)=dqsdif_total(ig)/ptimestep
    644                     else
    645                        pdqsdif(ig,iice)=dqsdif_total(ig)/ptimestep
    646                        pdqsdif(ig,ivap)=0.0
    647                     endif
    648                  endif
    649 
    650               end do            ! of DO ig=1,ngrid
    651            endif                ! if (water et iq=ivap)
     459
    652460        end do                  ! of do iq=1,nq
    653461      endif                     ! traceur
     
    685493         enddo
    686494
    687          if(water.and.forceWC)then ! force water conservation in model
    688                                    ! we calculate the difference and add it to the ground
    689                                    ! this is ugly and should be improved in the future
    690             do ig=1,ngrid
    691                Wtot=0.0
    692                do ilay=1,nlay
    693                   masse = (pplev(ig,ilay) - pplev(ig,ilay+1))/g
    694 !                  Wtot=Wtot+masse*(zq(ig,ilay,iice)-
    695 !     &                 (pq(ig,ilay,iice)+pdqfi(ig,ilay,iice)*ptimestep))
    696                   Wtot=Wtot+masse*(zq(ig,ilay,ivap)-
    697      &                 (pq(ig,ilay,ivap)+pdqfi(ig,ilay,ivap)*ptimestep))
    698                enddo
    699                Wdiff=Wtot/ptimestep+pdqsdif(ig,ivap)+pdqsdif(ig,iice)
    700 
    701                if(ztsrf2(ig).gt.T_h2O_ice_liq)then
    702                   pdqsdif(ig,ivap)=pdqsdif(ig,ivap)-Wdiff
    703                else
    704                   pdqsdif(ig,iice)=pdqsdif(ig,iice)-Wdiff
    705                endif
    706             enddo
    707 
    708          endif
    709 
    710495      endif
    711 
    712       if(water)then
    713       call writediagfi(ngrid,'beta','Dryness coefficient',' ',2,dryness)
    714       endif
    715496
    716497!      if(lastcall)then
Note: See TracChangeset for help on using the changeset viewer.