source: trunk/LMDZ.VENUS/libf/phyvenus/orosetup.F @ 1235

Last change on this file since 1235 was 101, checked in by slebonnois, 14 years ago

SL: modifications pour arriver a compiler le gcm VENUS !
Ca marche !
A noter: modifs de makelmdz

File size: 15.0 KB
Line 
1      SUBROUTINE orosetup
2     *         ( nlon   , nlev  , ktest
3     *         , kkcrit, kkcrith, kcrit, ksect , kkhlim
4     *         , kkenvh, kknu  , kknu2
5     *         , paphm1, papm1 , pum1 , pvm1, ptm1, pgeom1, pstab, pstd
6     *         , prho  , pri   , ptau, pvph, ppsi, pzdep
7     *         , pulow , pvlow 
8     *         , ptheta, pgam, pmea, ppic, pval
9     *         , pnu  ,  pd1  ,  pd2  ,pdmod  )
10C
11c**** *gwsetup*
12c
13c     purpose.
14c     --------
15c     SET-UP THE ESSENTIAL PARAMETERS OF THE SSO DRAG SCHEME:
16C     DEPTH OF LOW WBLOCKED LAYER, LOW-LEVEL FLOW, BACKGROUND
17C     STRATIFICATION.....
18c
19c**   interface.
20c     ----------
21c          from *orodrag*
22c
23c        explicit arguments :
24c        --------------------
25c     ==== inputs ===
26c
27c nlon----input-I-Total number of horizontal points that get into physics
28c nlev----input-I-Number of vertical levels
29c ktest--input-I: Flags to indicate active points
30c
31c ptsphy--input-R-Time-step (s)
32c paphm1--input-R: pressure at model 1/2 layer
33c papm1---input-R: pressure at model layer
34c pgeom1--input-R: Altitude of layer above ground
35c VENUS ATTENTION: CP VARIABLE PSTAB CALCULE EN AMONT DES PARAMETRISATIONS
36c pstab-----R-: Brunt-Vaisala freq.^2 at 1/2 layers (input except klev+1)
37c ptm1, pum1, pvm1--R-: t, u and v
38c pmea----input-R-Mean Orography (m)
39C pstd----input-R-SSO standard deviation (m)
40c psig----input-R-SSO slope
41c pgam----input-R-SSO Anisotropy
42c pthe----input-R-SSO Angle
43c ppic----input-R-SSO Peacks elevation (m)
44c pval----input-R-SSO Valleys elevation (m)
45
46c     ==== outputs ===
47c pulow, pvlow -output-R: Low-level wind
48c kkcrit----I-: Security value for top of low level flow
49c kcrit-----I-: Critical level
50c ksect-----I-: Not used
51c kkhlim----I-: Not used
52c kkenvh----I-: Top of blocked flow layer
53c kknu------I-: Layer that sees mountain peacks
54c kknu2-----I-: Layer that sees mountain peacks above mountain mean
55c kknub-----I-: Layer that sees mountain mean above valleys
56c prho------R-: Density at 1/2 layers
57c pri-------R-: Background Richardson Number, Wind shear measured along GW stress
58c pvph------R-: Wind in  plan of GW stress, Half levels.
59c ppsi------R-: Angle between low level wind and SS0 main axis.
60c pd1-------R-| Compared the ratio of the stress
61c pd2-------R-| that is along the wind to that Normal to it.
62c               pdi define the plane of low level stress
63c               compared to the low level wind.
64c see p. 108 Lott & Miller (1997).                     
65c pdmod-----R-: Norme of pdi
66
67c     === local arrays ===
68c
69c zvpf------R-: Wind projected in the plan of the low-level stress.
70
71c     ==== outputs ===
72c
73c        implicit arguments :   none
74c        --------------------
75c
76c     method.
77c     -------
78c
79c
80c     externals.
81c     ----------
82c
83c
84c     reference.
85c     ----------
86c
87c        see ecmwf research department documentation of the "i.f.s."
88c
89c     author.
90c     -------
91c
92c     modifications.
93c     --------------
94c     f.lott  for the new-gwdrag scheme november 1993
95c
96c-----------------------------------------------------------------------
97      use dimphy
98      implicit none
99
100#include "dimensions.h"
101#include "paramet.h"
102
103#include "YOMCST.h"
104#include "YOEGWD.h"
105
106c-----------------------------------------------------------------------
107c
108c*       0.1   arguments
109c              ---------
110c
111      integer nlon,nlev
112      integer kkcrit(nlon),kkcrith(nlon),kcrit(nlon),ksect(nlon),
113     *        kkhlim(nlon),ktest(nlon),kkenvh(nlon)
114
115c
116      real paphm1(nlon,klev+1),papm1(nlon,klev),pum1(nlon,klev),
117     *     pvm1(nlon,klev),ptm1(nlon,klev),pgeom1(nlon,klev),
118     *     prho(nlon,klev+1),pri(nlon,klev+1),pstab(nlon,klev+1),
119     *     ptau(nlon,klev+1),pvph(nlon,klev+1),ppsi(nlon,klev+1),
120     *     pzdep(nlon,klev)
121       real pulow(nlon),pvlow(nlon),ptheta(nlon),pgam(nlon),pnu(nlon),
122     *     pd1(nlon),pd2(nlon),pdmod(nlon)
123      real pstd(nlon),pmea(nlon),ppic(nlon),pval(nlon)
124c
125c-----------------------------------------------------------------------
126c
127c*       0.2   local arrays
128c              ------------
129c
130c
131      integer ilevh ,jl,jk,iii
132      real zcons1,zhgeo,zu,zphi
133      real zvt1,zvt2,zdwind,zwind,zdelp
134      real zstabm,zstabp,zrhom,zrhop
135      logical lo
136      logical ll1(klon,klev+1)
137      integer kknu(klon),kknu2(klon),kknub(klon),kknul(klon),
138     *        kentp(klon),ncount(klon) 
139c
140      real zhcrit(klon,klev),zvpf(klon,klev),
141     *     zdp(klon,klev)
142      real znorm(klon),zb(klon),zc(klon),
143     *      zulow(klon),zvlow(klon),znup(klon),znum(klon)
144
145c     ------------------------------------------------------------------
146c
147c*         1.    initialization
148c                --------------
149c
150c       PRINT *,' in orosetup'
151 100  continue
152c
153c     ------------------------------------------------------------------
154c
155c*         1.1   computational constants
156c                -----------------------
157c
158 110  continue
159c
160      ilevh =klev/3
161c
162      zcons1=1./rd
163c
164c     ------------------------------------------------------------------
165c
166c*         2.
167c                --------------
168c
169 200  continue
170c
171c     ------------------------------------------------------------------
172c
173c*         2.1     define low level wind, project winds in plane of
174c*                 low level wind, determine sector in which to take
175c*                 the variance and set indicator for critical levels.
176c
177c
178c
179      do 2001 jl=kidia,kfdia
180      kknu(jl)    =klev
181      kknu2(jl)   =klev
182      kknub(jl)   =klev
183      kknul(jl)   =klev
184      pgam(jl) =max(pgam(jl),gtsec)
185      ll1(jl,klev+1)=.false.
186 2001 continue
187c
188c Ajouter une initialisation (L. Li, le 23fev99):
189c
190      do jk=klev,ilevh,-1
191      do jl=kidia,kfdia
192      ll1(jl,jk)= .false.
193      ENDDO
194      ENDDO
195c
196c*      define top of low level flow
197c       ----------------------------
198      do 2002 jk=klev,ilevh,-1
199      do 2003 jl=kidia,kfdia
200      if(ktest(jl).eq.1) then
201      lo=(paphm1(jl,jk)/paphm1(jl,klev+1)).ge.gsigcr
202      if(lo) then
203        kkcrit(jl)=jk
204      endif
205      zhcrit(jl,jk)=ppic(jl)-pval(jl)           
206      zhgeo=pgeom1(jl,jk)/rg
207      ll1(jl,jk)=(zhgeo.gt.zhcrit(jl,jk))
208C     if(ll1(jl,jk).xor.ll1(jl,jk+1)) then
209      if(ll1(jl,jk).neqv.ll1(jl,jk+1)) then
210        kknu(jl)=jk
211      endif
212      if(.not.ll1(jl,ilevh))kknu(jl)=ilevh
213      endif
214 2003 continue
215 2002 continue
216      do 2004 jk=klev,ilevh,-1
217      do 2005 jl=kidia,kfdia
218      if(ktest(jl).eq.1) then
219      zhcrit(jl,jk)=ppic(jl)-pmea(jl)
220      zhgeo=pgeom1(jl,jk)/rg
221      ll1(jl,jk)=(zhgeo.gt.zhcrit(jl,jk))
222      if(ll1(jl,jk) .neqv. ll1(jl,jk+1)) then
223        kknu2(jl)=jk
224      endif
225      if(.not.ll1(jl,ilevh))kknu2(jl)=ilevh
226      endif
227 2005 continue
228 2004 continue
229      do 2006 jk=klev,ilevh,-1
230      do 2007 jl=kidia,kfdia
231      if(ktest(jl).eq.1) then
232      zhcrit(jl,jk)=amin1(ppic(jl)-pmea(jl),pmea(jl)-pval(jl))
233      zhgeo=pgeom1(jl,jk)/rg
234      ll1(jl,jk)=(zhgeo.gt.zhcrit(jl,jk))
235c     if(ll1(jl,jk).xor.ll1(jl,jk+1)) then
236      if(ll1(jl,jk).neqv.ll1(jl,jk+1)) then
237        kknub(jl)=jk
238      endif
239      if(.not.ll1(jl,ilevh))kknub(jl)=ilevh
240      endif
241 2007 continue
242 2006 continue
243c
244      do 2010 jl=kidia,kfdia 
245      if(ktest(jl).eq.1) then
246      kknu(jl)=min(kknu(jl),nktopg)
247      kknu2(jl)=min(kknu2(jl),nktopg)
248      kknub(jl)=min(kknub(jl),nktopg)
249      kknul(jl)=klev
250      endif
251 2010 continue     
252c
253 210  continue
254c
255cc*     initialize various arrays
256c
257      do 2107 jl=kidia,kfdia
258      prho(jl,klev+1)  =0.0
259cym correction en attendant mieux
260      prho(jl,1)  =0.0     
261      pstab(jl,klev+1) =0.0
262      pstab(jl,1)      =0.0
263      pri(jl,klev+1)   =9999.0
264      ppsi(jl,klev+1)  =0.0
265      pri(jl,1)        =0.0
266      pvph(jl,1)       =0.0
267      pvph(jl,klev+1)  =0.0
268cym correction en attendant mieux
269cym      pvph(jl,klev)    =0.0
270      pulow(jl)        =0.0
271      pvlow(jl)        =0.0
272      zulow(jl)        =0.0
273      zvlow(jl)        =0.0
274      kkcrith(jl)      =klev
275      kkenvh(jl)       =klev
276      kentp(jl)        =klev
277      kcrit(jl)        =1
278      ncount(jl)       =0
279      ll1(jl,klev+1)   =.false.
280 2107 continue
281c
282c*     define flow density and stratification (rho and N2)
283c      at semi layers.
284c      -------------------------------------------------------
285c
286      do 223 jk=klev,2,-1
287      do 222 jl=kidia,kfdia
288      if(ktest(jl).eq.1) then
289        zdp(jl,jk)=papm1(jl,jk)-papm1(jl,jk-1)
290        prho(jl,jk)=2.*paphm1(jl,jk)*zcons1/(ptm1(jl,jk)+ptm1(jl,jk-1))
291      endif
292  222 continue
293  223 continue
294c      print*,"altitude(m)=",pgeom1(kfdia/2,:)
295c      print*,"pression(Pa)=",papm1(kfdia/2,:)
296c
297c********************************************************************
298c
299c*     define Low level flow (between ground and peacks-valleys)
300c      ---------------------------------------------------------
301      do 2115 jk=klev,ilevh,-1
302      do 2116 jl=kidia,kfdia
303      if(ktest(jl).eq.1)  then
304      if(jk.ge.kknu2(jl).and.jk.le.kknul(jl)) then
305        pulow(jl)=pulow(jl)+pum1(jl,jk)*(paphm1(jl,jk+1)-paphm1(jl,jk))
306        pvlow(jl)=pvlow(jl)+pvm1(jl,jk)*(paphm1(jl,jk+1)-paphm1(jl,jk))
307        pstab(jl,klev+1)=pstab(jl,klev+1)
308     c                   +pstab(jl,jk)*(paphm1(jl,jk+1)-paphm1(jl,jk))
309        prho(jl,klev+1)=prho(jl,klev+1)
310     c                   +prho(jl,jk)*(paphm1(jl,jk+1)-paphm1(jl,jk))
311      end if
312      endif
313 2116 continue
314 2115 continue
315      do 2110 jl=kidia,kfdia
316      if(ktest(jl).eq.1)  then
317      pulow(jl)=pulow(jl)/(paphm1(jl,kknul(jl)+1)-paphm1(jl,kknu2(jl)))
318      pvlow(jl)=pvlow(jl)/(paphm1(jl,kknul(jl)+1)-paphm1(jl,kknu2(jl)))
319      znorm(jl)=max(sqrt(pulow(jl)**2+pvlow(jl)**2),gvsec)
320      pvph(jl,klev+1)=znorm(jl)
321      pstab(jl,klev+1)=pstab(jl,klev+1)
322     c                /(paphm1(jl,kknul(jl)+1)-paphm1(jl,kknu2(jl)))
323      prho(jl,klev+1)=prho(jl,klev+1)
324     c                /(paphm1(jl,kknul(jl)+1)-paphm1(jl,kknu2(jl)))
325      endif
326 2110 continue
327
328c
329c*******  setup orography orientation relative to the low level
330C       wind and define parameters of the Anisotropic wave stress.
331c
332      do 2112 jl=kidia,kfdia
333      if(ktest(jl).eq.1)  then
334        lo=(pulow(jl).lt.gvsec).and.(pulow(jl).ge.-gvsec)
335        if(lo) then
336          zu=pulow(jl)+2.*gvsec
337        else
338          zu=pulow(jl)
339        endif
340        zphi=atan(pvlow(jl)/zu)
341        ppsi(jl,klev+1)=ptheta(jl)*rpi/180.-zphi
342        zb(jl)=1.-0.18*pgam(jl)-0.04*pgam(jl)**2
343        zc(jl)=0.48*pgam(jl)+0.3*pgam(jl)**2
344        pd1(jl)=zb(jl)-(zb(jl)-zc(jl))*(sin(ppsi(jl,klev+1))**2)
345        pd2(jl)=(zb(jl)-zc(jl))*sin(ppsi(jl,klev+1))
346     *                         *cos(ppsi(jl,klev+1))
347        pdmod(jl)=sqrt(pd1(jl)**2+pd2(jl)**2)
348      endif
349 2112 continue
350c
351c  ************ projet flow in plane of lowlevel stress *************
352C  ************ Find critical levels...                 *************
353c
354      do 213 jk=1,klev
355      do 212 jl=kidia,kfdia
356      if(ktest(jl).eq.1)  then
357        zvt1       =pulow(jl)*pum1(jl,jk)+pvlow(jl)*pvm1(jl,jk)
358        zvt2       =-pvlow(jl)*pum1(jl,jk)+pulow(jl)*pvm1(jl,jk)
359        zvpf(jl,jk)=(zvt1*pd1(jl)+zvt2*pd2(jl))/(znorm(jl)*pdmod(jl))
360      endif
361      ptau(jl,jk)  =0.0
362      pzdep(jl,jk) =0.0
363      ppsi(jl,jk)  =0.0
364      ll1(jl,jk)   =.false.
365  212 continue
366  213 continue
367      do 215 jk=2,klev
368      do 214 jl=kidia,kfdia
369      if(ktest(jl).eq.1) then
370        zdp(jl,jk)=papm1(jl,jk)-papm1(jl,jk-1)
371        pvph(jl,jk)=((paphm1(jl,jk)-papm1(jl,jk-1))*zvpf(jl,jk)+
372     *            (papm1(jl,jk)-paphm1(jl,jk))*zvpf(jl,jk-1))
373     *            /zdp(jl,jk)
374        if(pvph(jl,jk).lt.gvsec) then
375          pvph(jl,jk)=gvsec
376          kcrit(jl)=jk
377        endif
378      endif
379  214 continue
380  215 continue
381c
382c*         2.3     mean flow richardson number.
383c
384  230 continue
385c
386      do 232 jk=2,klev
387      do 231 jl=kidia,kfdia
388      if(ktest(jl).eq.1) then
389        zdwind=max(abs(zvpf(jl,jk)-zvpf(jl,jk-1)),gvsec)
390        pri(jl,jk)=pstab(jl,jk)*(zdp(jl,jk)
391     *          /(rg*prho(jl,jk)*zdwind))**2
392        pri(jl,jk)=max(pri(jl,jk),grcrit)
393      endif
394  231 continue
395  232 continue
396 
397c
398c
399c*      define top of 'envelope' layer
400c       ----------------------------
401
402      do 233 jl=kidia,kfdia
403      pnu (jl)=0.0
404      znum(jl)=0.0
405 233  continue
406     
407      do 234 jk=2,klev-1
408      do 234 jl=kidia,kfdia
409     
410      if(ktest(jl).eq.1) then
411       
412      if (jk.ge.kknu2(jl)) then
413         
414            znum(jl)=pnu(jl)
415            zwind=(pulow(jl)*pum1(jl,jk)+pvlow(jl)*pvm1(jl,jk))/
416     *            max(sqrt(pulow(jl)**2+pvlow(jl)**2),gvsec)
417            zwind=max(sqrt(zwind**2),gvsec)
418            zdelp=paphm1(jl,jk+1)-paphm1(jl,jk)
419            zstabm=sqrt(max(pstab(jl,jk  ),gssec))
420            zstabp=sqrt(max(pstab(jl,jk+1),gssec))
421            zrhom=prho(jl,jk  )
422            zrhop=prho(jl,jk+1)
423            pnu(jl) = pnu(jl) + (zdelp/rg)*
424     *            ((zstabp/zrhop+zstabm/zrhom)/2.)/zwind     
425            if((znum(jl).le.gfrcrit).and.(pnu(jl).gt.gfrcrit)
426     *                          .and.(kkenvh(jl).eq.klev))
427     *      kkenvh(jl)=jk
428     
429      endif   
430
431      endif
432     
433 234  continue
434     
435c  calculation of a dynamical mixing height for when the waves
436C  BREAK AT LOW LEVEL: The drag will be repartited over
437C  a depths that depends on waves vertical wavelength,
438C  not just between two adjacent model layers.
439c  of gravity waves:
440
441      do 235 jl=kidia,kfdia
442      znup(jl)=0.0
443      znum(jl)=0.0
444 235  continue
445
446      do 236 jk=klev-1,2,-1
447      do 236 jl=kidia,kfdia
448     
449      if(ktest(jl).eq.1) then
450
451            znum(jl)=znup(jl)
452            zwind=(pulow(jl)*pum1(jl,jk)+pvlow(jl)*pvm1(jl,jk))/
453     *            max(sqrt(pulow(jl)**2+pvlow(jl)**2),gvsec)
454            zwind=max(sqrt(zwind**2),gvsec)
455            zdelp=paphm1(jl,jk+1)-paphm1(jl,jk)
456            zstabm=sqrt(max(pstab(jl,jk  ),gssec))
457            zstabp=sqrt(max(pstab(jl,jk+1),gssec))
458            zrhom=prho(jl,jk  )
459            zrhop=prho(jl,jk+1)
460            znup(jl) = znup(jl) + (zdelp/rg)*
461     *            ((zstabp/zrhop+zstabm/zrhom)/2.)/zwind     
462            if((znum(jl).le.rpi/4.).and.(znup(jl).gt.rpi/4.)
463     *                          .and.(kkcrith(jl).eq.klev))
464     *      kkcrith(jl)=jk
465     
466      endif
467     
468 236  continue
469 
470      do 237 jl=kidia,kfdia
471      if(ktest(jl).eq.1) then
472      kkcrith(jl)=max0(kkcrith(jl),ilevh*2)
473      kkcrith(jl)=max0(kkcrith(jl),kknu(jl))
474      if(kcrit(jl).ge.kkcrith(jl))kcrit(jl)=1
475      endif
476 237  continue         
477c
478c     directional info for flow blocking *************************
479c
480      do 251 jk=1,klev   
481      do 252 jl=kidia,kfdia
482      if(ktest(jl).eq.1) then
483      lo=(pum1(jl,jk).lt.gvsec).and.(pum1(jl,jk).ge.-gvsec)
484      if(lo) then
485        zu=pum1(jl,jk)+2.*gvsec
486      else
487        zu=pum1(jl,jk)
488      endif
489       zphi=atan(pvm1(jl,jk)/zu)
490       ppsi(jl,jk)=ptheta(jl)*rpi/180.-zphi
491      endif
492 252  continue
493 251  continue
494
495c      forms the vertical 'leakiness' **************************
496
497      do 254  jk=ilevh,klev
498      do 253  jl=kidia,kfdia
499      if(ktest(jl).eq.1) then
500      pzdep(jl,jk)=0
501      if(jk.ge.kkenvh(jl).and.kkenvh(jl).ne.klev) then
502        pzdep(jl,jk)=(pgeom1(jl,kkenvh(jl)  )-pgeom1(jl,  jk))/
503     *               (pgeom1(jl,kkenvh(jl)  )-pgeom1(jl,klev))
504      end if
505      endif
506 253  continue
507 254  continue
508
509      return
510      end
511
512
Note: See TracBrowser for help on using the repository browser.