source: codes/icosagcm/trunk/src/disvert_dcmip200.f90 @ 123

Last change on this file since 123 was 116, checked in by ymipsl, 12 years ago

Add dcmip 2.0-0 vertical discretisation

YM

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