Changeset 2343
- Timestamp:
- Jun 9, 2020, 1:56:52 PM (5 years ago)
- Location:
- trunk/LMDZ.MARS/libf/phymars
- Files:
-
- 4 deleted
- 4 edited
- 2 copied
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.MARS/libf/phymars/co2sat.F
r2341 r2343 1 SUBROUTINE co2sat(naersize,t,p,psat) 2 c SUBROUTINE co2sat(naersize,t,p,qsat) JA 3 IMPLICIT NONE 4 1 5 c======================================================================= 2 c SUBROUTINE co2sat 3 c----------------------------------------------------------------------- 4 c Aim: 5 c ---- 6 c Compute saturated steam pressure (from James et al, 1992) 6 c 7 c 8 c now: straight psat of CO2 (or qsat of CO2 but need of mmean) 9 c 7 10 c======================================================================= 8 subroutine co2sat(naersize, t, psat)9 10 implicit none11 c-----------------------------------------------------------------------12 c VARIABLES13 c-----------------------------------------------------------------------14 c Inputs:15 c -------16 integer, intent(in) ::17 & naersize ! dimension of tables t and psat18 19 real, intent(in) ::20 & t(naersize) ! temperature table21 11 22 c Output:23 c 24 real, intent(out) ::25 & psat(naersize) ! Saturated steam pressure (Pa) 12 c declarations: 13 c ------------- 14 c arguments: 15 c ---------- 26 16 27 c Local: 28 c ------ 29 integer :: 30 & i ! loop on naersize 31 c======================================================================= 32 c===== BEGIN 33 c======================================================================= 34 do i = 1, naersize 35 psat(i) = 1.382 * 1e12 * exp(-3182.48/t(i)) 36 end do 37 c======================================================================= 38 c===== END 39 c======================================================================= 17 c INPUT 18 integer naersize 19 real t(naersize) , p(naersize) 20 c OUTPUT 21 c real qsat(naersize) JA 22 real psat(naersize) 23 24 c local: 25 c ------ 26 INTEGER i 27 REAL r2,r3,r4 , To, es 28 SAVE r2,r3,r4 29 DATA r2,r3,r4/611.14,21.875,7.66/ 30 SAVE To 31 DATA To/273.16/ 32 33 do i=1,naersize 34 35 36 c pression de vapeur saturante (James et al. 1992): 37 38 psat(i) = 1.382 * 1e12 * exp(-3182.48/t(i)) !; (Pa) 39 40 c OR: 41 42 c qsat(i) = psat/p(i)*44.01/mmean ! Need of updated information on mmean 43 c qsat(i) = max(qsat(i), 1.e-30) 44 45 46 enddo 47 c qsat=psat JA 48 49 40 50 RETURN 41 51 END -
trunk/LMDZ.MARS/libf/phymars/co2snow.F
r2341 r2343 1 c======================================================================= 2 c Program for simulate the impact of the CO2 snow fall on 3 c the surface infrared emission (emissivity) 4 c----------------------------------------------------------------------- 5 c Algorithme: 6 c 1 - Initialization 7 c 2 - Compute the surface emissivity 8 c----------------------------------------------------------------------- 9 c Author: F. Forget 10 c----------------------------------------------------------------------- 11 c Reference paper: 12 c Francois Forget and James B. Pollack 13 c 14 c "Thermal infrared observations of the condensing Martian polar 15 c caps: CO2 ice temperatures and radiative budget" 16 c 17 c JOURNAL OF GEOPHYSICAL RESEARCH, VOL. 101, NO. E7, PAGES 16, 18 c 865-16,879, JULY 25, 1996 19 c======================================================================= 1 SUBROUTINE co2snow (ngrid,nlayer,ptimestep,emisref,condsub 2 & ,pplev,pcondicea,pcondices,pfallice,pemisurf) 20 3 21 SUBROUTINE co2snow(ngrid, nlayer, ptimestep, emisref, condsub,22 & pplev, pcondicea, pcondices, pfallice,23 & pemisurf)24 25 4 use surfdat_h, only: iceradius, dtemisice 26 5 use geometry_mod, only: latitude ! grid point latitudes (rad) 27 6 use time_phylmdz_mod, only: daysec 7 IMPLICIT NONE 28 8 29 IMPLICIT NONE 9 c======================================================================= 10 c Program for simulate the impact of the CO2 snow fall on 11 c the surface infrared emission (emissivity) and on 12 c the airborne dust 13 c F.Forget 1996 14 c======================================================================= 15 16 c Declarations 17 c ------------ 30 18 31 19 #include "callkeys.h" 32 20 21 c Arguments 22 c --------- 33 23 34 c======================================================================= 35 c Variables 36 c======================================================================= 37 c Inputs: 38 c ------- 39 integer, intent(in) :: 40 & ngrid, ! number of atmospheric columns 41 & nlayer ! number of atmospheric layers 42 43 real, intent(in) :: 44 & ptimestep, ! timestep of the physics (s) 45 & emisref(ngrid), ! grd or ice emissivity without snow 46 & pplev(ngrid,nlayer+1), ! interlayer pressure (Pa) 47 & pcondicea(ngrid,nlayer), ! CO2 condensation rate in layers 48 ! (kg/m2/s) 49 & pcondices(ngrid), ! CO2 condensation rate on the surface 50 ! (kg/m2/s) 51 & pfallice(ngrid,nlayer+1) ! falling CO2 ice (kg/m2/s) 52 53 logical, intent(in) :: 54 & condsub(ngrid) ! true if there is CO2 condensation or 55 ! sublimation in the column 24 INTEGER,INTENT(IN) :: ngrid ! number of atmospheric columns 25 INTEGER,INTENT(IN) :: nlayer ! number of atmospheric layers 26 REAL,INTENT(IN) :: ptimestep ! timestep of the physics (s) 27 REAL,INTENT(IN) :: emisref(ngrid) ! grd or ice emissivity without snow 28 logical,intent(in) :: condsub(ngrid) ! true if there is CO2 condensation 29 ! or sublimation in the column 30 REAL,INTENT(IN) :: pplev(ngrid,nlayer+1) ! interlayer pressure (Pa) 31 REAL,INTENT(IN) :: pcondicea(ngrid,nlayer) ! CO2 condensation rate (kg/m2/s) 32 REAL,INTENT(IN) :: pcondices(ngrid) ! CO2 condensation rate (kg/m2/s) 33 ! on the surface 34 REAL,INTENT(IN) :: pfallice(ngrid,nlayer+1) ! falling CO2 ice (kg/m2/s) 56 35 57 c Output: 58 c ------- 59 real, intent(out) :: 60 & pemisurf(ngrid) ! surface emissivity 36 REAL,INTENT(OUT) :: pemisurf(ngrid) ! surface emissivity 61 37 62 c local: 63 c ------ 64 integer :: 65 & l, 66 & ig, 67 & icap 38 c local 39 c ----- 40 integer ig , l , icap 68 41 69 real :: 70 & sumdaer, 71 & zdemisurf 42 REAL zdemisurf ,dtemis 43 REAL sumdaer 72 44 73 real, parameter :: 74 & alpha = 0.45 45 c saved 46 c ----- 47 REAL,save :: Kscat(2), scaveng 48 LOGICAL,SAVE :: firstcall=.true. 75 49 76 c saved: 77 c ------ 78 real, save :: 79 & Kscat(2) ! Kscat: coefficient for decreasing the surface 80 c ! emissivity 81 c ! 82 c ! Kscat = (0.001/3.) * alpha / iceradius 83 c ! with 0.3 < alpha < 0.6 84 c ! 85 c ! alpha set to 0.45 (coeff from emis = f (tau)) and 86 c ! iceradius the mean radius of the scaterring 87 c ! particles (200.e-6 < iceradius < 10.e-6) 88 c ! 89 c ! (2) = N and S hemispheres 50 c -------------- 51 c Initialisation 52 c -------------- 90 53 91 logical, save :: 92 & firstcall = .true. 93 c======================================================================= 94 c BEGIN 95 c======================================================================= 96 c 1 - Initialization 97 c======================================================================= 54 ! AS: firstcall OK absolute 98 55 if (firstcall) then 99 Kscat(1) = (0.001/3.) * alpha / iceradius(1) 100 Kscat(2) = (0.001/3.) * alpha / iceradius(2) 101 102 firstcall = .false. 56 57 c Kscat : coefficient for decreasing the surface emissivity 58 c =(0.001/3.)*alpha/iceradius , 59 c with 0.3< alpha < 0.6, set to 0.45 (coeff from emis = f (tau)) 60 c and iceradius the mean radius of the 61 c scaterring particles (200.e-6<iceradius<10.e-6) 62 63 Kscat(1)=(0.001/3.)*0.45/iceradius(1) 64 Kscat(2)=(0.001/3.)*0.45/iceradius(2) 65 66 c Scavenging Ratio (dust concentration in the air / in the snow) 67 scaveng = 100.0 68 69 c Collision Scavenging coefficient (m2.kg-1) 70 c Csca = 2.3 ! not used yet !!!!!!!!!!! 71 firstcall = .false. 72 103 73 end if 104 c=======================================================================105 c 2 - Compute the surface emissivity106 c=======================================================================107 do ig = 1, ngrid108 if (condsub(ig)) then109 if (latitude(ig).lt.0.) then110 icap = 2 ! Southern hemisphere111 else112 icap = 1 ! Northern Hemisphere113 end if114 74 115 ! compute zdemisurf using an integrated form for numerical 116 ! safety instead 117 zdemisurf = 118 & (emisref(ig) - pemisurf(ig)) / (dtemisice(icap) * daysec) 119 & + 120 & ( emisref(ig) * 121 & ( (pemisurf(ig)/emisref(ig))**(-3) + 122 & 3.*Kscat(icap)*pfallice(ig,1)*ptimestep )**(-1/3.) 123 & - pemisurf(ig) 124 & ) / ptimestep 125 126 pemisurf(ig) = pemisurf(ig) + zdemisurf * ptimestep 127 if (pemisurf(ig).lt.0.1) then 128 write(*,*)'ds co2snow: emis < 0.1 !!!' 129 write(*,*)'ig =' , ig 130 write(*,*)'pemisurf(ig)', pemisurf(ig) 131 write(*,*)'zdemisurf*ptimestep', zdemisurf*ptimestep 132 end if 133 else ! if condsub(ig) is false 75 76 c LOOP on grid points 77 c ------------------- 78 do ig=1,ngrid 79 if (condsub(ig)) then 80 81 c IF (scavenging) then 82 c Airborne Dust 83 c ------------- 84 c sumdaer=0. 85 c do l=nlayer, 1, -1 86 c pdaerosol(ig,l)= -paerosol(ig,l,1)* 87 c & (1-exp(-scaveng*pcondicea(ig,l)*ptimestep*g/ 88 c & (pplev(ig,l)-pplev(ig,l+1))))/ptimestep 89 90 c & - Csca*paerosol(ig,l,1) ! Scavenging by collision 91 c & * 0.5*(pfallice(ig,l)) ! not included 92 93 c test to avoid releasing to much dust when subliming: 94 c if(pdaerosol(ig,l).gt.-sumdaer)pdaerosol(ig,l)=-sumdaer 95 c sumdaer=sumdaer + pdaerosol(ig,l) 96 97 c if (-pdaerosol(ig,l)*ptimestep.gt.paerosol(ig,l,1)) then 98 c write(*,*) 'ds co2snow: aerosol < 0.0 !!!' 99 c write(*,*) 'ig =' , ig 100 c end if 101 c end do 102 c END IF 103 104 c Surface emissivity 105 c ------------------ 106 c dtemis: Time scale for increasing the ice emissivity 107 108 IF(latitude(ig).LT. 0.) THEN 109 icap=2 ! Southern hemisphere 110 ELSE 111 icap=1 ! Northern Hemisphere 112 ENDIF 113 114 zdemisurf = 115 & (emisref(ig)-pemisurf(ig))/(dtemisice(icap)*daysec) 116 c Using directly the diferential equation: 117 c & -Kscat(icap)*emisref(ig)* 118 c & (pemisurf(ig)/emisref(ig))**4 *pfallice(ig,1) 119 c Using an integrated form for numerical safety instead 120 & +(emisref(ig)* ((pemisurf(ig)/emisref(ig))**(-3)+3.*Kscat(icap)* 121 & pfallice(ig,1)*ptimestep)**(-1/3.) -pemisurf(ig))/ptimestep 122 123 124 pemisurf(ig) = pemisurf(ig) + zdemisurf*ptimestep 125 126 if (pemisurf(ig).lt.0.1) then 127 write(*,*) 'ds co2snow: emis < 0.1 !!!' 128 write(*,*) 'ig =' , ig 129 write(*,*)'pemisurf(ig)',pemisurf(ig) 130 write(*,*) 'zdemisurf*ptimestep',zdemisurf*ptimestep 131 end if 132 else 134 133 pemisurf(ig) = emisref(ig) 135 end if 136 end do ! ngrid 137 c======================================================================= 138 c END 139 c======================================================================= 134 end if 135 end do 136 140 137 return 141 138 end -
trunk/LMDZ.MARS/libf/phymars/physiq_mod.F
r2341 r2343 18 18 use watersat_mod, only: watersat 19 19 use co2condens_mod, only: co2condens 20 use co2condens_mod4micro, only: co2condens4micro21 20 use co2cloud_mod, only: co2cloud, mem_Mccn_co2, mem_Mh2o_co2, 22 21 & mem_Nccn_co2 … … 252 251 c Variables used by the CO2 clouds microphysical scheme: 253 252 DOUBLE PRECISION riceco2(ngrid,nlayer) ! co2 ice geometric mean radius (m) 253 real rsedcloudco2(ngrid,nlayer) !CO2 Cloud sedimentation radius 254 real rhocloudco2(ngrid,nlayer) !co2 Cloud density (kg.m-3) 254 255 real zdqssed_co2(ngrid) ! CO2 flux at the surface (kg.m-2.s-1) 255 256 real zcondicea_co2microp(ngrid,nlayer) … … 302 303 303 304 c Tendancies due to various processes: 304 REAL dqsurf(ngrid,nq) ! tendency for tracers on surface (Kg/m2/s)305 REAL dqsurf(ngrid,nq) 305 306 REAL zdtlw(ngrid,nlayer) ! (K/s) 306 307 REAL zdtsw(ngrid,nlayer) ! (K/s) … … 383 384 REAL mtot(ngrid) ! Total mass of water vapor (kg/m2) 384 385 REAL mstormdtot(ngrid) ! Total mass of stormdust tracer (kg/m2) 385 REAL mdusttot(ngrid) 386 REAL mdusttot(ngrid) ! Total mass of dust tracer (kg/m2) 386 387 REAL icetot(ngrid) ! Total mass of water ice (kg/m2) 387 REAL mtotco2 ! Total mass of co2, including ice at the surface (kg/m2) 388 REAL vaptotco2 ! Total mass of co2 vapor (kg/m2) 389 REAL icetotco2 ! Total mass of co2 ice (kg/m2) 388 REAL mtotco2(ngrid) ! Total mass of co2 vapor (kg/m2) 389 REAL icetotco2(ngrid) ! Total mass of co2 ice (kg/m2) 390 390 REAL Nccntot(ngrid) ! Total number of ccn (nbr/m2) 391 REAL NccnCO2tot(ngrid) ! Total number of ccnCO2 (nbr/m2)392 391 REAL Mccntot(ngrid) ! Total mass of ccn (kg/m2) 393 392 REAL rave(ngrid) ! Mean water ice effective radius (m) … … 404 403 REAL DoH_ice(ngrid,nlayer) !D/H ratio 405 404 REAL DoH_surf(ngrid) !D/H ratio surface 406 405 407 406 REAL dqdustsurf(ngrid) ! surface q dust flux (kg/m2/s) 408 407 REAL dndustsurf(ngrid) ! surface n dust flux (number/m2/s) … … 484 483 real tf_clf, ntf_clf ! tf: fraction of clouds, ntf: fraction without clouds 485 484 real rave2(ngrid), totrave2(ngrid) ! Mean water ice mean radius (m) 486 C test de conservation de la masse de CO2487 REAL co2totA488 REAL co2totB489 485 490 486 c entrainment by slope winds above sb-grid scale topography … … 500 496 501 497 c======================================================================= 502 c---------- begin added by CM503 pdq(:,:,:) = 0.504 c---------end added by CM505 506 498 507 499 c 1. Initialisation: 508 500 c ----------------- 501 509 502 c 1.1 Initialisation only at first call 510 503 c --------------------------------------- … … 563 556 ! starting without startfi.nc and with callsoil 564 557 ! is not yet possible as soildepth default is not defined 565 if (callsoil) then 558 if (callsoil) then 566 559 ! default mlayer distribution, following a power law: 567 560 ! mlayer(k)=lay1*alpha**(k-1/2) … … 732 725 dsotop(:,:)=0. 733 726 dwatercap(:)=0 734 727 735 728 #ifdef DUSTSTORM 736 729 pq_tmp(:,:,:)=0 … … 817 810 enddo 818 811 819 ! calculates the amount of co2 at the beginning of physics820 co2totA = 0.821 do ig=1,ngrid822 do l=1,nlayer823 co2totA = co2totA + (zplev(ig,l)-zplev(ig,l+1))/g*824 & (pq(ig,l,igcm_co2)+pq(ig,l,igcm_co2_ice)825 & +(pdq(ig,l,igcm_co2)+pdq(ig,l,igcm_co2_ice))*ptimestep)826 end do827 co2totA = co2totA + co2ice(ig)828 end do829 812 c----------------------------------------------------------------------- 830 813 c 2. Compute radiative tendencies : … … 869 852 & pq(1:ngrid,1:nlayer,igcm_o)* 870 853 & mmean(1:ngrid,1:nlayer)/mmol(igcm_o) 871 854 872 855 CALL nlte_tcool(ngrid,nlayer,zplay*9.869e-6, 873 856 $ pt,zzlay,co2vmr_gcm, n2vmr_gcm, covmr_gcm, … … 919 902 c ------------------ 920 903 ! callradite for the part with clouds 921 clearsky=.false. ! part with clouds for both cases CLFvarying true/false 904 clearsky=.false. ! part with clouds for both cases CLFvarying true/false 922 905 CALL callradite(icount,ngrid,nlayer,nq,zday,zls,pq,albedo, 923 906 & emis,mu0,zplev,zplay,pt,tsurf,fract,dist_sol,igout, … … 934 917 ! if 935 918 ! CLFvarying ...) ?? AP ?? 936 clearsky=.true. ! 919 clearsky=.true. ! 937 920 CALL callradite(icount,ngrid,nlayer,nq,zday,zls,pq, 938 921 & albedo,emis,mu0,zplev,zplay,pt,tsurf,fract, … … 1136 1119 & pdqrds,wspeed,dsodust,dsords,dsotop, 1137 1120 & tauref) 1138 1121 1139 1122 c update the tendencies of both dust after vertical transport 1140 1123 DO l=1,nlayer … … 1188 1171 hsummit(:)=14000. 1189 1172 endif 1190 clearatm=.true. ! stormdust is not accounted in the extra heating on top of the mountains 1173 clearatm=.true. ! stormdust is not accounted in the extra heating on top of the mountains 1191 1174 nohmons=.false. 1192 pdqtop(:,:,:)=0. 1175 pdqtop(:,:,:)=0. 1193 1176 CALL topmons(ngrid,nlayer,nq,ptime,ptimestep, 1194 1177 & pq,pdq,pt,pdt,zplev,zplay,zzlev, … … 1240 1223 CALL calldrag_noro(ngrid,nlayer,ptimestep, 1241 1224 & zplay,zplev,pt,pu,pv,zdtgw,zdugw,zdvgw) 1242 1225 1243 1226 DO l=1,nlayer 1244 1227 DO ig=1,ngrid … … 1326 1309 DO l=1,nlayer 1327 1310 DO ig=1,ngrid 1328 pdq(ig,l,iq)=pdq(ig,l,iq)+ zdqdif(ig,l,iq) 1311 pdq(ig,l,iq)=pdq(ig,l,iq)+ zdqdif(ig,l,iq) 1329 1312 ENDDO 1330 1313 ENDDO … … 1381 1364 1382 1365 if(calltherm .and. .not.turb_resolved) then 1383 1366 1384 1367 call calltherm_interface(ngrid,nlayer,nq, 1385 1368 $ tracer,igcm_co2, … … 1389 1372 $ pdu_th,pdv_th,pdt_th,pdq_th,lmax_th,zmax_th, 1390 1373 $ dtke_th,zdhdif,hfmax_th,wstar,sensibFlux) 1391 1374 1392 1375 DO l=1,nlayer 1393 1376 DO ig=1,ngrid … … 1398 1381 ENDDO 1399 1382 ENDDO 1400 1383 1401 1384 DO ig=1,ngrid 1402 1385 q2(ig,nlayer+1)=q2(ig,nlayer+1)+dtke_th(ig,nlayer+1)*ptimestep 1403 ENDDO 1386 ENDDO 1404 1387 1405 1388 if (tracer) then … … 1510 1493 & nq,tau,tauscaling,rdust,rice,nuice, 1511 1494 & rsedcloud,rhocloud,totcloudfrac) 1512 1495 1513 1496 c Temperature variation due to latent heat release 1514 1497 if (activice) then 1515 pdt(1:ngrid,1:nlayer) = 1516 & pdt(1:ngrid,1:nlayer) + 1498 pdt(1:ngrid,1:nlayer) = 1499 & pdt(1:ngrid,1:nlayer) + 1517 1500 & zdtcloud(1:ngrid,1:nlayer) 1518 1501 endif … … 1528 1511 if (hdo) then 1529 1512 ! increment HDO vapour and ice atmospheric tracers tendencies 1530 pdq(1:ngrid,1:nlayer,igcm_hdo_vap) = 1531 & pdq(1:ngrid,1:nlayer,igcm_hdo_vap) + 1513 pdq(1:ngrid,1:nlayer,igcm_hdo_vap) = 1514 & pdq(1:ngrid,1:nlayer,igcm_hdo_vap) + 1532 1515 & zdqcloud(1:ngrid,1:nlayer,igcm_hdo_vap) 1533 pdq(1:ngrid,1:nlayer,igcm_hdo_ice) = 1534 & pdq(1:ngrid,1:nlayer,igcm_hdo_ice) + 1516 pdq(1:ngrid,1:nlayer,igcm_hdo_ice) = 1517 & pdq(1:ngrid,1:nlayer,igcm_hdo_ice) + 1535 1518 & zdqcloud(1:ngrid,1:nlayer,igcm_hdo_ice) 1536 1519 endif !hdo … … 1605 1588 c nucleation 1606 1589 c imicroco2=50 micro-timestep is 1/50 of physical timestep 1607 zdqssed_co2(:) = 0. 1608 1609 IF (co2clouds) THEN 1610 call co2cloud(ngrid,nlayer,ptimestep, 1590 1591 IF (co2clouds ) THEN 1592 1593 1594 call co2cloud(ngrid,nlayer,ptimestep, 1611 1595 & zplev,zplay,pdpsrf,zzlay,pt,pdt, 1612 1596 & pq,pdq,zdqcloudco2,zdtcloudco2, 1613 1597 & nq,tau,tauscaling,rdust,rice,riceco2,nuice, 1598 & rsedcloudco2,rhocloudco2, 1614 1599 & rsedcloud,rhocloud,zzlev,zdqssed_co2, 1615 & pdu,pu,zcondicea_co2microp , co2ice)1600 & pdu,pu,zcondicea_co2microp) 1616 1601 1617 1602 … … 1627 1612 ! We need to check that we have Nccn & Ndust > 0 1628 1613 ! This is due to single precision rounding problems 1614 1629 1615 ! increment dust tracers tendancies 1630 pdq( :,:,igcm_dust_mass) = pdq(:,:,igcm_dust_mass)1631 & + zdqcloudco2(:,:,igcm_dust_mass)1632 1633 pdq( :,:,igcm_dust_number) = pdq(:,:,igcm_dust_number)1634 & + zdqcloudco2(:,:,igcm_dust_number)1635 1636 pdq( :,:,igcm_co2) = pdq(:,:,igcm_co2)1637 & + zdqcloudco2(:,:,igcm_co2)1638 1639 pdq( :,:,igcm_co2_ice) = pdq(:,:,igcm_co2_ice)1640 & + zdqcloudco2(:,:,igcm_co2_ice)1641 1642 pdq( :,:,igcm_ccnco2_mass) = pdq(:,:,igcm_ccnco2_mass)1643 & + zdqcloudco2(:,:,igcm_ccnco2_mass)1644 1645 pdq( :,:,igcm_ccnco2_number) = pdq(:,:,igcm_ccnco2_number)1646 & + zdqcloudco2(:,:,igcm_ccnco2_number)1647 1616 pdq(1:ngrid,1:nlayer,igcm_dust_mass) = 1617 & pdq(1:ngrid,1:nlayer,igcm_dust_mass) + 1618 & zdqcloudco2(1:ngrid,1:nlayer,igcm_dust_mass) 1619 pdq(1:ngrid,1:nlayer,igcm_dust_number) = 1620 & pdq(1:ngrid,1:nlayer,igcm_dust_number) + 1621 & zdqcloudco2(1:ngrid,1:nlayer,igcm_dust_number) 1622 pdq(1:ngrid,1:nlayer,igcm_co2) = 1623 & pdq(1:ngrid,1:nlayer,igcm_co2) + 1624 & zdqcloudco2(1:ngrid,1:nlayer,igcm_co2) 1625 pdq(1:ngrid,1:nlayer,igcm_co2_ice) = 1626 & pdq(1:ngrid,1:nlayer,igcm_co2_ice) + 1627 & zdqcloudco2(1:ngrid,1:nlayer,igcm_co2_ice) 1628 pdq(1:ngrid,1:nlayer,igcm_ccnco2_mass) = 1629 & pdq(1:ngrid,1:nlayer,igcm_ccnco2_mass) + 1630 & zdqcloudco2(1:ngrid,1:nlayer,igcm_ccnco2_mass) 1631 pdq(1:ngrid,1:nlayer,igcm_ccnco2_number) = 1632 & pdq(1:ngrid,1:nlayer,igcm_ccnco2_number) + 1633 & zdqcloudco2(1:ngrid,1:nlayer,igcm_ccnco2_number) 1648 1634 !Update water ice clouds values as well 1649 1635 if (co2useh2o) then … … 1657 1643 & pdq(1:ngrid,1:nlayer,igcm_ccn_number) + 1658 1644 & zdqcloudco2(1:ngrid,1:nlayer,igcm_ccn_number) 1659 1660 c Negative values? 1661 where (pq(:,:,igcm_ccn_mass) + 1645 where (pq(:,:,igcm_ccn_mass) + 1662 1646 & ptimestep*pdq(:,:,igcm_ccn_mass) < 0.) 1663 1647 pdq(:,:,igcm_ccn_mass) = … … 1666 1650 & - pq(:,:,igcm_ccn_number)/ptimestep + 1.e-30 1667 1651 end where 1668 c Negative values? 1669 where (pq(:,:,igcm_ccn_number) + 1652 where (pq(:,:,igcm_ccn_number) + 1670 1653 & ptimestep*pdq(:,:,igcm_ccn_number) < 0.) 1671 1654 pdq(:,:,igcm_ccn_mass) = … … 1706 1689 & - pq(:,:,igcm_dust_number)/ptimestep + 1.e-30 1707 1690 end where 1708 END IF ! of IF (co2clouds) 1691 1692 END IF ! of IF (co2clouds) 1709 1693 1710 1694 c 9b. Aerosol particles … … 1750 1734 & tau,tauscaling) 1751 1735 c Flux at the surface of co2 ice computed in co2cloud microtimestep 1736 IF (co2clouds) THEN 1737 zdqssed(1:ngrid,igcm_co2_ice)=zdqssed_co2(1:ngrid) 1738 ENDIF 1739 1752 1740 IF (rdstorm) THEN 1753 1741 c Storm dust cannot sediment to the surface … … 1879 1867 DO ig=1,ngrid 1880 1868 dtrad(ig,l)=dtrad(ig,l)+zdteuv(ig,l) 1881 pdt(ig,l)=pdt(ig,l)+zdtconduc(ig,l)+zdteuv(ig,l) 1869 pdt(ig,l)=pdt(ig,l)+zdtconduc(ig,l) 1870 & +zdteuv(ig,l) 1882 1871 pdv(ig,l)=pdv(ig,l)+zdvmolvis(ig,l) 1883 1872 pdu(ig,l)=pdu(ig,l)+zdumolvis(ig,l) … … 1894 1883 c (should be the last atmospherical physical process to be computed) 1895 1884 c ------------------------------------------- 1885 1896 1886 IF (tituscap) THEN 1897 1887 !!! get the actual co2 seasonal cap from Titus observations 1898 CALL geticecover( ngrid, 180.*zls/pi,1888 CALL geticecover( ngrid, 180.*zls/pi, 1899 1889 . 180.*longitude/pi, 180.*latitude/pi, co2ice ) 1900 1890 co2ice = co2ice * 10000. 1901 1891 ENDIF 1902 1892 1893 1894 pdpsrf(:) = 0 1903 1895 1904 1896 IF (callcond) THEN 1905 zdtc(:,:) = 0. 1906 zdtsurfc(:) = 0. 1907 zduc(:,:) = 0. 1908 zdvc(:,:) = 0. 1909 zdqc(:,:,:) = 0. 1910 1911 if (co2clouds) then 1912 CALL co2condens4micro(ngrid,nlayer,nq,ptimestep, 1913 $ capcal,zplay,zplev,tsurf,pt, 1914 $ pphi,pdt,pdu,pdv,zdtsurf,pu,pv,pq,pdq, 1915 $ co2ice,albedo,emis, 1916 $ zdtc,zdtsurfc,pdpsrf,zduc,zdvc,zdqc, 1917 $ fluxsurf_sw,zls, 1918 $ zdqssed_co2,zcondicea_co2microp, 1919 & zdtcloudco2) 1920 else 1921 CALL co2condens(ngrid,nlayer,nq,ptimestep, 1897 CALL co2condens(ngrid,nlayer,nq,ptimestep, 1922 1898 $ capcal,zplay,zplev,tsurf,pt, 1923 1899 $ pphi,pdt,pdu,pdv,zdtsurf,pu,pv,pq,pdq, … … 1927 1903 $ zdqssed_co2,zcondicea_co2microp, 1928 1904 & zdtcloudco2,zdqsc) 1929 DO iq=1, nq 1930 DO ig=1,ngrid 1931 dqsurf(ig,iq)=dqsurf(ig,iq)+zdqsc(ig,iq) 1932 ENDDO ! (ig) 1933 ENDDO ! (iq) 1934 end if 1935 DO l=1,nlayer 1905 1906 DO l=1,nlayer 1936 1907 DO ig=1,ngrid 1937 1908 pdt(ig,l)=pdt(ig,l)+zdtc(ig,l) … … 1939 1910 pdu(ig,l)=pdu(ig,l)+zduc(ig,l) 1940 1911 ENDDO 1941 ENDDO1942 DO ig=1,ngrid1943 zdtsurf(ig) = zdtsurf(ig) + zdtsurfc(ig)1944 ENDDO1945 1946 IF (tracer) THEN1912 ENDDO 1913 DO ig=1,ngrid 1914 zdtsurf(ig) = zdtsurf(ig) + zdtsurfc(ig) 1915 ENDDO 1916 1917 IF (tracer) THEN 1947 1918 DO iq=1, nq 1948 1919 DO l=1,nlayer 1949 1920 DO ig=1,ngrid 1950 pdq(ig,l,iq)=pdq(ig,l,iq)+ zdqc(ig,l,iq) 1921 pdq(ig,l,iq)=pdq(ig,l,iq)+ zdqc(ig,l,iq) 1951 1922 ENDDO 1952 1923 ENDDO … … 1966 1937 ps(ig) = zplev(ig,1) + pdpsrf(ig)*ptimestep 1967 1938 ENDDO 1939 1968 1940 ! update pressure levels 1969 1941 DO l=1,nlayer … … 1974 1946 ENDDO 1975 1947 zplev(:,nlayer+1) = 0. 1948 1976 1949 ! update layers altitude 1977 1950 DO l=2,nlayer … … 1983 1956 ENDDO 1984 1957 #endif 1958 1985 1959 ENDIF ! of IF (callcond) 1986 1960 … … 1997 1971 ENDDO ! (iq) 1998 1972 ENDIF 1973 1999 1974 c----------------------------------------------------------------------- 2000 1975 c 12. Surface and sub-surface soil temperature … … 2099 2074 2100 2075 DO ig=1,ngrid 2101 watercap(ig)=watercap(ig)+ptimestep*dwatercap(ig) 2076 watercap(ig)=watercap(ig)+ptimestep*dwatercap(ig) 2102 2077 ENDDO 2103 2078 … … 2128 2103 ENDDO 2129 2104 2130 ! Density 2105 ! Density 2131 2106 DO l=1,nlayer 2132 2107 DO ig=1,ngrid … … 2143 2118 ENDDO 2144 2119 2145 ! Total mass of co22146 mtotco2 = 0.2147 icetotco2 = 0.2148 vaptotco2 = 0.2149 do ig=1,ngrid2150 do l=1,nlayer2151 vaptotco2 = vaptotco2 + zq(ig,l,igcm_co2) *2152 & (zplev(ig,l) - zplev(ig,l+1)) / g2153 icetotco2 = icetotco2 + zq(ig,l,igcm_co2_ice) *2154 & (zplev(ig,l) - zplev(ig,l+1)) / g2155 end do2156 mtotco2 = mtotco2 + co2ice(ig)2157 end do2158 mtotco2 = mtotco2 + vaptotco2 + icetotco22159 2120 2160 2121 c Compute surface stress : (NB: z0 is a common in surfdat.h) … … 2289 2250 . icount,' date=',ztime_fin 2290 2251 2291 2252 2292 2253 call physdem1("restartfi.nc",nsoilmx,ngrid,nlayer,nq, 2293 2254 . ptimestep,ztime_fin, … … 2306 2267 if (tracer) then 2307 2268 ! Density-scaled opacities 2308 do ig=1,ngrid 2309 dsodust(ig,:) = 2269 do ig=1,ngrid 2270 dsodust(ig,:) = 2310 2271 & dsodust(ig,:)*tauscaling(ig) 2311 dsords(ig,:) = 2272 dsords(ig,:) = 2312 2273 & dsords(ig,:)*tauscaling(ig) 2313 2274 dsotop(ig,:) = 2314 2275 & dsotop(ig,:)*tauscaling(ig) 2315 2276 enddo 2316 2277 2317 2278 if(doubleq) then 2318 2279 do ig=1,ngrid … … 2372 2333 & zq(ig,:,igcm_ccnco2_mass)*tauscaling(ig) 2373 2334 enddo 2335 c D. BARDET compute integrated CO2 vapor and ice content 2336 mtotco2(:)=0 2337 icetotco2(:)=0 2338 do ig=1,ngrid 2339 do l=1,nlayer 2340 mtotco2(ig) = mtotco2(ig) + 2341 & zq(ig,l,igcm_co2) * 2342 & (zplev(ig,l) - zplev(ig,l+1)) / g 2343 icetotco2(ig) = icetotco2(ig) + 2344 & zq(ig,l,igcm_co2_ice) * 2345 & (zplev(ig,l) - zplev(ig,l+1)) / g 2346 enddo 2347 enddo 2374 2348 endif ! of if (co2clouds) 2375 2349 … … 2385 2359 ENDIF !hdo 2386 2360 2387 do ig=1,ngrid 2361 do ig=1,ngrid 2388 2362 do l=1,nlayer 2389 2363 mtot(ig) = mtot(ig) + … … 2394 2368 & (zplev(ig,l) - zplev(ig,l+1)) / g 2395 2369 IF (hdo) then 2396 mtotD(ig) = mtotD(ig) + 2397 & zq(ig,l,igcm_hdo_vap) * 2370 mtotD(ig) = mtotD(ig) + 2371 & zq(ig,l,igcm_hdo_vap) * 2398 2372 & (zplev(ig,l) - zplev(ig,l+1)) / g 2399 icetotD(ig) = icetotD(ig) + 2400 & zq(ig,l,igcm_hdo_ice) * 2373 icetotD(ig) = icetotD(ig) + 2374 & zq(ig,l,igcm_hdo_ice) * 2401 2375 & (zplev(ig,l) - zplev(ig,l+1)) / g 2402 2376 ENDIF !hdo … … 2470 2444 2471 2445 endif ! of if (water) 2446 2447 2472 2448 endif ! of if (tracer) 2449 2473 2450 #ifndef MESOSCALE 2474 2451 c ----------------------------------------------------------------- … … 2849 2826 2850 2827 #else 2851 2852 call WRITEDIAGFI(ngrid,"tsurf","Surface temperature","K",2,2853 & tsurf)2854 call WRITEDIAGFI(ngrid,"ps","surface pressure","Pa",2,ps)2855 call WRITEDIAGFI(ngrid,"co2ice","co2 ice thickness","kg.m-2",2,2856 & co2ice)2857 call WRITEDIAGFI(ngrid,"temp","temperature","K",3,zt)2858 call WRITEDIAGFI(ngrid,"u","Zonal wind","m.s-1",3,zu)2859 call WRITEDIAGFI(ngrid,"v","Meridional wind","m.s-1",3,zv)2860 call WRITEDIAGFI(ngrid,"emis","Surface emissivity","w.m-1",2,2861 & emis)2862 call WRITEDIAGFI(ngrid,"tsoil","Soil temperature",2863 & "K",3,tsoil)2864 call WRITEDIAGFI(ngrid,"inertiedat","Soil inertia",2865 & "K",3,inertiedat)2828 !!! this is to ensure correct initialisation of mesoscale model 2829 call WRITEDIAGFI(ngrid,"tsurf","Surface temperature","K",2, 2830 & tsurf) 2831 call WRITEDIAGFI(ngrid,"ps","surface pressure","Pa",2,ps) 2832 call WRITEDIAGFI(ngrid,"co2ice","co2 ice thickness","kg.m-2",2, 2833 & co2ice) 2834 call WRITEDIAGFI(ngrid,"temp","temperature","K",3,zt) 2835 call WRITEDIAGFI(ngrid,"u","Zonal wind","m.s-1",3,zu) 2836 call WRITEDIAGFI(ngrid,"v","Meridional wind","m.s-1",3,zv) 2837 call WRITEDIAGFI(ngrid,"emis","Surface emissivity","w.m-1",2, 2838 & emis) 2839 call WRITEDIAGFI(ngrid,"tsoil","Soil temperature", 2840 & "K",3,tsoil) 2841 call WRITEDIAGFI(ngrid,"inertiedat","Soil inertia", 2842 & "K",3,inertiedat) 2866 2843 #endif 2844 2867 2845 2868 2846 c ---------------------------------------------------------- 2869 2847 c Outputs of the CO2 cycle 2870 2848 c ---------------------------------------------------------- 2871 2872 if (tracer.and.(igcm_co2.ne.0)) then 2873 ! call WRITEDIAGFI(ngrid,"co2_l1","co2 mix. ratio in 1st layer", 2874 ! & "kg/kg",2,zq(1,1,igcm_co2)) 2875 call WRITEDIAGFI(ngrid,"co2","co2 mass mixing ratio", 2876 & "kg/kg",3,zq(:,:,igcm_co2)) 2877 2878 if (co2clouds) then 2879 call WRITEDIAGFI(ngrid,'zdtcloudco2', 2880 & 'temperature variation of CO2 latent heat', 2881 & 'K/s',3,zdtcloudco2) 2849 2850 if (tracer.and.(igcm_co2.ne.0)) then 2851 ! call WRITEDIAGFI(ngrid,"co2_l1","co2 mix. ratio in 1st layer", 2852 ! & "kg/kg",2,zq(1,1,igcm_co2)) 2853 call WRITEDIAGFI(ngrid,"co2","co2 mass mixing ratio", 2854 & "kg/kg",3,zq(1,1,igcm_co2)) 2855 if (co2clouds) then 2856 CALL WRITEDIAGFI(ngrid,'mtotco2', 2857 & 'total mass of CO2 vapor', 2858 & 'kg/m2',2,mtotco2) 2859 CALL WRITEDIAGFI(ngrid,'zdtcloudco2', 2860 & 'temperature variation of CO2 latent heat', 2861 & 'K/s',3,zdtcloudco2) 2862 2863 CALL WRITEDIAGFI(ngrid,'icetotco2', 2864 & 'total mass of CO2 ice', 2865 & 'kg/m2',2,icetotco2) 2882 2866 2883 call WRITEDIAGFI(ngrid,'ccnqco2','CCNco2 mass mr', 2884 & 'kg/kg',3,qccnco2) 2885 2886 call WRITEDIAGFI(ngrid,'ccnNco2','CCNco2 number', 2887 & 'part/kg',3,nccnco2) 2888 2889 call WRITEDIAGFI(ngrid,'co2_ice','co2_ice','kg/kg', 2890 & 3,zq(:,:,igcm_co2_ice)) 2891 2892 call WRITEDIAGFI(ngrid,'precip_co2_ice', 2893 & 'surface deposition of co2 ice', 2894 & 'kg.m-2.s-1',2, 2895 & zdqssed(1:ngrid,igcm_co2_ice)) 2896 end if ! of if (co2clouds) 2897 end if ! of if (tracer.and.(igcm_co2.ne.0)) 2898 2899 ! Output He tracer, if there is one 2900 if (tracer.and.(igcm_he.ne.0)) then 2901 call WRITEDIAGFI(ngrid,"he","helium mass mixing ratio", 2902 & "kg/kg",3,zq(1,1,igcm_he)) 2903 vmr = zq(1:ngrid,1:nlayer,igcm_he) 2904 & * mmean(1:ngrid,1:nlayer)/mmol(igcm_he) 2905 call WRITEDIAGFI(ngrid,'vmr_he','helium vol. mixing ratio', 2906 & 'mol/mol',3,vmr) 2907 end if 2867 call WRITEDIAGFI(ngrid,'ccnqco2','CCNco2 mass mr', 2868 & 'kg/kg',3,qccnco2) 2869 call WRITEDIAGFI(ngrid,'ccnNco2','CCNco2 number', 2870 & 'part/kg',3,nccnco2) 2871 call WRITEDIAGFI(ngrid,'co2_ice','co2_ice','kg/kg', 2872 & 3,zq(:,:,igcm_co2_ice)) 2873 call WRITEDIAGFI(ngrid,'precip_co2_ice', 2874 & 'surface deposition of co2 ice', 2875 & 'kg.m-2.s-1',2, 2876 & zdqssed(1:ngrid,igcm_co2_ice)) 2877 endif ! of if (co2clouds) 2878 endif ! of if (tracer.and.(igcm_co2.ne.0)) 2879 ! Output He tracer, if there is one 2880 if (tracer.and.(igcm_he.ne.0)) then 2881 call WRITEDIAGFI(ngrid,"he","helium mass mixing ratio", 2882 & "kg/kg",3,zq(1,1,igcm_he)) 2883 vmr=zq(1:ngrid,1:nlayer,igcm_he) 2884 & *mmean(1:ngrid,1:nlayer)/mmol(igcm_he) 2885 call WRITEDIAGFI(ngrid,'vmr_he','helium vol. mixing ratio', 2886 & 'mol/mol',3,vmr) 2887 endif 2908 2888 2909 2889 c ---------------------------------------------------------- 2910 2890 c Outputs of the water cycle 2911 2891 c ---------------------------------------------------------- 2912 if (tracer) then 2913 if (water) then 2892 if (tracer) then 2893 if (water) then 2894 2914 2895 #ifdef MESOINI 2915 2896 !!!! waterice = q01, voir readmeteo.F90 2916 call WRITEDIAGFI(ngrid,'q01',noms(igcm_h2o_ice),2917 & 'kg/kg',3,2918 & zq(1:ngrid,1:nlayer,igcm_h2o_ice))2897 call WRITEDIAGFI(ngrid,'q01',noms(igcm_h2o_ice), 2898 & 'kg/kg',3, 2899 & zq(1:ngrid,1:nlayer,igcm_h2o_ice)) 2919 2900 !!!! watervapor = q02, voir readmeteo.F90 2920 call WRITEDIAGFI(ngrid,'q02',noms(igcm_h2o_vap),2921 & 'kg/kg',3,2922 & zq(1:ngrid,1:nlayer,igcm_h2o_vap))2901 call WRITEDIAGFI(ngrid,'q02',noms(igcm_h2o_vap), 2902 & 'kg/kg',3, 2903 & zq(1:ngrid,1:nlayer,igcm_h2o_vap)) 2923 2904 !!!! surface waterice qsurf02 (voir readmeteo) 2924 call WRITEDIAGFI(ngrid,'qsurf02','surface tracer',2925 & 'kg.m-2',2,2926 & qsurf(1:ngrid,igcm_h2o_ice))2905 call WRITEDIAGFI(ngrid,'qsurf02','surface tracer', 2906 & 'kg.m-2',2, 2907 & qsurf(1:ngrid,igcm_h2o_ice)) 2927 2908 #endif 2928 call WRITEDIAGFI(ngrid,'mtot', 2929 & 'total mass of water vapor', 2930 & 'kg/m2',2,mtot) 2931 call WRITEDIAGFI(ngrid,'icetot', 2932 & 'total mass of water ice', 2933 & 'kg/m2',2,icetot) 2934 vmr = zq(1:ngrid,1:nlayer,igcm_h2o_ice) 2935 & * mmean(1:ngrid,1:nlayer)/mmol(igcm_h2o_ice) 2936 call WRITEDIAGFI(ngrid,'vmr_h2oice','h2o ice vmr', 2937 & 'mol/mol',3,vmr) 2938 vmr = zq(1:ngrid,1:nlayer,igcm_h2o_vap) 2939 & * mmean(1:ngrid,1:nlayer)/mmol(igcm_h2o_vap) 2940 call WRITEDIAGFI(ngrid,'vmr_h2ovap','h2o vap vmr', 2941 & 'mol/mol',3,vmr) 2942 call WRITEDIAGFI(ngrid,'reffice', 2943 & 'Mean reff', 2944 & 'm',2,rave) 2945 call WRITEDIAGFI(ngrid,'h2o_ice','h2o_ice','kg/kg', 2946 & 3,zq(:,:,igcm_h2o_ice)) 2947 call WRITEDIAGFI(ngrid,'h2o_vap','h2o_vap','kg/kg', 2948 & 3,zq(:,:,igcm_h2o_vap)) 2909 CALL WRITEDIAGFI(ngrid,'mtot', 2910 & 'total mass of water vapor', 2911 & 'kg/m2',2,mtot) 2912 CALL WRITEDIAGFI(ngrid,'icetot', 2913 & 'total mass of water ice', 2914 & 'kg/m2',2,icetot) 2915 vmr=zq(1:ngrid,1:nlayer,igcm_h2o_ice) 2916 & *mmean(1:ngrid,1:nlayer)/mmol(igcm_h2o_ice) 2917 CALL WRITEDIAGFI(ngrid,'vmr_h2oice','h2o ice vmr', 2918 & 'mol/mol',3,vmr) 2919 vmr=zq(1:ngrid,1:nlayer,igcm_h2o_vap) 2920 & *mmean(1:ngrid,1:nlayer)/mmol(igcm_h2o_vap) 2921 CALL WRITEDIAGFI(ngrid,'vmr_h2ovap','h2o vap vmr', 2922 & 'mol/mol',3,vmr) 2923 CALL WRITEDIAGFI(ngrid,'reffice', 2924 & 'Mean reff', 2925 & 'm',2,rave) 2926 2927 call WRITEDIAGFI(ngrid,'h2o_ice','h2o_ice','kg/kg', 2928 & 3,zq(:,:,igcm_h2o_ice)) 2929 call WRITEDIAGFI(ngrid,'h2o_vap','h2o_vap','kg/kg', 2930 & 3,zq(:,:,igcm_h2o_vap)) 2949 2931 2950 2932 if (hdo) then … … 2972 2954 do l=1,nlayer 2973 2955 do ig=1,ngrid 2974 if (zq(ig,l,igcm_h2o_vap).gt.qperemin) then 2956 if (zq(ig,l,igcm_h2o_vap).gt.qperemin) then 2975 2957 DoH_vap(ig,l) = ( zq(ig,l,igcm_hdo_vap)/ 2976 2958 & zq(ig,l,igcm_h2o_vap) )*1./(2.*155.76e-6) … … 2994 2976 CALL WRITEDIAGFI(ngrid,'DoH_vap', 2995 2977 & 'D/H ratio in vapor', 2996 & ' ',3,DoH_vap) 2978 & ' ',3,DoH_vap) 2997 2979 CALL WRITEDIAGFI(ngrid,'DoH_ice', 2998 2980 & 'D/H ratio in ice', … … 3051 3033 endif 3052 3034 !A. Pottier 3053 if (CLFvarying) then !AP14 nebulosity3054 call WRITEDIAGFI(ngrid,'totcloudfrac',3055 & 3035 if (CLFvarying) then !AP14 nebulosity 3036 call WRITEDIAGFI(ngrid,'totcloudfrac', 3037 & 'Total cloud fraction', 3056 3038 & ' ',2,totcloudfrac) 3057 end if !clf varying 3058 end if !(water) 3059 3060 if (water.and..not.photochem) then 3061 iq = nq 3062 c write(str2(1:2),'(i2.2)') iq 3063 c call WRITEDIAGFI(ngrid,'dqs'//str2,'dqscloud', 3064 c & 'kg.m-2',2,zdqscloud(1,iq)) 3065 c call WRITEDIAGFI(ngrid,'dqch'//str2,'var chim', 3066 c & 'kg/kg',3,zdqchim(1,1,iq)) 3067 c call WRITEDIAGFI(ngrid,'dqd'//str2,'var dif', 3068 c & 'kg/kg',3,zdqdif(1,1,iq)) 3069 c call WRITEDIAGFI(ngrid,'dqa'//str2,'var adj', 3070 c & 'kg/kg',3,zdqadj(1,1,iq)) 3071 c call WRITEDIAGFI(ngrid,'dqc'//str2,'var c', 3072 c & 'kg/kg',3,zdqc(1,1,iq)) 3073 end if !(water.and..not.photochem) 3074 end if !tracer 3039 endif !clf varying 3040 3041 endif !(water) 3042 3043 3044 if (water.and..not.photochem) then 3045 iq=nq 3046 c write(str2(1:2),'(i2.2)') iq 3047 c call WRITEDIAGFI(ngrid,'dqs'//str2,'dqscloud', 3048 c & 'kg.m-2',2,zdqscloud(1,iq)) 3049 c call WRITEDIAGFI(ngrid,'dqch'//str2,'var chim', 3050 c & 'kg/kg',3,zdqchim(1,1,iq)) 3051 c call WRITEDIAGFI(ngrid,'dqd'//str2,'var dif', 3052 c & 'kg/kg',3,zdqdif(1,1,iq)) 3053 c call WRITEDIAGFI(ngrid,'dqa'//str2,'var adj', 3054 c & 'kg/kg',3,zdqadj(1,1,iq)) 3055 c call WRITEDIAGFI(ngrid,'dqc'//str2,'var c', 3056 c & 'kg/kg',3,zdqc(1,1,iq)) 3057 endif !(water.and..not.photochem) 3058 endif 3075 3059 3076 3060 c ---------------------------------------------------------- … … 3078 3062 c ---------------------------------------------------------- 3079 3063 3080 call WRITEDIAGFI(ngrid,'tauref',3081 & 'Dust ref opt depth','NU',2,tauref)3082 3083 if (tracer.and.(dustbin.ne.0)) then3084 3085 call WRITEDIAGFI(ngrid,'tau','taudust','SI',2,tau(1,1))3064 call WRITEDIAGFI(ngrid,'tauref', 3065 & 'Dust ref opt depth','NU',2,tauref) 3066 3067 if (tracer.and.(dustbin.ne.0)) then 3068 3069 call WRITEDIAGFI(ngrid,'tau','taudust','SI',2,tau(1,1)) 3086 3070 3087 3071 #ifndef MESOINI … … 3113 3097 call WRITEDIAGFI(ngrid,'dustN','Dust number', 3114 3098 & 'part/kg',3,ndust) 3115 3099 3116 3100 select case (trim(dustiropacity)) 3117 3101 case ("tes") … … 3186 3170 call WRITEDIAGFI(ngrid,'totaldustq','total dust mass', 3187 3171 & 'kg/kg',3,qdusttotal) 3188 3172 3189 3173 select case (trim(dustiropacity)) 3190 3174 case ("tes") … … 3211 3195 end select 3212 3196 endif ! (slpwind) 3213 3197 3214 3198 if (scavenging) then 3215 3199 call WRITEDIAGFI(ngrid,'ccnq','CCN mass mr', … … 3277 3261 c ---------------------------------------------------------- 3278 3262 3279 if(callthermos) then 3263 if(callthermos) then 3280 3264 3281 3265 call WRITEDIAGFI(ngrid,"q15um","15 um cooling","K/s", … … 3299 3283 endif !(callthermos) 3300 3284 3301 call WRITEDIAGFI(ngrid,"q15um","15 um cooling","K/s",3302 $ 3,zdtnlte)3303 call WRITEDIAGFI(ngrid,"quv","UV heating","K/s",3304 $ 3,zdteuv)3305 call WRITEDIAGFI(ngrid,"cond","Thermal conduction","K/s",3306 $ 3,zdtconduc)3307 call WRITEDIAGFI(ngrid,"qnir","NIR heating","K/s",3308 $ 3,zdtnirco2)3309 3310 3285 c ---------------------------------------------------------- 3311 3286 c ---------------------------------------------------------- … … 3317 3292 c Outputs of thermals 3318 3293 c ---------------------------------------------------------- 3319 if (calltherm) then 3294 if (calltherm) then 3295 3320 3296 ! call WRITEDIAGFI(ngrid,'dtke', 3321 ! & 3322 ! & 3,dtke_th)3297 ! & 'tendance tke thermiques','m**2/s**2', 3298 ! & 3,dtke_th) 3323 3299 ! call WRITEDIAGFI(ngrid,'d_u_ajs', 3324 ! & 3325 ! & 3,pdu_th*ptimestep)3300 ! & 'tendance u thermiques','m/s', 3301 ! & 3,pdu_th*ptimestep) 3326 3302 ! call WRITEDIAGFI(ngrid,'d_v_ajs', 3327 ! & 3328 ! & 3,pdv_th*ptimestep)3303 ! & 'tendance v thermiques','m/s', 3304 ! & 3,pdv_th*ptimestep) 3329 3305 ! if (tracer) then 3330 ! 3331 ! 3332 ! & 3333 ! & 3,ptimestep*pdq_th(:,:,2))3334 ! endif3335 ! end 3306 ! if (nq .eq. 2) then 3307 ! call WRITEDIAGFI(ngrid,'deltaq_th', 3308 ! & 'delta q thermiques','kg/kg', 3309 ! & 3,ptimestep*pdq_th(:,:,2)) 3310 ! endif 3311 ! endif 3336 3312 3337 3313 call WRITEDIAGFI(ngrid,'zmax_th', 3338 & 3339 & 2,zmax_th)3314 & 'hauteur du thermique','m', 3315 & 2,zmax_th) 3340 3316 call WRITEDIAGFI(ngrid,'hfmax_th', 3341 & 3342 & 2,hfmax_th)3317 & 'maximum TH heat flux','K.m/s', 3318 & 2,hfmax_th) 3343 3319 call WRITEDIAGFI(ngrid,'wstar', 3344 & 'maximum TH vertical velocity','m/s', 3345 & 2,wstar) 3346 end if 3320 & 'maximum TH vertical velocity','m/s', 3321 & 2,wstar) 3322 3323 endif 3347 3324 3348 3325 c ---------------------------------------------------------- … … 3382 3359 c 3383 3360 c CALL writeg1d(ngrid,1,fluxsurf_lw,'Fs_ir','W.m-2') 3384 c CALL writeg1d(ngrid,1,tsurf,'tsurf','K') 3385 c CALL writeg1d(ngrid,1,ps,'ps','Pa') 3386 c CALL writeg1d(ngrid,nlayer,zt,'T','K') 3361 c CALL writeg1d(ngrid,1,tsurf,'tsurf','K') 3362 c CALL writeg1d(ngrid,1,ps,'ps','Pa') 3363 3364 c CALL writeg1d(ngrid,nlayer,zt,'T','K') 3387 3365 c CALL writeg1d(ngrid,nlayer,pu,'u','m.s-1') 3388 3366 c CALL writeg1d(ngrid,nlayer,pv,'v','m.s-1') … … 3405 3383 & 0,wstar) 3406 3384 3407 end if ! of if (calltherm) 3408 3409 call WRITEDIAGFI(ngrid,'w','vertical velocity' 3385 co2col(:)=0. 3386 if (tracer) then 3387 do l=1,nlayer 3388 do ig=1,ngrid 3389 co2col(ig)=co2col(ig)+ 3390 & zq(ig,l,1)*(zplev(ig,l)-zplev(ig,l+1))/g 3391 enddo 3392 enddo 3393 3394 end if 3395 call WRITEDIAGFI(ngrid,'co2col','integrated co2 mass' & 3396 & ,'kg/m-2',0,co2col) 3397 endif ! of if (calltherm) 3398 3399 call WRITEDIAGFI(ngrid,'w','vertical velocity' & 3410 3400 & ,'m/s',1,pw) 3411 3401 call WRITEDIAGFI(ngrid,"q2","q2","kg.m-3",1,q2) … … 3418 3408 call WRITEDIAGFI(ngrid,"pplev","Pressure","Pa",1,zplev) 3419 3409 call WRITEDIAGFI(ngrid,"rho","rho","kg.m-3",1,rho) 3420 call WRITEDIAGFI(ngrid,"dtrad","rad. heat. rate", 3410 call WRITEDIAGFI(ngrid,"dtrad","rad. heat. rate", & 3421 3411 & "K.s-1",1,dtrad) 3422 3412 call WRITEDIAGFI(ngrid,'sw_htrt','sw heat. rate', 3423 3413 & 'w.m-2',1,zdtsw) 3424 3414 call WRITEDIAGFI(ngrid,'lw_htrt','lw heat. rate', 3425 3415 & 'w.m-2',1,zdtlw) 3426 3416 call WRITEDIAGFI(ngrid,"co2ice","co2 ice thickness" … … 3428 3418 3429 3419 if (igcm_co2.ne.0) then 3430 call co2sat(ngrid*nlayer,zt,z qsatco2)3420 call co2sat(ngrid*nlayer,zt,zplay,zqsatco2) 3431 3421 do ig=1,ngrid 3432 3422 do l=1,nlayer … … 3447 3437 c call WRITEDIAGFI(ngrid,"satuco2","vap in satu","kg/kg",1, 3448 3438 c & satuco2) 3449 c call WRITE DIAGFI(ngrid,"riceco2","ice radius","m"3439 c call WRITEdiagfi(ngrid,"riceco2","ice radius","m" 3450 3440 c & ,1,riceco2) 3451 3441 ! or output in diagfi.nc (for testphys1d) … … 3566 3556 & * (zplev(1,l) - zplev(1,l+1)) / g 3567 3557 if (hdo) THEN 3568 mtotD = mtotD + zq(1,l,igcm_hdo_vap) 3558 mtotD = mtotD + zq(1,l,igcm_hdo_vap) 3569 3559 & * (zplev(1,l) - zplev(1,l+1)) / g 3570 icetotD = icetotD + zq(1,l,igcm_hdo_ice) 3560 icetotD = icetotD + zq(1,l,igcm_hdo_ice) 3571 3561 & * (zplev(1,l) - zplev(1,l+1)) / g 3572 3562 ENDIF !hdo … … 3576 3566 hdotot = hdotot+mtotD+icetotD 3577 3567 ENDIF ! hdo 3578 3568 3579 3569 3580 3570 CALL WRITEDIAGFI(ngrid,'h2otot', … … 3620 3610 CALL WRITEDIAGFI(ngrid,'DoH_vap', 3621 3611 & 'D/H ratio in vapor', 3622 & ' ',1,DoH_vap) 3612 & ' ',1,DoH_vap) 3623 3613 CALL WRITEDIAGFI(ngrid,'DoH_ice', 3624 3614 & 'D/H ratio in ice', … … 3715 3705 3716 3706 ENDIF ! hdo 3717 3707 3718 3708 call WRITEDIAGFI(ngrid,"rice","ice radius","m",1, 3719 3709 & rice) … … 3725 3715 endif !clfvarying 3726 3716 3727 ENDIF ! of IF (water) 3728 3729 3730 ! co2clouds 3731 if (co2clouds) then 3732 call WRITEDIAGFI(ngrid,'mtotco2', 3733 & 'total mass of CO2, including ice surf', 3734 & 'kg/m2',0,mtotco2) 3735 3736 call WRITEDIAGFI(ngrid,'vaptotco2', 3737 & 'total mass of CO2 vapor', 3738 & 'kg/m2',0,vaptotco2) 3739 3740 call WRITEDIAGFI(ngrid,'zdtcloudco2', 3741 & 'temperature variation of CO2 latent heat', 3742 & 'K/s',3,zdtcloudco2) 3743 3744 call WRITEDIAGFI(ngrid,'icetotco2', 3745 & 'total mass of CO2 ice', 3746 & 'kg/m2',0,icetotco2) 3747 end if 3717 ENDIF ! of IF (water) 3748 3718 3749 3719 ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc 3750 3720 ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc 3721 3751 3722 3752 3723 zlocal(1)=-log(zplay(1,1)/zplev(1,1))* Rnew(1,1)*zt(1,1)/g … … 3765 3736 3766 3737 END IF ! if(ngrid.ne.1) 3767 3768 co2totB = 0. ! added by C.M.3769 do ig=1,ngrid3770 do l=1,nlayer3771 co2totB = co2totB + (zplev(ig,l)-zplev(ig,l+1))/g*3772 & (pq(ig,l,igcm_co2)+pq(ig,l,igcm_co2_ice)3773 & +(pdq(ig,l,igcm_co2)+pdq(ig,l,igcm_co2_ice))*ptimestep)3774 enddo3775 co2totB = co2totB + co2ice(ig)3776 enddo3777 3778 call WRITEDIAGFI(ngrid,'co2conservation',3779 & 'Total CO2 mass conservation in physic',3780 & '%',0,(co2totA-co2totB)/co2totA)3781 call test_vmr(pq(:,:,igcm_co2), pdq(:,:,igcm_co2), ptimestep,3782 & ngrid, nlayer, 'end physiq_mod')3783 3738 3784 3739 ! XIOS outputs -
trunk/LMDZ.MARS/libf/phymars/tcondco2.F90
r2342 r2343 8 8 ! Condensation temperature for co2 ice; based on 9 9 ! the saturation in co2sat.F JA17 10 !-------------------------------------------------- 10 !--------------------------------------------------i 11 11 12 12 integer, intent(in) :: ngrid,nlay … … 14 14 double precision, intent(out), dimension(ngrid,nlay):: tcond ! CO2 condensation temperature (atm) 15 15 double precision:: A,B,pco2 16 real :: qco217 16 integer:: ig,l 18 17 19 18 A=dlog(1.382d12) 20 19 B=-3182.48 21 qco2=0. 20 22 21 DO l=1,nlay 23 22 DO ig=1,ngrid
Note: See TracChangeset
for help on using the changeset viewer.