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

Last change on this file since 2236 was 1943, checked in by jvatant, 7 years ago

Add XIOS outputs for chemistry including "*_tot" fields (concat GCM+upper atm : 0->1300km )
Only in pseudo-pressure axis for now, pseudo-altitude TBD.
--JVO

File size: 3.8 KB
Line 
1SUBROUTINE chem_settings(nid,ngrid,nlayer,indextime)
2
3! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
4!
5! Author : Jan Vatant d'Ollone (2018)
6! ------
7!
8! Purpose : + Intialise upper atmosphere chemistry pressure grid
9! -------   and composition fields.
10!           + This subroutine is called in phyetat0 and reads
11!           from a NetCDF "startfi.nc" file.
12!           + The presence of pressure grid is compulsory in the
13!           file but not composition fields. The presence of the
14!           1st field is tested and then we assume there's either
15!           no one or all of the 44 chemistry scheme species.
16!
17! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
18
19USE comchem_h
20USE iostart, only: get_field, get_var, inquire_dimension_length
21USE callkeys_mod, only : callchim
22
23USE vertical_layers_mod, only: presnivs, pseudoalt
24
25IMPLICIT NONE
26
27!======================================================================
28!  INPUTS :
29!  --------
30  INTEGER,INTENT(IN)  :: nid            ! Input Netcdf file ID
31  INTEGER,INTENT(IN)  :: ngrid          ! # of horizontal grid points
32  INTEGER,INTENT(IN)  :: nlayer         ! # of vertical layers
33  INTEGER,INTENT(IN)  :: indextime      ! position on time axis
34!======================================================================
35! local variables:
36  REAL :: phi0, phi
37
38  INTEGER :: ierr       ! status (returned by NetCDF functions)
39  INTEGER :: nvarid     ! ID of NetCDF variable
40  INTEGER :: dimid      ! ID of NetCDF dimension
41 
42  INTEGER :: ilay, iq
43 
44  LOGICAL ::  found
45 
46  CHARACTER(LEN=13) :: modname
47!======================================================================
48
49  ! 0. Start by reading how many layers of upper chemistry there are
50 
51  nlaykim_up=inquire_dimension_length("upper_chemistry_layers")
52 
53  ! 1. Allocates arrays in comchem_h
54 
55  CALL ini_comchem_h(ngrid)
56
57  ! 2. Load upper chemistry pressure grid
58 
59  CALL get_var("preskim",preskim,found)
60  IF (.NOT.found) THEN
61    CALL abort_physic(modname,"Failed loading <preskim>",1)
62  ENDIF
63  WRITE(*,*) "chem_settings: Upper chemistry pressure grid <preskim> range:", &
64               maxval(preskim), minval(preskim)
65               
66  ! 3. Compute others chemistry grid
67 
68  ! a. Total pressure grid (0->1300km)
69  DO ilay=1,nlayer ! GCM levels
70    preskim_tot(ilay) = presnivs(ilay)
71  ENDDO
72  DO ilay=1,nlaykim_up ! Upper chemistry
73    preskim_tot(ilay+nlayer) = preskim(ilay)
74  ENDDO
75 
76  ! b. Pseudo-altitudes ( TBD - hydrostatic equilibrium or read somewhere ?)         
77 
78  ! 4. Inquire ( and load ) upper chemistry composition fields
79 
80  CALL get_field("H_up",ykim_up(1,:,:),found,indextime)
81  IF (.NOT.found) THEN
82 
83    ! We assume we can't do uncomplete chemistry
84    WRITE(*,*) "chem_settings: No upper chemistry fields."
85   
86    IF ( callchim ) THEN ! if chemistry we must have the upper fields !
87      CALL abort_physic(modname,"Failed loading uppper chemistry fields, whereas callchim set to true !",1)
88    ENDIF
89   
90    DEALLOCATE(ykim_up) ! it will be useless
91    DEALLOCATE(ykim_tot) ! it will be useless
92   
93  ELSE
94 
95    WRITE(*,*) "chem_settings: H in upper atmosphere <H_up> range:", &
96               minval(ykim_up(1,:,:)), maxval(ykim_up(1,:,:))
97               
98    ! Load others fields if first one found only as we assume we can't do uncomplete chemistry
99    ! NB : We assume a given order of the 44 chemistry species !!
100    ! ( H=1, H2=2 ..., C4N2=44) -> cf comchem_h
101   
102    DO iq=2,nkim
103      CALL get_field(trim(cnames(iq))//"_up",ykim_up(iq,:,:),found,indextime)
104      IF (.NOT.found) THEN
105        CALL abort_physic(modname,"Failed loading <"//trim(cnames(iq))//"_up>",1)
106      ENDIF
107      WRITE(*,*) "chem_settings: "//trim(cnames(iq))//" in upper atmosphere <"//trim(cnames(iq))//"_up> range:", &
108                 minval(ykim_up(iq,:,:)), maxval(ykim_up(iq,:,:))
109    ENDDO
110     
111  ENDIF ! of if H_up found
112 
113END SUBROUTINE chem_settings
Note: See TracBrowser for help on using the repository browser.