File indexing completed on 2025-05-05 05:08:24 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_U_CORIOLIS(
31fb0e0e6d Jean*0008 I bi, bj, k, vFld,
aea29c8517 Alis*0009 U uCoriolisTerm,
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 vFld(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
0033 INTEGER myThid
0034
71207ba845 Alis*0035
0036
0037 _RL uCoriolisTerm(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,sNy+OLy-1
0047 DO i=1-OLx+1,sNx+OLx
31fb0e0e6d Jean*0048 uCoriolisTerm(i,j) = halfRL
0049 & *( _fCori( i ,j,bi,bj) + _fCori(i-1,j,bi,bj) )
0050 & *0.25 _d 0*( vFld( i ,j) + vFld( i ,j+1)
0051 & + vFld(i-1,j) + vFld(i-1,j+1)
0052 & )
0053 ENDDO
0054 ENDDO
0055 ELSEIF ( selectCoriScheme.LE.3 ) THEN
0056
0057 DO j=1-OLy,sNy+OLy-1
0058 DO i=1-OLx+1,sNx+OLx
0059 uCoriolisTerm(i,j) = halfRL
0060 & *( _fCori( i ,j,bi,bj)
0061 & *halfRL*( vFld( i ,j) + vFld( i ,j+1) )
04a64662e0 Alis*0062 & + _fCori(i-1,j,bi,bj)
31fb0e0e6d Jean*0063 & *halfRL*( vFld(i-1,j) + vFld(i-1,j+1) ) )
04a64662e0 Alis*0064 ENDDO
0065 ENDDO
0066 ELSE
31fb0e0e6d Jean*0067
7843dde2de jm-c 0068 DO j=1-OLy,sNy+OLy-1
0069 DO i=1-OLx+1,sNx+OLx
31fb0e0e6d Jean*0070 uCoriolisTerm(i,j) = halfRL
0071 & *( _fCori( i ,j,bi,bj) + _fCori(i-1,j,bi,bj) )
0072 & *( vFld( i , j )*dxG( i , j ,bi,bj)*hFacS( i , j ,k,bi,bj)
0073 & + vFld( i ,j+1)*dxG( i ,j+1,bi,bj)*hFacS( i ,j+1,k,bi,bj)
0074 & + vFld(i-1, j )*dxG(i-1, j ,bi,bj)*hFacS(i-1, j ,k,bi,bj)
0075 & + vFld(i-1,j+1)*dxG(i-1,j+1,bi,bj)*hFacS(i-1,j+1,k,bi,bj)
0076 & )*0.25 _d 0*recip_dxC(i,j,bi,bj)*recip_hFacW(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,sNy+OLy-1
0086 DO i=1-OLx+1,sNx+OLx
8088b71082 Alis*0087 uCoriolisTerm(i,j) = uCoriolisTerm(i,j)
31fb0e0e6d Jean*0088 & *4. _d 0/MAX( oneRS,
010a91abcf Jean*0089 & maskS( i , j ,k,bi,bj)+maskS( i ,j+1,k,bi,bj)
0090 & +maskS(i-1, j ,k,bi,bj)+maskS(i-1,j+1,k,bi,bj) )
8088b71082 Alis*0091 ENDDO
0092 ENDDO
0093 ENDIF
0094
aea29c8517 Alis*0095 RETURN
0096 END