source: LMDZ6/trunk/libf/dyn3d/sw_case_williamson91_6.f90 @ 5273

Last change on this file since 5273 was 5272, checked in by abarral, 2 days ago

Turn paramet.h into a module

  • Property copyright set to
    Name of program: LMDZ
    Creation date: 1984
    Version: LMDZ5
    License: CeCILL version 2
    Holder: Laboratoire de m\'et\'eorologie dynamique, CNRS, UMR 8539
    See the license file in the root directory
File size: 4.2 KB
Line 
1!
2! $Id $
3!
4SUBROUTINE sw_case_williamson91_6(vcov,ucov,teta,masse,ps)
5
6  !=======================================================================
7  !
8  !   Author:    Thomas Dubos      original: 26/01/2010
9  !   -------
10  !
11  !   Subject:
12  !   ------
13  !   Realise le cas-test 6 de Williamson et al. (1991) : onde de Rossby-Haurwitz
14  !
15  !   Method:
16  !   --------
17  !
18  !   Interface:
19  !   ----------
20  !
21  !  Input:
22  !  ------
23  !
24  !  Output:
25  !  -------
26  !
27  !=======================================================================
28  USE comconst_mod, ONLY: cpp, omeg, rad
29  USE comvert_mod, ONLY: ap, bp, preff
30
31  USE dimensions_mod, ONLY: iim, jjm, llm, ndm
32USE paramet_mod_h, ONLY: iip1, iip2, iip3, jjp1, llmp1, llmp2, llmm1, kftd, ip1jm, ip1jmp1, &
33          ip1jmi1, ijp1llm, ijmllm, mvar, jcfil, jcfllm
34IMPLICIT NONE
35  !-----------------------------------------------------------------------
36  !   Declararations:
37  !   ---------------
38
39
40
41  include "comgeom.h"
42  include "iniprint.h"
43
44  !   Arguments:
45  !   ----------
46
47  !   variables dynamiques
48  REAL :: vcov(ip1jm,llm),ucov(ip1jmp1,llm) ! vents covariants
49  REAL :: teta(ip1jmp1,llm)                 ! temperature potentielle
50  REAL :: ps(ip1jmp1)                       ! pression  au sol
51  REAL :: masse(ip1jmp1,llm)                ! masse d'air
52  REAL :: phis(ip1jmp1)                     ! geopotentiel au sol
53
54  !   Local:
55  !   ------
56
57  REAL :: p (ip1jmp1,llmp1  )               ! pression aux interfac.des couches
58  REAL :: pks(ip1jmp1)                      ! exner au  sol
59  REAL :: pk(ip1jmp1,llm)                   ! exner au milieu des couches
60  REAL :: pkf(ip1jmp1,llm)                  ! exner filt.au milieu des couches
61  REAL :: alpha(ip1jmp1,llm),beta(ip1jmp1,llm)
62
63  REAL :: sinth,costh,costh2, Ath,Bth,Cth, lon,dps
64  INTEGER :: i,j,ij
65
66  REAL, PARAMETER    :: rho=1 ! masse volumique de l'air (arbitraire)
67  REAL, PARAMETER    :: K    = 7.848e-6  ! K = \omega
68  REAL, PARAMETER    :: gh0  = 9.80616 * 8e3
69  INTEGER, PARAMETER :: R0=4, R1=R0+1, R2=R0+2         ! mode 4
70  ! NB : rad = 6371220 dans W91 (6371229 dans LMDZ)
71   ! omeg = 7.292e-5 dans W91 (7.2722e-5 dans LMDZ)
72
73  IF(0==0) THEN
74  ! Williamson et al. (1991) : onde de Rossby-Haurwitz
75     teta = preff/rho/cpp
76  ! geopotentiel (pression de surface)
77     do j=1,jjp1
78        costh2 = cos(rlatu(j))**2
79        Ath = (R0+1)*(costh2**2) + (2*R0*R0-R0-2)*costh2 - 2*R0*R0
80        Ath = .25*(K**2)*(costh2**(R0-1))*Ath
81        Ath = .5*K*(2*omeg+K)*costh2 + Ath
82        Bth = (R1*R1+1)-R1*R1*costh2
83        Bth = 2*(omeg+K)*K/(R1*R2) * (costh2**(R0/2))*Bth
84        Cth = R1*costh2 - R2
85        Cth = .25*K*K*(costh2**R0)*Cth
86        do i=1,iip1
87           ij=(j-1)*iip1+i
88           lon = rlonv(i)
89           dps = Ath + Bth*cos(R0*lon) + Cth*cos(2*R0*lon)
90           ps(ij) = rho*(gh0 + (rad**2)*dps)
91        enddo
92     enddo
93     write(lunout,*) 'W91 ps', MAXVAL(ps), MINVAL(ps)
94  ! vitesse zonale ucov
95     do j=1,jjp1
96        costh  = cos(rlatu(j))
97        costh2 = costh**2
98        Ath = rad*K*costh
99        Bth = R0*(1-costh2)-costh2
100        Bth = rad*K*Bth*(costh**(R0-1))
101        do i=1,iip1
102           ij=(j-1)*iip1+i
103           lon = rlonu(i)
104           ucov(ij,1) = (Ath + Bth*cos(R0*lon))
105        enddo
106     enddo
107     write(lunout,*) 'W91 u', MAXVAL(ucov(:,1)), MINVAL(ucov(:,1))
108     ucov(:,1)=ucov(:,1)*cu
109  ! vitesse meridienne vcov
110     do j=1,jjm
111        sinth  = sin(rlatv(j))
112        costh  = cos(rlatv(j))
113        Ath = -rad*K*R0*sinth*(costh**(R0-1))
114        do i=1,iip1
115           ij=(j-1)*iip1+i
116           lon = rlonv(i)
117           vcov(ij,1) = Ath*sin(R0*lon)
118        enddo
119     enddo
120     write(lunout,*) 'W91 v', MAXVAL(vcov(:,1)), MINVAL(vcov(:,1))
121     vcov(:,1)=vcov(:,1)*cv
122
123      ! ucov=0
124      ! vcov=0
125  ELSE
126  ! test non-tournant, onde se propageant en latitude
127     do j=1,jjp1
128        do i=1,iip1
129           ij=(j-1)*iip1+i
130           ps(ij) = 1e5*(1 + .1*exp(-100*(1+sin(rlatu(j)))**2) )
131        enddo
132     enddo
133
134  ! rho = preff/(cpp*teta)
135     teta = .01*preff/cpp   ! rho = 100 ; phi = ps/rho = 1e3 ; c=30 m/s = 2600 km/j = 23 degres / j
136     ucov=0.
137     vcov=0.
138  END IF
139
140  CALL pression ( ip1jmp1, ap, bp, ps, p       )
141  CALL massdair(p,masse)
142
143END SUBROUTINE sw_case_williamson91_6
144!-----------------------------------------------------------------------
Note: See TracBrowser for help on using the repository browser.