- Timestamp:
- 2021-03-03T17:04:07+01:00 (3 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
NEMO/branches/2021/dev_r14273_HPC-02_Daley_Tiling/src/OCE/TRA/traadv.F90
r14574 r14576 61 61 LOGICAL :: ln_traadv_qck ! QUICKEST scheme flag 62 62 63 INTEGER :: nadv ! choice of the type of advection scheme63 INTEGER, PUBLIC :: nadv ! choice of the type of advection scheme 64 64 ! ! associated indices: 65 INTEGER, PARAMETER :: np_NO_adv = 0 ! no T-S advection66 INTEGER, PARAMETER :: np_CEN = 1 ! 2nd/4th order centered scheme67 INTEGER, PARAMETER :: np_FCT = 2 ! 2nd/4th order Flux Corrected Transport scheme68 INTEGER, PARAMETER :: np_MUS = 3 ! MUSCL scheme69 INTEGER, PARAMETER :: np_UBS = 4 ! 3rd order Upstream Biased Scheme70 INTEGER, PARAMETER :: np_QCK = 5 ! QUICK scheme65 INTEGER, PARAMETER, PUBLIC :: np_NO_adv = 0 ! no T-S advection 66 INTEGER, PARAMETER, PUBLIC :: np_CEN = 1 ! 2nd/4th order centered scheme 67 INTEGER, PARAMETER, PUBLIC :: np_FCT = 2 ! 2nd/4th order Flux Corrected Transport scheme 68 INTEGER, PARAMETER, PUBLIC :: np_MUS = 3 ! MUSCL scheme 69 INTEGER, PARAMETER, PUBLIC :: np_UBS = 4 ! 3rd order Upstream Biased Scheme 70 INTEGER, PARAMETER, PUBLIC :: np_QCK = 5 ! QUICK scheme 71 71 72 72 !! * Substitutions … … 178 178 ! 179 179 CASE ( np_CEN ) ! Centered scheme : 2nd / 4th order 180 IF (nn_hls.EQ.2) CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kmm), 'T', 1. ) 180 ! [comm_cleanup] 181 ! IF (nn_hls.EQ.2) CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kmm), 'T', 1. ) 181 182 CALL tra_adv_cen ( kt, nit000, 'TRA', zuu, zvv, zww, Kmm, pts, jpts, Krhs, nn_cen_h, nn_cen_v ) 182 183 CASE ( np_FCT ) ! FCT scheme : 2nd / 4th order 183 184 IF (nn_hls.EQ.2) THEN 184 CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kbb), 'T', 1., pts(:,:,:,:,Kmm), 'T', 1.) 185 CALL lbc_lnk( 'traadv', zuu(:,:,:), 'U', -1., zvv(:,:,:), 'V', -1., zww(:,:,:), 'W', 1.) 185 ! [comm_cleanup] - lbc_lnk shifted into step 186 ! CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kbb), 'T', 1., pts(:,:,:,:,Kmm), 'T', 1.) 187 ! CALL lbc_lnk( 'traadv', zuu(:,:,:), 'U', -1., zvv(:,:,:), 'V', -1., zww(:,:,:), 'W', 1.) 186 188 #if defined key_loop_fusion 187 189 CALL tra_adv_fct_lf ( kt, nit000, 'TRA', rDt, zuu, zvv, zww, Kbb, Kmm, pts, jpts, Krhs, nn_fct_h, nn_fct_v ) … … 194 196 CASE ( np_MUS ) ! MUSCL 195 197 IF (nn_hls.EQ.2) THEN 196 CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kbb), 'T', 1.) 198 ! [comm_cleanup] - lbc_lnk shifted into step 199 ! CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kbb), 'T', 1.) 197 200 #if defined key_loop_fusion 198 201 CALL tra_adv_mus_lf ( kt, nit000, 'TRA', rDt, zuu, zvv, zww, Kbb, Kmm, pts, jpts, Krhs, ln_mus_ups ) … … 204 207 END IF 205 208 CASE ( np_UBS ) ! UBS 206 IF (nn_hls.EQ.2) CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kbb), 'T', 1.) 209 ! [comm_cleanup] - lbc_lnk shifted into step 210 ! IF (nn_hls.EQ.2) CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kbb), 'T', 1.) 207 211 CALL tra_adv_ubs ( kt, nit000, 'TRA', rDt, zuu, zvv, zww, Kbb, Kmm, pts, jpts, Krhs, nn_ubs_v ) 208 212 CASE ( np_QCK ) ! QUICKEST 209 IF (nn_hls.EQ.2) THEN 210 CALL lbc_lnk( 'traadv', zuu(:,:,:), 'U', -1., zvv(:,:,:), 'V', -1.) 211 CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kbb), 'T', 1.) 212 END IF 213 ! [comm_cleanup] - lbc_lnk shifted into step 214 ! IF (nn_hls.EQ.2) THEN 215 ! CALL lbc_lnk( 'traadv', zuu(:,:,:), 'U', -1., zvv(:,:,:), 'V', -1.) 216 ! CALL lbc_lnk( 'traadv', pts(:,:,:,:,Kbb), 'T', 1.) 217 ! END IF 213 218 CALL tra_adv_qck ( kt, nit000, 'TRA', rDt, zuu, zvv, zww, Kbb, Kmm, pts, jpts, Krhs ) 214 219 !
Note: See TracChangeset
for help on using the changeset viewer.