Changeset 1648 for trunk/LMDZ.TITAN/libf/phytitan
- Timestamp:
- Jan 19, 2017, 2:46:53 PM (8 years ago)
- Location:
- trunk/LMDZ.TITAN/libf/phytitan
- Files:
-
- 4 added
- 15 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.TITAN/libf/phytitan/calc_cpp_mugaz.F90
r1647 r1648 34 34 do igas=1,ngasmx 35 35 36 if(igas.eq.vgas)then 37 ! ignore variable gas in cpp calculation 36 ! all values at 300 K from Engineering Toolbox 37 if(igas.eq.igas_N2)then 38 mugaz_c = mugaz_c + 28.01*gfrac(igas,nivref) 39 elseif(igas.eq.igas_H2)then 40 mugaz_c = mugaz_c + 2.01*gfrac(igas,nivref) 41 elseif(igas.eq.igas_CH4)then 42 mugaz_c = mugaz_c + 16.04*gfrac(igas,nivref) 38 43 else 39 ! all values at 300 K from Engineering Toolbox 40 if(igas.eq.igas_N2)then 41 mugaz_c = mugaz_c + 28.01*gfrac(igas) 42 elseif(igas.eq.igas_H2)then 43 mugaz_c = mugaz_c + 2.01*gfrac(igas) 44 elseif(igas.eq.igas_CH4)then 45 mugaz_c = mugaz_c + 16.04*gfrac(igas) 46 elseif(igas.eq.igas_C2H6)then 47 ! C2H6 http://encyclopedia.airliquide.com/Encyclopedia.asp?GasID=28 48 mugaz_c = mugaz_c + 30.07*gfrac(igas) 49 elseif(igas.eq.igas_C2H2)then 50 ! C2H2 http://encyclopedia.airliquide.com/Encyclopedia.asp?GasID=1 51 mugaz_c = mugaz_c + 26.04*gfrac(igas) 52 else 53 print*,'Error in calc_cpp_mugaz: Gas species not recognised!' 54 call abort 55 endif 44 print*,'Error in calc_cpp_mugaz: Gas species not recognised!' 45 call abort 56 46 endif 57 58 47 enddo 59 48 … … 61 50 do igas=1,ngasmx 62 51 63 if(igas.eq.vgas)then 64 ! ignore variable gas in cpp calculation 52 ! all values at 300 K from Engineering Toolbox 53 if(igas.eq.igas_N2)then 54 cpp_c = cpp_c + 1.040*gfrac(igas,nivref)*28.01/mugaz_c 55 elseif(igas.eq.igas_H2)then 56 cpp_c = cpp_c + 14.31*gfrac(igas,nivref)*2.01/mugaz_c 57 elseif(igas.eq.igas_CH4)then 58 cpp_c = cpp_c + 2.226*gfrac(igas,nivref)*16.04/mugaz_c 65 59 else 66 ! all values at 300 K from Engineering Toolbox 67 if(igas.eq.igas_N2)then 68 cpp_c = cpp_c + 1.040*gfrac(igas)*28.01/mugaz_c 69 elseif(igas.eq.igas_H2)then 70 cpp_c = cpp_c + 14.31*gfrac(igas)*2.01/mugaz_c 71 elseif(igas.eq.igas_CH4)then 72 cpp_c = cpp_c + 2.226*gfrac(igas)*16.04/mugaz_c 73 elseif(igas.eq.igas_C2H6)then 74 ! C2H6 75 ! http://encyclopedia.airliquide.com/Encyclopedia.asp?GasID=28 76 cpp_c = cpp_c + 1.763*gfrac(igas)*30.07/mugaz_c 77 elseif(igas.eq.igas_C2H2)then 78 ! C2H2 79 ! http://encyclopedia.airliquide.com/Encyclopedia.asp?GasID=1 80 cpp_c = cpp_c + 1.575*gfrac(igas)*26.04/mugaz_c 81 else 82 print*,'Error in calc_cpp_mugaz: Gas species not recognised!' 83 call abort 84 endif 60 print*,'Error in calc_cpp_mugaz: Gas species not recognised!' 61 call abort 85 62 endif 86 87 63 enddo 88 89 90 91 92 64 93 65 cpp_c = 1000.0*cpp_c -
trunk/LMDZ.TITAN/libf/phytitan/calc_rayleigh.F90
r1647 r1648 26 26 27 27 use radinc_h, only: L_NSPECTV 28 use radcommon_h, only: WAVEV, BWNV, DWNV, tstellar, tauray, taurayvar,scalep28 use radcommon_h, only: WAVEV, BWNV, DWNV, tstellar, tauray, scalep 29 29 use gases_h 30 30 use comcstfi_mod, only: g, mugaz … … 38 38 39 39 logical typeknown 40 real*8 tauvar,tau varvar,tausum,tausumvar,tauwei,tauweivar,bwidth,bstart40 real*8 tauvar,tausum,tauwei,bwidth,bstart 41 41 double precision df 42 42 … … 52 52 typeknown=.false. 53 53 do igas=1,ngasmx 54 if(igas.eq.vgas)then 55 print*,'variable gas is ',trim(gnom(igas)),' in Rayleigh scattering ' 56 endif 57 if((igas/=vgas).and.(gfrac(igas).lt.5.e-2))then 54 if(gfrac(igas,nivref).lt.5.e-2)then 58 55 print*,'Ignoring ',trim(gnom(igas)),' in Rayleigh scattering '// & 59 56 'as its mixing ratio is less than 0.05.' … … 74 71 endif 75 72 76 if( (gfrac(igas).eq.1.0).and.(vgas.eq.0))then73 if(gfrac(igas,nivref).eq.1.0)then 77 74 print*,'Rayleigh scattering is for a pure ',trim(gnom(igas)),' atmosphere.' 78 75 typeknown=.true. … … 92 89 tausum = 0.0 93 90 tauwei = 0.0 94 tausumvar = 0.095 tauweivar = 0.096 91 bstart = 10000.0/BWNV(N+1) 97 92 bwidth = (10000.0/BWNV(N)) - (10000.0/BWNV(N+1)) … … 100 95 101 96 tauvar=0.0 102 tauvarvar=0.0103 97 do igas=1,ngasmx 104 if( (igas/=vgas).and.(gfrac(igas).lt.5.e-2))then98 if(gfrac(igas,nivref).lt.5.e-2)then 105 99 ! ignore variable gas in Rayleigh calculation 106 100 ! ignore gases of mixing ratio < 0.05 in Rayleigh calculation … … 117 111 endif 118 112 119 if(igas.eq.vgas) then 120 tauvarvar=tauvarvar+tauconsti(igas)*tauvari(igas) 121 tauvar=tauvar+0.0*0.0*gfrac(igas) 122 else 123 tauvar=tauvar+tauconsti(igas)*tauvari(igas)*gfrac(igas) 124 endif 113 tauvar=tauvar+tauconsti(igas)*tauvari(igas)*gfrac(igas,nivref) 125 114 126 115 enddo … … 130 119 tauwei=tauwei+df 131 120 tausum=tausum+tauvar*df 132 tauweivar=tauweivar+df133 tausumvar=tausumvar+tauvarvar*df134 121 135 122 enddo 136 123 TAURAY(N)=tausum/tauwei 137 TAURAYVAR(N)=tausumvar/tauweivar138 124 ! we multiply by scalep here (100) because plev, which is used in optcv, 139 125 ! is in units of mBar, so we need to convert. -
trunk/LMDZ.TITAN/libf/phytitan/callcorrk.F90
r1647 r1648 1 1 subroutine callcorrk(ngrid,nlayer,pq,nq,qsurf, & 2 2 albedo,albedo_equivalent,emis,mu0,pplev,pplay,pt, & 3 tsurf,fract,dist_star,aerosol, muvar,&3 tsurf,fract,dist_star,aerosol, & 4 4 dtlw,dtsw,fluxsurf_lw, & 5 5 fluxsurf_sw,fluxsurfabs_sw,fluxtop_lw, & … … 17 17 USE tracer_h 18 18 use comcstfi_mod, only: pi, mugaz, cpp 19 use callkeys_mod, only: diurnal,tracer,nosurf, satval,&19 use callkeys_mod, only: diurnal,tracer,nosurf, & 20 20 strictboundcorrk,specOLR 21 21 … … 59 59 REAL,INTENT(IN) :: fract(ngrid) ! Fraction of day. 60 60 REAL,INTENT(IN) :: dist_star ! Distance star-planet (AU). 61 REAL,INTENT(IN) :: muvar(ngrid,nlayer+1)62 61 logical,intent(in) :: firstcall ! Signals first call to physics. 63 62 logical,intent(in) :: lastcall ! Signals last call to physics. … … 133 132 real*8 taugsurf(L_NSPECTV,L_NGAUSS-1) 134 133 real*8 taugsurfi(L_NSPECTI,L_NGAUSS-1) 135 real*8 qvar(L_LEVELS) ! Mixing ratio of variable component (mol/mol).136 134 137 135 ! Local aerosol optical properties for each column on RADIATIVE grid. … … 153 151 character(len=10) :: tmp2 154 152 155 ! For fixed water vapour profiles.156 integer i_var157 real RH158 real*8 pq_temp(nlayer)159 ! real(KIND=r8) :: pq_temp(nlayer) ! better F90 way.. DOESNT PORT TO F77!!!160 real ptemp, Ttemp, qsat161 162 153 logical OLRz 163 154 real*8 NFLUXGNDV_nu(L_NSPECTV) 164 165 ! Included by RW for runaway greenhouse 1D study. 166 real vtmp(nlayer) 167 REAL*8 muvarrad(L_LEVELS) 168 155 169 156 ! Included by MT for albedo calculations. 170 157 REAL*8 albedo_temp(L_NSPECTV) ! For equivalent albedo calculation. … … 459 446 else 460 447 acosz=mu0(ig) ! Cosine of sun incident angle : 3D simulations or local 1D simulations using latitude. 461 endif462 463 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!464 !!! Note by JL13 : In the following, some indices were changed in the interpolations,465 !!! so that the model results are less dependent on the number of layers !466 !!!467 !!! --- The older versions are commented with the comment !JL13index ---468 !!!469 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!470 471 472 do k=1,L_LEVELS473 qvar(k) = 1.0D-7474 end do475 476 477 ! IMPORTANT: Now convert from kg/kg to mol/mol.478 ! do k=1,L_LEVELS479 ! qvar(k) = qvar(k)/(epsi+qvar(k)*(1.-epsi))480 ! end do481 482 DO l=1,nlayer483 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)))/2485 END DO486 487 muvarrad(1) = muvarrad(2)488 muvarrad(2*nlayer+1)=muvar(ig,1)489 490 ! Keep values inside limits for which we have radiative transfer coefficients !!!491 if(L_REFVAR.gt.1)then ! (there was a bug here)492 do k=1,L_LEVELS493 if(qvar(k).lt.wrefvar(1))then494 qvar(k)=wrefvar(1)+1.0e-8495 elseif(qvar(k).gt.wrefvar(L_REFVAR))then496 qvar(k)=wrefvar(L_REFVAR)-1.0e-8497 endif498 end do499 448 endif 500 449 … … 574 523 endif 575 524 elseif(tlevrad(k).gt.tgasmax)then 576 print*,'Maximum temperature is outside the radiative'577 print*,'transfer kmatrix bounds, exiting.'578 print*,"k=",k," tlevrad(k)=",tlevrad(k)579 print*,"tgasmax=",tgasmax525 ! print*,'Maximum temperature is outside the radiative' 526 ! print*,'transfer kmatrix bounds, exiting.' 527 ! print*,"k=",k," tlevrad(k)=",tlevrad(k) 528 ! print*,"tgasmax=",tgasmax 580 529 if (strictboundcorrk) then 581 530 call abort 582 531 else 583 print*,'***********************************************'584 print*,'we allow model to continue with tlevrad=tgasmax'585 print*,' ... we assume we know what you are doing ... '586 print*,' ... but do not let this happen too often ... '587 print*,'***********************************************'532 ! print*,'***********************************************' 533 ! print*,'we allow model to continue with tlevrad=tgasmax' 534 ! print*,' ... we assume we know what you are doing ... ' 535 ! print*,' ... but do not let this happen too often ... ' 536 ! print*,'***********************************************' 588 537 !tlevrad(k)=tgasmax 589 538 endif … … 607 556 endif 608 557 elseif(tmid(k).gt.tgasmax)then 609 print*,'Maximum temperature is outside the radiative'610 print*,'transfer kmatrix bounds, exiting.'611 print*,"k=",k," tmid(k)=",tmid(k)612 print*,"tgasmax=",tgasmax558 ! print*,'Maximum temperature is outside the radiative' 559 ! print*,'transfer kmatrix bounds, exiting.' 560 ! print*,"k=",k," tmid(k)=",tmid(k) 561 ! print*,"tgasmax=",tgasmax 613 562 if (strictboundcorrk) then 614 563 call abort 615 564 else 616 print*,'***********************************************'617 print*,'we allow model to continue with tmid=tgasmin'618 print*,' ... we assume we know what you are doing ... '619 print*,' ... but do not let this happen too often ... '620 print*,'***********************************************'565 ! print*,'***********************************************' 566 ! print*,'we allow model to continue with tmid=tgasmin' 567 ! print*,' ... we assume we know what you are doing ... ' 568 ! print*,' ... but do not let this happen too often ... ' 569 ! print*,'***********************************************' 621 570 tmid(k)=tgasmax 622 571 endif … … 649 598 call optcv(dtauv,tauv,taucumv,plevrad, & 650 599 qxvaer,qsvaer,gvaer,wbarv,cosbv,tauray,tauaero, & 651 tmid,pmid,taugsurf, qvar,muvarrad)600 tmid,pmid,taugsurf,gweight) 652 601 653 602 call sfluxv(dtauv,tauv,taucumv,albv,dwnv,wbarv,cosbv, & … … 692 641 call optci(plevrad,tlevrad,dtaui,taucumi, & 693 642 qxiaer,qsiaer,giaer,cosbi,wbari,tauaero,tmid,pmid, & 694 taugsurfi, qvar,muvarrad)643 taugsurfi,gweight) 695 644 696 645 call sfluxi(plevrad,tlevrad,dtaui,taucumi,ubari,albi, & … … 813 762 IF( ALLOCATED( pgasref ) ) DEALLOCATE( pgasref ) 814 763 IF( ALLOCATED( tgasref ) ) DEALLOCATE( tgasref ) 815 IF( ALLOCATED( wrefvar ) ) DEALLOCATE( wrefvar )816 764 IF( ALLOCATED( pfgasref ) ) DEALLOCATE( pfgasref ) 817 765 !$OMP END MASTER -
trunk/LMDZ.TITAN/libf/phytitan/callkeys_mod.F90
r1647 r1648 60 60 real,save :: size_tropo 61 61 real,save :: size_strato 62 real,save :: satval 63 !$OMP THREADPRIVATE(size_tropo,size_strato,satval) 62 !$OMP THREADPRIVATE(size_tropo,size_strato) 64 63 real,save :: pceil 65 64 !$OMP THREADPRIVATE(pceil) -
trunk/LMDZ.TITAN/libf/phytitan/gases_h.F90
r1647 r1648 3 3 implicit none 4 4 5 !====================================================================== C5 !============================================================================================C 6 6 ! 7 7 ! gases_h 8 8 ! 9 ! A F90-allocatable version for gases.h -- AS 12/20119 ! * A F90-allocatable version for gases.h -- AS 12/2011 10 10 ! 11 !======================================================================C 11 ! * Titan's version : J. Vatant d'Ollone (2017) 12 ! * gfrac is now 2D (altitude-dependent for the CIA-calculations) 13 ! * Reference level (nivref) is added for the cpp_mu and rayleigh routines 14 !===========================================================================================C 12 15 13 16 ! Set and allocated in su_gases.F90 14 17 integer :: ngasmx 15 integer :: vgas16 character*20,allocatable,DIMENSION(:) :: gnom ! name of the gas, readby master17 real,allocatable,DIMENSION(: ) :: gfrac18 integer :: nivref 19 character*20,allocatable,DIMENSION(:) :: gnom ! name of the gas, set by master 20 real,allocatable,DIMENSION(:,:) :: gfrac 18 21 19 22 ! in analogy with tracer.h ... 20 integer :: igas_H223 21 24 integer :: igas_N2 22 25 integer :: igas_CH4 23 integer :: igas_ C2H224 integer :: igas_C2H625 !!$OMP THREADPRIVATE(ngasmx, vgas,gnom,gfrac,&26 ! !$OMP igas_H2,igas_N2,igas_CH4 ,igas_C2H2,igas_C2H6)26 integer :: igas_H2 27 28 !!$OMP THREADPRIVATE(ngasmx,nivref,gnom,gfrac,& 29 ! !$OMP igas_H2,igas_N2,igas_CH4) 27 30 28 31 end module gases_h -
trunk/LMDZ.TITAN/libf/phytitan/inifis_mod.F90
r1647 r1648 439 439 440 440 !================================= 441 442 write(*,*)"What is the saturation % of the variable species?"443 satval=0.8444 call getin_p("satval",satval)445 write(*,*)" satval = ",satval446 441 447 442 write(*,*) "Gravitationnal sedimentation ?" … … 477 472 ! mugaz=8.314*1000./pr 478 473 endif ! of if (force_cpp) 479 call su_gases 474 475 476 call su_gases(nlayer,tracer) 480 477 call calc_cpp_mugaz 481 478 479 482 480 PRINT*,'--------------------------------------------' 483 481 PRINT* … … 519 517 ENDDO 520 518 521 ! initialize variables in radinc_h522 519 call ini_radinc_h(nlayer) 523 520 -
trunk/LMDZ.TITAN/libf/phytitan/interpolateN2N2.F90
r1315 r1648 78 78 write(*,*) 'is correct. You can change it in callphys.def with:' 79 79 write(*,*) 'datadir = /absolute/path/to/datagcm' 80 write(*,*) 'Also check that the continuum data continuum_data/N2-N2_ norm_2011.cia is there.'80 write(*,*) 'Also check that the continuum data continuum_data/N2-N2_2011.cia is there.' 81 81 call abort 82 82 else -
trunk/LMDZ.TITAN/libf/phytitan/optci.F90
r1647 r1648 1 1 subroutine optci(PLEV,TLEV,DTAUI,TAUCUMI, & 2 2 QXIAER,QSIAER,GIAER,COSBI,WBARI,TAUAERO, & 3 TMID,PMID,TAUGSURF, QVAR,MUVAR)3 TMID,PMID,TAUGSURF,GWEIGHT) 4 4 5 5 use radinc_h 6 use radcommon_h, only: gasi,tlimit, wrefVAR,Cmk,tgasref,pfgasref,wnoi,scalep,indi,glat_ig6 use radcommon_h, only: gasi,tlimit,Cmk,tgasref,pfgasref,wnoi,scalep,indi,glat_ig 7 7 use gases_h 8 use comcstfi_mod, only: g, r , mugaz8 use comcstfi_mod, only: g, r 9 9 use callkeys_mod, only: continuum,graybody 10 10 implicit none … … 49 49 real*8 TAEROS(L_LEVELS,L_NSPECTI,NAERKIND) 50 50 51 ! Titan customisation 52 ! J. Vatant d'Ollone (2016) 53 real*8 GWEIGHT(L_NGAUSS) 54 real*8 DHAZE_T(L_LEVELS+1,L_NSPECTI) 55 real*8 DHAZES_T(L_LEVELS+1,L_NSPECTI) 56 real*8 SSA_T(L_LEVELS+1,L_NSPECTI) 57 real*8 ASF_T(L_LEVELS+1,L_NSPECTI) 58 real*8 INT_DTAU(L_NLAYRAD,L_NSPECTI) 59 real*8 K_HAZE(L_NLAYRAD,L_NSPECTI) 60 61 CHARACTER*2 str2 62 ! ========================== 63 51 64 integer L, NW, NG, K, LK, IAER 52 65 integer MT(L_LEVELS), MP(L_LEVELS), NP(L_LEVELS) … … 60 73 double precision p_cross 61 74 62 ! variable species mixing ratio variables63 real*8 QVAR(L_LEVELS), WRATIO(L_LEVELS), MUVAR(L_LEVELS)64 75 real*8 KCOEF(4) 65 integer NVAR(L_LEVELS) 66 76 67 77 ! temporary variables for multiple aerosol calculation 68 78 real*8 atemp … … 73 83 !real*8 rho !! see test below 74 84 75 integer igas, jgas 85 integer igas, jgas, ilay 76 86 77 87 integer interm … … 95 105 96 106 ! if we have continuum opacities, we need dz 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 99 !JL13 the mugaz/muvar factor takes into account water meanmolecular weight if water is present 100 101 call tpindex(PMID(K),TMID(K),QVAR(K),pfgasref,tgasref,WREFVAR, & 102 LCOEF,MT(K),MP(K),NVAR(K),WRATIO(K)) 107 dz(k) = dpr(k)*R*TMID(K)/(glat_ig*PMID(K)) 108 U(k) = Cmk*DPR(k) ! only Cmk line in optci.F 109 110 call tpindex(PMID(K),TMID(K),pfgasref,tgasref,LCOEF,MT(K),MP(K)) 103 111 104 112 do LK=1,4 … … 120 128 do K=2,L_LEVELS 121 129 130 ilay = k / 2 ! int. arithmetic => gives the gcm layer index 131 122 132 ! continuum absorption 123 133 DCONT = 0.0d0 … … 129 139 do igas=1,ngasmx 130 140 131 if(gfrac(igas).eq.-1)then ! variable 132 p_cont = dble(PMID(k)*scalep*QVAR(k)) ! qvar = mol/mol 133 else 134 p_cont = dble(PMID(k)*scalep*gfrac(igas)*(1.-QVAR(k))) 135 endif 141 p_cont = dble(PMID(k)*scalep*gfrac(igas,ilay)) 136 142 137 143 dtemp=0.0d0 … … 151 157 ! then cross-interactions with other gases 152 158 do jgas=1,ngasmx 153 p_cross = dble(PMID(k)*scalep*gfrac(jgas )*(1.-QVAR(k)))159 p_cross = dble(PMID(k)*scalep*gfrac(jgas,ilay)) 154 160 dtempc = 0.0d0 155 161 if(jgas.eq.igas_N2)then 156 162 interm = indi(nw,igas,jgas) 157 163 call interpolateN2H2(wn_cont,T_cont,p_cross,p_cont,dtempc,.false.,interm) 164 indi(nw,igas,jgas) = interm 165 endif 166 dtemp = dtemp + dtempc 167 enddo 168 169 elseif(igas.eq.igas_CH4)then 170 171 ! first do self-induced absorption 172 interm = indi(nw,igas,igas) 173 call interpolateCH4CH4(wn_cont,T_cont,p_cont,dtemp,.false.,interm) 174 indi(nw,igas,igas) = interm 175 176 ! then cross-interactions with other gases 177 do jgas=1,ngasmx 178 p_cross = dble(PMID(k)*scalep*gfrac(jgas,ilay)) 179 dtempc = 0.0d0 180 if(jgas.eq.igas_N2)then 181 interm = indi(nw,igas,jgas) 182 call interpolateN2CH4(wn_cont,T_cont,p_cross,p_cont,dtempc,.false.,interm) 158 183 indi(nw,igas,jgas) = interm 159 184 endif … … 185 210 DAERO=SUM(TAEROS(K,NW,1:naerkind)) 186 211 212 !================= Titan customisation ======================================== 213 call disr_haze(dz(k),plev(k),wnoi(nw),dhaze_T(k,nw),SSA_T(k,nw),ASF_T(k,nw)) 214 ! ============================================================================= 215 216 187 217 do ng=1,L_NGAUSS-1 188 218 189 219 ! Now compute TAUGAS 190 220 191 ! Interpolate between water mixing ratios 192 ! WRATIO = 0.0 if the requested water amount is equal to, or outside the 193 ! the water data range 194 195 if(L_REFVAR.eq.1)then ! added by RW for special no variable case 196 KCOEF(1) = GASI(MT(K),MP(K),1,NW,NG) 197 KCOEF(2) = GASI(MT(K),MP(K)+1,1,NW,NG) 198 KCOEF(3) = GASI(MT(K)+1,MP(K)+1,1,NW,NG) 199 KCOEF(4) = GASI(MT(K)+1,MP(K),1,NW,NG) 200 else 201 202 KCOEF(1) = GASI(MT(K),MP(K),NVAR(K),NW,NG) + WRATIO(K)* & 203 (GASI(MT(K),MP(K),NVAR(K)+1,NW,NG) - & 204 GASI(MT(K),MP(K),NVAR(K),NW,NG)) 205 206 KCOEF(2) = GASI(MT(K),MP(K)+1,NVAR(K),NW,NG) + WRATIO(K)* & 207 (GASI(MT(K),MP(K)+1,NVAR(K)+1,NW,NG) - & 208 GASI(MT(K),MP(K)+1,NVAR(K),NW,NG)) 209 210 KCOEF(3) = GASI(MT(K)+1,MP(K)+1,NVAR(K),NW,NG) + WRATIO(K)* & 211 (GASI(MT(K)+1,MP(K)+1,NVAR(K)+1,NW,NG) - & 212 GASI(MT(K)+1,MP(K)+1,NVAR(K),NW,NG)) 213 214 KCOEF(4) = GASI(MT(K)+1,MP(K),NVAR(K),NW,NG) + WRATIO(K)* & 215 (GASI(MT(K)+1,MP(K),NVAR(K)+1,NW,NG) - & 216 GASI(MT(K)+1,MP(K),NVAR(K),NW,NG)) 217 218 endif 221 KCOEF(1) = GASI(MT(K),MP(K),1,NW,NG) 222 KCOEF(2) = GASI(MT(K),MP(K)+1,1,NW,NG) 223 KCOEF(3) = GASI(MT(K)+1,MP(K)+1,1,NW,NG) 224 KCOEF(4) = GASI(MT(K)+1,MP(K),1,NW,NG) 219 225 220 226 ! Interpolate the gaseous k-coefficients to the requested T,P values … … 228 234 DTAUKI(K,nw,ng) = TAUGAS & 229 235 + DCONT & ! For parameterized continuum absorption 230 + DAERO ! For aerosol absorption 236 + DAERO & ! For aerosol absorption 237 + DHAZE_T(K,NW) ! For Titan haze 231 238 232 239 end do … … 238 245 DTAUKI(K,nw,ng) = 0.d0 & 239 246 + DCONT & ! For parameterized continuum absorption 240 + DAERO ! For aerosol absorption 247 + DAERO & ! For aerosol absorption 248 + DHAZE_T(K,NW) ! For Titan Haze 241 249 242 250 end do … … 244 252 245 253 DTAUKI(L_LEVELS+1,1:L_NSPECTI,1:L_NGAUSS)=0.d0 254 255 246 256 !======================================================================= 247 257 ! Now the full treatment for the layers, where besides the opacity 248 258 ! we need to calculate the scattering albedo and asymmetry factors 259 ! ====================================================================== 249 260 250 261 do iaer=1,naerkind … … 256 267 end do 257 268 269 ! Haze scattering 258 270 DO NW=1,L_NSPECTI 259 DO L=1,L_NLAYRAD 271 DO K=2,L_LEVELS+1 272 DHAZES_T(K,NW) = DHAZE_T(K,NW) * SSA_T(K,NW) 273 ENDDO 274 ENDDO 275 276 DO NW=1,L_NSPECTI 277 DO L=1,L_NLAYRAD-1 260 278 K = 2*L+1 261 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) + SUM(TAUAEROLK(K+1,NW,1:naerkind)) 279 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) + SUM(TAUAEROLK(K+1,NW,1:naerkind)) & 280 + DHAZES_T(K,NW) + DHAZES_T(K+1,NW) 262 281 END DO ! L vertical loop 282 283 !last level 284 L = L_NLAYRAD 285 K = 2*L+1 286 287 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) + DHAZES_T(K,NW) 288 263 289 END DO ! NW spectral loop 264 290 291 ! ====================================================================== 265 292 266 293 DO NW=1,L_NSPECTI 267 294 NG = L_NGAUSS 268 DO L=1,L_NLAYRAD 295 DO L=1,L_NLAYRAD-1 269 296 270 297 K = 2*L+1 298 271 299 DTAUI(L,nw,ng) = DTAUKI(K,NW,NG) + DTAUKI(K+1,NW,NG)! + 1.e-50 272 300 … … 278 306 GIAER(K+1,NW,IAER) * TAUAEROLK(K+1,NW,IAER) 279 307 end do 308 atemp = atemp + ASF_T(K,NW)*DHAZES_T(K,NW) 280 309 WBARI(L,nw,ng) = btemp(L,nw) / DTAUI(L,NW,NG) 281 310 else … … 291 320 292 321 END DO ! L vertical loop 322 323 ! No vertical averaging on bottom layer 324 325 L = L_NLAYRAD 326 K = 2*L+1 327 DTAUI(L,nw,ng) = DTAUKI(K,NW,NG) 328 329 atemp = 0. 330 if(DTAUI(L,NW,NG) .GT. 1.0D-9) then 331 do iaer=1,naerkind 332 atemp = atemp + & 333 GIAER(K,NW,IAER) * TAUAEROLK(K,NW,IAER) 334 end do 335 atemp = atemp + ASF_T(K,NW)*DHAZES_T(K,NW) 336 WBARI(L,nw,ng) = btemp(L,nw) / DTAUI(L,NW,NG) 337 else 338 WBARI(L,nw,ng) = 0.0D0 339 DTAUI(L,NW,NG) = 1.0D-9 340 endif 341 342 if(btemp(L,nw) .GT. 0.0d0) then 343 cosbi(L,NW,NG) = atemp/btemp(L,nw) 344 else 345 cosbi(L,NW,NG) = 0.0D0 346 end if 293 347 294 348 ! Now the other Gauss points, if needed. 295 349 296 350 DO NG=1,L_NGAUSS-1 351 297 352 IF(TAUGSURF(NW,NG) .gt. TLIMIT) THEN 298 353 299 DO L=1,L_NLAYRAD 354 DO L=1,L_NLAYRAD-1 300 355 K = 2*L+1 301 356 DTAUI(L,nw,ng) = DTAUKI(K,NW,NG)+DTAUKI(K+1,NW,NG)! + 1.e-50 302 357 303 358 if(DTAUI(L,NW,NG) .GT. 1.0D-9) then 304 305 WBARI(L,nw,ng) = btemp(L,nw) / DTAUI(L,NW,NG) 306 359 WBARI(L,nw,ng) = btemp(L,nw) / DTAUI(L,NW,NG) 307 360 else 308 361 WBARI(L,nw,ng) = 0.0D0 … … 312 365 cosbi(L,NW,NG) = cosbi(L,NW,L_NGAUSS) 313 366 END DO ! L vertical loop 367 368 ! No vertical averaging on bottom layer 369 370 L = L_NLAYRAD 371 K = 2*L+1 372 DTAUI(L,nw,ng) = DTAUKI(K,NW,NG) 373 if(DTAUI(L,NW,NG) .GT. 1.0D-9) then 374 WBARI(L,nw,ng) = btemp(L,nw) / DTAUI(L,NW,NG) 375 else 376 WBARI(L,nw,ng) = 0.0D0 377 DTAUI(L,NW,NG) = 1.0D-9 378 endif 379 cosbi(L,NW,NG) = cosbi(L,NW,L_NGAUSS) 380 314 381 END IF 315 382 … … 334 401 ! ascending ray with angle theta = 0. 335 402 336 !open(127,file='taucum.out') 337 !do nw=1,L_NSPECTI 338 ! write(127,*) taucumi(L_LEVELS,nw,L_NGAUSS) 339 !enddo 340 !close(127) 341 342 ! print*,'WBARI' 343 ! print*,WBARI 344 ! print*,'DTAUI' 345 ! print*,DTAUI 346 ! call abort 347 403 404 ! Titan's outputs (J.V.O, 2016)=============================================== 405 ! do l=1,L_NLAYRAD 406 ! do nw=1,L_NSPECTI 407 ! INT_DTAU(L,NW) = 0.0d+0 408 ! DO NG=1,L_NGAUSS 409 ! INT_DTAU(L,NW)= INT_DTAU(L,NW) + dtaui(L,nw,ng)*gweight(NG) 410 ! enddo 411 ! enddo 412 ! enddo 413 414 ! do nw=1,L_NSPECTI 415 ! write(str2,'(i2.2)') nw 416 ! call writediagfi(1,'kgi'//str2,'Gaz extinction coefficient IR band '//str2,'m-1',1,int_dtau(L_NLAYRAD:1:-1,nw)/dz_lay(L_NLAYRAD:1:-1)) 417 ! call writediagfi(1,'khi'//str2,'Haze extinction coefficient IR band '//str2,'m-1',1,k_haze(L_NLAYRAD:1:-1,nw)/dz_lay(L_NLAYRAD:1:-1)) 418 ! enddo 419 420 ! ============================================================================== 348 421 349 422 return -
trunk/LMDZ.TITAN/libf/phytitan/optcv.F90
r1647 r1648 1 1 SUBROUTINE OPTCV(DTAUV,TAUV,TAUCUMV,PLEV, & 2 2 QXVAER,QSVAER,GVAER,WBARV,COSBV, & 3 TAURAY,TAUAERO,TMID,PMID,TAUGSURF, QVAR,MUVAR)3 TAURAY,TAUAERO,TMID,PMID,TAUGSURF,GWEIGHT) 4 4 5 5 use radinc_h 6 use radcommon_h, only: gasv, tlimit, wrefVAR,Cmk, tgasref, pfgasref,wnov,scalep,indv,glat_ig6 use radcommon_h, only: gasv, tlimit, Cmk, tgasref, pfgasref,wnov,scalep,indv,glat_ig 7 7 use gases_h 8 use comcstfi_mod, only: g, r , mugaz8 use comcstfi_mod, only: g, r 9 9 use callkeys_mod, only: continuum,graybody,callgasvis 10 10 … … 55 55 real*8 TAEROS(L_LEVELS,L_NSPECTV,NAERKIND) 56 56 57 ! Titan customisation 58 ! J. Vatant d'Ollone (2016) 59 real*8 GWEIGHT(L_NGAUSS) 60 real*8 DHAZE_T(L_LEVELS+1,L_NSPECTI) 61 real*8 DHAZES_T(L_LEVELS+1,L_NSPECTI) 62 real*8 SSA_T(L_LEVELS+1,L_NSPECTI) 63 real*8 ASF_T(L_LEVELS+1,L_NSPECTI) 64 real*8 INT_DTAU(L_NLAYRAD,L_NSPECTI) 65 real*8 K_HAZE(L_NLAYRAD,L_NSPECTI) 66 67 CHARACTER*2 str2 68 ! ========================== 69 57 70 integer L, NW, NG, K, LK, IAER 58 71 integer MT(L_LEVELS), MP(L_LEVELS), NP(L_LEVELS) … … 69 82 double precision p_cross 70 83 71 ! variable species mixing ratio variables72 real*8 QVAR(L_LEVELS), WRATIO(L_LEVELS), MUVAR(L_LEVELS)73 84 real*8 KCOEF(4) 74 integer NVAR(L_LEVELS)75 85 76 86 ! temporary variables for multiple aerosol calculation … … 82 92 real*8 dz(L_LEVELS) 83 93 84 integer igas, jgas 94 integer igas, jgas, ilay 85 95 86 96 integer interm … … 107 117 ! if we have continuum opacities, we need dz 108 118 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 113 114 call tpindex(PMID(K),TMID(K),QVAR(K),pfgasref,tgasref,WREFVAR, & 115 LCOEF,MT(K),MP(K),NVAR(K),WRATIO(K)) 119 dz(k) = dpr(k)*R*TMID(K)/(glat_ig*PMID(K)) 120 U(k) = Cmk*DPR(k) ! only Cmk line in optcv.F 121 122 call tpindex(PMID(K),TMID(K),pfgasref,tgasref,LCOEF,MT(K),MP(K)) 116 123 117 124 do LK=1,4 … … 133 140 end do ! levels 134 141 end do 135 142 136 143 ! we ignore K=1... 137 144 do K=2,L_LEVELS 145 146 ilay = k / 2 ! int. arithmetic => gives the gcm layer index 138 147 139 148 do NW=1,L_NSPECTV … … 153 162 do igas=1,ngasmx 154 163 155 if(gfrac(igas).eq.-1)then ! variable 156 p_cont = dble(PMID(k)*scalep*QVAR(k)) ! qvar = mol/mol 157 else 158 p_cont = dble(PMID(k)*scalep*gfrac(igas)*(1.-QVAR(k))) 159 endif 164 p_cont = dble(PMID(k)*scalep*gfrac(igas,ilay)) 160 165 161 166 dtemp=0.0 … … 176 181 ! then cross-interactions with other gases 177 182 do jgas=1,ngasmx 178 p_cross = dble(PMID(k)*scalep*gfrac(jgas )*(1.-QVAR(k)))183 p_cross = dble(PMID(k)*scalep*gfrac(jgas,ilay)) 179 184 dtempc = 0.0 180 185 if(jgas.eq.igas_N2)then … … 187 192 enddo 188 193 194 elseif(igas.eq.igas_CH4)then 195 196 ! first do self-induced absorption 197 interm = indv(nw,igas,igas) 198 call interpolateCH4CH4(wn_cont,T_cont,p_cont,dtemp,.false.,interm) 199 indv(nw,igas,igas) = interm 200 201 ! then cross-interactions with other gases 202 do jgas=1,ngasmx 203 p_cross = dble(PMID(k)*scalep*gfrac(jgas,ilay)) 204 dtempc = 0.0 205 if(jgas.eq.igas_N2)then 206 interm = indv(nw,igas,jgas) 207 call interpolateN2CH4(wn_cont,T_cont,p_cross,p_cont,dtempc,.false.,interm) 208 indv(nw,igas,jgas) = interm 209 endif 210 dtemp = dtemp + dtempc 211 enddo 212 189 213 endif 190 214 … … 197 221 endif 198 222 223 !================= Titan customisation ======================================== 224 call disr_haze(dz(k),plev(k),wnov(nw),dhaze_T(k,nw),SSA_T(k,nw),ASF_T(k,nw)) 225 ! ============================================================================= 226 199 227 do ng=1,L_NGAUSS-1 200 228 201 229 ! Now compute TAUGAS 202 230 203 ! Interpolate between water mixing ratios 204 ! WRATIO = 0.0 if the requested water amount is equal to, or outside the 205 ! the water data range 206 207 if(L_REFVAR.eq.1)then ! added by RW for special no variable case 208 KCOEF(1) = GASV(MT(K),MP(K),1,NW,NG) 209 KCOEF(2) = GASV(MT(K),MP(K)+1,1,NW,NG) 210 KCOEF(3) = GASV(MT(K)+1,MP(K)+1,1,NW,NG) 211 KCOEF(4) = GASV(MT(K)+1,MP(K),1,NW,NG) 212 else 213 214 KCOEF(1) = GASV(MT(K),MP(K),NVAR(K),NW,NG) + WRATIO(K)* & 215 (GASV(MT(K),MP(K),NVAR(K)+1,NW,NG) - & 216 GASV(MT(K),MP(K),NVAR(K),NW,NG)) 217 218 KCOEF(2) = GASV(MT(K),MP(K)+1,NVAR(K),NW,NG) + WRATIO(K)* & 219 (GASV(MT(K),MP(K)+1,NVAR(K)+1,NW,NG) - & 220 GASV(MT(K),MP(K)+1,NVAR(K),NW,NG)) 221 222 KCOEF(3) = GASV(MT(K)+1,MP(K)+1,NVAR(K),NW,NG) + WRATIO(K)*& 223 (GASV(MT(K)+1,MP(K)+1,NVAR(K)+1,NW,NG) - & 224 GASV(MT(K)+1,MP(K)+1,NVAR(K),NW,NG)) 225 226 KCOEF(4) = GASV(MT(K)+1,MP(K),NVAR(K),NW,NG) + WRATIO(K)* & 227 (GASV(MT(K)+1,MP(K),NVAR(K)+1,NW,NG) - & 228 GASV(MT(K)+1,MP(K),NVAR(K),NW,NG)) 229 230 endif 231 KCOEF(1) = GASV(MT(K),MP(K),1,NW,NG) 232 KCOEF(2) = GASV(MT(K),MP(K)+1,1,NW,NG) 233 KCOEF(3) = GASV(MT(K)+1,MP(K)+1,1,NW,NG) 234 KCOEF(4) = GASV(MT(K)+1,MP(K),1,NW,NG) 231 235 232 236 ! Interpolate the gaseous k-coefficients to the requested T,P values … … 240 244 DTAUKV(K,nw,ng) = TAUGAS & 241 245 + TRAYAER & ! TRAYAER includes all scattering contributions 242 + DCONT ! For parameterized continuum aborption 246 + DCONT & ! For parameterized continuum aborption 247 + DHAZE_T(K,NW) ! For Titan haze 243 248 244 249 end do … … 248 253 249 254 NG = L_NGAUSS 250 DTAUKV(K,nw,ng) = TRAY(K,NW) + DCONT ! For parameterized continuum absorption 255 DTAUKV(K,nw,ng) = TRAY(K,NW) + DCONT & ! For parameterized continuum absorption 256 + DHAZE_T(K,NW) ! For Titan haze 251 257 252 258 do iaer=1,naerkind … … 261 267 ! Now the full treatment for the layers, where besides the opacity 262 268 ! we need to calculate the scattering albedo and asymmetry factors 263 269 ! ====================================================================== 270 264 271 do iaer=1,naerkind 265 272 DO NW=1,L_NSPECTV … … 269 276 ENDDO 270 277 end do 278 279 ! Haze scattering 280 DO NW=1,L_NSPECTV 281 DO K=2,L_LEVELS+1 282 DHAZES_T(K,NW) = DHAZE_T(K,NW) * SSA_T(K,NW) 283 ENDDO 284 ENDDO 285 271 286 272 287 DO NW=1,L_NSPECTV 273 288 DO L=1,L_NLAYRAD-1 274 289 K = 2*L+1 275 atemp(L,NW) = SUM(GVAER(K,NW,1:naerkind) * TAUAEROLK(K,NW,1:naerkind))+SUM(GVAER(K+1,NW,1:naerkind) * TAUAEROLK(K+1,NW,1:naerkind)) 276 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) + SUM(TAUAEROLK(K+1,NW,1:naerkind)) 290 291 atemp(L,NW) = SUM(GVAER(K,NW,1:naerkind) * TAUAEROLK(K,NW,1:naerkind)) & 292 + SUM(GVAER(K+1,NW,1:naerkind) * TAUAEROLK(K+1,NW,1:naerkind)) & 293 + ASF_T(K,NW)*DHAZES_T(K,NW) 294 295 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) + SUM(TAUAEROLK(K+1,NW,1:naerkind)) & 296 + DHAZES_T(K,NW) 297 277 298 ctemp(L,NW) = btemp(L,NW) + 0.9999*(TRAY(K,NW) + TRAY(K+1,NW)) 278 299 btemp(L,NW) = btemp(L,NW) + TRAY(K,NW) + TRAY(K+1,NW) … … 283 304 L = L_NLAYRAD 284 305 K = 2*L+1 285 atemp(L,NW) = SUM(GVAER(K,NW,1:naerkind) * TAUAEROLK(K,NW,1:naerkind)) 286 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) 306 307 atemp(L,NW) = SUM(GVAER(K,NW,1:naerkind) * TAUAEROLK(K,NW,1:naerkind)) & 308 + ASF_T(K,NW)*DHAZES_T(K,NW) 309 btemp(L,NW) = SUM(TAUAEROLK(K,NW,1:naerkind)) & 310 + DHAZES_T(K,NW) 287 311 ctemp(L,NW) = btemp(L,NW) + 0.9999*TRAY(K,NW) 288 312 btemp(L,NW) = btemp(L,NW) + TRAY(K,NW) … … 292 316 END DO ! NW spectral loop 293 317 318 ! =========================================================================================== 319 294 320 DO NG=1,L_NGAUSS 295 321 DO NW=1,L_NSPECTV … … 309 335 310 336 WBARV(L,NW,NG) = ctemp(L,NW) / DTAUV(L,NW,NG) 337 311 338 END DO ! NW spectral loop 312 339 END DO ! NG Gauss loop … … 329 356 330 357 358 ! Titan's outputs (J.V.O, 2016)=============================================== 359 ! do l=1,L_NLAYRAD 360 ! do nw=1,L_NSPECTV 361 ! INT_DTAU(L,NW) = 0.0d+0 362 ! DO NG=1,L_NGAUSS 363 ! INT_DTAU(L,NW)= INT_DTAU(L,NW) + dtauv(L,nw,ng)*gweight(NG) 364 ! enddo 365 ! enddo 366 ! enddo 367 368 ! do nw=1,L_NSPECTV 369 ! write(str2,'(i2.2)') nw 370 ! call writediagfi(1,'kgv'//str2,'Gaz extinction coefficient VI band '//str2,'m-1',1,int_dtau(L_NLAYRAD:1:-1,nw)/dz_lay(L_NLAYRAD:1:-1)) 371 ! call writediagfi(1,'khv'//str2,'Haze extinction coefficient VI band '//str2,'m-1',1,k_haze(L_NLAYRAD:1:-1,nw)/dz_lay(L_NLAYRAD:1:-1)) 372 ! enddo 373 374 ! ============================================================================== 375 376 331 377 return 332 378 -
trunk/LMDZ.TITAN/libf/phytitan/physiq_mod.F90
r1647 r1648 15 15 16 16 use radinc_h, only : L_NSPECTI,L_NSPECTV,naerkind 17 use gases_h, only: gnom, gfrac18 17 use radcommon_h, only: sigma, glat, grav, BWNV 19 18 use surfdat_h, only: phisfi, zmea, zstd, zsig, zgam, zthe … … 23 22 use geometry_mod, only: latitude, longitude, cell_area 24 23 USE comgeomfi_h, only: totarea, totarea_planet 25 USE tracer_h, only: noms, mmol, radius, rho_q,qext, &24 USE tracer_h, only: noms, mmol, radius, qext, & 26 25 alpha_lift, alpha_devil, qextrhor, & 27 26 igcm_dustbin … … 353 352 !$OMP THREADPRIVATE(qsurf_hist) 354 353 355 real muvar(ngrid,nlayer+1) ! For Runaway Greenhouse 1D study. By RW356 357 354 real,allocatable,dimension(:,:,:),save :: reffrad ! Aerosol effective radius (m). By RW 358 355 real,allocatable,dimension(:,:,:),save :: nueffrad ! Aerosol effective radius variance. By RW … … 660 657 ! II.a Call correlated-k radiative transfer scheme 661 658 ! ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 662 663 muvar(1:ngrid,1:nlayer+1)=mugaz659 660 call call_profilgases(nlayer) 664 661 665 662 ! standard callcorrk 666 663 call callcorrk(ngrid,nlayer,pq,nq,qsurf, & 667 664 albedo,albedo_equivalent,emis,mu0,pplev,pplay,pt, & 668 tsurf,fract,dist_star,aerosol, muvar,&665 tsurf,fract,dist_star,aerosol, & 669 666 zdtlw,zdtsw,fluxsurf_lw,fluxsurf_sw, & 670 667 fluxsurfabs_sw,fluxtop_lw, & -
trunk/LMDZ.TITAN/libf/phytitan/radcommon_h.F90
r1529 r1648 7 7 ! 8 8 ! radcommon.h 9 ! 9 !v 10 10 !----------------------------------------------------------------------C 11 11 ! … … 36 36 ! TAURAY - Array (NSPECTV elements) of the pressure-independent 37 37 ! part of Rayleigh scattering optical depth. 38 ! TAURAYVAR - Array (NSPECTV elements) of the pressure-independent39 ! part of Rayleigh scattering optical depth for the variable gas.40 38 ! FZEROI - Fraction of zeros in the IR CO2 k-coefficients, for 41 39 ! each temperature, pressure, and spectral interval … … 63 61 REAL*8 BWNI(L_NSPECTI+1), WNOI(L_NSPECTI), DWNI(L_NSPECTI), WAVEI(L_NSPECTI) !BWNI read by master in setspi 64 62 REAL*8 BWNV(L_NSPECTV+1), WNOV(L_NSPECTV), DWNV(L_NSPECTV), WAVEV(L_NSPECTV) !BWNV read by master in setspv 65 REAL*8 STELLARF(L_NSPECTV), TAURAY(L_NSPECTV) , TAURAYVAR(L_NSPECTV)63 REAL*8 STELLARF(L_NSPECTV), TAURAY(L_NSPECTV) 66 64 !$OMP THREADPRIVATE(WNOI,DWNI,WAVEI,& 67 65 !$OMP WNOV,DWNV,WAVEV,& 68 !$OMP STELLARF,TAURAY ,TAURAYVAR)66 !$OMP STELLARF,TAURAY) 69 67 70 68 REAL*8 blami(L_NSPECTI+1) … … 79 77 !!! ALLOCATABLE STUFF SO THAT DIMENSIONS ARE READ in *.dat FILES -- AS 12/2011 80 78 REAL*8, DIMENSION(:,:,:,:,:), ALLOCATABLE :: gasi, gasv 81 REAL*8, DIMENSION(:), ALLOCATABLE :: PGASREF, TGASREF, WREFVAR,PFGASREF79 REAL*8, DIMENSION(:), ALLOCATABLE :: PGASREF, TGASREF, PFGASREF 82 80 real*8 FZEROI(L_NSPECTI) 83 81 real*8 FZEROV(L_NSPECTV) 84 82 real*8 pgasmin, pgasmax 85 83 real*8 tgasmin, tgasmax 86 !$OMP THREADPRIVATE(gasi,gasv,& ! wrefvar,pgasref,tgasref,pfgasref read by master in sugas_corrk84 !$OMP THREADPRIVATE(gasi,gasv,& !pgasref,tgasref,pfgasref read by master in sugas_corrk 87 85 !$OMP FZEROI,FZEROV) !pgasmin,pgasmax,tgasmin,tgasmax read by master in sugas_corrk 88 86 -
trunk/LMDZ.TITAN/libf/phytitan/su_gases.F90
r1647 r1648 1 subroutine su_gases 1 subroutine su_gases(nlayer,tracer) 2 2 3 3 use gases_h … … 5 5 implicit none 6 6 7 integer igas, ierr, count 8 7 integer,intent(in) :: nlayer 8 logical,intent(in) :: tracer 9 10 integer igas, ierr 11 9 12 !================================================================== 10 13 ! … … 17 20 ! R. Wordsworth (2011) 18 21 ! Allocatable arrays by A. Spiga (2011) 19 ! 22 ! Titan's version : J. Vatant d'Ollone (2017) 23 ! * force igas_X labels and def gnom for N2,CH4,H2 24 ! * get rid of variable species ( enrichment dimension will be set in corrk routines ) 25 ! 20 26 !================================================================== 21 27 22 28 !$OMP MASTER 23 ! load gas names from file 'gases.def' 29 30 31 ngasmx = 3 ! N2, CH4, H2 32 33 34 ! load reference level and reference molar fractions from file 'gases.def' 24 35 open(90,file='gases.def',status='old',form='formatted',iostat=ierr) 36 25 37 if (ierr.eq.0) then 26 38 write(*,*) "sugases.F90: reading file gases.def" 27 read(90,*) 28 read(90,*,iostat=ierr) ngasmx 39 read(90,*) ! header 40 41 ! We allocate gfrac and we set gas molar fractions for the reference level only. 42 ! This will be useful for the cpp_mu and rayleigh routines 43 ! Other gas molar fractions are now set in routine callprofilgases 44 45 write(*,*) 'sugases.F90: allocating and reading gas molar fractions from reference level in gases.def...' 46 47 if(.not.allocated(gfrac)) allocate(gfrac(ngasmx,nlayer)) 48 49 read(90,*,iostat=ierr) nivref 29 50 if (ierr.ne.0) then 30 write(*,*) "sugases.F90: error reading number of gases"51 write(*,*) "sugases.F90: error reading reference level" 31 52 write(*,*) " (first line of gases.def) " 32 53 call abort 33 54 endif 34 35 print*,ngasmx, " gases found in gases.def. Allocating names and molar fractions..." 36 37 if (.not.allocated(gnom)) allocate(gnom(ngasmx)) 55 56 print*, "layer", nivref, "is reference level found in gases.def ..." 57 38 58 do igas=1,ngasmx 39 read(90,*,iostat=ierr) g nom(igas)59 read(90,*,iostat=ierr) gfrac(igas,nivref) 40 60 if (ierr.ne.0) then 41 write(*,*) 'sugases.F90: error reading gas names in gases.def...'61 write(*,*) 'sugases.F90: error reading reference gas molar fractions in gases.def... aborting' 42 62 call abort 43 63 endif 44 64 enddo !of do igas=1,ngasmx 45 65 46 vgas=047 if(.not.allocated(gfrac)) allocate(gfrac(ngasmx))48 do igas=1,ngasmx49 read(90,*,iostat=ierr) gfrac(igas)50 if (ierr.ne.0) then51 write(*,*) 'sugases.F90: error reading gas molar fractions in gases.def...'52 call abort53 endif54 66 55 ! find variable gas (if any) 56 if(gfrac(igas).eq.-1.0)then 57 if(vgas.eq.0)then 58 vgas=igas 59 else 60 print*,'You seem to be choosing two variable gases' 61 print*,'Check that gases.def is correct' 62 call abort 63 endif 64 endif 65 66 enddo !of do igas=1,ngasmx 67 ! We force gnom = (N2, CH4, H2) and igas_X for Titan 68 69 igas_N2 = 1 70 igas_CH4 = 2 71 igas_H2 = 3 67 72 68 73 69 ! assign the 'igas_X' labels 70 count=0 71 do igas=1,ngasmx 72 if (trim(gnom(igas)).eq."H2_" .or. trim(gnom(igas)).eq."H2") then 73 igas_H2=igas 74 count=count+1 75 elseif (trim(gnom(igas)).eq."N2_" .or. trim(gnom(igas)).eq."N2") then 76 igas_N2=igas 77 count=count+1 78 elseif (trim(gnom(igas)).eq."CH4") then 79 igas_CH4=igas 80 count=count+1 81 elseif (trim(gnom(igas)).eq."C2H6") then 82 igas_C2H6=igas 83 count=count+1 84 elseif (trim(gnom(igas)).eq."C2H2") then 85 igas_C2H2=igas 86 count=count+1 87 endif 88 enddo 89 90 if(count.ne.ngasmx)then 91 print*,'Mismatch between ngas and number of recognised gases in sugas_corrk.F90.' 92 print*,'Either we haven`t managed to assign all the gases, or there are duplicates.' 93 print*,'Please try again.' 94 endif 95 74 if (.not.allocated(gnom)) allocate(gnom(ngasmx)) 75 gnom(igas_N2) = "N2_" 76 gnom(igas_CH4) = "CH4" 77 gnom(igas_H2) = "H2_" 78 79 96 80 else 97 81 write(*,*) 'Cannot find required file "gases.def"' 98 82 call abort 99 83 endif 84 100 85 close(90) 101 86 !$OMP END MASTER -
trunk/LMDZ.TITAN/libf/phytitan/sugas_corrk.F90
r1647 r1648 24 24 use radcommon_h, only : tgasref,tgasmin,tgasmax 25 25 use radcommon_h, only : gasv,gasi,FZEROI,FZEROV,gweight 26 use radcommon_h, only : wrefvar,WNOI,WNOV26 use radcommon_h, only : WNOI,WNOV 27 27 use datafile_mod, only: datadir 28 28 use comcstfi_mod, only: mugaz … … 44 44 ! ALLOCATABLE ARRAYS -- AS 12/2011 45 45 REAL*8, DIMENSION(:,:,:,:,:), ALLOCATABLE,SAVE :: gasi8, gasv8 !read by master 46 character*20,allocatable,DIMENSION(:),SAVE :: gastype ! for check with gnom, read by master47 46 48 47 real*8 x, xi(4), yi(4), ans, p … … 79 78 read(111,*) ngas 80 79 81 if(ngas.ne.ngasmx)then82 print*,'Number of gases in radiative transfer data (',ngas,') does not', &83 'match that in gases.def (',ngasmx,'), exiting.'84 call abort85 endif86 87 80 if(ngas.gt.5 .or. ngas.lt.1)then 88 81 print*,ngas,' species in database [', & … … 90 83 '], radiative code cannot handle this.' 91 84 call abort 92 endif 93 94 ! dynamically allocate gastype and read from Q.dat 95 IF ( .NOT. ALLOCATED( gastype ) ) ALLOCATE( gastype( ngas ) ) 96 97 do igas=1,ngas 98 read(111,*) gastype(igas) 99 print*,'Gas ',igas,' is ',gastype(igas) 100 enddo 101 102 ! get array size, load the coefficients 103 open(111,file=TRIM(file_path),form='formatted') 104 read(111,*) L_REFVAR 105 IF( .NOT. ALLOCATED( wrefvar ) ) ALLOCATE( WREFVAR(L_REFVAR) ) 106 read(111,*) wrefvar 107 close(111) 108 109 ! Check that gastype and gnom match 110 do igas=1,ngas 111 print*,'Gas ',igas,' is ',trim(gnom(igas)) 112 if (trim(gnom(igas)).ne.trim(gastype(igas))) then 113 print*,'Name of a gas in radiative transfer data (',trim(gastype(igas)),') does not ', & 114 'match that in gases.def (',trim(gnom(igas)),'), exiting. You should compare ', & 115 'gases.def with Q.dat in your radiative transfer directory.' 116 call abort 117 endif 118 enddo 119 print*,'Confirmed gas match in radiative transfer and gases.def!' 120 121 ! display the values 122 print*,'Variable gas volume mixing ratios:' 123 do n=1,L_REFVAR 124 !print*,n,'.',wrefvar(n),' kg/kg' ! pay attention! 125 print*,n,'.',wrefvar(n),' mol/mol' 126 end do 127 print*,'' 85 endif 86 87 L_REFVAR = 1 ! JVO 2017 : set to 1 to keep the code running until the new variable species treatment 128 88 129 89 !======================================================================= … … 628 588 enddo 629 589 630 endif 631 590 elseif (igas .eq. igas_CH4) then 591 592 ! first do self-induced absorption 593 dummy = -9999 594 call interpolateCH4CH4(200.D+0,200.D+0,7500.D+0,testcont,.true.,dummy) 595 ! then cross-interactions with other gases 596 do jgas=1,ngasmx 597 if (jgas .eq. igas_N2) then 598 dummy = -9999 599 call interpolateN2CH4(200.D+0,250.0D+0,100000.D+0,5000.D+0,testcont,.true.,dummy) 600 endif 601 enddo 602 603 endif 604 632 605 enddo 633 606 endif … … 645 618 IF( ALLOCATED( gasv8 ) ) DEALLOCATE( gasv8 ) 646 619 IF( ALLOCATED( pgasref ) ) DEALLOCATE( pgasref ) 647 IF( ALLOCATED( gastype ) ) DEALLOCATE( gastype )648 620 !$OMP END MASTER 649 621 !$OMP BARRIER -
trunk/LMDZ.TITAN/libf/phytitan/tpindex.F
r1616 r1648 1 subroutine tpindex(pw,tw,qvar,pref,tref,wrefvar,LCOEF,MT,MP, 2 & NVAR,wratio) 1 subroutine tpindex(pw,tw,pref,tref,LCOEF,MT,MP) 3 2 4 3 !================================================================== … … 6 5 ! Purpose 7 6 ! ------- 8 ! Interpolate K-coefficients to the given P,T and Qvar values.7 ! Interpolate K-coefficients to the given P,T. 9 8 ! 10 9 ! Notes … … 58 57 real*8 Tref(L_NTREF) 59 58 real*8 pref(L_PINT) 60 real*8 wrefvar(L_REFVAR)61 59 62 integer MT, MP, N, M, NP , NVAR63 real*8 PW, TW , Qvar, wratio60 integer MT, MP, N, M, NP 61 real*8 PW, TW 64 62 real*8 PWL, LCOEF(4), T, U 65 63 … … 143 141 LCOEF(4) = (1.0-T)*U 144 142 145 ! Get the indicies for abundance of the varying species. There are 10 sets of146 ! k-coefficients with differing amounts of variable vs. constant gas.147 148 IF(QVAR.le.WREFVAR(1)) then149 NVAR = 1150 WRATIO = 0.0D0 ! put all the weight on the first point151 ELSEIF(QVAR.ge.WREFVAR(L_REFVAR)) then152 NVAR = L_REFVAR-1 ! TB16 in order to not oversize NVAr when doing153 !NVAR+1154 WRATIO = 1.00D0 ! put all the weight on the last point155 ELSE156 DO N=2,L_REFVAR157 IF(QVAR.GE.WREFVAR(N-1) .and. QVAR.lt.WREFVAR(N)) then158 NVAR = N-1159 WRATIO = (QVAR - WREFVAR(N-1))/(WREFVAR(N) - WREFVAR(N-1))160 GOTO 30161 END IF162 END DO163 END IF164 165 143 30 CONTINUE 166 144 -
trunk/LMDZ.TITAN/libf/phytitan/tracer_h.F90
r1647 r1648 19 19 real varian ! Characteristic variance of log-normal distribution 20 20 real r3n_q ! used to compute r0 from number and mass mixing ratio 21 real rho_dust ! Mars dust density (kg.m-3)22 21 real ref_r0 ! for computing reff=ref_r0*r0 (in log.n. distribution) 23 22 !$OMP THREADPRIVATE(noms,mmol,radius,rho_q,qext,alpha_lift,alpha_devil,qextrhor, & 24 !$OMP varian,r3n_q,r ho_dust,rho_ice,ref_r0)23 !$OMP varian,r3n_q,ref_r0) 25 24 26 25 ! tracer indexes: these are initialized in initracer and should be 0 if the
Note: See TracChangeset
for help on using the changeset viewer.