Changeset 2665 for LMDZ5/trunk/libf/phylmd
- Timestamp:
- Oct 12, 2016, 2:53:20 PM (8 years ago)
- Location:
- LMDZ5/trunk/libf/phylmd
- Files:
-
- 8 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ5/trunk/libf/phylmd/acama_gwd_rando_m.F90
r2357 r2665 136 136 RUWFRT=gwd_front_ruwmax 137 137 SATFRT=gwd_front_sat 138 CMAX = 40. ! Characteristic phase speed138 CMAX = 50. ! Characteristic phase speed 139 139 ! Phase speed test 140 140 ! RUWFRT=0.01 … … 145 145 ! CRUCIAL PARAMETERS FOR THE WIND FILTERING 146 146 XLAUNCH=0.95 ! Parameter that control launching altitude 147 RDISS = 1! Diffusion parameter147 RDISS = 0.5 ! Diffusion parameter 148 148 149 149 ! maximum of rain for which our theory applies (in kg/m^2/s) … … 377 377 ! RESTORE DIMENSION OF A FLUX 378 378 ! *RD*TR/PR 379 *1. + RUW0(JW, :) 379 ! *1. + RUW0(JW, :) 380 *1. 380 381 381 382 ! Factor related to the characteristics of the waves: NONE … … 417 418 ! No breaking (Eq.6) 418 419 ! Dissipation (Eq. 8) 419 WWP(JW, :) = WWM(JW, :) * EXP(- 2. * RDISS * PR / (PH(:, LL + 1) &420 WWP(JW, :) = WWM(JW, :) * EXP(- 4. * RDISS * PR / (PH(:, LL + 1) & 420 421 + PH(:, LL)) * ((BV(:, LL + 1) + BV(:, LL)) / 2.)**3 & 421 422 / MAX(ABS(ZOP(JW, :) + ZOM(JW, :)) / 2., ZOISEC)**4 & -
LMDZ5/trunk/libf/phylmd/flott_gwd_rando_m.F90
r2333 r2665 120 120 121 121 122 RDISS = 1.! Diffusion parameter122 RDISS = 0.5 ! Diffusion parameter 123 123 ! ONLINE 124 124 RUWMAX=GWD_RANDO_RUWMAX … … 346 346 ! No breaking (Eq.6) 347 347 ! Dissipation (Eq. 8) 348 WWP(JW, :) = WWM(JW, :) * EXP(- 2. * RDISS * PR / (PH(:, LL + 1) &348 WWP(JW, :) = WWM(JW, :) * EXP(- 4. * RDISS * PR / (PH(:, LL + 1) & 349 349 + PH(:, LL)) * ((BV(:, LL + 1) + BV(:, LL)) / 2.)**3 & 350 350 / MAX(ABS(ZOP(JW, :) + ZOM(JW, :)) / 2., ZOISEC)**4 & -
LMDZ5/trunk/libf/phylmd/grid_noro_m.F90
r2576 r2665 6 6 USE assert_eq_m, ONLY: assert_eq 7 7 PRIVATE 8 PUBLIC :: grid_noro, grid_noro0 8 PUBLIC :: grid_noro, grid_noro0, read_noro 9 9 10 10 … … 71 71 ! CORRELATIONS OF USN OROGRAPHY GRADIENTS ! dim (imar+2*iext,jmdp+2) 72 72 REAL, ALLOCATABLE :: zxtzxusn(:,:), zytzyusn(:,:), zxtzyusn(:,:) 73 REAL, ALLOCATABLE :: mask_tmp(:,:), zmea0(:,:) ! dim (imar+1,jmar) 74 REAL, ALLOCATABLE :: num_tot(:,:), num_lan(:,:) ! dim (imax,jmax) 75 REAL, ALLOCATABLE :: a(:), b(:) ! dim (imax) 76 REAL, ALLOCATABLE :: c(:), d(:) ! dim (jmax) 73 REAL, ALLOCATABLE :: num_tot(:,:), num_lan(:,:) ! dim (imar+1,jmar) 74 REAL, ALLOCATABLE :: a(:), b(:) ! dim (imar+1) 75 REAL, ALLOCATABLE :: c(:), d(:) ! dim (jmar) 77 76 LOGICAL :: masque_lu 78 77 INTEGER :: i, ii, imdp, imar, iext 79 78 INTEGER :: j, jj, jmdp, jmar, nn 80 REAL :: xpi, zdeltax, zlenx, weighx, xincr, z meanor081 REAL :: rad, zdeltay, zleny, weighy, masque, z measud082 REAL :: zbordnor, zmeanor, zstdnor, zsignor, zweinor, zpicnor, zvalnor 83 REAL :: zbordsud, zmeasud, zstdsud, zsigsud, zweisud, zpicsud, zvalsud 84 REAL :: zbordest, zbordoue, xk, xl, xm, xp, xq, xw 79 REAL :: xpi, zdeltax, zlenx, weighx, xincr, zweinor, xk, xl, xm 80 REAL :: rad, zdeltay, zleny, weighy, masque, zweisud, xp, xq, xw 81 82 83 85 84 !------------------------------------------------------------------------------- 86 85 imdp=assert_eq(SIZE(xd),SIZE(zd,1),TRIM(modname)//" imdp") … … 170 169 DO jj = 1, jmar 171 170 DO j = 2,jmdp+1 172 zlenx =zleny*COS(yusn(j))171 zlenx=zleny*COS(yusn(j)) 173 172 zdeltax=zdeltay*COS(yusn(j)) 174 zbordnor=(xincr+c(jj)-yusn(j))*rad175 zbordsud=(xincr-d(jj)+yusn(j))*rad176 weighy=AMAX1(0.,AMIN1(zbordnor,zbordsud,zleny)) 173 weighy=(xincr+AMIN1(c(jj)-yusn(j),yusn(j)-d(jj)))*rad 174 weighy=AMAX1(0.,AMIN1(weighy,zleny)) 175 177 176 IF(weighy==0.) CYCLE 178 177 DO i = 2, imdp+2*iext-1 179 zbordest=(xusn(i)-a(ii)+xincr)*rad*COS(yusn(j))180 zbordoue=(b(ii)+xincr-xusn(i))*rad*COS(yusn(j))181 weighx=AMAX1(0.,AMIN1(zbordest,zbordoue,zlenx)) 178 weighx=(xincr+AMIN1(xusn(i)-a(ii),b(ii)-xusn(i)))*rad*COS(yusn(j)) 179 weighx=AMAX1(0.,AMIN1(weighx,zlenx)) 180 182 181 IF(weighx==0.) CYCLE 183 182 num_tot(ii,jj)=num_tot(ii,jj)+1.0 … … 198 197 !--- COMPUTE PARAMETERS NEEDED BY LOTT & MILLER (1997) AND LOTT (1999) SSO SCHEME 199 198 IF(.NOT.masque_lu) THEN 200 WHERE(weight(:, 1:jmar-1)/=0.0) mask=num_lan(:,:)/num_tot(:,:)199 WHERE(weight(:,:)/=0.0) mask=num_lan(:,:)/num_tot(:,:) 201 200 END IF 202 nn=COUNT(weight(:, 1:jmar-1)==0.0)201 nn=COUNT(weight(:,:)==0.0) 203 202 IF(nn/=0) WRITE(lunout,*)'Problem with weight ; vanishing occurrences: ',nn 204 203 WHERE(weight(:,:)/=0.0) … … 224 223 !--- FIRST FILTER, MOVING AVERAGE OVER 9 POINTS. 225 224 !------------------------------------------------------------------------------- 226 ALLOCATE(zmea0(imar+1,jmar))227 zmea0(:,:)=zmea(:,:) ! GK211005 (CG) UNSMOOTHED TOPO 225 zphi(:,:)=zmea(:,:) ! GK211005 (CG) UNSMOOTHED TOPO 226 228 227 CALL MVA9(zmea); CALL MVA9(zstd); CALL MVA9(zpic); CALL MVA9(zval) 229 228 CALL MVA9(zxtzx); CALL MVA9(zxtzy); CALL MVA9(zytzy) 230 229 231 230 !--- MASK BASED ON GROUND MAXIMUM, 10% THRESHOLD. (SURFACE PARAMS MEANINGLESS) 232 ALLOCATE(mask_tmp(imar+1,jmar)); mask_tmp(:,:)=0.0 233 WHERE(mask>=0.1) mask_tmp = 1. 234 WHERE(weight(:,:)/=0.0) 235 ! zphi (:,:)= mask_tmp(:,:)*zmea (:,:) ! GK211005 (CG) not necessarly smoothed 236 zphi (:,:)= mask_tmp(:,:)*zmea0(:,:) 237 zmea0(:,:)= mask_tmp(:,:)*zmea0(:,:) 238 zmea (:,:)= mask_tmp(:,:)*zmea (:,:) 239 zpic (:,:)= mask_tmp(:,:)*zpic (:,:) 240 zval (:,:)= mask_tmp(:,:)*zval (:,:) 241 zstd (:,:)= mask_tmp(:,:)*zstd (:,:) 231 WHERE(weight(:,:)==0.0.OR.mask<0.1) 232 zphi(:,:)=0.0; zmea(:,:)=0.0; zpic(:,:)=0.0; zval(:,:)=0.0; zstd(:,:)=0.0 242 233 END WHERE 243 234 DO ii = 1, imar 244 235 DO jj = 1, jmar 245 IF (weight(ii,jj)/=0.0) THEN 246 !--- Coefficients K, L et M: 247 xk=(zxtzx(ii,jj)+zytzy(ii,jj))/2. 248 xl=(zxtzx(ii,jj)-zytzy(ii,jj))/2. 249 xm=zxtzy(ii,jj) 250 xp=xk-SQRT(xl**2+xm**2) 251 xq=xk+SQRT(xl**2+xm**2) 252 xw=1.e-8 253 IF(xp<=xw) xp=0. 254 IF(xq<=xw) xq=xw 255 IF(ABS(xm)<=xw) xm=xw*SIGN(1.,xm) 256 !--- SLOPE 257 zsig(ii,jj)=SQRT(xq)*mask_tmp(ii,jj) 258 !---ISOTROPY 259 zgam(ii,jj)=xp/xq*mask_tmp(ii,jj) 260 !--- THETA ANGLE 261 zthe(ii,jj)=57.29577951*ATAN2(xm,xl)/2.*mask_tmp(ii,jj) 262 END IF 236 IF(weight(ii,jj)==0.0) CYCLE 237 !--- Coefficients K, L et M: 238 xk=(zxtzx(ii,jj)+zytzy(ii,jj))/2. 239 xl=(zxtzx(ii,jj)-zytzy(ii,jj))/2. 240 xm=zxtzy(ii,jj) 241 xp=xk-SQRT(xl**2+xm**2) 242 xq=xk+SQRT(xl**2+xm**2) 243 xw=1.e-8 244 IF(xp<=xw) xp=0. 245 IF(xq<=xw) xq=xw 246 IF(ABS(xm)<=xw) xm=xw*SIGN(1.,xm) 247 !--- SLOPE, ANISOTROPY AND THETA ANGLE 248 zsig(ii,jj)=SQRT(xq) 249 zgam(ii,jj)=xp/xq 250 zthe(ii,jj)=90.*ATAN2(xm,xl)/xpi 263 251 END DO 264 252 END DO 253 WHERE(weight(:,:)==0.0.OR.mask<0.1) 254 zsig(:,:)=0.0; zgam(:,:)=0.0; zthe(:,:)=0.0 255 END WHERE 256 265 257 WRITE(lunout,*)' MEAN ORO:' ,MAXVAL(zmea) 266 258 WRITE(lunout,*)' ST. DEV.:' ,MAXVAL(zstd) … … 271 263 WRITE(lunout,*)' val:' ,MAXVAL(zval) 272 264 273 !--- Values at poles 274 zmea0(imar+1,:)=zmea0(1,:) 275 zmea (imar+1,:)=zmea (1,:) 276 zphi (imar+1,:)=zphi (1,:) 277 zpic (imar+1,:)=zpic (1,:) 278 zval (imar+1,:)=zval (1,:) 279 zstd (imar+1,:)=zstd (1,:) 280 zsig (imar+1,:)=zsig (1,:) 281 zgam (imar+1,:)=zgam (1,:) 282 zthe (imar+1,:)=zthe (1,:) 283 284 zweinor =SUM(weight(1:imar, 1),DIM=1) 285 zweisud =SUM(weight(1:imar,jmar),DIM=1) 286 zmeanor0=SUM(weight(1:imar, 1)*zmea0(1:imar, 1),DIM=1) 287 zmeasud0=SUM(weight(1:imar,jmar)*zmea0(1:imar,jmar),DIM=1) 288 zmeanor =SUM(weight(1:imar, 1)*zmea (1:imar, 1),DIM=1) 289 zmeasud =SUM(weight(1:imar,jmar)*zmea (1:imar,jmar),DIM=1) 290 zstdnor =SUM(weight(1:imar, 1)*zstd (1:imar, 1),DIM=1) 291 zstdsud =SUM(weight(1:imar,jmar)*zstd (1:imar,jmar),DIM=1) 292 zsignor =SUM(weight(1:imar, 1)*zsig (1:imar, 1),DIM=1) 293 zsigsud =SUM(weight(1:imar,jmar)*zsig (1:imar,jmar),DIM=1) 294 zpicnor =SUM(weight(1:imar, 1)*zpic (1:imar, 1),DIM=1) 295 zpicsud =SUM(weight(1:imar,jmar)*zpic (1:imar,jmar),DIM=1) 296 zvalnor =SUM(weight(1:imar, 1)*zval (1:imar, 1),DIM=1) 297 zvalsud =SUM(weight(1:imar,jmar)*zval (1:imar,jmar),DIM=1) 298 299 zmea(:,1)=zmeanor /zweinor; zmea(:,jmar)=zmeasud /zweisud 300 ! zphi(:,1)=zmeanor0/zweinor; zphi(:,jmar)=zmeasud0/zweisud TO COMMIT 301 zphi(:,1)=zmeanor /zweinor; zphi(:,jmar)=zmeasud /zweisud 302 zpic(:,1)=zpicnor /zweinor; zpic(:,jmar)=zpicsud /zweisud 303 zval(:,1)=zvalnor /zweinor; zval(:,jmar)=zvalsud /zweisud 304 zstd(:,1)=zstdnor /zweinor; zstd(:,jmar)=zstdsud /zweisud 305 zsig(:,1)=zsignor /zweinor; zsig(:,jmar)=zsigsud /zweisud 306 zgam(:,1)=1.; zgam(:,jmar)=1. 307 zthe(:,1)=0.; zthe(:,jmar)=0. 265 !--- Values at redundant longitude 266 zmea(imar+1,:)=zmea(1,:) 267 zphi(imar+1,:)=zphi(1,:) 268 zpic(imar+1,:)=zpic(1,:) 269 zval(imar+1,:)=zval(1,:) 270 zstd(imar+1,:)=zstd(1,:) 271 zsig(imar+1,:)=zsig(1,:) 272 zgam(imar+1,:)=zgam(1,:) 273 zthe(imar+1,:)=zthe(1,:) 274 275 !--- Values at north pole 276 zweinor =SUM(weight(1:imar,1)) 277 zmea(:,1)=SUM(weight(1:imar,1)*zmea(1:imar,1))/zweinor 278 zphi(:,1)=SUM(weight(1:imar,1)*zphi(1:imar,1))/zweinor 279 zpic(:,1)=SUM(weight(1:imar,1)*zpic(1:imar,1))/zweinor 280 zval(:,1)=SUM(weight(1:imar,1)*zval(1:imar,1))/zweinor 281 zstd(:,1)=SUM(weight(1:imar,1)*zstd(1:imar,1))/zweinor 282 zsig(:,1)=SUM(weight(1:imar,1)*zsig(1:imar,1))/zweinor 283 zgam(:,1)=1.; zthe(:,1)=0. 284 285 !--- Values at south pole 286 zweisud =SUM(weight(1:imar,jmar),DIM=1) 287 zmea(:,jmar)=SUM(weight(1:imar,jmar)*zmea(1:imar,jmar))/zweisud 288 zphi(:,jmar)=SUM(weight(1:imar,jmar)*zphi(1:imar,jmar))/zweisud 289 zpic(:,jmar)=SUM(weight(1:imar,jmar)*zpic(1:imar,jmar))/zweisud 290 zval(:,jmar)=SUM(weight(1:imar,jmar)*zval(1:imar,jmar))/zweisud 291 zstd(:,jmar)=SUM(weight(1:imar,jmar)*zstd(1:imar,jmar))/zweisud 292 zsig(:,jmar)=SUM(weight(1:imar,jmar)*zsig(1:imar,jmar))/zweisud 293 zgam(:,jmar)=1.; zthe(:,jmar)=0. 308 294 309 295 END SUBROUTINE grid_noro … … 323 309 !------------------------------------------------------------------------------- 324 310 ! Arguments: 325 REAL, INTENT(IN) 326 REAL, INTENT(IN) :: zd(:,:) !--- INPUT FIELD (imdp,jmdp)327 REAL, INTENT(IN) 328 REAL, INTENT(OUT) 329 REAL, INTENT( INOUT):: mask(:,:) !--- MASK (imar+1,jmar)311 REAL, INTENT(IN) :: xd(:), yd(:) !--- INPUT COORDINATES (imdp) (jmdp) 312 REAL, INTENT(IN) :: zd(:,:) !--- INPUT FIELD (imdp, jmdp) 313 REAL, INTENT(IN) :: x(:), y(:) !--- OUTPUT COORDINATES (imar+1) (jmar) 314 REAL, INTENT(OUT) :: zphi(:,:) !--- GEOPOTENTIAL (imar+1,jmar) 315 REAL, INTENT(OUT) :: mask(:,:) !--- MASK (imar+1,jmar) 330 316 !------------------------------------------------------------------------------- 331 317 ! Local variables: 332 318 CHARACTER(LEN=256) :: modname="grid_noro0" 333 319 REAL, ALLOCATABLE :: xusn(:), yusn(:) ! dim (imdp+2*iext) (jmdp+2) 334 REAL, ALLOCATABLE :: zusn(:,:) ! dim (imdp+2*iext, jmdp+2)320 REAL, ALLOCATABLE :: zusn(:,:) ! dim (imdp+2*iext, jmdp+2) 335 321 REAL, ALLOCATABLE :: weight(:,:) ! dim (imar+1,jmar) 336 REAL, ALLOCATABLE :: mask_tmp(:,:), zmea(:,:)! dim (imar+1,jmar)337 REAL, ALLOCATABLE :: num_tot(:,:), num_lan(:,:) ! dim (imax,jmax)338 REAL, ALLOCATABLE :: a(:), b(:) ! dim (imax)339 REAL, ALLOCATABLE :: c(:), d(:) ! dim (jmax) 322 REAL, ALLOCATABLE :: num_tot(:,:), num_lan(:,:) ! dim (imar+1,jmar) 323 REAL, ALLOCATABLE :: a(:), b(:) ! dim (imar+1) 324 REAL, ALLOCATABLE :: c(:), d(:) ! dim (jmar) 325 340 326 LOGICAL :: masque_lu 341 327 INTEGER :: i, ii, imdp, imar, iext 342 328 INTEGER :: j, jj, jmdp, jmar, nn 343 REAL :: xpi, zlenx, weighx, xincr, zbordnor, zmeanor, zweinor, zbordest344 REAL :: rad, zleny, weighy, masque, zbordsud, zmeasud, zweisud, zbordoue 329 REAL :: xpi, zlenx, zleny, weighx, weighy, xincr, masque, rad 330 345 331 !------------------------------------------------------------------------------- 346 332 imdp=assert_eq(SIZE(xd),SIZE(zd,1),TRIM(modname)//" imdp") … … 392 378 393 379 !--- INITIALIZATIONS: 394 ALLOCATE(weight(imar+1,jmar)); weight(:,:)= 0.0 395 ALLOCATE(zmea (imar+1,jmar)); zmea (:,:)= 0.0 380 ALLOCATE(weight(imar+1,jmar)); weight(:,:)=0.0; zphi(:,:)=0.0 396 381 397 382 !--- SUMMATION OVER GRIDPOINT AREA … … 403 388 DO jj = 1, jmar 404 389 DO j = 2,jmdp+1 405 zlenx =zleny *COS(yusn(j)) 406 zbordnor=(xincr+c(jj)-yusn(j))*rad 407 zbordsud=(xincr-d(jj)+yusn(j))*rad 408 weighy=AMAX1(0.,AMIN1(zbordnor,zbordsud,zleny)) 409 IF(weighy/=0) THEN 410 DO i = 2, imdp+2*iext-1 411 zbordest=(xusn(i)-a(ii)+xincr)*rad*COS(yusn(j)) 412 zbordoue=(b(ii)+xincr-xusn(i))*rad*COS(yusn(j)) 413 weighx=AMAX1(0.,AMIN1(zbordest,zbordoue,zlenx)) 414 IF(weighx/=0)THEN 415 num_tot(ii,jj)=num_tot(ii,jj)+1.0 416 IF(zusn(i,j)>=1.)num_lan(ii,jj)=num_lan(ii,jj)+1.0 417 weight(ii,jj)=weight(ii,jj)+weighx*weighy 418 zmea (ii,jj)=zmea (ii,jj)+zusn(i,j)*weighx*weighy !--- MEAN 419 END IF 420 END DO 421 END IF 390 zlenx=zleny*COS(yusn(j)) 391 weighy=(xincr+AMIN1(c(jj)-yusn(j),yusn(j)-d(jj)))*rad 392 weighy=AMAX1(0.,AMIN1(weighy,zleny)) 393 IF(weighy/=0) CYCLE 394 DO i = 2, imdp+2*iext-1 395 weighx=(xincr+AMIN1(xusn(i)-a(ii),b(ii)-xusn(i)))*rad*COS(yusn(j)) 396 weighx=AMAX1(0.,AMIN1(weighx,zlenx)) 397 IF(weighx/=0) CYCLE 398 num_tot(ii,jj)=num_tot(ii,jj)+1.0 399 IF(zusn(i,j)>=1.)num_lan(ii,jj)=num_lan(ii,jj)+1.0 400 weight(ii,jj)=weight(ii,jj)+weighx*weighy 401 zphi (ii,jj)=zphi (ii,jj)+zusn(i,j)*weighx*weighy !--- MEAN 402 END DO 422 403 END DO 423 404 END DO … … 426 407 !--- COMPUTE PARAMETERS NEEDED BY LOTT & MILLER (1997) AND LOTT (1999) SSO SCHEME 427 408 IF(.NOT.masque_lu) THEN 428 WHERE(weight(:, 1:jmar-1)/=0.0) mask=num_lan(:,:)/num_tot(:,:)409 WHERE(weight(:,:)/=0.0) mask=num_lan(:,:)/num_tot(:,:) 429 410 END IF 430 nn=COUNT(weight(:, 1:jmar-1)==0.0)411 nn=COUNT(weight(:,:)==0.0) 431 412 IF(nn/=0) WRITE(lunout,*)'Problem with weight ; vanishing occurrences: ',nn 432 WHERE(weight/=0.0) z mea(:,:)=zmea(:,:)/weight(:,:)413 WHERE(weight/=0.0) zphi(:,:)=zphi(:,:)/weight(:,:) 433 414 434 415 !--- MASK BASED ON GROUND MAXIMUM, 10% THRESHOLD (<10%: SURF PARAMS MEANINGLESS) 435 ALLOCATE(mask_tmp(imar+1,jmar)); mask_tmp(:,:)=0.0 436 WHERE(mask>=0.1) mask_tmp = 1. 437 WHERE(weight(:,:)/=0.0) 438 zphi(:,:)=mask_tmp(:,:)*zmea(:,:) 439 zmea(:,:)=mask_tmp(:,:)*zmea(:,:) 440 END WHERE 416 WHERE(weight(:,:)==0.0.OR.mask<0.1) zphi(:,:)=0.0 417 WRITE(lunout,*)' MEAN ORO:' ,MAXVAL(zphi) 418 419 !--- Values at redundant longitude and at poles 420 zphi(imar+1,:)=zphi(1,:) 421 zphi(:, 1)=SUM(weight(1:imar, 1)*zphi(1:imar, 1))/SUM(weight(1:imar, 1)) 422 zphi(:,jmar)=SUM(weight(1:imar,jmar)*zphi(1:imar,jmar))/SUM(weight(1:imar,jmar)) 423 424 END SUBROUTINE grid_noro0 425 ! 426 !------------------------------------------------------------------------------- 427 428 429 !------------------------------------------------------------------------------- 430 ! 431 SUBROUTINE read_noro(x,y,fname,zphi,zmea,zstd,zsig,zgam,zthe,zpic,zval,mask) 432 ! 433 !------------------------------------------------------------------------------- 434 ! Purpose: Read parameters usually determined with grid_noro from a file. 435 !=============================================================================== 436 USE netcdf, ONLY: NF90_OPEN, NF90_INQ_DIMID, NF90_INQUIRE_DIMENSION, & 437 NF90_NOERR, NF90_CLOSE, NF90_INQ_VARID, NF90_GET_VAR, NF90_STRERROR, & 438 NF90_NOWRITE 439 IMPLICIT NONE 440 !------------------------------------------------------------------------------- 441 ! Arguments: 442 REAL, INTENT(IN) :: x(:), y(:) !--- OUTPUT COORDINATES (imar+1) (jmar) 443 CHARACTER(LEN=*), INTENT(IN) :: fname ! PARAMETERS FILE NAME 444 REAL, INTENT(OUT) :: zphi(:,:) !--- GEOPOTENTIAL (imar+1,jmar) 445 REAL, INTENT(OUT) :: zmea(:,:) !--- MEAN OROGRAPHY (imar+1,jmar) 446 REAL, INTENT(OUT) :: zstd(:,:) !--- STANDARD DEVIATION (imar+1,jmar) 447 REAL, INTENT(OUT) :: zsig(:,:) !--- SLOPE (imar+1,jmar) 448 REAL, INTENT(OUT) :: zgam(:,:) !--- ANISOTROPY (imar+1,jmar) 449 REAL, INTENT(OUT) :: zthe(:,:) !--- SMALL AXIS ORIENTATION (imar+1,jmar) 450 REAL, INTENT(OUT) :: zpic(:,:) !--- MAXIMUM ALTITUDE (imar+1,jmar) 451 REAL, INTENT(OUT) :: zval(:,:) !--- MINIMUM ALTITUDE (imar+1,jmar) 452 REAL, INTENT(OUT) :: mask(:,:) !--- MASK (imar+1,jmar) 453 !------------------------------------------------------------------------------- 454 ! Local variables: 455 CHARACTER(LEN=256) :: modname="read_noro" 456 INTEGER :: imar, jmar, fid, did, vid 457 LOGICAL :: masque_lu 458 REAL :: xpi, d2r 459 !------------------------------------------------------------------------------- 460 imar=assert_eq([SIZE(x),SIZE(zphi,1),SIZE(zmea,1),SIZE(zstd,1),SIZE(zsig,1), & 461 SIZE(zgam,1),SIZE(zthe,1),SIZE(zpic,1),SIZE(zval,1), & 462 SIZE(mask,1)],TRIM(modname)//" imar")-1 463 jmar=assert_eq([SIZE(y),SIZE(zphi,2),SIZE(zmea,2),SIZE(zstd,2),SIZE(zsig,2), & 464 SIZE(zgam,2),SIZE(zthe,2),SIZE(zpic,2),SIZE(zval,2), & 465 SIZE(mask,2)],TRIM(modname)//" jmar") 466 xpi=ACOS(-1.0); d2r=xpi/180. 467 WRITE(lunout,*)"*** Orography parameters at sub-cell scale from file ***" 468 469 !--- ARE WE USING A READ MASK ? 470 masque_lu=ANY(mask/=-99999.); IF(.NOT.masque_lu) mask=0.0 471 WRITE(lunout,*)'Masque lu: ',masque_lu 472 CALL ncerr(NF90_OPEN(fname,NF90_NOWRITE,fid)) 473 CALL check_dim('x','longitude',x(1:imar)) 474 CALL check_dim('y','latitude' ,y(1:jmar)) 475 IF(.NOT.masque_lu) CALL get_fld('mask',mask) 476 CALL get_fld('Zphi',zphi) 477 CALL get_fld('Zmea',zmea) 478 CALL get_fld('mu' ,zstd) 479 CALL get_fld('Zsig',zsig) 480 CALL get_fld('Zgam',zgam) 481 CALL get_fld('Zthe',zthe) 482 zpic=zmea+2*zstd 483 zval=MAX(0.,zmea-2.*zstd) 484 CALL ncerr(NF90_CLOSE(fid)) 441 485 WRITE(lunout,*)' MEAN ORO:' ,MAXVAL(zmea) 442 443 !--- Values at poles 444 zphi(imar+1,:)=zphi(1,:) 445 446 zweinor=SUM(weight(1:imar, 1),DIM=1) 447 zweisud=SUM(weight(1:imar,jmar),DIM=1) 448 zmeanor=SUM(weight(1:imar, 1)*zmea(1:imar, 1),DIM=1) 449 zmeasud=SUM(weight(1:imar,jmar)*zmea(1:imar,jmar),DIM=1) 450 zphi(:,1)=zmeanor/zweinor; zphi(:,jmar)=zmeasud/zweisud 451 452 END SUBROUTINE grid_noro0 486 WRITE(lunout,*)' ST. DEV.:' ,MAXVAL(zstd) 487 WRITE(lunout,*)' PENTE:' ,MAXVAL(zsig) 488 WRITE(lunout,*)' ANISOTROP:',MAXVAL(zgam) 489 WRITE(lunout,*)' ANGLE:' ,MINVAL(zthe),MAXVAL(zthe) 490 WRITE(lunout,*)' pic:' ,MAXVAL(zpic) 491 WRITE(lunout,*)' val:' ,MAXVAL(zval) 492 493 CONTAINS 494 495 496 SUBROUTINE get_fld(var,fld) 497 CHARACTER(LEN=*), INTENT(IN) :: var 498 REAL, INTENT(INOUT) :: fld(:,:) 499 CALL ncerr(NF90_INQ_VARID(fid,var,vid),var) 500 CALL ncerr(NF90_GET_VAR(fid,vid,fld(1:imar,:)),var) 501 fld(imar+1,:)=fld(1,:) 502 END SUBROUTINE get_fld 503 504 SUBROUTINE check_dim(dimd,nam,dimv) 505 CHARACTER(LEN=*), INTENT(IN) :: dimd 506 CHARACTER(LEN=*), INTENT(IN) :: nam 507 REAL, INTENT(IN) :: dimv(:) 508 REAL, ALLOCATABLE :: tmp(:) 509 INTEGER :: n 510 CALL ncerr(NF90_INQ_DIMID(fid,dimd,did)) 511 CALL ncerr(NF90_INQUIRE_DIMENSION(fid,did,len=n)); ALLOCATE(tmp(n)) 512 CALL ncerr(NF90_INQ_VARID(fid,dimd,did)) 513 CALL ncerr(NF90_GET_VAR(fid,did,tmp)) 514 IF(MAXVAL(tmp)>xpi) tmp=tmp*d2r 515 IF(n/=SIZE(dimv).OR.ANY(ABS(tmp-dimv)>1E-6)) THEN 516 WRITE(lunout,*)'Problem with file "'//TRIM(fname)//'".' 517 CALL abort_physic(modname,'Grid differs from LMDZ for '//TRIM(nam)//'.',1) 518 END IF 519 END SUBROUTINE check_dim 520 521 SUBROUTINE ncerr(ncres,var) 522 IMPLICIT NONE 523 INTEGER, INTENT(IN) :: ncres 524 CHARACTER(LEN=*), INTENT(IN), OPTIONAL :: var 525 CHARACTER(LEN=256) :: mess 526 IF(ncres/=NF90_NOERR) THEN 527 mess='Problem with file "'//TRIM(fname)//'"' 528 IF(PRESENT(var)) mess=TRIM(mess)//' and variable "'//TRIM(var)//'"' 529 WRITE(lunout,*)TRIM(mess)//'.' 530 CALL abort_physic(modname,NF90_STRERROR(ncres),1) 531 END IF 532 END SUBROUTINE ncerr 533 534 END SUBROUTINE read_noro 453 535 ! 454 536 !------------------------------------------------------------------------------- … … 494 576 END MODULE grid_noro_m 495 577 578 -
LMDZ5/trunk/libf/phylmd/limit_read_mod.F90
r2311 r2665 148 148 USE netcdf 149 149 USE indice_sol_mod 150 USE phys_cal_mod, ONLY : calend, year_len 151 USE print_control_mod, ONLY: lunout, prt_level 150 152 151 153 IMPLICIT NONE … … 170 172 ! Locals variables 171 173 !**************************************************************************************** 172 INTEGER :: nid, nvarid 174 INTEGER :: nid, nvarid, ndimid, nn 173 175 INTEGER :: ii, ierr 174 176 INTEGER, DIMENSION(2) :: start, epais … … 178 180 REAL, DIMENSION(klon_glo) :: alb_glo ! albedo at global grid 179 181 CHARACTER(len=20) :: modname='limit_read_mod' 182 CHARACTER(LEN=99) :: abort_message, calendar, str 180 183 181 184 ! End declaration … … 207 210 ! 1) Open the file limit.nc if it is the right moment to read, once a day. 208 211 ! The file is read only by the master thread of the master mpi process(is_mpi_root) 212 ! Check by the way if the number of records is correct. 209 213 ! 210 214 !**************************************************************************************** … … 220 224 IF (ierr /= NF90_NOERR) CALL abort_physic(modname,& 221 225 'Pb d''ouverture du fichier de conditions aux limites',1) 222 226 227 !--- WARNING IF CALENDAR IS KNOWN AND DOES NOT MATCH THE ONE OF LMDZ 228 ierr=NF90_INQ_VARID(nid, 'TEMPS', nvarid) 229 ierr=NF90_GET_ATT(nid, nvarid, 'calendar', calendar) 230 IF(ierr==NF90_NOERR.AND.calendar/=calend.AND.prt_level>=1) THEN 231 WRITE(lunout,*)'BEWARE: gcm and limit.nc calendars differ: ' 232 WRITE(lunout,*)' '//TRIM(calend)//' for gcm' 233 WRITE(lunout,*)' '//TRIM(calendar)//' for limit.nc file' 234 END IF 235 236 !--- ERROR IF FILE RECORDS NUMBER IS NOT EQUAL TO EXPECTED NUMBER OF DAYS 237 ierr=NF90_INQUIRE(nid, UnlimitedDimID=ndimid) 238 ierr=NF90_INQUIRE_DIMENSION(nid, ndimid, len=nn) 239 WRITE(str,'(i)')nn; str=ADJUSTL(str) 240 abort_message='limit.nc records number ('//TRIM(str)//') does'//& 241 ' not match year length (' 242 WRITE(str,'(i)')year_len; str=ADJUSTL(str) 243 abort_message=TRIM(abort_message)//TRIM(str)//')' 244 IF(nn/=year_len) CALL abort_physic(modname,abort_message,1) 245 246 !--- ERROR IF FILES AND LMDZ HORIZONTAL RESOLUTIONS DO NOT MATCH 247 ierr=NF90_INQ_DIMID(nid, 'points_physiques', ndimid) 248 ierr=NF90_INQUIRE_DIMENSION(nid, ndimid, len=nn) 249 WRITE(str,'(i)')nn; str=ADJUSTL(str) 250 abort_message='limit.nc horizontal number of cells ('//TRIM(str)//') does'//& 251 ' not match LMDZ klon_glo (' 252 WRITE(str,'(i)')klon_glo; str=ADJUSTL(str) 253 abort_message=TRIM(abort_message)//TRIM(str)//')' 254 IF(nn/=klon_glo) CALL abort_physic(modname,abort_message,1) 255 223 256 ! La tranche de donnees a lire: 224 257 start(1) = 1 -
LMDZ5/trunk/libf/phylmd/phys_output_ctrlout_mod.F90
r2656 r2665 1204 1204 TYPE(ctrl_out), SAVE :: o_ep = ctrl_out((/ 2, 10, 10, 10, 10, 10, 11, 11, 11 /), & 1205 1205 'ep', 'ep', 'su', (/ ('', i=1, 9) /)) 1206 TYPE(ctrl_out), SAVE :: o_duphy = ctrl_out((/ 2, 10, 10, 10, 10, 10, 11, 11, 11 /), & 1207 'duphy', 'Physics du', 'm/s2', (/ ('', i=1, 9) /)) 1206 1208 TYPE(ctrl_out), SAVE :: o_dtphy = ctrl_out((/ 2, 10, 10, 10, 10, 10, 11, 11, 11 /), & 1207 1209 'dtphy', 'Physics dT', 'K/s', (/ ('', i=1, 9) /)) -
LMDZ5/trunk/libf/phylmd/phys_output_mod.F90
r2551 r2665 32 32 new_aod, aerosol_couple, flag_aerosol_strat, & 33 33 pdtphys, paprs, pphis, pplay, lmax_th, ptconv, ptconvth, ivap, & 34 d_ t, qx, d_qx, zmasse, ok_sync)34 d_u, d_t, qx, d_qx, zmasse, ok_sync) 35 35 36 36 USE iophy … … 65 65 REAL, INTENT(IN) :: pdtphys 66 66 REAL, DIMENSION(klon), INTENT(IN) :: pphis 67 REAL, DIMENSION(klon, klev), INTENT(IN) :: pplay, d_ t67 REAL, DIMENSION(klon, klev), INTENT(IN) :: pplay, d_u, d_t 68 68 REAL, DIMENSION(klon, klev+1), INTENT(IN) :: paprs 69 69 REAL, DIMENSION(klon,klev,nqtot), INTENT(IN):: qx, d_qx -
LMDZ5/trunk/libf/phylmd/phys_output_write_mod.F90
r2656 r2665 19 19 ok_ade, ok_aie, ivap, iliq, isol, new_aod, ok_sync, & 20 20 ptconv, read_climoz, clevSTD, ptconvth, & 21 d_ t, qx, d_qx, zmasse, flag_aerosol, flag_aerosol_strat, ok_cdnc)21 d_u, d_t, qx, d_qx, zmasse, flag_aerosol, flag_aerosol_strat, ok_cdnc) 22 22 23 23 ! This subroutine does the actual writing of diagnostics that were … … 122 122 o_zfull, o_zhalf, o_rneb, o_rnebjn, o_rnebcon, & 123 123 o_rnebls, o_rhum, o_ozone, o_ozone_light, & 124 o_d tphy, o_dqphy, o_dqphy2d, o_dqlphy, o_dqlphy2d, &124 o_duphy, o_dtphy, o_dqphy, o_dqphy2d, o_dqlphy, o_dqlphy2d, & 125 125 o_dqsphy, o_dqsphy2d, o_albe_srf, o_z0m_srf, o_z0h_srf, & 126 126 o_ages_srf, o_snow_srf, o_alb1, o_alb2, o_tke, & … … 336 336 REAL, DIMENSION(klon,nlevSTD) :: zx_tmp_fi3d_STD 337 337 REAL, DIMENSION(klon) :: pphis 338 REAL, DIMENSION(klon, klev) :: pplay, d_ t338 REAL, DIMENSION(klon, klev) :: pplay, d_u, d_t 339 339 REAL, DIMENSION(klon, klev+1) :: paprs 340 340 REAL, DIMENSION(klon,klev,nqtot) :: qx, d_qx … … 1214 1214 ENDIF 1215 1215 1216 CALL histwrite_phy(o_duphy, d_u) 1217 1216 1218 CALL histwrite_phy(o_dtphy, d_t) 1217 1219 -
LMDZ5/trunk/libf/phylmd/physiq_mod.F90
r2661 r2665 1540 1540 flag_aerosol_strat, pdtphys, paprs, pphis, & 1541 1541 pplay, lmax_th, ptconv, ptconvth, ivap, & 1542 d_ t, qx, d_qx, zmasse, ok_sync_omp)1542 d_u, d_t, qx, d_qx, zmasse, ok_sync_omp) 1543 1543 !$OMP END MASTER 1544 1544 !$OMP BARRIER … … 4521 4521 ok_ade, ok_aie, ivap, iliq, isol, new_aod, & 4522 4522 ok_sync, ptconv, read_climoz, clevSTD, & 4523 ptconvth, d_ t, qx, d_qx, zmasse,&4523 ptconvth, d_u, d_t, qx, d_qx, zmasse, & 4524 4524 flag_aerosol, flag_aerosol_strat, ok_cdnc) 4525 4525 #endif
Note: See TracChangeset
for help on using the changeset viewer.