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
0004
0005
0006
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
0013
0014
0015
0016
aea29c8517 Alis*0017
71207ba845 Alis*0018
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
31fb0e0e6d Jean*0027
71207ba845 Alis*0028
0029
0030
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
0036
0037 _RL vCoriolisTerm(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
0038
0039
0040
31fb0e0e6d Jean*0041 INTEGER i, j
71207ba845 Alis*0042
aea29c8517 Alis*0043
31fb0e0e6d Jean*0044 IF ( selectCoriScheme.LE.1 ) THEN
0045
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
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
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
0083
8088b71082 Alis*0084
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