source: trunk/LMDZ.VENUS/libf/phyvenus/hrtherm.F @ 3567

Last change on this file since 3567 was 2836, checked in by abierjon, 2 years ago

VENUS GCM:

INCLUDING THE IONOSPHERE CODE IN VENUS GCM


ATTENTION: INCREASED MEMORY DEMAND

NEEDS AT LEAST 135 GB of allocated memory

==============================================================
===> LIST OF APPENDED FILES AND INTERNAL ADDITIONS <==========
==============================================================

NEW MODEL SPECIES

  • deftank/traceur-chemistry-IONOSPHERE.def

Neutrals: 4 Species: N, NO, NO2, N(2D)

Ions: 15 species:

CO2+, CO+, O+, O2+, H+,

N2+, H2O+, OH+, C+, HCO+,

H3O+, HCO2+, N+, NO+, elec

FROM 36 to 55 chemical species

NEW KEYWORD OF PHYSIQ.DEF

  • deftank/physiq-96x96x90-chemistry-IONOSPHERE.def
  • ok_ionchem: keyword supposed to activate ion chemistry.

(be careful that n, no, no2, n2d and the ion species are in the deftank/traceur-chemistry-IONOSPHERE.def)

  • ok_jonline: keyword supposed to activate the online photochemistry

(be careful that n, no, no2 and n2d are in the traceur-chemistry-IONOSPHERE.def)

==============================================================
===> LIST OF MODIFIED PROGRAMS <=========================
==============================================================

nonoro_gwd_ran_mod.F90

  • Change EPFLUXMAX value from 5.E-3 to 1.E-3

photochemistry_venus.F90 (krates; photolysis_online; indices;)

  • Import of keywords: ok_ionchem, tuneupperatm & ok_jonline
  • addition of ion species in order
  • Forcing electroneutrality
  • Update of the reactions a001 and a002 with taking into account the other species
  • Change of formula for a002 with the formulation of Baulch et al., 1976 (confirmed by Smith and Robertson, 2008)

photolysis_mod.F90

  • Modification of the rdsolarflux subroutine to include interpolation with Atlas1 and Atlas3 in connection with E10.7

concentration2.F90

  • Added chemical species n2d, no, no2 and n in the conductivity calculation.

The ions have been excluded because their sum is 105 times less dense than the neutrals and
their thermal conductivity is unknown

iono_h.F90

  • Addition of the phdisrate routine
  • replace the electronic temperature of Mars by that of

origin = 1: Theis et al. 1980 (Venus) with bilinear interpolation altitude/cos(SZA)
origin = 2: Theis et al. 1984 (Venus) with the formula of the electronic temperature at high solar activity

  • addition of an ion temperature model based on VIRA

cleshphys.h

  • added ok_ionchem & ok_jonline in COMMON/clesphys_l/

conf_phys.f90

  • add ok_ionchem & ok_jonline as parameters to read from physiq.def file set to .false. by default

chemparam_mod.F90

  • Add species in M_tr and corresponding i_X. Set all i_X to zero before reading traceur-chemistry-IONOSPHERE.def
  • Added Type_tr table to differentiate species: 1 == neutral, 2 == ION, 3 == liquid, 10 == others


euvheat.F90; hrtherm.F; jthermcalc_e107.F; param_read_e107.F

  • Normalization with Mars

A.M

