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 branches/2011/dev_r2787_LOCEAN3_TRA_TRP/NEMOGCM/NEMO/NST_SRC – NEMO

source: branches/2011/dev_r2787_LOCEAN3_TRA_TRP/NEMOGCM/NEMO/NST_SRC/agrif_opa_interp.F90 @ 2789

Last change on this file since 2789 was 2789, checked in by cetlod, 13 years ago

Implementation of the merge of TRA/TRP : first guess, see ticket #842

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