source: CONFIG/UNIFORM/v7/ICOLMDZOR_v7/SOURCES/DYNAMICO/src/vertical/disvert_dcmip200.f90 @ 5878

Last change on this file since 5878 was 5878, checked in by aclsce, 3 years ago

Merged LMDZORv6.2.2 with ICOLMDZOR_v7 configuration te be able to launch LMDZOR experiment from ICOLMDZOR configuration.
Use of NPv6.2 physiq version in ICOLMDZOR experiments.

File size: 2.2 KB
Line 
1  MODULE disvert_dcmip200_mod
2  USE icosa
3 
4  REAL(rstd), SAVE, ALLOCATABLE,TARGET :: ap(:)
5!$OMP THREADPRIVATE(ap)
6  REAL(rstd), SAVE, ALLOCATABLE,TARGET :: bp(:)
7!$OMP THREADPRIVATE(bp)
8  REAL(rstd), SAVE, ALLOCATABLE,TARGET :: presnivs(:)
9!$OMP THREADPRIVATE(presnivs)
10  REAL(rstd), SAVE, ALLOCATABLE,TARGET :: presinter(:)
11!$OMP THREADPRIVATE(presinter)
12
13
14CONTAINS
15!=========================================================================
16
17  SUBROUTINE init_disvert
18  USE icosa
19  USE mpipara
20  IMPLICIT NONE
21 
22    ALLOCATE(ap(llm+1))
23    ALLOCATE(bp(llm+1))
24    ALLOCATE(presnivs(llm))
25    ALLOCATE(presinter(llm+1))
26   
27    CALL disvert(ap,bp,presnivs,presinter)   
28
29  END SUBROUTINE init_disvert 
30
31  SUBROUTINE disvert(ap,bp,presnivs,presinter)
32  USE icosa
33  USE mpipara
34  IMPLICIT NONE
35  REAL(rstd),INTENT(OUT) :: ap(:)
36  REAL(rstd),INTENT(OUT) :: bp(:)
37  REAL(rstd),INTENT(OUT) :: presnivs(:)
38  REAL(rstd),INTENT(OUT) :: presinter(:)
39  ! reads from run.def : ncar_dz, ncar_T0, ncar_p0, ncar_disvert_c
40  INTEGER :: l,cindx
41  REAL(rstd) ::  eta_top, eta
42  REAL(rstd),PARAMETER :: N=0.01         ! Brunt-Vaisala frequency (s-1)
43  REAL(rstd),PARAMETER :: T0=300.       ! Surface temperature at the equator (K)
44  REAL(rstd) :: Rd       
45  REAL(rstd), PARAMETER :: Gamma=0.0065       
46
47  Rd=cpp*kappa
48  ncar_dz=400 ; CALL getin('ncar_dz',ncar_dz);
49  cindx=1 ; CALL getin('ncar_disvert_c',cindx)
50
51 
52   
53  eta_top = (1-Gamma/T0*llm*ncar_dz)**(g/(Rd*Gamma)) 
54  do l = 1,llm+1
55     eta = (1-Gamma/T0*(l-1)*ncar_dz)**(g/(Rd*Gamma))
56     PRINT *,'eta ->', eta
57     bp(l) = ((eta - eta_top)/(1 - eta_top))**cindx
58     ap(l) = preff * ( eta - bp(l) )
59  ENDDO
60  bp(1)=1.
61  ap(1)=0.
62  bp(llm+1) = 0
63 
64  DO l = 1, llm
65     presnivs(l) = 0.5 *( ap(l)+bp(l)*preff + ap(l+1)+bp(l+1)*preff )
66  ENDDO
67
68  DO l=1, llm+1
69     presinter(l)= ap(l)+bp(l)*preff
70  ENDDO
71
72
73!$OMP MASTER 
74  IF (is_mpi_root) PRINT *, 'Vertical placement of model levels according to DCMIP Appendix E.3'
75  IF (is_mpi_root) PRINT *, 'Parameters : ncar_dz=', ncar_dz, '  ncar_p0=',ncar_p0, '  ncar_disvert_c=',cindx
76  IF (is_mpi_root) PRINT *, 'Isothermal amtosphere with ncar_T0=',ncar_T0 
77!$OMP END MASTER 
78
79END SUBROUTINE disvert
80
81END  MODULE disvert_dcmip200_mod
Note: See TracBrowser for help on using the repository browser.