1 |
|
|
! $Id: pres2lev.F 1179 2009-06-11 14:18:47Z jghattas $ |
2 |
|
|
! |
3 |
|
|
MODULE pres2lev_mod |
4 |
|
|
|
5 |
|
|
CONTAINS |
6 |
|
|
|
7 |
|
|
!****************************************************** |
8 |
|
|
SUBROUTINE pres2lev(varo,varn,lmo,lmn,po,pn,ni,nj,ok_invertp) |
9 |
|
|
! |
10 |
|
|
! interpolation lineaire pour passer |
11 |
|
|
! a une nouvelle discretisation verticale pour |
12 |
|
|
! les variables de GCM |
13 |
|
|
! Francois Forget (01/1995) |
14 |
|
|
! MOdif remy roca 12/97 pour passer de pres2sig |
15 |
|
|
! Modif F.Codron 07/08 po en 3D |
16 |
|
|
!********************************************************** |
17 |
|
|
|
18 |
|
|
IMPLICIT NONE |
19 |
|
|
|
20 |
|
|
! Declarations: |
21 |
|
|
! ============== |
22 |
|
|
! |
23 |
|
|
! ARGUMENTS |
24 |
|
|
! """"""""" |
25 |
|
|
LOGICAL, INTENT(IN) :: ok_invertp |
26 |
|
|
INTEGER, INTENT(IN) :: lmo ! dimensions ancienne couches |
27 |
|
|
INTEGER, INTENT(IN) :: lmn ! dimensions nouvelle couches |
28 |
|
|
|
29 |
|
|
INTEGER, INTENT(IN) :: ni,nj ! nombre de point horizontal |
30 |
|
|
REAL, INTENT(IN) :: po(ni*nj,lmo) ! niveau de pression ancienne grille |
31 |
|
|
REAL, INTENT(IN) :: pn(ni*nj,lmn) ! niveau de pression nouvelle grille |
32 |
|
|
|
33 |
|
|
REAL, INTENT(IN) :: varo(ni*nj,lmo) ! var dans l'ancienne grille |
34 |
|
|
REAL, INTENT(OUT) :: varn(ni*nj,lmn) ! var dans la nouvelle grille |
35 |
|
|
|
36 |
|
|
REAL :: zvaro(ni*nj,lmo),zpo(ni*nj,lmo) |
37 |
|
|
|
38 |
|
|
! Autres variables |
39 |
|
|
! """""""""""""""" |
40 |
|
|
INTEGER :: ln ,lo, k |
41 |
|
|
REAL :: coef |
42 |
|
|
|
43 |
|
|
|
44 |
|
|
! Inversion de l'ordre des niveaux verticaux |
45 |
|
|
IF (ok_invertp) THEN |
46 |
|
|
DO lo=1,lmo |
47 |
|
|
DO k=1,ni*nj |
48 |
|
|
zpo(k,lo)=po(k,lmo+1-lo) |
49 |
|
|
zvaro(k,lo)=varo(k,lmo+1-lo) |
50 |
|
|
ENDDO |
51 |
|
|
ENDDO |
52 |
|
|
ELSE |
53 |
|
|
DO lo=1,lmo |
54 |
|
|
DO k=1,ni*nj |
55 |
|
|
zpo(k,lo)=po(k,lo) |
56 |
|
|
zvaro(k,lo)=varo(k,lo) |
57 |
|
|
ENDDO |
58 |
|
|
ENDDO |
59 |
|
|
ENDIF |
60 |
|
|
|
61 |
|
|
DO ln=1,lmn |
62 |
|
|
DO lo=1,lmo-1 |
63 |
|
|
DO k=1,ni*nj |
64 |
|
|
IF (pn(k,ln) >= zpo(k,1) ) THEN |
65 |
|
|
varn(k,ln) = zvaro(k,1) |
66 |
|
|
ELSE IF (pn(k,ln) <= zpo(k,lmo)) THEN |
67 |
|
|
varn(k,ln) = zvaro(k,lmo) |
68 |
|
|
ELSE IF ( pn(k,ln) <= zpo(k,lo) .AND. pn(k,ln) > zpo(k,lo+1) ) THEN |
69 |
|
|
coef = (pn(k,ln)-zpo(k,lo)) / (zpo(k,lo+1)-zpo(k,lo)) |
70 |
|
|
varn(k,ln) = zvaro(k,lo) + coef*(zvaro(k,lo+1)-zvaro(k,lo)) |
71 |
|
|
ENDIF |
72 |
|
|
|
73 |
|
|
ENDDO |
74 |
|
|
ENDDO |
75 |
|
|
ENDDO |
76 |
|
|
|
77 |
|
|
END SUBROUTINE pres2lev |
78 |
|
|
|
79 |
|
|
END MODULE pres2lev_mod |