source: LMDZ.3.3/trunk/libf/dyn3d/nudge.F @ 3764

Last change on this file since 3764 was 356, checked in by lmdz, 23 years ago

Lecture du fichier netcdf pour determination du nombre de niveaux verticaux MAF
LF

  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 7.6 KB
RevLine 
[207]1c $Header$
[189]2      subroutine nudge(itau,ucov,vcov,teta,masse,ps)
3
4      IMPLICIT NONE
5
6c      ......   Version  du 10/01/98    ..........
7
8c             avec  coordonnees  verticales hybrides
9c   avec nouveaux operat. dissipation * ( gradiv2,divgrad2,nxgraro2 )
10
11c=======================================================================
12c
13c   Auteur:  P. Le Van /L. Fairhead/F.Hourdin
14c   -------
15c
16c   Objet:
17c   ------
18c
19c   GCM LMD nouvelle grille
20c
21c=======================================================================
22
23c   ...  Dans inigeom , nouveaux calculs pour les elongations  cu , cv
24c        et possibilite d'appeler une fonction f(y)  a derivee tangente
25c        hyperbolique a la  place de la fonction a derivee sinusoidale.         
26
27c   ...  Possibilite de choisir le shema de Van-leer pour l'advection de
[356]28c         q  , en faisant iadv = 10  dans   traceur  (29/04/97) .
[189]29c
30c-----------------------------------------------------------------------
31c   Declarations:
32c   -------------
33
34#include "dimensions.h"
35#include "paramet.h"
36#include "comconst.h"
37#include "comdissnew.h"
38#include "comvert.h"
39#include "comgeom.h"
40#include "logic.h"
41#include "temps.h"
42#include "control.h"
43#include "ener.h"
44#include "netcdf.inc"
45#include "description.h"
46#include "serre.h"
47#include "tracstoke.h"
48
49
50c   variables dynamiques
51      REAL vcov(ip1jm,llm),ucov(ip1jmp1,llm) ! vents covariants
52      REAL teta(ip1jmp1,llm)                 ! temperature potentielle
53      REAL ps(ip1jmp1)                       ! pression  au sol
54      REAL masse(ip1jmp1,llm)                ! masse d'air
55
56c   variables dynamiques pour les reanalyses.
57      REAL ucovrea1(ip1jmp1,llm),vcovrea1(ip1jm,llm) !vts cov reas
58      REAL tetarea1(ip1jmp1,llm)             ! temp pot  reales
59      REAL masserea1(ip1jmp1,llm)             ! masse
60      REAL psrea1(ip1jmp1)             ! ps
61      REAL ucovrea2(ip1jmp1,llm),vcovrea2(ip1jm,llm) !vts cov reas
62      REAL tetarea2(ip1jmp1,llm)             ! temp pot  reales
63      REAL masserea2(ip1jmp1,llm)             ! masse
64      REAL psrea2(ip1jmp1)             ! ps
65      real alphaT,alphaP,alphau,alphav
66      real dday_step,toto,reste,itau_test
67      INTEGER step_rea,count_no_rea
68
69
70c
71      INTEGER itau,ij,l
[356]72      integer ncidt,varidpl,nlev,status
73      integer rcod,rid
[189]74      real ditau,tau,a
[356]75      save nlev
[189]76
[356]77      LOGICAL first,ncep
[189]78      integer online
[356]79      save first,online,ncep
[198]80      data first,online/.true.,1/
[356]81      data ncep/.false./
[189]82
83      save ucovrea1,vcovrea1,tetarea1,masserea1,psrea1
84      save ucovrea2,vcovrea2,tetarea2,masserea2,psrea2
85
86      save alphaT,alphau,alphav,alphaP,itau_test
87      save step_rea,count_no_rea
88
89c-----------------------------------------------------------------------
90c   initialisations pour la lecture des reanalyses.
91c    alpha determine la part des injections de donnees a chaque etape
92c    alpha=1 signifie pas d'injection
93c    alpha=0 signifie injection totale
94c-----------------------------------------------------------------------
95
96      print*,'ONLINE=',online
97      if(online.eq.-1) then
98          return
99      endif
100
101      if (first) then
102         print*
103     s   ,'1: en-ligne, 0: hors-ligne (x=x_rea), -1: climat (x=x_gcm)'
104cnec         read(*,*) online
[204]105cnec      online=-1
106cnec     print*,'Entrer les constantes de temps de rappel en jours'
[189]107cnec         read(*,*)alphaT
108cnec         read(*,*)alphau
109cnec         read(*,*)alphav
110cnec         read(*,*)alphaP
111             alphaT=0.1
112             alphau=0.1
113             alphav=0.1
114             alphaP=1.e10
[204]115         print*,'alphaT,alphau,alphav,alphaP'
116     s          ,alphaT,alphau,alphav,alphaP
[189]117         if(online.eq.-1) return
118         print*,'alpha rappel pour T, u, v, P ',
119     s    alphaT,alphau,alphav,alphaP
120c   En fait, le coef alpha qu'on utilise est
121c   x_gcm = a * x_gcm + ( 1 - a ) * x_reanalys
122c   on a alors a=1-dt/tau
123c   ou dt est la frequence a laquelle on corrige (ici iperiod*dtvr)
124c   et tau la constante de temps lue. D'ou:
125         if (online.eq.1) then
126            alphaT=1.-iperiod*dtvr/(daysec*alphaT)
127            alphau=1.-iperiod*dtvr/(daysec*alphau)
128            alphav=1.-iperiod*dtvr/(daysec*alphav)
129            alphaP=1.-iperiod*dtvr/(daysec*alphaP)
130         else
131            alphaT=0.
132            alphau=0.
133            alphav=0.
134            alphaP=0.
135c           physic=.false.
136         endif
137         print*,'alpha rappel pour T, u, v, P ',
138     s    alphaT,alphau,alphav,alphaP
139
140         itau_test=1001
141         step_rea=1
142         count_no_rea=0
143
144c    itau_test    montre si l'importation a deja ete faite au rang itau
[356]145c lecture d'un fichier netcdf pour determiner le nombre de niveaux
146         ncidt=NCOPN('T.nc',NCNOWRIT,rcod)
147         if (ncep) then
148          status=NF_INQ_DIMID(ncidt,'LEVEL',rid)
149         else
150          status=NF_INQ_DIMID(ncidt,'PRESSURE',rid)
151         endif
152          status=NF_INQ_DIMLEN(ncidt,rid,nlev)
153         print *,'nlev', nlev
154          call ncclos(ncidt,rcod)
[189]155c   Lecture du premier etat des reanalyses.
156         call read_reanalyse(1
[356]157     s   ,ucovrea2,vcovrea2,tetarea2,masserea2,ps,1,nlev)
[189]158
159c-----------------------------------------------------------------------
160c   Debut de l'integration temporelle:
161c   ----------------------------------
162
163         first=.false.
164      endif ! first
165c
166C-----------------------------------------------------------------------
167C----- IMPORTATION DES VENTS,PRESSION ET TEMPERATURE REELS:
168C-----------------------------------------------------------------------
169
170      ditau=real(itau)
171      dday_step=real(day_step)
172      write(*,*)'ditau,dday_step'
173      write(*,*)ditau,dday_step
174      toto=4*ditau/dday_step
175      reste=toto-aint(toto)
176c     write(*,*)'toto,reste',toto,reste
177
178      if (reste.eq.0.) then
179        if (itau_test.eq.itau) then
180          write(*,*)'deuxieme passage de advreel a itau=',itau
181          stop
182        else
183           CALL SCOPY( ijmllm ,vcovrea2, 1, vcovrea1 , 1 )
184           CALL SCOPY( ijp1llm,ucovrea2, 1, ucovrea1 , 1 )
185           CALL SCOPY( ijp1llm,tetarea2,1,tetarea1   , 1 )
[204]186c          CALL SCOPY( ijp1llm,masserea2,1,masserea1   , 1 )
187c          CALL SCOPY( ip1jmp1,psrea2, 1,  psrea1, 1 )
[189]188
189          print*,'LECTURE REANALYSES, pas ',step_rea
190     s         ,'apres ',count_no_rea,' non lectures'
191           step_rea=step_rea+1
192           itau_test=itau
193           call read_reanalyse(step_rea
[356]194     s     ,ucovrea2,vcovrea2,tetarea2,masserea2,ps,1,nlev)
[189]195        endif
196      else
197        count_no_rea=count_no_rea+1
198      endif
199 
200C-----------------------------------------------------------------------
201c   Corrrections
202c
203c    x_gcm = a * x_gcm + (1-a) * x_reanalyses
204C-----------------------------------------------------------------------
205
206      ditau=real(itau)
207      dday_step=real(day_step)
208
209c     print*,'alpha1',alphaT,alphaP,alphau,alphav
210
211      tau=4*ditau/dday_step
212      tau=tau-aint(tau)
213
214      do l=1,llm
215         do ij=1,ip1jmp1
216            a=(1.-tau)*ucovrea1(ij,l)+tau*ucovrea2(ij,l)
217            ucov(ij,l)=alphau*ucov(ij,l)+(1-alphau)*a
218            a=(1.-tau)*tetarea1(ij,l)+tau*tetarea2(ij,l)
219            teta(ij,l)=alphaT*teta(ij,l)+(1-alphaT)*a
[204]220c           a=(1.-tau)*masserea1(ij,l)+tau*masserea2(ij,l)
221c           masse(ij,l)=alphaP*masse(ij,l)+(1-alphaP)*a
[189]222         enddo
223         do ij=1,ip1jm
224            a=(1.-tau)*vcovrea1(ij,l)+tau*vcovrea2(ij,l)
225            vcov(ij,l)=alphav*vcov(ij,l)+(1-alphav)*a
226         enddo
227      enddo
228
229c     call dump2d(iip1,jjp1,tetarea1,'TETA REA 1     ')
230c     call dump2d(iip1,jjp1,tetarea2,'TETA REA 2     ')
231c     call dump2d(iip1,jjp1,teta,'TETA           ')
232Cmaf  on ne nudge pas sur la pression de surface
233c      do ij=1,ip1jmp1
234c         a=(1.-tau)*psrea1(ij)+tau*psrea2(ij)
235c         ps(ij)=alphaP*ps(ij)+(1-alphaP)*a
236c      enddo
237
238
239      return
240      end
Note: See TracBrowser for help on using the repository browser.