Changeset 4544
- Timestamp:
- May 19, 2023, 12:12:49 PM (20 months ago)
- Location:
- LMDZ6/branches/LMDZ_ECRad/libf/phylmd/ecrad
- Files:
-
- 1 added
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ6/branches/LMDZ_ECRad/libf/phylmd/ecrad/radiation_scheme.F90
r4444 r4544 87 87 & NWEIGHT_PAR, IBAND_PAR, WEIGHT_PAR, & 88 88 & ITYPE_TROP_BG_AER, TROP_BG_AER_MASS_EXT, & 89 & ITYPE_STRAT_BG_AER, STRAT_BG_AER_MASS_EXT 89 & ITYPE_STRAT_BG_AER, STRAT_BG_AER_MASS_EXT, ISolverSpartacus 90 90 ! Commentes : jour, date de la simulation 91 91 !USE YOMRIP0 , ONLY : NINDAT … … 105 105 106 106 USE mod_phys_lmdz_para 107 USE setup_config_from_lmdz, ONLY : driver_config_type 107 108 108 109 IMPLICIT NONE … … 269 270 ! Ratio of cloud overlap decorrelation length for cloud water 270 271 ! inhomogeneities to that for cloud boundaries (typically 0.5) 271 REAL(KIND=JPRB) :: ZDECORR_LEN_RATIO 272 !REAL(KIND=JPRB) :: ZDECORR_LEN_RATIO = 0.5_jprb 273 274 !AI mai 2023 275 ! A mettre dans namelist 276 !real(jprb) :: high_inv_effective_size 277 !real(jprb) :: middle_inv_effective_size 278 !real(jprb) :: low_inv_effective_size 279 280 !real(jprb) :: cloud_inhom_separation_factor 281 !real(jprb) :: cloud_separation_scale_surface 282 !real(jprb) :: cloud_separation_scale_toa 283 !real(jprb) :: cloud_separation_scale_power 272 284 273 285 ! The surface net longwave flux if the surface was a black body, used … … 290 302 291 303 ! AI ATTENTION 292 real(jprb), parameter :: frac_std = 0.75 304 ! A mettre dans namelist 305 !real(jprb), parameter :: frac_std = 0.75 293 306 294 307 ! Name of file names specified on command line … … 301 314 !$OMP THREADPRIVATE(debut_ecrad) 302 315 316 type(driver_config_type) :: driver_config 303 317 ! Import time functions for iseed calculation 304 318 ! AI ATTENTION propre a ifs … … 450 464 cloud%fraction(KIDIA:KFDIA,:) = PCLOUD_FRAC(KIDIA:KFDIA,:) 451 465 452 !AI ATTENTION a voir avec JL 453 ! Compute effective radii and convert to metres 454 !CALL LIQUID_EFFECTIVE_RADIUS(KIDIA, KFDIA, KLON, KLEV, & 455 ! & PPRESSURE, PTEMPERATURE, PCLOUD_FRAC, PQ_LIQUID, PQ_RAIN, & 456 ! & PLAND_SEA_MASK, PCCN_LAND, PCCN_SEA, & 457 ! & ZRE_LIQUID_UM) 466 !!! ok AI ATTENTION a voir avec JL 467 ! Compute effective radi and convert to metres 468 ! AI. : on passe directement les champs de LMDZ 458 469 cloud%re_liq(KIDIA:KFDIA,:) = ZRE_LIQUID_UM(KIDIA:KFDIA,:) 459 460 !CALL ICE_EFFECTIVE_RADIUS(KIDIA, KFDIA, KLON, KLEV, &461 ! & PPRESSURE, PTEMPERATURE, PCLOUD_FRAC, PQ_ICE, PQ_SNOW, PGEMU, &462 ! & ZRE_ICE_UM)463 470 cloud%re_ice(KIDIA:KFDIA,:) = ZRE_ICE_UM(KIDIA:KFDIA,:) 464 471 … … 468 475 ! decorrelation lengths for cloud water content inhomogeneities and 469 476 ! cloud boundaries, and set it in the "rad_config" object. 477 ! IFS : 470 478 !CALL CLOUD_OVERLAP_DECORR_LEN(KIDIA, KFDIA, KLON, PGEMU, YRERAD%NDECOLAT, & 471 479 ! & ZDECORR_LEN_KM, PDECORR_LEN_RATIO=ZDECORR_LEN_RATIO) 472 473 ! AI ATTENTION (valeur lue dans namelist) 474 !ZDECORR_LEN_RATIO = 0.5_JPRB 475 !rad_config%cloud_inhom_decorr_scaling = ZDECORR_LEN_RATIO 480 ! AI valeur dans namelist 481 ! rad_config%cloud_inhom_decorr_scaling = ZDECORR_LEN_RATIO 482 476 483 !AI ATTENTION meme valeur que dans offline 477 ZDECORR_LEN_KM = 2000.0_JPRB 484 ! A mettre dans namelist 485 ZDECORR_LEN_KM = driver_config%overlap_decorr_length 478 486 DO JLON = KIDIA,KFDIA 479 487 CALL cloud%set_overlap_param(thermodynamics, & 480 & 481 & 488 & ZDECORR_LEN_KM(JLON), & 489 & istartcol=JLON, iendcol=JLON) 482 490 ENDDO 483 491 492 ! IFS : 484 493 ! Cloud water content fractional standard deviation is configurable 485 494 ! from namelist NAERAD but must be globally constant. Before it was … … 487 496 !CALL cloud%create_fractional_std(KLON, KLEV, YRERAD%RCLOUD_FRAC_STD) 488 497 ! AI ATTENTION frac_std=0.75 meme valeur que dans la version offline 489 CALL cloud%create_fractional_std(KLON, KLEV, frac_std) 490 498 CALL cloud%create_fractional_std(KLON, KLEV, driver_config%frac_std) 499 500 if (rad_config%i_solver_sw == ISolverSPARTACUS & 501 & .or. rad_config%i_solver_lw == ISolverSPARTACUS) then 491 502 ! AI ! Read cloud properties needed by SPARTACUS 492 ! By default mid and high cloud effective size is 10 km493 !CALL cloud%create_inv_cloud_effective_size(KLON,KLEV,1.0_JPRB/10000.0_JPRB)494 ! But for boundary clouds (eta > 0.8) we set it to 1 km495 !DO JLEV = 1,KLEV496 ! DO JLON = KIDIA,KFDIA497 ! IF (PPRESSURE(JLON,JLEV) > 0.8_JPRB * PPRESSURE_H(JLON,KLEV+1)) THEN498 ! cloud%inv_cloud_effective_size(JLON,JLEV) = 1.0e-3_JPRB499 ! ENDIF500 ! ENDDO501 !ENDDO502 503 !AI ATTENTION meme traitement dans le version offline 503 call cloud%create_inv_cloud_effective_size_eta(KLON, KLEV, & 504 if (driver_config%low_inv_effective_size >= 0.0_jprb & 505 & .or. driver_config%middle_inv_effective_size >= 0.0_jprb & 506 & .or. driver_config%high_inv_effective_size >= 0.0_jprb) then 507 call cloud%create_inv_cloud_effective_size_eta(klon, klev, & 504 508 & thermodynamics%pressure_hl, & 505 & 0.005_JPRB, & 506 & 0.0001_JPRB, & 507 & 0.0001, 0.8_jprb, 0.45_jprb) 509 & driver_config%low_inv_effective_size, & 510 & driver_config%middle_inv_effective_size, & 511 & driver_config%high_inv_effective_size, 0.8_jprb, 0.45_jprb) 512 else if (driver_config%cloud_separation_scale_surface > 0.0_jprb & 513 .and. driver_config%cloud_separation_scale_toa > 0.0_jprb) then 514 call cloud%param_cloud_effective_separation_eta(klon, klev, & 515 & thermodynamics%pressure_hl, & 516 & driver_config%cloud_separation_scale_surface, & 517 & driver_config%cloud_separation_scale_toa, & 518 & driver_config%cloud_separation_scale_power, & 519 & driver_config%cloud_inhom_separation_factor) 520 endif 521 endif 508 522 509 523 print*,'******** AEROSOLS (allocate + input) **************************************'
Note: See TracChangeset
for help on using the changeset viewer.