/[MITgcm]/MITgcm/pkg/mom_vecinv/mom_vecinv.F
ViewVC logotype

Diff of /MITgcm/pkg/mom_vecinv/mom_vecinv.F

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

revision 1.49 by jmc, Fri Sep 23 19:19:37 2005 UTC revision 1.50 by baylor, Mon Sep 26 15:27:11 2005 UTC
# Line 95  c     _RL  mtFacV Line 95  c     _RL  mtFacV
95        _RL omega3(1-OLx:sNx+OLx,1-OLy:sNy+OLy)        _RL omega3(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
96        _RL vort3(1-OLx:sNx+OLx,1-OLy:sNy+OLy)        _RL vort3(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
97        _RL hDiv(1-OLx:sNx+OLx,1-OLy:sNy+OLy)        _RL hDiv(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
98          _RL viscAh_Z(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
99          _RL viscAh_D(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
100          _RL viscA4_Z(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
101          _RL viscA4_D(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
102          LOGICAL harmonic,biharmonic,useVariableViscosity
103    
104  #ifdef ALLOW_MNC  #ifdef ALLOW_MNC
105        INTEGER offsets(9)        INTEGER offsets(9)
# Line 144  c       mT(i,j)    = 0. Line 149  c       mT(i,j)    = 0.
149          vort3(i,j) = 0.          vort3(i,j) = 0.
150          omega3(i,j)= 0.          omega3(i,j)= 0.
151          ke(i,j)    = 0.          ke(i,j)    = 0.
152            viscAh_Z(i,j) = 0.
153            viscAh_D(i,j) = 0.
154            viscA4_Z(i,j) = 0.
155            viscA4_D(i,j) = 0.
156    
157  #ifdef ALLOW_AUTODIFF_TAMC  #ifdef ALLOW_AUTODIFF_TAMC
158          strain(i,j)  = 0. _d 0          strain(i,j)  = 0. _d 0
159          tension(i,j) = 0. _d 0          tension(i,j) = 0. _d 0
# Line 196  c     CALL MOM_VI_HFACZ_DISS(bi,bj,k,hFa Line 206  c     CALL MOM_VI_HFACZ_DISS(bi,bj,k,hFa
206       & CALL MOM_CALC_ABSVORT3(bi,bj,k,vort3,omega3,myThid)       & CALL MOM_CALC_ABSVORT3(bi,bj,k,vort3,omega3,myThid)
207    
208        IF (momViscosity) THEN        IF (momViscosity) THEN
209    C      Calculate Viscosities
210          CALL MOM_CALC_VISC(
211         I        bi,bj,k,
212         O        viscAh_Z,viscAh_D,viscA4_Z,viscA4_D,
213         O        harmonic,biharmonic,useVariableViscosity,
214         I        hDiv,vort3,tension,strain,KE,hfacZ,
215         I        myThid)
216    
217  C      Calculate del^2 u and del^2 v for bi-harmonic term  C      Calculate del^2 u and del^2 v for bi-harmonic term
218         IF ( (viscA4.NE.0. .AND. no_slip_sides)         IF (biharmonic) THEN
      &     .OR. viscA4D.NE.0. .OR. viscA4Z.NE.0.  
      &     .OR. viscA4Grid.NE.0.  
      &     .OR. viscC4leith.NE.0.  
      &     .OR. viscC4leithD.NE.0.  
      &     .OR. viscC4smag.NE.0.  
      &    ) THEN  
219           CALL MOM_VI_DEL2UV(bi,bj,k,hDiv,vort3,hFacZ,           CALL MOM_VI_DEL2UV(bi,bj,k,hDiv,vort3,hFacZ,
220       O                      del2u,del2v,       O                      del2u,del2v,
221       &                      myThid)       &                      myThid)
# Line 218  C      in terms of tension and strain Line 230  C      in terms of tension and strain
230         IF (useStrainTensionVisc) THEN         IF (useStrainTensionVisc) THEN
231           CALL MOM_HDISSIP(bi,bj,k,hDiv,vort3,tension,strain,KE,           CALL MOM_HDISSIP(bi,bj,k,hDiv,vort3,tension,strain,KE,
232       I                    hFacZ,       I                    hFacZ,
233         I                    viscAh_Z,viscAh_D,viscA4_Z,viscA4_D,
234         I                    harmonic,biharmonic,useVariableViscosity,
235       O                    guDiss,gvDiss,       O                    guDiss,gvDiss,
236       I                    myThid)       I                    myThid)
237         ELSE         ELSE
238  C      in terms of vorticity and divergence  C      in terms of vorticity and divergence
239           CALL MOM_VI_HDISSIP(bi,bj,k,hDiv,vort3,tension,strain,KE,           CALL MOM_VI_HDISSIP(bi,bj,k,hDiv,vort3,tension,strain,KE,
240       I                       hFacZ,dStar,zStar,       I                       hFacZ,dStar,zStar,
241         I                       viscAh_Z,viscAh_D,viscA4_Z,viscA4_D,
242         I                       harmonic,biharmonic,useVariableViscosity,
243       O                       guDiss,gvDiss,       O                       guDiss,gvDiss,
244       &                       myThid)               &                       myThid)        
245         ENDIF         ENDIF
# Line 263  C--   Tendency is minus divergence of th Line 279  C--   Tendency is minus divergence of th
279  C-- No-slip and drag BCs appear as body forces in cell abutting topography  C-- No-slip and drag BCs appear as body forces in cell abutting topography
280        IF (momViscosity.AND.no_slip_sides) THEN        IF (momViscosity.AND.no_slip_sides) THEN
281  C-     No-slip BCs impose a drag at walls...  C-     No-slip BCs impose a drag at walls...
282         CALL MOM_U_SIDEDRAG(bi,bj,k,uFld,del2u,hFacZ,vF,myThid)         CALL MOM_U_SIDEDRAG(
283         I        bi,bj,k,
284         I        uFld, del2u, hFacZ,
285         I        viscAh_Z,viscA4_Z,
286         I        harmonic,biharmonic,useVariableViscosity,
287         O        vF,
288         I        myThid)
289         DO j=jMin,jMax         DO j=jMin,jMax
290          DO i=iMin,iMax          DO i=iMin,iMax
291           guDiss(i,j) = guDiss(i,j)+vF(i,j)           guDiss(i,j) = guDiss(i,j)+vF(i,j)
# Line 323  C--   Tendency is minus divergence of th Line 345  C--   Tendency is minus divergence of th
345  C-- No-slip and drag BCs appear as body forces in cell abutting topography  C-- No-slip and drag BCs appear as body forces in cell abutting topography
346        IF (momViscosity.AND.no_slip_sides) THEN        IF (momViscosity.AND.no_slip_sides) THEN
347  C-     No-slip BCs impose a drag at walls...  C-     No-slip BCs impose a drag at walls...
348         CALL MOM_V_SIDEDRAG(bi,bj,k,vFld,del2v,hFacZ,vF,myThid)         CALL MOM_V_SIDEDRAG(
349         I        bi,bj,k,
350         I        vFld, del2v, hFacZ,
351         I        viscAh_Z,viscA4_Z,
352         I        harmonic,biharmonic,useVariableViscosity,
353         O        vF,
354         I        myThid)
355         DO j=jMin,jMax         DO j=jMin,jMax
356          DO i=iMin,iMax          DO i=iMin,iMax
357           gvDiss(i,j) = gvDiss(i,j)+vF(i,j)           gvDiss(i,j) = gvDiss(i,j)+vF(i,j)

Legend:
Removed from v.1.49  
changed lines
  Added in v.1.50

  ViewVC Help
Powered by ViewVC 1.1.22