Changeset 2254 for trunk/LMDZ.GENERIC/libf/phystd
- Timestamp:
- Mar 10, 2020, 4:59:49 PM (5 years ago)
- Location:
- trunk/LMDZ.GENERIC/libf/phystd
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.GENERIC/libf/phystd/aeropacity.F90
r1988 r2254 63 63 64 64 real aerosol0, obs_tau_col_aurora, pm, pente_cloud 65 66 real dp_strato(ngrid) 67 real dp_tropo(ngrid) 65 68 66 69 INTEGER l,ig,iq,iaer … … 371 374 !================================================================== 372 375 ! Two-layer aerosols (unknown composition) 373 ! S. Guerlet (2013) 376 ! S. Guerlet (2013) - Modif by J. Vatant d'Ollone (2020) 374 377 !================================================================== 375 378 … … 379 382 aerosol(1:ngrid,1:nlayer,iaer)=0.0 380 383 ! 2. Opacity calculation 381 DO ig=1,ngrid 382 DO l=1,nlayer-1 384 385 386 ! JVO 20 : Modif to have each of the layers (strato and tropo) correctly normalized 387 ! Otherwise we previously had the total optical depth correct but for each 388 ! separately, so it didn't match the input values + what's more normalizing 389 ! to the sum was making them non-independent : eg changing tau_tropo was 390 ! affecting stratopsheric values of optical depth ... 391 ! 392 ! Note that the main consequence of the former version bug was (in most cases) 393 ! to strongly underestimate the stratospheric optical depths compared to the 394 ! required values, eg, with tau_tropo=10 and tau_strato=0.1, you actually ended 395 ! with an actual tau_strato of 1E-4 ... ! 396 ! 397 ! NB : Because of the extra transition opacity if the layers are non contiguous, 398 ! be aware that at the the bottom we have tau > tau_strato + tau_tropo 399 400 DO ig=1,ngrid 401 dp_tropo(ig) = 0.D0 402 dp_strato(ig) = 0.D0 403 DO l=1,nlayer-1 383 404 aerosol(ig,l,iaer) = ( pplev(ig,l) - pplev(ig,l+1) ) 384 405 !! 1. below tropospheric layer: no aerosols 385 406 IF (pplev(ig,l) .gt. pres_bottom_tropo) THEN 386 aerosol(ig,l,iaer) = 0. *aerosol(ig,l,iaer)407 aerosol(ig,l,iaer) = 0.D0 387 408 !! 2. tropo layer 388 409 ELSEIF (pplev(ig,l) .le. pres_bottom_tropo .and. pplev(ig,l) .ge. pres_top_tropo) THEN 389 aerosol(ig,l,iaer) = obs_tau_col_tropo*aerosol(ig,l,iaer) 390 !! 3. linear transition 391 ELSEIF (pplev(ig,l) .lt. pres_top_tropo .and. pplev(ig,l) .gt. pres_bottom_strato) THEN 392 expfactor=log(obs_tau_col_strato/obs_tau_col_tropo)/log(pres_bottom_strato/pres_top_tropo) 393 aerosol(ig,l,iaer)= obs_tau_col_tropo*((pplev(ig,l)/pres_top_tropo)**expfactor)*aerosol(ig,l,iaer)/1.5 394 !! 4. strato layer 395 ELSEIF (pplev(ig,l) .le. pres_bottom_strato .and. pplev(ig,l) .gt. pres_top_strato) THEN 396 aerosol(ig,l,iaer)= obs_tau_col_strato*aerosol(ig,l,iaer) 410 dp_tropo(ig) = dp_tropo(ig) + aerosol(ig,l,iaer) 411 !! 3. linear transition 412 ! JVO 20 : This interpolation needs to be done AFTER we set strato and tropo (see below) 413 !! 4. strato layer 414 ELSEIF (pplev(ig,l) .le. pres_bottom_strato .and. pplev(ig,l) .ge. pres_top_strato) THEN 415 dp_strato(ig) = dp_strato(ig) + aerosol(ig,l,iaer) 397 416 !! 5. above strato layer: no aerosols 398 417 ELSEIF (pplev(ig,l) .lt. pres_top_strato) THEN 399 aerosol(ig,l,iaer) = 0. *aerosol(ig,l,iaer)418 aerosol(ig,l,iaer) = 0.D0 400 419 ENDIF 401 ENDDO 402 ENDDO 403 404 ! 3. Re-normalize to observed total column 405 tau_col(:)=0.0 406 DO l=1,nlayer 407 DO ig=1,ngrid 408 tau_col(ig) = tau_col(ig) & 409 + aerosol(ig,l,iaer)/(obs_tau_col_tropo+obs_tau_col_strato) 410 ENDDO 411 ENDDO 420 ENDDO 421 ENDDO 422 423 ! 3. Re-normalize to the (input) observed (total) column (for each of the layers) 412 424 413 425 DO ig=1,ngrid 414 DO l=1,nlayer-1 415 aerosol(ig,l,iaer)=aerosol(ig,l,iaer)/tau_col(ig) 416 ENDDO 426 DO l=1,nlayer-1 427 IF (pplev(ig,l) .le. pres_bottom_tropo .and. pplev(ig,l) .ge. pres_top_tropo) THEN 428 aerosol(ig,l,iaer) = obs_tau_col_tropo*aerosol(ig,l,iaer)/dp_tropo(ig) 429 ELSEIF (pplev(ig,l) .lt. pres_top_tropo .and. pplev(ig,l) .gt. pres_bottom_strato) THEN 430 expfactor=log(pplev(ig,l)/pres_top_tropo)/log(pres_bottom_strato/pres_top_tropo) 431 aerosol(ig,l,iaer) = (obs_tau_col_strato/dp_strato(ig))**expfactor & 432 * (obs_tau_col_tropo/dp_tropo(ig))**(1.0-expfactor) & 433 * aerosol(ig,l,iaer) 434 ELSEIF (pplev(ig,l) .le. pres_bottom_strato .and. pplev(ig,l) .ge. pres_top_strato) THEN 435 aerosol(ig,l,iaer) = obs_tau_col_strato*aerosol(ig,l,iaer)/dp_strato(ig) 436 ENDIF 437 write(*,*), aerosol(ig,l,iaer) 438 ENDDO 417 439 ENDDO 418 440 -
trunk/LMDZ.GENERIC/libf/phystd/callcorrk.F90
r2244 r2254 81 81 82 82 ! OUTPUT 83 REAL,INTENT(OUT) :: aerosol(ngrid,nlayer,naerkind) ! Aerosol tau (kg/kg).83 REAL,INTENT(OUT) :: aerosol(ngrid,nlayer,naerkind) ! Aerosol tau. 84 84 REAL,INTENT(OUT) :: dtlw(ngrid,nlayer) ! Heating rate (K/s) due to LW radiation. 85 85 REAL,INTENT(OUT) :: dtsw(ngrid,nlayer) ! Heating rate (K/s) due to SW radiation. -
trunk/LMDZ.GENERIC/libf/phystd/inifis_mod.F90
r2245 r2254 594 594 write(*,*)" pres_bottom_strato = ",pres_bottom_strato 595 595 596 ! Sanity check 597 if (pres_bottom_strato .gt. pres_top_tropo) then 598 print*,'Error : TWOLAY AEROSOL, Please ensure that in callphys.def' 599 print*,'you have pres_top_tropo > pres_bottom_strato !' 600 stop 601 endif 602 596 603 write(*,*)"TWOLAY AEROSOL: pres_top_strato? in pa" 597 604 pres_top_strato=100.0
Note: See TracChangeset
for help on using the changeset viewer.