source: trunk/LMDZ.TITAN/libf/phytitan/calc_rayleigh.F90 @ 2236

Last change on this file since 2236 was 1648, checked in by jvatant, 8 years ago

Modifications to custom radiative transfer to Titan
+ Enables an altitude dependant gfrac for CIA computations

-> many radical changes in su_gases and co ..
-> read vertical CH4 profile with call_profilgases
-> Now you need a 'profile.def' that I will add in the deftank

+ Added interpolate CIA routines for CH4
+ Added temporary mean aerosol profile opacity routine (disr_haze)

File size: 4.3 KB
Line 
1      subroutine calc_rayleigh
2
3!==================================================================
4!     
5!     Purpose
6!     -------
7!     Average the Rayleigh scattering in each band, weighting the
8!     average by the blackbody function at temperature tstellar.
9!     Works for an arbitrary mix of gases (currently CO2, N2 and
10!     H2 are possible).
11!     
12!     Authors
13!     -------
14!     Robin Wordsworth (2010)
15!     Jeremy Leconte (2012): Added option for variable gas. Improved water rayleigh (Bucholtz 1995).
16!
17!     Called by
18!     ---------
19!     setspv.F
20!     
21!     Calls
22!     -----
23!     none
24!     
25!==================================================================
26
27      use radinc_h, only: L_NSPECTV
28      use radcommon_h, only: WAVEV, BWNV, DWNV, tstellar, tauray, scalep
29      use gases_h
30      use comcstfi_mod, only: g, mugaz
31
32      implicit none
33
34      real*8 wl
35      integer N,Nfine,ifine,igas
36      parameter(Nfine=500.0)
37      real*8 :: P0 = 9.423D+6   ! Rayleigh scattering reference pressure in pascals.   
38
39      logical typeknown
40      real*8 tauvar,tausum,tauwei,bwidth,bstart
41      double precision df
42
43      real*8 tauconsti(ngasmx)
44      real*8 tauvari(ngasmx)
45
46      integer icantbewrong
47
48      ! tau0/p0=tau/p (Hansen 1974)
49      ! Then calculate tau0 = (8*pi^3*p_1atm)/(3*N0^2) * 4*delta^2/(g*mugaz*lambda^4)
50      ! where delta=n-1 and N0 is an amagat
51
52      typeknown=.false.
53      do igas=1,ngasmx
54         if(gfrac(igas,nivref).lt.5.e-2)then
55            print*,'Ignoring ',trim(gnom(igas)),' in Rayleigh scattering '// &
56            'as its mixing ratio is less than 0.05.'
57            ! ignore variable gas in Rayleigh calculation
58            ! ignore gases of mixing ratio < 0.05 in Rayleigh calculation
59            tauconsti(igas) = 0.0
60         else
61            if(igas.eq.igas_N2)then
62               tauconsti(igas) = (9.81/g)*8.569E-3*scalep/(P0/93.0)
63            elseif(igas.eq.igas_H2)then
64               tauconsti(igas) = (10.0/g)*0.0241*scalep/101325.0
65               !tauconsti(igas) = (10.0/g)*0.0487*scalep/(101325.0)
66               ! uses n=1.000132 from Optics, Fourth Edition.
67               ! was out by a factor 2!
68            else
69               print*,'Error in calc_rayleigh: Gas species not recognised!'
70               call abort
71            endif
72
73            if(gfrac(igas,nivref).eq.1.0)then
74               print*,'Rayleigh scattering is for a pure ',trim(gnom(igas)),' atmosphere.'
75               typeknown=.true.
76            endif
77
78         endif
79      enddo
80
81      if(.not.typeknown)then
82         print*,'Rayleigh scattering is for a mixed gas atmosphere.'
83         typeknown=.true.
84      endif
85
86 
87      do N=1,L_NSPECTV
88         
89         tausum = 0.0
90         tauwei = 0.0
91         bstart = 10000.0/BWNV(N+1)
92         bwidth = (10000.0/BWNV(N)) - (10000.0/BWNV(N+1))
93         do ifine=1,Nfine
94            wl=bstart+dble(ifine)*bwidth/Nfine
95
96            tauvar=0.0
97            do igas=1,ngasmx
98               if(gfrac(igas,nivref).lt.5.e-2)then
99                  ! ignore variable gas in Rayleigh calculation
100                  ! ignore gases of mixing ratio < 0.05 in Rayleigh calculation
101                  tauvari(igas)   = 0.0
102               else
103                  if(igas.eq.igas_N2)then
104                     tauvari(igas) = (1.0+0.0113/wl**2+0.00013/wl**4)/wl**4
105                  elseif(igas.eq.igas_H2)then
106                     tauvari(igas) = 1.0/wl**4
107                  else
108                     print*,'Error in calc_rayleigh: Gas species not recognised!'
109                     call abort
110                  endif
111               endif
112
113               tauvar=tauvar+tauconsti(igas)*tauvari(igas)*gfrac(igas,nivref)
114
115            enddo
116
117            call blackl(dble(wl*1e-6),dble(tstellar),df)
118            df=df*bwidth/Nfine
119            tauwei=tauwei+df
120            tausum=tausum+tauvar*df
121         
122         enddo
123         TAURAY(N)=tausum/tauwei
124         ! we multiply by scalep here (100) because plev, which is used in optcv,
125         ! is in units of mBar, so we need to convert.
126
127      end do
128
129      IF (L_NSPECTV > 6) THEN
130        icantbewrong = L_NSPECTV-6
131        print*,'At 1 atm and lambda = ',WAVEV(icantbewrong),' um'
132        print*,'tau_R = ',TAURAY(icantbewrong)*1013.25
133        print*,'sig_R = ',TAURAY(icantbewrong)*g*mugaz*1.67e-27*100, &
134               'cm^2 molecule^-1'
135      ENDIF
136
137    end subroutine calc_rayleigh
Note: See TracBrowser for help on using the repository browser.