Changeset 12740 for NEMO/trunk/tests/WAD/MY_SRC/usrdef_zgr.F90
- Timestamp:
- 2020-04-12T11:03:06+02:00 (4 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
NEMO/trunk/tests/WAD/MY_SRC/usrdef_zgr.F90
r12377 r12740 29 29 PUBLIC usr_def_zgr ! called by domzgr.F90 30 30 31 !! * Substitutions 32 # include "do_loop_substitute.h90" 31 33 !!---------------------------------------------------------------------- 32 34 !! NEMO/OCE 4.0 , NEMO Consortium (2018) … … 242 244 ! at v-point: averaging zht 243 245 zhv = 0._wp 244 DO jj = 1, jpjm1245 zhv( :,jj) = 0.5_wp * ( zht(:,jj) + zht(:,jj+1) )246 END DO246 DO_2D_00_00 247 zhv(ji,jj) = 0.5_wp * ( zht(ji,jj) + zht(ji,jj+1) ) 248 END_2D 247 249 CALL lbc_lnk( 'usrdef_zgr', zhv, 'V', 1. ) ! boundary condition: this mask the surrounding grid-points 248 250 DO jj = mj0(1), mj1(1) ! first row of global domain only … … 279 281 ht_0 = zht 280 282 k_bot(:,:) = jpkm1 * k_top(:,:) !* bottom ocean = jpk-1 (here use k_top as a land mask) 281 DO jj = 1, jpj 282 DO ji = 1, jpi 283 IF( zht(ji,jj) <= -(rn_wdld - rn_wdmin2)) THEN 284 k_bot(ji,jj) = 0 285 k_top(ji,jj) = 0 286 ENDIF 287 END DO 288 END DO 283 DO_2D_11_11 284 IF( zht(ji,jj) <= -(rn_wdld - rn_wdmin2)) THEN 285 k_bot(ji,jj) = 0 286 k_top(ji,jj) = 0 287 ENDIF 288 END_2D 289 289 ! 290 290 ! !* terrain-following coordinate with e3.(k)=cst) 291 291 ! ! OVERFLOW case : identical with j-index (T=V, U=F) 292 DO jj = 1, jpjm1 293 DO ji = 1, jpim1 294 z1_jpkm1 = 1._wp / REAL( k_bot(ji,jj) - k_top(ji,jj) + 1 , wp) 295 DO jk = 1, jpk 296 zwet = MAX( zht(ji,jj), rn_wdmin1 ) 297 pdept(ji,jj,jk) = zwet * z1_jpkm1 * ( REAL( jk , wp ) - 0.5_wp ) 298 pdepw(ji,jj,jk) = zwet * z1_jpkm1 * ( REAL( jk-1 , wp ) ) 299 pe3t (ji,jj,jk) = zwet * z1_jpkm1 300 pe3w (ji,jj,jk) = zwet * z1_jpkm1 301 zwet = MAX( zhu(ji,jj), rn_wdmin1 ) 302 pe3u (ji,jj,jk) = zwet * z1_jpkm1 303 pe3uw(ji,jj,jk) = zwet * z1_jpkm1 304 pe3f (ji,jj,jk) = zwet * z1_jpkm1 305 zwet = MAX( zhv(ji,jj), rn_wdmin1 ) 306 pe3v (ji,jj,jk) = zwet * z1_jpkm1 307 pe3vw(ji,jj,jk) = zwet * z1_jpkm1 308 END DO 309 END DO 310 END DO 292 DO_2D_00_00 293 z1_jpkm1 = 1._wp / REAL( k_bot(ji,jj) - k_top(ji,jj) + 1 , wp) 294 DO jk = 1, jpk 295 zwet = MAX( zht(ji,jj), rn_wdmin1 ) 296 pdept(ji,jj,jk) = zwet * z1_jpkm1 * ( REAL( jk , wp ) - 0.5_wp ) 297 pdepw(ji,jj,jk) = zwet * z1_jpkm1 * ( REAL( jk-1 , wp ) ) 298 pe3t (ji,jj,jk) = zwet * z1_jpkm1 299 pe3w (ji,jj,jk) = zwet * z1_jpkm1 300 zwet = MAX( zhu(ji,jj), rn_wdmin1 ) 301 pe3u (ji,jj,jk) = zwet * z1_jpkm1 302 pe3uw(ji,jj,jk) = zwet * z1_jpkm1 303 pe3f (ji,jj,jk) = zwet * z1_jpkm1 304 zwet = MAX( zhv(ji,jj), rn_wdmin1 ) 305 pe3v (ji,jj,jk) = zwet * z1_jpkm1 306 pe3vw(ji,jj,jk) = zwet * z1_jpkm1 307 END DO 308 END_2D 311 309 CALL lbc_lnk( 'usrdef_zgr', pdept, 'T', 1. ) 312 310 CALL lbc_lnk( 'usrdef_zgr', pdepw, 'T', 1. )
Note: See TracChangeset
for help on using the changeset viewer.