New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
agrif_opa_interp.F90 in trunk/NEMOGCM/NEMO/NST_SRC – NEMO

source: trunk/NEMOGCM/NEMO/NST_SRC/agrif_opa_interp.F90 @ 2715

Last change on this file since 2715 was 2715, checked in by rblod, 13 years ago

First attempt to put dynamic allocation on the trunk

  • Property svn:keywords set to Id
File size: 21.3 KB
Line 
1MODULE agrif_opa_interp
2   !!======================================================================
3   !!                   ***  MODULE  agrif_opa_interp  ***
4   !! AGRIF: interpolation package
5   !!======================================================================
6   !! History :  2.0  !  2002-06  (XXX)  Original cade
7   !!             -   !  2005-11  (XXX)
8   !!            3.2  !  2009-04  (R. Benshila)
9   !!----------------------------------------------------------------------
10#if defined key_agrif && ! defined key_offline
11   !!----------------------------------------------------------------------
12   !!   'key_agrif'                                              AGRIF zoom
13   !!   NOT 'key_offline'                               NO off-line tracers
14   !!----------------------------------------------------------------------
15   !!   Agrif_tra     :
16   !!   Agrif_dyn     :
17   !!   interpu       :
18   !!   interpv       :
19   !!----------------------------------------------------------------------
20   USE par_oce
21   USE oce
22   USE dom_oce     
23   USE sol_oce
24   USE agrif_oce
25   USE phycst
26   USE in_out_manager
27   USE agrif_opa_sponge
28   USE lib_mpp
29
30   IMPLICIT NONE
31   PRIVATE
32   
33   PUBLIC   Agrif_tra, Agrif_dyn, Agrif_ssh, interpu, interpv
34
35#  include "domzgr_substitute.h90" 
36#  include "vectopt_loop_substitute.h90"
37   !!----------------------------------------------------------------------
38   !! NEMO/NST 3.3 , NEMO Consortium (2010)
39   !! $Id$
40   !! Software governed by the CeCILL licence (NEMOGCM/NEMO_CeCILL.txt)
41   !!----------------------------------------------------------------------
42
43   CONTAINS
44   
45   SUBROUTINE Agrif_tra
46      !!----------------------------------------------------------------------
47      !!                  ***  ROUTINE Agrif_Tra  ***
48      !!----------------------------------------------------------------------
49      USE wrk_nemo, ONLY: wrk_in_use, wrk_not_released
50      USE wrk_nemo, ONLY: wrk_3d_1, wrk_3d_2
51      !!
52      INTEGER  ::   ji, jj, jk   ! dummy loop indices
53      REAL(wp) ::   zrhox , alpha1, alpha2, alpha3
54      REAL(wp) ::   alpha4, alpha5, alpha6, alpha7
55      REAL(wp), POINTER, DIMENSION(:,:,:) :: zta, zsa
56      !!----------------------------------------------------------------------
57      !
58      IF( Agrif_Root() )   RETURN
59
60      zta => wrk_3d_1 ; zsa => wrk_3d_2
61      IF( wrk_in_use(3, 1,2) )THEN
62         CALL ctl_stop('agrif_tra: requested workspace arrays unavailable.')
63         RETURN
64      END IF
65
66      Agrif_SpecialValue    = 0.e0
67      Agrif_UseSpecialValue = .TRUE.
68      zta(:,:,:) = 0.e0
69      zsa(:,:,:) = 0.e0
70
71      CALL Agrif_Bc_variable( zta, tn_id, procname = interptn )
72      CALL Agrif_Bc_variable( zsa, sn_id, procname = interpsn )
73      Agrif_UseSpecialValue = .FALSE.
74
75      zrhox = Agrif_Rhox()
76
77      alpha1 = ( zrhox - 1. ) * 0.5
78      alpha2 = 1. - alpha1
79
80      alpha3 = ( zrhox - 1. ) / ( zrhox + 1. )
81      alpha4 = 1. - alpha3
82
83      alpha6 = 2. * ( zrhox - 1. ) / ( zrhox + 1. )
84      alpha7 =    - ( zrhox - 1. ) / ( zrhox + 3. )
85      alpha5 = 1. - alpha6 - alpha7
86
87      IF( nbondi == 1 .OR. nbondi == 2 ) THEN
88
89         ta(nlci,:,:) = alpha1 * zta(nlci,:,:) + alpha2 * zta(nlci-1,:,:)
90         sa(nlci,:,:) = alpha1 * zsa(nlci,:,:) + alpha2 * zsa(nlci-1,:,:)
91
92         DO jk = 1, jpkm1
93            DO jj = 1, jpj
94               IF( umask(nlci-2,jj,jk) == 0.e0 ) THEN
95                  ta(nlci-1,jj,jk) = ta(nlci,jj,jk) * tmask(nlci-1,jj,jk)
96                  sa(nlci-1,jj,jk) = sa(nlci,jj,jk) * tmask(nlci-1,jj,jk)
97               ELSE
98                  ta(nlci-1,jj,jk)=(alpha4*ta(nlci,jj,jk)+alpha3*ta(nlci-2,jj,jk))*tmask(nlci-1,jj,jk)
99                  sa(nlci-1,jj,jk)=(alpha4*sa(nlci,jj,jk)+alpha3*sa(nlci-2,jj,jk))*tmask(nlci-1,jj,jk)
100                  IF( un(nlci-2,jj,jk) > 0.e0 ) THEN
101                     ta(nlci-1,jj,jk)=( alpha6*ta(nlci-2,jj,jk)+alpha5*ta(nlci,jj,jk)  &
102                        &             + alpha7*ta(nlci-3,jj,jk) ) * tmask(nlci-1,jj,jk)
103                     sa(nlci-1,jj,jk)=( alpha6*sa(nlci-2,jj,jk)+alpha5*sa(nlci,jj,jk)  &
104                        &             + alpha7*sa(nlci-3,jj,jk) ) * tmask(nlci-1,jj,jk)
105                  ENDIF
106               ENDIF
107            END DO
108         END DO
109      ENDIF
110
111      IF( nbondj == 1 .OR. nbondj == 2 ) THEN
112
113         ta(:,nlcj,:) = alpha1 * zta(:,nlcj,:) + alpha2 * zta(:,nlcj-1,:)
114         sa(:,nlcj,:) = alpha1 * zsa(:,nlcj,:) + alpha2 * zsa(:,nlcj-1,:)
115
116         DO jk = 1, jpkm1
117            DO ji = 1, jpi
118               IF( vmask(ji,nlcj-2,jk) == 0.e0 ) THEN
119                  ta(ji,nlcj-1,jk) = ta(ji,nlcj,jk) * tmask(ji,nlcj-1,jk)
120                  sa(ji,nlcj-1,jk) = sa(ji,nlcj,jk) * tmask(ji,nlcj-1,jk)
121               ELSE
122                  ta(ji,nlcj-1,jk)=(alpha4*ta(ji,nlcj,jk)+alpha3*ta(ji,nlcj-2,jk))*tmask(ji,nlcj-1,jk)       
123                  sa(ji,nlcj-1,jk)=(alpha4*sa(ji,nlcj,jk)+alpha3*sa(ji,nlcj-2,jk))*tmask(ji,nlcj-1,jk)
124                  IF (vn(ji,nlcj-2,jk) > 0.e0 ) THEN
125                     ta(ji,nlcj-1,jk)=( alpha6*ta(ji,nlcj-2,jk)+alpha5*ta(ji,nlcj,jk)  &
126                        &             + alpha7*ta(ji,nlcj-3,jk) ) * tmask(ji,nlcj-1,jk)
127                     sa(ji,nlcj-1,jk)=( alpha6*sa(ji,nlcj-2,jk)+alpha5*sa(ji,nlcj,jk)  &
128                        &             + alpha7*sa(ji,nlcj-3,jk))*tmask(ji,nlcj-1,jk)
129                  ENDIF
130               ENDIF
131            END DO
132         END DO
133      ENDIF
134
135      IF( nbondi == -1 .OR. nbondi == 2 ) THEN
136         ta(1,:,:) = alpha1 * zta(1,:,:) + alpha2 * zta(2,:,:)
137         sa(1,:,:) = alpha1 * zsa(1,:,:) + alpha2 * zsa(2,:,:)     
138         DO jk = 1, jpkm1
139            DO jj = 1, jpj
140               IF( umask(2,jj,jk) == 0.e0 ) THEN
141                  ta(2,jj,jk) = ta(1,jj,jk) * tmask(2,jj,jk)
142                  sa(2,jj,jk) = sa(1,jj,jk) * tmask(2,jj,jk)
143               ELSE
144                  ta(2,jj,jk)=(alpha4*ta(1,jj,jk)+alpha3*ta(3,jj,jk))*tmask(2,jj,jk)       
145                  sa(2,jj,jk)=(alpha4*sa(1,jj,jk)+alpha3*sa(3,jj,jk))*tmask(2,jj,jk)
146                  IF( un(2,jj,jk) < 0.e0 ) THEN
147                     ta(2,jj,jk)=(alpha6*ta(3,jj,jk)+alpha5*ta(1,jj,jk)+alpha7*ta(4,jj,jk))*tmask(2,jj,jk)
148                     sa(2,jj,jk)=(alpha6*sa(3,jj,jk)+alpha5*sa(1,jj,jk)+alpha7*sa(4,jj,jk))*tmask(2,jj,jk)
149                  ENDIF
150               ENDIF
151            END DO
152         END DO
153      ENDIF
154
155      IF( nbondj == -1 .OR. nbondj == 2 ) THEN
156         ta(:,1,:) = alpha1 * zta(:,1,:) + alpha2 * zta(:,2,:)
157         sa(:,1,:) = alpha1 * zsa(:,1,:) + alpha2 * zsa(:,2,:)
158         DO jk=1,jpk     
159            DO ji=1,jpi
160               IF( vmask(ji,2,jk) == 0.e0 ) THEN
161                  ta(ji,2,jk)=ta(ji,1,jk) * tmask(ji,2,jk)
162                  sa(ji,2,jk)=sa(ji,1,jk) * tmask(ji,2,jk)
163               ELSE
164                  ta(ji,2,jk)=(alpha4*ta(ji,1,jk)+alpha3*ta(ji,3,jk))*tmask(ji,2,jk)
165                  sa(ji,2,jk)=(alpha4*sa(ji,1,jk)+alpha3*sa(ji,3,jk))*tmask(ji,2,jk) 
166                  IF( vn(ji,2,jk) < 0.e0 ) THEN
167                     ta(ji,2,jk)=(alpha6*ta(ji,3,jk)+alpha5*ta(ji,1,jk)+alpha7*ta(ji,4,jk))*tmask(ji,2,jk)
168                     sa(ji,2,jk)=(alpha6*sa(ji,3,jk)+alpha5*sa(ji,1,jk)+alpha7*sa(ji,4,jk))*tmask(ji,2,jk)
169                  ENDIF
170               ENDIF
171            END DO
172         END DO
173      ENDIF
174      !
175      IF( wrk_not_released(3, 1,2) ) THEN
176         CALL ctl_stop('agrif_tra: failed to release workspace arrays.')
177      ENDIF
178      !
179   END SUBROUTINE Agrif_tra
180
181
182   SUBROUTINE Agrif_dyn( kt )
183      !!----------------------------------------------------------------------
184      !!                  ***  ROUTINE Agrif_DYN  ***
185      !!---------------------------------------------------------------------- 
186      USE wrk_nemo, ONLY: wrk_in_use, wrk_not_released
187      USE wrk_nemo, ONLY: wrk_2d_4, wrk_2d_5
188      USE wrk_nemo, ONLY: wrk_2d_6, wrk_2d_7
189      USE wrk_nemo, ONLY: wrk_3d_1, wrk_3d_2
190      !!
191      INTEGER, INTENT(in) ::   kt
192      !!
193      INTEGER :: ji,jj,jk
194      REAL(wp) :: timeref
195      REAL(wp) :: z2dt, znugdt
196      REAL(wp) :: zrhox, rhoy
197      REAL(wp), POINTER, DIMENSION(:,:,:) :: zua, zva
198      REAL(wp), POINTER, DIMENSION(:,:) :: spgv1, spgu1, zua2d, zva2d
199      !!---------------------------------------------------------------------- 
200
201      IF( Agrif_Root() )   RETURN
202
203      spgu1  => wrk_2d_4 ; spgv1 => wrk_2d_5
204      zua2d  => wrk_2d_6 ; zva2d => wrk_2d_7
205      zua  => wrk_3d_1 ; zva => wrk_3d_2
206      IF( wrk_in_use(2, 4,5,6,7) .OR. wrk_in_use(3, 1,2) )THEN
207         CALL ctl_stop('agrif_dyn: requested workspace arrays unavailable.')
208         RETURN
209      END IF
210
211      zrhox = Agrif_Rhox()
212      rhoy = Agrif_Rhoy()
213
214      timeref = 1.
215
216      ! time step: leap-frog
217      z2dt = 2. * rdt
218      ! time step: Euler if restart from rest
219      IF( neuler == 0 .AND. kt == nit000 ) z2dt = rdt
220      ! coefficients
221      znugdt =  grav * z2dt   
222
223      Agrif_SpecialValue=0.
224      Agrif_UseSpecialValue = ln_spc_dyn
225
226      zua = 0.
227      zva = 0.
228      CALL Agrif_Bc_variable(zua,un_id,procname=interpu)
229      CALL Agrif_Bc_variable(zva,vn_id,procname=interpv)
230      zua2d = 0.
231      zva2d = 0.
232
233      Agrif_SpecialValue=0.
234      Agrif_UseSpecialValue = ln_spc_dyn
235      CALL Agrif_Bc_variable(zua2d,e1u_id,calledweight=1.,procname=interpu2d)
236      CALL Agrif_Bc_variable(zva2d,e2v_id,calledweight=1.,procname=interpv2d)
237      Agrif_UseSpecialValue = .FALSE.
238
239
240      IF((nbondi == -1).OR.(nbondi == 2)) THEN
241
242         DO jj=1,jpj
243            laplacu(2,jj) = timeref * (zua2d(2,jj)/(rhoy*e2u(2,jj)))*umask(2,jj,1)
244         END DO
245
246         DO jk=1,jpkm1
247            DO jj=1,jpj
248               ua(1:2,jj,jk) = (zua(1:2,jj,jk)/(rhoy*e2u(1:2,jj)))
249               ua(1:2,jj,jk) = ua(1:2,jj,jk) / fse3u(1:2,jj,jk)
250            END DO
251         END DO
252
253         DO jk=1,jpkm1
254            DO jj=1,jpj
255               ua(2,jj,jk) = (ua(2,jj,jk) - z2dt * znugdt * laplacu(2,jj))*umask(2,jj,jk)
256            END DO
257         END DO
258
259         spgu(2,:)=0.
260
261         DO jk=1,jpkm1
262            DO jj=1,jpj
263               spgu(2,jj)=spgu(2,jj)+fse3u(2,jj,jk)*ua(2,jj,jk)
264            END DO
265         END DO
266
267         DO jj=1,jpj
268            IF (umask(2,jj,1).NE.0.) THEN
269               spgu(2,jj)=spgu(2,jj)/hu(2,jj)
270            ENDIF
271         END DO
272
273         DO jk=1,jpkm1
274            DO jj=1,jpj
275               ua(2,jj,jk) = 0.25*(ua(1,jj,jk)+2.*ua(2,jj,jk)+ua(3,jj,jk))
276               ua(2,jj,jk) = ua(2,jj,jk) * umask(2,jj,jk)
277            END DO
278         END DO
279
280         spgu1(2,:)=0.
281
282         DO jk=1,jpkm1
283            DO jj=1,jpj
284               spgu1(2,jj)=spgu1(2,jj)+fse3u(2,jj,jk)*ua(2,jj,jk)
285            END DO
286         END DO
287
288         DO jj=1,jpj
289            IF (umask(2,jj,1).NE.0.) THEN
290               spgu1(2,jj)=spgu1(2,jj)/hu(2,jj)
291            ENDIF
292         END DO
293
294         DO jk=1,jpkm1
295            DO jj=1,jpj
296               ua(2,jj,jk) = (ua(2,jj,jk)+spgu(2,jj)-spgu1(2,jj))*umask(2,jj,jk)
297            END DO
298         END DO
299
300         DO jk=1,jpkm1
301            DO jj=1,jpj
302               va(2,jj,jk) = (zva(2,jj,jk)/(zrhox*e1v(2,jj)))*vmask(2,jj,jk)
303               va(2,jj,jk) = va(2,jj,jk) / fse3v(2,jj,jk)
304            END DO
305         END DO
306
307      ENDIF
308
309      IF((nbondi == 1).OR.(nbondi == 2)) THEN
310
311         DO jj=1,jpj
312            laplacu(nlci-2,jj) = timeref * (zua2d(nlci-2,jj)/(rhoy*e2u(nlci-2,jj)))
313         END DO
314
315         DO jk=1,jpkm1
316            DO jj=1,jpj
317               ua(nlci-2:nlci-1,jj,jk) = (zua(nlci-2:nlci-1,jj,jk)/(rhoy*e2u(nlci-2:nlci-1,jj)))
318
319               ua(nlci-2:nlci-1,jj,jk) = ua(nlci-2:nlci-1,jj,jk) / fse3u(nlci-2:nlci-1,jj,jk)
320
321            END DO
322         END DO
323
324         DO jk=1,jpkm1
325            DO jj=1,jpj
326               ua(nlci-2,jj,jk) = (ua(nlci-2,jj,jk)- z2dt * znugdt * laplacu(nlci-2,jj))*umask(nlci-2,jj,jk)
327            END DO
328         END DO
329
330
331         spgu(nlci-2,:)=0.
332
333         do jk=1,jpkm1
334            do jj=1,jpj
335               spgu(nlci-2,jj)=spgu(nlci-2,jj)+fse3u(nlci-2,jj,jk)*ua(nlci-2,jj,jk)
336            enddo
337         enddo
338
339         DO jj=1,jpj
340            IF (umask(nlci-2,jj,1).NE.0.) THEN
341               spgu(nlci-2,jj)=spgu(nlci-2,jj)/hu(nlci-2,jj)
342            ENDIF
343         END DO
344
345         DO jk=1,jpkm1
346            DO jj=1,jpj
347               ua(nlci-2,jj,jk) = 0.25*(ua(nlci-3,jj,jk)+2.*ua(nlci-2,jj,jk)+ua(nlci-1,jj,jk))
348
349               ua(nlci-2,jj,jk) = ua(nlci-2,jj,jk) * umask(nlci-2,jj,jk)
350
351            END DO
352         END DO
353
354         spgu1(nlci-2,:)=0.
355
356         DO jk=1,jpkm1
357            DO jj=1,jpj
358               spgu1(nlci-2,jj)=spgu1(nlci-2,jj)+fse3u(nlci-2,jj,jk)*ua(nlci-2,jj,jk)*umask(nlci-2,jj,jk)
359            END DO
360         END DO
361
362         DO jj=1,jpj
363            IF (umask(nlci-2,jj,1).NE.0.) THEN
364               spgu1(nlci-2,jj)=spgu1(nlci-2,jj)/hu(nlci-2,jj)
365            ENDIF
366         END DO
367
368         DO jk=1,jpkm1
369            DO jj=1,jpj
370               ua(nlci-2,jj,jk) = (ua(nlci-2,jj,jk)+spgu(nlci-2,jj)-spgu1(nlci-2,jj))*umask(nlci-2,jj,jk)
371            END DO
372         END DO
373
374         DO jk=1,jpkm1
375            DO jj=1,jpj-1
376               va(nlci-1,jj,jk) = (zva(nlci-1,jj,jk)/(zrhox*e1v(nlci-1,jj)))*vmask(nlci-1,jj,jk)
377               va(nlci-1,jj,jk) = va(nlci-1,jj,jk) / fse3v(nlci-1,jj,jk)
378            END DO
379         END DO
380
381      ENDIF
382
383      IF((nbondj == -1).OR.(nbondj == 2)) THEN
384
385         DO ji=1,jpi
386            laplacv(ji,2) = timeref * (zva2d(ji,2)/(zrhox*e1v(ji,2)))
387         END DO
388
389         DO jk=1,jpkm1
390            DO ji=1,jpi
391               va(ji,1:2,jk) = (zva(ji,1:2,jk)/(zrhox*e1v(ji,1:2)))
392               va(ji,1:2,jk) = va(ji,1:2,jk) / fse3v(ji,1:2,jk)
393            END DO
394         END DO
395
396         DO jk=1,jpkm1
397            DO ji=1,jpi
398               va(ji,2,jk) = (va(ji,2,jk) - z2dt * znugdt * laplacv(ji,2))*vmask(ji,2,jk)
399            END DO
400         END DO
401
402         spgv(:,2)=0.
403
404         DO jk=1,jpkm1
405            DO ji=1,jpi
406               spgv(ji,2)=spgv(ji,2)+fse3v(ji,2,jk)*va(ji,2,jk)
407            END DO
408         END DO
409
410         DO ji=1,jpi
411            IF (vmask(ji,2,1).NE.0.) THEN
412               spgv(ji,2)=spgv(ji,2)/hv(ji,2)
413            ENDIF
414         END DO
415
416         DO jk=1,jpkm1
417            DO ji=1,jpi
418               va(ji,2,jk)=0.25*(va(ji,1,jk)+2.*va(ji,2,jk)+va(ji,3,jk))
419               va(ji,2,jk)=va(ji,2,jk)*vmask(ji,2,jk)
420            END DO
421         END DO
422
423         spgv1(:,2)=0.
424
425         DO jk=1,jpkm1
426            DO ji=1,jpi
427               spgv1(ji,2)=spgv1(ji,2)+fse3v(ji,2,jk)*va(ji,2,jk)*vmask(ji,2,jk)
428            END DO
429         END DO
430
431         DO ji=1,jpi
432            IF (vmask(ji,2,1).NE.0.) THEN
433               spgv1(ji,2)=spgv1(ji,2)/hv(ji,2)
434            ENDIF
435         END DO
436
437         DO jk=1,jpkm1
438            DO ji=1,jpi
439               va(ji,2,jk) = (va(ji,2,jk)+spgv(ji,2)-spgv1(ji,2))*vmask(ji,2,jk)
440            END DO
441         END DO
442
443         DO jk=1,jpkm1
444            DO ji=1,jpi
445               ua(ji,2,jk) = (zua(ji,2,jk)/(rhoy*e2u(ji,2)))*umask(ji,2,jk) 
446               ua(ji,2,jk) = ua(ji,2,jk) / fse3u(ji,2,jk)
447            END DO
448         END DO
449
450      ENDIF
451
452      IF((nbondj == 1).OR.(nbondj == 2)) THEN
453
454         DO ji=1,jpi
455            laplacv(ji,nlcj-2) = timeref * (zva2d(ji,nlcj-2)/(zrhox*e1v(ji,nlcj-2)))
456         END DO
457
458         DO jk=1,jpkm1
459            DO ji=1,jpi
460               va(ji,nlcj-2:nlcj-1,jk) = (zva(ji,nlcj-2:nlcj-1,jk)/(zrhox*e1v(ji,nlcj-2:nlcj-1)))
461               va(ji,nlcj-2:nlcj-1,jk) = va(ji,nlcj-2:nlcj-1,jk) / fse3v(ji,nlcj-2:nlcj-1,jk)
462            END DO
463         END DO
464
465         DO jk=1,jpkm1
466            DO ji=1,jpi
467               va(ji,nlcj-2,jk) = (va(ji,nlcj-2,jk)-z2dt * znugdt * laplacv(ji,nlcj-2))*vmask(ji,nlcj-2,jk)
468            END DO
469         END DO
470
471
472         spgv(:,nlcj-2)=0.
473
474         DO jk=1,jpkm1
475            DO ji=1,jpi
476               spgv(ji,nlcj-2)=spgv(ji,nlcj-2)+fse3v(ji,nlcj-2,jk)*va(ji,nlcj-2,jk)
477            END DO
478         END DO
479
480         DO ji=1,jpi
481            IF (vmask(ji,nlcj-2,1).NE.0.) THEN
482               spgv(ji,nlcj-2)=spgv(ji,nlcj-2)/hv(ji,nlcj-2)
483            ENDIF
484         END DO
485
486         DO jk=1,jpkm1
487            DO ji=1,jpi
488               va(ji,nlcj-2,jk)=0.25*(va(ji,nlcj-3,jk)+2.*va(ji,nlcj-2,jk)+va(ji,nlcj-1,jk))
489               va(ji,nlcj-2,jk) = va(ji,nlcj-2,jk) * vmask(ji,nlcj-2,jk)
490            END DO
491         END DO
492
493         spgv1(:,nlcj-2)=0.
494
495         DO jk=1,jpkm1
496            DO ji=1,jpi
497               spgv1(ji,nlcj-2)=spgv1(ji,nlcj-2)+fse3v(ji,nlcj-2,jk)*va(ji,nlcj-2,jk)
498            END DO
499         END DO
500
501         DO ji=1,jpi
502            IF (vmask(ji,nlcj-2,1).NE.0.) THEN
503               spgv1(ji,nlcj-2)=spgv1(ji,nlcj-2)/hv(ji,nlcj-2)
504            ENDIF
505         END DO
506
507         DO jk=1,jpkm1
508            DO ji=1,jpi
509               va(ji,nlcj-2,jk) = (va(ji,nlcj-2,jk)+spgv(ji,nlcj-2)-spgv1(ji,nlcj-2))*vmask(ji,nlcj-2,jk)
510            END DO
511         END DO
512
513         DO jk=1,jpkm1
514            DO ji=1,jpi
515               ua(ji,nlcj-1,jk) = (zua(ji,nlcj-1,jk)/(rhoy*e2u(ji,nlcj-1)))*umask(ji,nlcj-1,jk)
516               ua(ji,nlcj-1,jk) = ua(ji,nlcj-1,jk) / fse3u(ji,nlcj-1,jk)
517            END DO
518         END DO
519
520      ENDIF
521      !
522      IF( wrk_not_released(3, 1,2) .OR. wrk_not_released(2, 4,5,6,7)) THEN
523         CALL ctl_stop('agrif_dyn: failed to release workspace arrays.')
524      ENDIF
525      !
526   END SUBROUTINE Agrif_dyn
527
528
529   SUBROUTINE Agrif_ssh( kt )
530      !!----------------------------------------------------------------------
531      !!                  ***  ROUTINE Agrif_DYN  ***
532      !!---------------------------------------------------------------------- 
533      INTEGER, INTENT(in) ::   kt
534      !!
535      !!---------------------------------------------------------------------- 
536
537      IF( Agrif_Root() )   RETURN
538
539
540      IF((nbondi == -1).OR.(nbondi == 2)) THEN
541         ssha(2,:)=ssha(3,:)
542         sshn(2,:)=sshn(3,:)
543      ENDIF
544
545      IF((nbondi == 1).OR.(nbondi == 2)) THEN
546         ssha(nlci-1,:)=ssha(nlci-2,:)
547         sshn(nlci-1,:)=sshn(nlci-2,:)       
548      ENDIF
549
550      IF((nbondj == -1).OR.(nbondj == 2)) THEN
551         ssha(:,2)=sshn(:,3)
552         sshn(:,2)=sshb(:,3)
553      ENDIF
554
555      IF((nbondj == 1).OR.(nbondj == 2)) THEN
556         ssha(:,nlcj-1)=ssha(:,nlcj-2)
557         ssha(:,nlcj-1)=sshn(:,nlcj-2)               
558      ENDIF
559
560   END SUBROUTINE Agrif_ssh
561
562
563   SUBROUTINE interpu(tabres,i1,i2,j1,j2,k1,k2)
564      !!----------------------------------------------------------------------
565      !!                  ***  ROUTINE interpu  ***
566      !!---------------------------------------------------------------------- 
567      INTEGER, INTENT(in) :: i1,i2,j1,j2,k1,k2
568      REAL(wp),DIMENSION(i1:i2,j1:j2,k1:k2), INTENT(inout) :: tabres
569      !!
570      INTEGER :: ji,jj,jk
571      !!---------------------------------------------------------------------- 
572
573      DO jk=k1,k2
574         DO jj=j1,j2
575            DO ji=i1,i2
576               tabres(ji,jj,jk) = e2u(ji,jj) * un(ji,jj,jk)
577               tabres(ji,jj,jk) = tabres(ji,jj,jk) * fse3u(ji,jj,jk)
578            END DO
579         END DO
580      END DO
581   END SUBROUTINE interpu
582
583
584   SUBROUTINE interpu2d(tabres,i1,i2,j1,j2)
585      !!----------------------------------------------------------------------
586      !!                  ***  ROUTINE interpu2d  ***
587      !!---------------------------------------------------------------------- 
588      INTEGER, INTENT(in) :: i1,i2,j1,j2
589      REAL(wp), DIMENSION(i1:i2,j1:j2), INTENT(inout) :: tabres
590      !!
591      INTEGER :: ji,jj
592      !!---------------------------------------------------------------------- 
593
594      DO jj=j1,j2
595         DO ji=i1,i2
596            tabres(ji,jj) = e2u(ji,jj) * ((gcx(ji+1,jj) - gcx(ji,jj))/e1u(ji,jj)) &
597               * umask(ji,jj,1)
598         END DO
599      END DO
600
601   END SUBROUTINE interpu2d
602
603
604   SUBROUTINE interpv(tabres,i1,i2,j1,j2,k1,k2)
605      !!----------------------------------------------------------------------
606      !!                  ***  ROUTINE interpv  ***
607      !!---------------------------------------------------------------------- 
608      INTEGER, INTENT(in) :: i1,i2,j1,j2,k1,k2
609      REAL(wp),DIMENSION(i1:i2,j1:j2,k1:k2), INTENT(inout) :: tabres
610      !!
611      INTEGER :: ji, jj, jk
612      !!---------------------------------------------------------------------- 
613
614      DO jk=k1,k2
615         DO jj=j1,j2
616            DO ji=i1,i2
617               tabres(ji,jj,jk) = e1v(ji,jj) * vn(ji,jj,jk)
618               tabres(ji,jj,jk) = tabres(ji,jj,jk) * fse3v(ji,jj,jk)
619            END DO
620         END DO
621      END DO
622
623   END SUBROUTINE interpv
624
625
626   SUBROUTINE interpv2d(tabres,i1,i2,j1,j2)
627      !!----------------------------------------------------------------------
628      !!                  ***  ROUTINE interpu2d  ***
629      !!---------------------------------------------------------------------- 
630      INTEGER, INTENT(in) :: i1,i2,j1,j2
631      REAL(wp), DIMENSION(i1:i2,j1:j2), INTENT(inout) :: tabres
632      !!
633      INTEGER :: ji,jj
634      !!---------------------------------------------------------------------- 
635
636      DO jj=j1,j2
637         DO ji=i1,i2
638            tabres(ji,jj) = e1v(ji,jj) * ((gcx(ji,jj+1) - gcx(ji,jj))/e2v(ji,jj)) &
639               * vmask(ji,jj,1)
640         END DO
641      END DO
642
643   END SUBROUTINE interpv2d
644
645#else
646   !!----------------------------------------------------------------------
647   !!   Empty module                                          no AGRIF zoom
648   !!----------------------------------------------------------------------
649CONTAINS
650   SUBROUTINE Agrif_OPA_Interp_empty
651      WRITE(*,*)  'agrif_opa_interp : You should not have seen this print! error?'
652   END SUBROUTINE Agrif_OPA_Interp_empty
653#endif
654
655   !!======================================================================
656END MODULE agrif_opa_interp
Note: See TracBrowser for help on using the repository browser.