File indexing completed on 2018-03-02 18:42:18 UTC
view on githubraw file Latest commit add29e06 on 2018-01-31 20:35:05 UTC
cec2469d72 Alis*0001 #include "MOM_VECINV_OPTIONS.h"
aea29c8517 Alis*0002
355718db32 Jean*0003
0004
0005
5d7e0a8948 Jean*0006 SUBROUTINE MOM_VI_V_CORIOLIS(
355718db32 Jean*0007 I bi, bj, k,
3370e71df9 Mart*0008 I selectVortScheme, useJamartMomAdv,
355718db32 Jean*0009 I uFld, omega3, hFacZ, r_hFacZ,
0010 O vCoriolisTerm,
0011 I myThid )
0012
cab1a69b8a Jean*0013
0014
355718db32 Jean*0015
0016
0017
cab1a69b8a Jean*0018
355718db32 Jean*0019
0020
0021
0022 IMPLICIT NONE
aea29c8517 Alis*0023
0024
0025 #include "SIZE.h"
0026 #include "EEPARAMS.h"
0027 #include "GRID.h"
0028
355718db32 Jean*0029
aea29c8517 Alis*0030
355718db32 Jean*0031 INTEGER bi, bj, k
0032 _RL uFld (1-OLx:sNx+OLx,1-OLy:sNy+OLy)
0033 _RL omega3 (1-OLx:sNx+OLx,1-OLy:sNy+OLy)
0034 _RS hFacZ (1-OLx:sNx+OLx,1-OLy:sNy+OLy)
0035 _RS r_hFacZ (1-OLx:sNx+OLx,1-OLy:sNy+OLy)
aea29c8517 Alis*0036 _RL vCoriolisTerm(1-OLx:sNx+OLx,1-OLy:sNy+OLy)
3370e71df9 Mart*0037 INTEGER selectVortScheme
0038 LOGICAL useJamartMomAdv
aea29c8517 Alis*0039 INTEGER myThid
355718db32 Jean*0040
aea29c8517 Alis*0041
0042
355718db32 Jean*0043
0044 CHARACTER*(MAX_LEN_MBUF) msgBuf
0045 LOGICAL upwindVort3
0046 INTEGER i, j
0047 _RL uBarXY, uBarYm, uBarYp
0048 _RL vort3v
4e5f84a272 Jean*0049 _RL vort3im, vort3ij, vort3pm, vort3pj
0050 _RL oneThird, tmpFac
355718db32 Jean*0051 _RS epsil
0052 PARAMETER( upwindVort3 = .FALSE. )
aea29c8517 Alis*0053
cab1a69b8a Jean*0054 epsil = 1. _d -9
4e5f84a272 Jean*0055 tmpFac = 1. _d 0
0056
0057 oneThird = 1. _d 0 / 3. _d 0
aea29c8517 Alis*0058
355718db32 Jean*0059 IF ( selectVortScheme.EQ.0 ) THEN
0060
0061
0062 DO j=2-Oly,sNy+Oly
0063 DO i=1-Olx,sNx+Olx-1
aea29c8517 Alis*0064 uBarXY=0.25*(
616600b8d2 Patr*0065 & (uFld( i , j )*dyG( i , j ,bi,bj)*_hFacW( i , j ,k,bi,bj)
0066 & +uFld( i ,j-1)*dyG( i ,j-1,bi,bj)*_hFacW( i ,j-1,k,bi,bj))
0067 & +(uFld(i+1, j )*dyG(i+1, j ,bi,bj)*_hFacW(i+1, j ,k,bi,bj)
355718db32 Jean*0068 & +uFld(i+1,j-1)*dyG(i+1,j-1,bi,bj)*_hFacW(i+1,j-1,k,bi,bj))
0069 & )
0070 IF (upwindVort3) THEN
aea29c8517 Alis*0071 IF (uBarXY.GT.0.) THEN
0072 vort3v=omega3(i,j)*r_hFacZ(i,j)
0073 ELSE
0074 vort3v=omega3(i+1,j)*r_hFacZ(i+1,j)
0075 ENDIF
0076 ELSE
cab1a69b8a Jean*0077 vort3v=0.5*(omega3(i,j)*r_hFacZ(i,j)
0078 & +omega3(i+1,j)*r_hFacZ(i+1,j))
aea29c8517 Alis*0079 ENDIF
355718db32 Jean*0080 vCoriolisTerm(i,j)= -vort3v*uBarXY*recip_dyC(i,j,bi,bj)
0081 & * _maskS(i,j,k,bi,bj)
0082 ENDDO
0083 ENDDO
0084
0085 ELSEIF ( selectVortScheme.EQ.1 ) THEN
0086
0087
0088 DO j=2-Oly,sNy+Oly
0089 DO i=1-Olx,sNx+Olx-1
0090 uBarXY= 0.5*(
0091 & (uFld( i , j )*dyG( i , j ,bi,bj)*hFacZ( i ,j)
0092 & +uFld( i ,j-1)*dyG( i ,j-1,bi,bj)*hFacZ( i ,j))
5d7e0a8948 Jean*0093 & +(uFld(i+1, j )*dyG(i+1, j ,bi,bj)*hFacZ(i+1,j)
0094 & +uFld(i+1,j-1)*dyG(i+1,j-1,bi,bj)*hFacZ(i+1,j))
355718db32 Jean*0095 & )/MAX( epsil, hFacZ(i,j)+hFacZ(i+1,j) )
0096 IF (upwindVort3) THEN
cab1a69b8a Jean*0097 IF (uBarXY.GT.0.) THEN
0098 vort3v=omega3(i,j)
0099 ELSE
0100 vort3v=omega3(i+1,j)
0101 ENDIF
0102 ELSE
0103 vort3v=0.5*(omega3(i,j)+omega3(i+1,j))
0104 ENDIF
355718db32 Jean*0105 vCoriolisTerm(i,j)= -vort3v*uBarXY*recip_dyC(i,j,bi,bj)
0106 & * _maskS(i,j,k,bi,bj)
0107 ENDDO
0108 ENDDO
0109
0110 ELSEIF ( selectVortScheme.EQ.2 ) THEN
0111
0112
0113 DO j=2-Oly,sNy+Oly
0114 DO i=1-Olx,sNx+Olx-1
0115 uBarYm=0.5*(
0116 & uFld( i , j )*dyG( i , j ,bi,bj)*_hFacW( i , j ,k,bi,bj)
0117 & +uFld( i ,j-1)*dyG( i ,j-1,bi,bj)*_hFacW( i ,j-1,k,bi,bj) )
0118 uBarYp=0.5*(
0119 & uFld(i+1, j )*dyG(i+1, j ,bi,bj)*_hFacW(i+1, j ,k,bi,bj)
0120 & +uFld(i+1,j-1)*dyG(i+1,j-1,bi,bj)*_hFacW(i+1,j-1,k,bi,bj) )
0121 IF (upwindVort3) THEN
0122 IF ( (uBarYm+uBarYp) .GT.0.) THEN
0123 vort3v=uBarYm*r_hFacZ( i ,j)*omega3( i ,j)
0124 ELSE
0125 vort3v=uBarYp*r_hFacZ(i+1,j)*omega3(i+1,j)
0126 ENDIF
0127 ELSE
0128 vort3v = ( uBarYm*r_hFacZ( i ,j)*omega3( i ,j)
0129 & +uBarYp*r_hFacZ(i+1,j)*omega3(i+1,j)
0130 & )*0.5 _d 0
0131 ENDIF
0132 vCoriolisTerm(i,j)= -vort3v*recip_dyC(i,j,bi,bj)
0133 & * _maskS(i,j,k,bi,bj)
0134 ENDDO
0135 ENDDO
0136
4e5f84a272 Jean*0137 ELSEIF ( selectVortScheme.EQ.3 ) THEN
0138
0139
0140
0141
0142
0143
0144 DO j=2-Oly,sNy+Oly-1
0145 DO i=1-Olx,sNx+Olx-1
0146 vort3im= ( r_hFacZ(i, j )*omega3(i, j )
0147 & +(r_hFacZ(i+1,j)*omega3(i+1,j)
0148 & +r_hFacZ(i,j-1)*omega3(i,j-1)
0149 & ))*oneThird
0150
0151 & *uFld( i ,j-1)*dyG( i ,j-1,bi,bj)*_hFacW( i ,j-1,k,bi,bj)
0152 vort3ij= ( r_hFacZ(i, j )*omega3(i, j )
0153 & +(r_hFacZ(i+1,j)*omega3(i+1,j)
0154 & +r_hFacZ(i,j+1)*omega3(i,j+1)
0155 & ))*oneThird
0156
0157 & *uFld( i , j )*dyG( i , j ,bi,bj)*_hFacW( i , j ,k,bi,bj)
0158 vort3pm= ( r_hFacZ(i+1,j)*omega3(i+1,j)
0159 & +(r_hFacZ(i, j )*omega3(i, j )
0160 & +r_hFacZ(i+1,j-1)*omega3(i+1,j-1)
0161 & ))*oneThird
0162
0163 & *uFld(i+1,j-1)*dyG(i+1,j-1,bi,bj)*_hFacW(i+1,j-1,k,bi,bj)
0164 vort3pj= ( r_hFacZ(i+1,j)*omega3(i+1,j)
0165 & +(r_hFacZ(i, j )*omega3(i, j )
0166 & +r_hFacZ(i+1,j+1)*omega3(i+1,j+1)
0167 & ))*oneThird
0168
0169 & *uFld(i+1, j )*dyG(i+1, j ,bi,bj)*_hFacW(i+1, j ,k,bi,bj)
0170
0171 vCoriolisTerm(i,j)= -( (vort3im+vort3ij)+(vort3pm+vort3pj) )
0172 & *0.25 _d 0 *recip_dyC(i,j,bi,bj)
0173 & * _maskS(i,j,k,bi,bj)
0174 ENDDO
0175 ENDDO
0176
355718db32 Jean*0177 ELSE
0178 WRITE(msgBuf,'(A,I5,A)')
0179 & 'MOM_VI_V_CORIOLIS: selectVortScheme=', selectVortScheme,
0180 & ' not implemented'
0181 CALL PRINT_ERROR( msgBuf, myThid )
0182 STOP 'ABNORMAL END: S/R MOM_VI_V_CORIOLIS'
0183
0184 ENDIF
0185
0186 IF ( useJamartMomAdv ) THEN
4e5f84a272 Jean*0187 DO j=2-Oly,sNy+Oly-1
355718db32 Jean*0188 DO i=1-Olx,sNx+Olx-1
0189 vCoriolisTerm(i,j) = vCoriolisTerm(i,j)
0190 & * 4. _d 0 * _hFacS(i,j,k,bi,bj)
0191 & / MAX( epsil,
0192 & (_hFacW( i ,j,k,bi,bj)+_hFacW( i ,j-1,k,bi,bj))
0193 & +(_hFacW(i+1,j,k,bi,bj)+_hFacW(i+1,j-1,k,bi,bj))
0194 & )
0195 ENDDO
aea29c8517 Alis*0196 ENDDO
355718db32 Jean*0197 ENDIF
aea29c8517 Alis*0198
0199 RETURN
0200 END