/[MITgcm]/MITgcm/pkg/generic_advdiff/gad_u3_adv_x.F
ViewVC logotype

Annotation of /MITgcm/pkg/generic_advdiff/gad_u3_adv_x.F

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.2 - (hide annotations) (download)
Mon Aug 20 20:44:01 2001 UTC (22 years, 9 months ago) by jmc
Branch: MAIN
CVS Tags: checkpoint40pre9, checkpoint40pre8, checkpoint40
Changes since 1.1: +11 -6 lines
Reduce to 2nd or 3rd order near a boundary, depending on the flow direction

1 jmc 1.2 C $Header: /u/gcmpack/models/MITgcmUV/pkg/generic_advdiff/gad_u3_adv_x.F,v 1.1 2001/07/12 00:31:59 jmc Exp $
2 jmc 1.1 C $Name: $
3    
4     #include "GAD_OPTIONS.h"
5    
6     SUBROUTINE GAD_U3_ADV_X(
7     I bi,bj,k,
8     I uTrans,
9     I tracer,
10     O uT,
11     I myThid )
12     C /==========================================================\
13     C | SUBROUTINE GAD_U3_ADV_X |
14     C | o Compute Zonal advective Flux of Tracer using |
15     C | 3rd Order Upwind Scheme |
16 jmc 1.2 C | o reduced to 2nd or 3rd Order near a boundary |
17 jmc 1.1 C |==========================================================|
18     IMPLICIT NONE
19    
20     C == GLobal variables ==
21     #include "SIZE.h"
22     #include "GRID.h"
23     #include "GAD.h"
24    
25     C == Routine arguments ==
26     INTEGER bi,bj,k
27     _RL uTrans(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
28     _RL tracer(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
29     _RL uT (1-OLx:sNx+OLx,1-OLy:sNy+OLy)
30     INTEGER myThid
31    
32     C == Local variables ==
33     INTEGER i,j
34     _RL Rjm,Rj,Rjp,Rjjm,Rjjp
35    
36     DO j=1-Oly,sNy+Oly
37     uT(1-Olx,j)=0.
38     uT(2-Olx,j)=0.
39     uT(sNx+Olx,j)=0.
40     DO i=1-Olx+2,sNx+Olx-1
41 jmc 1.2 Rjp=(tracer(i+1,j)-tracer(i,j))
42     c & *maskW(i+1,j,k,bi,bj)
43     Rj =(tracer(i,j)-tracer(i-1,j))
44     c & *maskW(i,j,k,bi,bj)
45     Rjm=(tracer(i-1,j)-tracer(i-2,j))
46     c & *maskW(i-1,j,k,bi,bj)
47     C- jmc: mask not needed here above if Rjjp & Rjjm & uTrans are masked
48     Rjjp=(Rjp-Rj)*maskW(i+1,j,k,bi,bj)
49     Rjjm=(Rj-Rjm)*maskW(i-1,j,k,bi,bj)
50 jmc 1.1 uT(i,j) =
51     & uTrans(i,j)*(
52     & Tracer(i,j)+Tracer(i-1,j)-oneSixth*( Rjjp+Rjjm )
53     & )*0.5 _d 0
54     & +ABS( uTrans(i,j) )*0.5 _d 0*oneSixth*( Rjjp-Rjjm )
55     ENDDO
56     ENDDO
57    
58     RETURN
59     END

  ViewVC Help
Powered by ViewVC 1.1.22