Back to home page

darwin3

 
 

    


File indexing completed on 2025-09-13 12:07:52 UTC

view on githubraw file Latest commit 31fb0e0e on 2025-05-05 02:15:14 UTC
6d54cf9ca1 Ed H*0001 #include "MOM_FLUXFORM_OPTIONS.h"
aea29c8517 Alis*0002 
71207ba845 Alis*0003 CBOP
                0004 C !ROUTINE: MOM_V_CORIOLIS
                0005 
                0006 C !INTERFACE: ==========================================================
010a91abcf Jean*0007       SUBROUTINE MOM_V_CORIOLIS(
31fb0e0e6d Jean*0008      I        bi, bj, k, uFld,
aea29c8517 Alis*0009      U        vCoriolisTerm,
31fb0e0e6d Jean*0010      I        myThid )
aea29c8517 Alis*0011 
71207ba845 Alis*0012 C !DESCRIPTION:
                0013 C Calculates the horizontal Coriolis term in the meridional equation:
                0014 C \begin{equation*}
                0015 C -\overline{f}^j \overline{u}^{ij}
                0016 C \end{equation*}
aea29c8517 Alis*0017 
71207ba845 Alis*0018 C !USES: ===============================================================
                0019       IMPLICIT NONE
aea29c8517 Alis*0020 #include "SIZE.h"
                0021 #include "EEPARAMS.h"
                0022 #include "PARAMS.h"
                0023 #include "GRID.h"
                0024 #include "SURFACE.h"
                0025 
71207ba845 Alis*0026 C !INPUT PARAMETERS: ===================================================
31fb0e0e6d Jean*0027 C  bi, bj               :: tile indices
71207ba845 Alis*0028 C  k                    :: vertical level
                0029 C  uFld                 :: zonal flow
                0030 C  myThid               :: thread number
31fb0e0e6d Jean*0031       INTEGER bi, bj, k
aea29c8517 Alis*0032       _RL uFld(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
                0033       INTEGER myThid
                0034 
71207ba845 Alis*0035 C !OUTPUT PARAMETERS: ==================================================
                0036 C  vCoriolisTerm        :: Coriolis term
                0037       _RL vCoriolisTerm(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
                0038 
                0039 C !LOCAL VARIABLES: ====================================================
                0040 C  i,j                  :: loop indices
31fb0e0e6d Jean*0041       INTEGER i, j
71207ba845 Alis*0042 CEOP
aea29c8517 Alis*0043 
31fb0e0e6d Jean*0044       IF ( selectCoriScheme.LE.1 ) THEN
                0045 C-    Original discretization
7843dde2de jm-c 0046        DO j=1-OLy+1,sNy+OLy
                0047         DO i=1-OLx,sNx+OLx-1
31fb0e0e6d Jean*0048          vCoriolisTerm(i,j) = -halfRL
                0049      &   *( _fCori(i, j ,bi,bj) + _fCori(i,j-1,bi,bj) )
                0050      &   *0.25 _d 0*( uFld(i, j ) + uFld(i+1, j )
                0051      &              + uFld(i,j-1) + uFld(i+1,j-1)
                0052      &              )
                0053         ENDDO
                0054        ENDDO
                0055       ELSEIF ( selectCoriScheme.LE.3 ) THEN
                0056 C-    Energy conserving discretization
                0057        DO j=1-OLy+1,sNy+OLy
                0058         DO i=1-OLx,sNx+OLx-1
                0059          vCoriolisTerm(i,j) = -halfRL
                0060      &        *( _fCori(i, j ,bi,bj)
                0061      &          *halfRL*( uFld( i , j ) + uFld(i+1, j ) )
04a64662e0 Alis*0062      &         + _fCori(i,j-1,bi,bj)
31fb0e0e6d Jean*0063      &          *halfRL*( uFld( i ,j-1) + uFld(i+1,j-1) ) )
04a64662e0 Alis*0064         ENDDO
                0065        ENDDO
                0066       ELSE
31fb0e0e6d Jean*0067 C-    Using averaged transport:
7843dde2de jm-c 0068        DO j=1-OLy+1,sNy+OLy
                0069         DO i=1-OLx,sNx+OLx-1
31fb0e0e6d Jean*0070          vCoriolisTerm(i,j) = -halfRL
                0071      &   *( _fCori(i, j ,bi,bj) + _fCori(i,j-1,bi,bj) )
                0072      &   *( uFld( i , j )*dyG( i , j ,bi,bj)*hFacW( i , j ,k,bi,bj)
                0073      &    + uFld(i+1, j )*dyG(i+1, j ,bi,bj)*hFacW(i+1, j ,k,bi,bj)
                0074      &    + uFld( i ,j-1)*dyG( i ,j-1,bi,bj)*hFacW( i ,j-1,k,bi,bj)
                0075      &    + uFld(i+1,j-1)*dyG(i+1,j-1,bi,bj)*hFacW(i+1,j-1,k,bi,bj)
                0076      &    )*0.25 _d 0*recip_dyC(i,j,bi,bj)*recip_hFacS(i,j,k,bi,bj)
04a64662e0 Alis*0077         ENDDO
aea29c8517 Alis*0078        ENDDO
04a64662e0 Alis*0079       ENDIF
aea29c8517 Alis*0080 
7843dde2de jm-c 0081       IF ( selectCoriScheme.EQ.1 .OR. selectCoriScheme.EQ.3 ) THEN
31fb0e0e6d Jean*0082 C-    Scale term so that only "wet" points are used
                0083 C     Due to: Jamart and Ozer, 1986, JGR 91 (C9), 10,621-10,631
8088b71082 Alis*0084 C         "Numerical Boundary Layers and Spurious Residual Flows"
7843dde2de jm-c 0085        DO j=1-OLy+1,sNy+OLy
                0086         DO i=1-OLx,sNx+OLx-1
8088b71082 Alis*0087          vCoriolisTerm(i,j) = vCoriolisTerm(i,j)
31fb0e0e6d Jean*0088      &   *4. _d 0/MAX( oneRS,
010a91abcf Jean*0089      &                 maskW( i , j ,k,bi,bj)+maskW(i+1, j ,k,bi,bj)
                0090      &                +maskW( i ,j-1,k,bi,bj)+maskW(i+1,j-1,k,bi,bj) )
8088b71082 Alis*0091         ENDDO
                0092        ENDDO
                0093       ENDIF
                0094 
aea29c8517 Alis*0095       RETURN
                0096       END