source: LMDZ5/trunk/libf/dyn3d_common/inidissip.F90 @ 2597

Last change on this file since 2597 was 2597, checked in by Ehouarn Millour, 8 years ago

Cleanup in the dynamics: get rid of comconst.h, make it a module comconst_mod.
EM

  • 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
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.0 KB
Line 
1!
2! $Id: inidissip.F90 2597 2016-07-22 06:44:47Z emillour $
3!
4SUBROUTINE inidissip ( lstardis,nitergdiv,nitergrot,niterh  , &
5     tetagdiv,tetagrot,tetatemp, vert_prof_dissip)
6  !=======================================================================
7  !   initialisation de la dissipation horizontale
8  !=======================================================================
9  !-----------------------------------------------------------------------
10  !   declarations:
11  !   -------------
12
13  USE control_mod, only : dissip_period,iperiod
14  USE comconst_mod, ONLY: dissip_deltaz, dissip_factz, dissip_zref, &
15                          dtdiss, dtvr, rad
16
17  IMPLICIT NONE
18  include "dimensions.h"
19  include "paramet.h"
20  include "comdissipn.h"
21  include "comvert.h"
22  include "logic.h"
23  include "iniprint.h"
24
25  LOGICAL,INTENT(in) :: lstardis
26  INTEGER,INTENT(in) :: nitergdiv,nitergrot,niterh
27  REAL,INTENT(in) :: tetagdiv,tetagrot,tetatemp
28
29  integer, INTENT(in):: vert_prof_dissip
30  ! Vertical profile of horizontal dissipation
31  ! Allowed values:
32  ! 0: rational fraction, function of pressure
33  ! 1: tanh of altitude
34
35! Local variables:
36  REAL fact,zvert(llm),zz
37  REAL zh(ip1jmp1),zu(ip1jmp1), gx(ip1jmp1), divgra(ip1jmp1)
38  real zv(ip1jm), gy(ip1jm), deltap(ip1jmp1,llm)
39  REAL ullm,vllm,umin,vmin,zhmin,zhmax
40  REAL zllm
41
42  INTEGER l,ij,idum,ii
43  REAL tetamin
44  REAL pseudoz
45  character (len=80) :: abort_message
46
47  REAL ran1
48
49
50  !-----------------------------------------------------------------------
51  !
52  !   calcul des valeurs propres des operateurs par methode iterrative:
53  !   -----------------------------------------------------------------
54
55  crot     = -1.
56  cdivu    = -1.
57  cdivh    = -1.
58
59  !   calcul de la valeur propre de divgrad:
60  !   --------------------------------------
61  idum = 0
62  DO l = 1, llm
63     DO ij = 1, ip1jmp1
64        deltap(ij,l) = 1.
65     ENDDO
66  ENDDO
67
68  idum  = -1
69  zh(1) = RAN1(idum)-.5
70  idum  = 0
71  DO ij = 2, ip1jmp1
72     zh(ij) = RAN1(idum) -.5
73  ENDDO
74
75  CALL filtreg (zh,jjp1,1,2,1,.TRUE.,1)
76
77  CALL minmax(iip1*jjp1,zh,zhmin,zhmax )
78
79  IF ( zhmin .GE. zhmax  )     THEN
80     write(lunout,*)'  Inidissip  zh min max  ',zhmin,zhmax
81     abort_message='probleme generateur alleatoire dans inidissip'
82     call abort_gcm('inidissip',abort_message,1)
83  ENDIF
84
85  zllm = ABS( zhmax )
86  DO l = 1,50
87     IF(lstardis) THEN
88        CALL divgrad2(1,zh,deltap,niterh,divgra)
89     ELSE
90        CALL divgrad (1,zh,niterh,divgra)
91     ENDIF
92
93     zllm  = ABS(maxval(divgra))
94     zh = divgra / zllm
95  ENDDO
96
97  IF(lstardis) THEN
98     cdivh = 1./ zllm
99  ELSE
100     cdivh = zllm ** ( -1./niterh )
101  ENDIF
102
103  !   calcul des valeurs propres de gradiv (ii =1) et  nxgrarot(ii=2)
104  !   -----------------------------------------------------------------
105  write(lunout,*)'inidissip: calcul des valeurs propres'
106
107  DO    ii = 1, 2
108     !
109     DO ij = 1, ip1jmp1
110        zu(ij)  = RAN1(idum) -.5
111     ENDDO
112     CALL filtreg (zu,jjp1,1,2,1,.TRUE.,1)
113     DO ij = 1, ip1jm
114        zv(ij) = RAN1(idum) -.5
115     ENDDO
116     CALL filtreg (zv,jjm,1,2,1,.FALSE.,1)
117
118     CALL minmax(iip1*jjp1,zu,umin,ullm )
119     CALL minmax(iip1*jjm, zv,vmin,vllm )
120
121     ullm = ABS ( ullm )
122     vllm = ABS ( vllm )
123
124     DO    l = 1, 50
125        IF(ii.EQ.1) THEN
126           !cccc             CALL covcont( 1,zu,zv,zu,zv )
127           IF(lstardis) THEN
128              CALL gradiv2( 1,zu,zv,nitergdiv,gx,gy )
129           ELSE
130              CALL gradiv ( 1,zu,zv,nitergdiv,gx,gy )
131           ENDIF
132        ELSE
133           IF(lstardis) THEN
134              CALL nxgraro2( 1,zu,zv,nitergrot,gx,gy )
135           ELSE
136              CALL nxgrarot( 1,zu,zv,nitergrot,gx,gy )
137           ENDIF
138        ENDIF
139
140        zllm = max(abs(maxval(gx)), abs(maxval(gy)))
141        zu = gx / zllm
142        zv = gy / zllm
143     end DO
144
145     IF ( ii.EQ.1 ) THEN
146        IF(lstardis) THEN
147           cdivu  = 1./zllm
148        ELSE
149           cdivu  = zllm **( -1./nitergdiv )
150        ENDIF
151     ELSE
152        IF(lstardis) THEN
153           crot   = 1./ zllm
154        ELSE
155           crot   = zllm **( -1./nitergrot )
156        ENDIF
157     ENDIF
158
159  end DO
160
161  !   petit test pour les operateurs non star:
162  !   ----------------------------------------
163
164  !     IF(.NOT.lstardis) THEN
165  fact    = rad*24./REAL(jjm)
166  fact    = fact*fact
167  write(lunout,*)'inidissip: coef u ', fact/cdivu, 1./cdivu
168  write(lunout,*)'inidissip: coef r ', fact/crot , 1./crot
169  write(lunout,*)'inidissip: coef h ', fact/cdivh, 1./cdivh
170  !     ENDIF
171
172  !-----------------------------------------------------------------------
173  !   variation verticale du coefficient de dissipation:
174  !   --------------------------------------------------
175
176  if (vert_prof_dissip == 1) then
177     do l=1,llm
178        pseudoz=8.*log(preff/presnivs(l))
179        zvert(l)=1+ &
180             (tanh((pseudoz-dissip_zref)/dissip_deltaz)+1.)/2. &
181             *(dissip_factz-1.)
182     enddo
183  else
184     DO l=1,llm
185        zvert(l)=1.
186     ENDDO
187     fact=2.
188     DO l = 1, llm
189        zz      = 1. - preff/presnivs(l)
190        zvert(l)= fact -( fact-1.)/( 1.+zz*zz )
191     ENDDO
192  endif
193
194
195  write(lunout,*)'inidissip: Constantes de temps de la diffusion horizontale'
196
197  tetamin =  1.e+6
198
199  DO l=1,llm
200     tetaudiv(l)   = zvert(l)/tetagdiv
201     tetaurot(l)   = zvert(l)/tetagrot
202     tetah(l)      = zvert(l)/tetatemp
203
204     IF( tetamin.GT. (1./tetaudiv(l)) ) tetamin = 1./ tetaudiv(l)
205     IF( tetamin.GT. (1./tetaurot(l)) ) tetamin = 1./ tetaurot(l)
206     IF( tetamin.GT. (1./   tetah(l)) ) tetamin = 1./    tetah(l)
207  ENDDO
208
209  ! If dissip_period=0 calculate value for dissipation period, else keep value read from gcm.def
210  IF (dissip_period == 0) THEN
211     dissip_period = INT( tetamin/( 2.*dtvr*iperiod) ) * iperiod
212     write(lunout,*)'inidissip: tetamin dtvr iperiod dissip_period(intermed) ',tetamin,dtvr,iperiod,dissip_period
213     dissip_period = MAX(iperiod,dissip_period)
214  END IF
215
216  dtdiss  = dissip_period * dtvr
217  write(lunout,*)'inidissip: dissip_period=',dissip_period,' dtdiss=',dtdiss,' dtvr=',dtvr
218
219  DO l = 1,llm
220     write(lunout,*)zvert(l),dtdiss*tetaudiv(l),dtdiss*tetaurot(l), &
221          dtdiss*tetah(l)
222  ENDDO
223
224END SUBROUTINE inidissip
Note: See TracBrowser for help on using the repository browser.