File size: 4.0 KB
RevLine 
[1310]1c**********************************************************************
2
[2464]3      subroutine hrtherm(ig,euvmod,rm,nespeuv,tx,iz,zenit,jtot)
[1310]4
5
6c     feb 2002        fgg           first version
7c     nov 2002        fgg           second version
8
9c**********************************************************************
10      use dimphy
[2464]11      use param_v4_h, only: ninter,nabs,jfotsout,fluxtop,freccen
12
[1310]13      implicit none
14
15c     common variables and constants
16
17
18#include "clesphys.h"
19
20
21c    local parameters and variables
22
23      real       xabsi(nabs,klev)                       !densities (cm^-3)
24      real       jergs(ninter,nabs,klev)
25     
26      integer    i,j,k,indexint          !indexes
27      character  dn
28
29
30c     input and output variables
31
32      integer    ig  ,euvmod
33      integer    nespeuv
34      real       rm(klev,nespeuv)              !density matrix (cm^-3)
35      real       jtot(klev)                    !output: heating rate(erg/s cm3)
36      real       tx(klev)                      !temperature
37      real       zenit
38      real       iz(klev)
39
40      ! tracer indexes for the EUV heating:
41!!! ATTENTION. These values have to be identical to those in euvheat.F90
42!!! If the values are changed there, the same has to be done here  !!!
43
[2836]44!      integer,parameter :: i_co2=1
45!      integer,parameter :: i_n2=13
46!      integer,parameter :: i_n=14
47!      integer,parameter :: i_o=3
48!      integer,parameter :: i_co=4
[1310]49
[2836]50      integer,parameter :: ix_co2  =  1
51      integer,parameter :: ix_co   =  2
52      integer,parameter :: ix_o    =  3
53      integer,parameter :: ix_o1d  =  4
54      integer,parameter :: ix_o2   =  5
55      integer,parameter :: ix_o3   =  6
56      integer,parameter :: ix_h    =  7
57      integer,parameter :: ix_h2   =  8
58      integer,parameter :: ix_oh   =  9
59      integer,parameter :: ix_ho2  = 10
60      integer,parameter :: ix_h2o2 = 11
61      integer,parameter :: ix_h2o  = 12
62      integer,parameter :: ix_n    = 13
63      integer,parameter :: ix_n2d  = 14
64      integer,parameter :: ix_no   = 15
65      integer,parameter :: ix_no2  = 16
66      integer,parameter :: ix_n2   = 17
[1310]67
68c*************************PROGRAM STARTS*******************************
69
70      !If nighttime, photoabsorption coefficient set to 0
71      if(zenit.gt.90.) then  !140 in the martian routine
72         dn='n'
73         else
74         dn='d'
75      end if
76      if(dn.eq.'n') then
77        do i=1,klev                                   
78              jtot(i)=0.
79        enddo       
80        return
81      endif
82
83      !initializations
84      jergs(:,:,:)=0.
85      xabsi(:,:)=0.
86      jtot(:)=0.
87      !All number densities to a single array, xabsi(species,layer)
88      ! WARNING xabs(nabs,nlev), j=1,nabs --> the values of j should
89      !         be the same for xabs than for jfotsout(indexint,j,i)
90      !
91      do i=1,klev
[2836]92         xabsi(1,i)  = rm(i,ix_co2)    ! CO2
93         xabsi(2,i)  = rm(i,ix_o2)     ! O2
94         xabsi(3,i)  = rm(i,ix_o)      ! O(3P)
95         xabsi(4,i)  = rm(i,ix_h2o)    ! H2O
96         xabsi(5,i)  = rm(i,ix_h2)     ! H2
97         xabsi(6,i)  = rm(i,ix_h2o2)   ! H2O2
[1310]98         !Only if O3, N or ion chemistry requested
[2836]99         if(euvmod.ge.1) then
100            xabsi(7,i)  = rm(i,ix_o3)  ! O3
101         endif
102         xabsi(8,i)  = rm(i,ix_n2)     ! N2
[1310]103         !Only if N or ion chemistry requested
[2836]104         if(euvmod.ge.2) then
105            xabsi(9,i)  = rm(i,ix_n)   ! N
106            xabsi(10,i) = rm(i,ix_no)  ! NO
107            xabsi(13,i) = rm(i,ix_no2) ! NO2
108         endif
109         xabsi(11,i) = rm(i,ix_co)     ! CO
110         xabsi(12,i) = rm(i,ix_h)      ! H
[1310]111      end do
112
113      !Calculation of photoabsortion coefficient
[2464]114      call jthermcalc_e107(ig,klev,euvmod,rm,nespeuv,tx,iz,zenit)
[1310]115
116      !Total photoabsorption coefficient    !  erg/(s*cm3)
117      do i=1,klev
118         jtot(i)=0.
119        do j=1,nabs
120          do indexint=1,ninter
121            jergs(indexint,j,i) = jfotsout(indexint,j,i)
122     $              * xabsi (j,i) * fluxtop(indexint) 
123     $              / (0.5e9 * freccen(indexint))
124            jtot(i)=jtot(i)+jergs(indexint,j,i)   
125 
[1442]126
[1310]127          end do
128        end do
129      end do
130
131      return
132
133      end
134
Note: See TracBrowser for help on using the repository browser.