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