- Timestamp:
- 2017-01-16T20:11:00+01:00 (7 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/UKMO/CO6_shelfclimate/NEMOGCM/NEMO/OPA_SRC/BDY/bdyini.F90
r7566 r7567 49 49 !!---------------------------------------------------------------------- 50 50 !! NEMO/OPA 4.0 , NEMO Consortium (2011) 51 !! $Id$ 51 !! $Id$ 52 52 !! Software governed by the CeCILL licence (NEMOGCM/NEMO_CeCILL.txt) 53 53 !!---------------------------------------------------------------------- … … 102 102 & cn_ice_lim, nn_ice_lim_dta, & 103 103 & rn_ice_tem, rn_ice_sal, rn_ice_age, & 104 & ln_vol, nn_volctl, nn_rimwidth104 & ln_vol, nn_volctl, ln_sponge, rn_sponge, nn_rimwidth 105 105 !! 106 106 NAMELIST/nambdy_index/ ctypebdy, nbdyind, nbdybeg, nbdyend 107 108 109 ! ! JT 110 NAMELIST/nambdy_ssh/ ln_ssh_bdy 111 ! ! JT 107 112 INTEGER :: ios ! Local integer output status for namelist read 108 113 !!---------------------------------------------------------------------- … … 132 137 902 IF( ios /= 0 ) CALL ctl_nam ( ios , 'nambdy in configuration namelist', lwp ) 133 138 IF(lwm) WRITE ( numond, nambdy ) 139 140 141 142 143 144 145 146 147 148 !JT Read nambdy_ssh namelist 149 REWIND( numnam_ref ) ! Namelist nambdy in reference namelist :Unstructured open boundaries 150 READ ( numnam_ref, nambdy_ssh, IOSTAT = ios, ERR = 905) 151 905 IF( ios /= 0 ) CALL ctl_nam ( ios , 'nambdy_ssh in reference namelist', lwp ) 152 153 REWIND( numnam_cfg ) ! Namelist nambdy in configuration namelist :Unstructured open boundaries 154 READ ( numnam_cfg, nambdy_ssh, IOSTAT = ios, ERR = 906) 155 906 IF( ios /= 0 ) CALL ctl_nam ( ios , 'nambdy_ssh in configuration namelist', lwp ) 156 IF(lwm) WRITE ( numond, nambdy_ssh ) 157 158 IF(lwp) WRITE(numout,*) 159 IF(lwp) WRITE(numout,*) 'nambdy_ssh : use of ssh boundaries' 160 IF(lwp) WRITE(numout,*) '~~~~~~~~' 161 IF(lwp) WRITE(numout,*) ' ln_ssh_bdy: ' 162 DO ib_bdy = 1,nb_bdy 163 IF(lwp) WRITE(numout,*) ' ln_ssh_bdy(',ib_bdy,'): ',ln_ssh_bdy(ib_bdy) 164 ENDDO 165 IF(lwp) WRITE(numout,*) '~~~~~~~~' 166 IF(lwp) WRITE(numout,*) 167 !JT 168 169 170 171 172 173 134 174 135 175 ! ----------------------------------------- … … 185 225 CASE DEFAULT ; CALL ctl_stop( 'unrecognised value for cn_dyn2d' ) 186 226 END SELECT 227 228 !JT override dta_bdy(ib_bdy)%ll_ssh with namelist value (ln_ssh_bdy) 229 IF(lwp) WRITE(numout,*) 'nambdy_ssh : use of ssh boundaries' 230 IF(lwp) WRITE(numout,*) '~~~~~~~~' 231 IF(lwp) WRITE(numout,*) ' ib_bdy: ',ib_bdy 232 IF(lwp) WRITE(numout,*) ' Prior to Implementation of nambdy_ssh' 233 IF(lwp) WRITE(numout,*) ' dta_bdy(ib_bdy)%ll_ssh: ',dta_bdy(ib_bdy)%ll_ssh 234 235 dta_bdy(ib_bdy)%ll_ssh = ln_ssh_bdy(ib_bdy) 236 237 IF(lwp) WRITE(numout,*) ' After to Implementation of nambdy_ssh' 238 IF(lwp) WRITE(numout,*) ' dta_bdy(ib_bdy)%ll_ssh: ',dta_bdy(ib_bdy)%ll_ssh 239 IF(lwp) WRITE(numout,*) '~~~~~~~~' 240 241 !JT 242 187 243 IF( cn_dyn2d(ib_bdy) /= 'none' ) THEN 188 244 SELECT CASE( nn_dyn2d_dta(ib_bdy) ) ! … … 213 269 dta_bdy(ib_bdy)%ll_u3d = .true. 214 270 dta_bdy(ib_bdy)%ll_v3d = .true. 271 CASE('neumann') 272 IF(lwp) WRITE(numout,*) ' Neumann conditions' 273 dta_bdy(ib_bdy)%ll_u3d = .false. 274 dta_bdy(ib_bdy)%ll_v3d = .false. 275 CASE('zerograd') 276 IF(lwp) WRITE(numout,*) ' Zero gradient for baroclinic velocities' 277 dta_bdy(ib_bdy)%ll_u3d = .false. 278 dta_bdy(ib_bdy)%ll_v3d = .false. 215 279 CASE('zero') 216 280 IF(lwp) WRITE(numout,*) ' Zero baroclinic velocities (runoff case)' … … 365 429 IF(lwp) WRITE(numout,*) ' Width of relaxation zone = ', nn_rimwidth(ib_bdy) 366 430 IF(lwp) WRITE(numout,*) 431 432 IF( ln_sponge(ib_bdy) ) THEN ! check sponge layer choice 433 IF(lwp) WRITE(numout,*) ' Sponge layer applied at open boundaries' 434 IF(lwp) WRITE(numout,*) ' Multiplier for diffusion in sponge layer : ', rn_sponge 435 IF(lwp) WRITE(numout,*) 436 ELSE 437 IF(lwp) WRITE(numout,*) ' No Sponge layer applied at open boundaries' 438 IF(lwp) WRITE(numout,*) 439 ENDIF 440 441 442 367 443 368 444 ENDDO … … 1092 1168 END DO 1093 1169 END DO 1170 1171 1172 !JT 1173 ! Compute multiplier for diffusion for sponge layer 1174 ! ------------------------------------------------- 1175 IF( ln_sponge(ib_bdy) ) THEN 1176 igrd=1 1177 DO ib = 1, idx_bdy(ib_bdy)%nblen(igrd) 1178 nbi => idx_bdy(ib_bdy)%nbi(ib,igrd) 1179 nbj => idx_bdy(ib_bdy)%nbj(ib,igrd) 1180 nbr => idx_bdy(ib_bdy)%nbr(ib,igrd) 1181 sponge_factor(nbi,nbj) = 1.0 + (rn_sponge-1.0) * ( 1.- TANH( FLOAT( nbr - 1 ) *0.5 ) ) 1182 END DO 1183 ENDIF 1184 !JT 1185 1094 1186 1095 1187 ! Compute damping coefficients
Note: See TracChangeset
for help on using the changeset viewer.