Changeset 1410 for trunk/LMDZ.MARS/libf
- Timestamp:
- Apr 7, 2015, 3:41:32 PM (10 years ago)
- Location:
- trunk/LMDZ.MARS/libf/phymars
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.MARS/libf/phymars/aeropacity.F
r1376 r1410 123 123 real l_top ! layer of the storm's top 124 124 REAL zalt(ngrid, nlayer) ! useful factor to compute l_top 125 REAL zdqnorm(ngrid, nlayer,2)126 125 #endif 127 126 … … 459 458 #ifdef DUSTSTORM 460 459 c ----------------------------------------------------------------- 461 c the quantity of dust to add at the first time step is calculated 462 c to match a tunable opacity perturbation. 460 ! Calculate reference opacity without perturbation 463 461 c ----------------------------------------------------------------- 464 462 IF (firstcall) THEN … … 472 470 ENDDO 473 471 tauref(:) = tauref(:) * odpref / pplev(:,1) 472 474 473 c-------------------------------------------------- 475 c Parameters of the opacity perturbation474 c Get parameters of the opacity perturbation 476 475 c-------------------------------------------------- 477 478 iaer=1 !!!! PROVISOIRE !!!! 476 iaer=1 ! just change dust 479 477 480 478 write(*,*) "Add a local storm ?" … … 518 516 write(*,*) " reffstorm = ",reffstorm 519 517 518 !! LOOP: modify opacity 520 519 DO ig=1,ngrid 521 520 522 523 c--------------------------------------- 524 c distance to the center: 525 c----------------------------------------- 526 521 !! distance to the center: 527 522 ray(ig)=SQRT((lati(ig)*180./pi-latloc)**2 + 528 523 & (long(ig)*180./pi -lonloc)**2) 529 524 530 531 525 !! transition factor for storm 532 !! increase factor ray diff for steepness526 !! factor is hardcoded -- increase it to steepen 533 527 yeah = (TANH(2.+(radloc-ray(ig))*10.)+1.)/2. 534 528 535 c------------------------------------------------- 536 c Tau's new map: 537 c------------------------------------------ 538 539 tauuser(ig)=max(tauref(ig) * pplev(ig,1) /odpref , 540 & taulocref * yeah) 541 542 c--------------------------------------------------------- 543 c compute l_top 544 c---------------------------------------------------------- 545 529 !! new opacity field 530 !! -- add an opacity set to taulocref 531 !! -- the additional reference opacity will 532 !! thus be taulocref*odpref/pplev 533 tauuser(ig)=max( tauref(ig) * pplev(ig,1) /odpref , 534 & taulocref * yeah ) 535 536 !! compute l_top 546 537 DO l=1,nlayer 547 538 zalt(ig,l) = LOG( pplev(ig,1)/pplev(ig,l) ) … … 552 543 ENDDO 553 544 554 c--------------------------------------------------------- 555 c change reffrad if ever needed 556 c---------------------------------------------------------- 557 545 !! change reffrad if ever needed 558 546 IF (reffstorm .gt. 0.) THEN 559 547 DO l=1,nlayer … … 565 553 ENDIF 566 554 567 568 c--------------------------------------------------------------------------- 569 ENDDO !! boucle sur ngridmx 570 c--------------------------------------------------------------------------- 571 c---------------------------------------------------------------------------- 572 c compute int_factor 573 c--------------------------------------------------------------------------- 574 555 ENDDO 556 !! END LOOP 557 558 !! compute perturbation in each layer (equation 8 in Spiga et al. JGR 2013) 575 559 DO ig=1,ngrid 576 560 int_factor(ig)=0. … … 585 569 ENDDO 586 570 DO l=1, nlayer 587 588 c------------------------------------------------------------------------- 589 c Mass mixing ratio perturbation due to the local dust storm in each 590 c layer 591 c------------------------------------------------------------------------- 571 !! Mass mixing ratio perturbation due to local dust storm in each layer 592 572 more_dust(ig,l,1)= 593 573 & (tauuser(ig)-(tauref(ig) … … 603 583 ENDDO 604 584 605 c-------------------------------------------------------------------------------------- 606 c quantity of dust which is added at the first time step 607 c in dynamical core. 608 c-------------------------------------------------------------------------------------- 609 610 DO l=1, l_top 611 zdqnorm(:,l,1) = more_dust(:,l,1) 612 zdqnorm(:,l,2) = more_dust(:,l,2) 585 !! quantity of dust for each layer with the addition of the perturbation 586 DO l=1, l_top 613 587 pq(:,l,igcm_dust_mass)= pq(:,l,igcm_dust_mass) 614 . + zdqnorm(:,l,1)588 . + more_dust(:,l,1) 615 589 pq(:,l,igcm_dust_number)= pq(:,l,igcm_dust_number) 616 . + zdqnorm(:,l,2)617 618 ENDIF619 620 ENDIF !firstcall590 . + more_dust(:,l,2) 591 ENDDO 592 ENDIF !! IF (localstorm) 593 tauref(:)=0. 594 ENDIF !! IF (firstcall) 621 595 #endif 622 596 … … 643 617 ENDDO 644 618 645 ENDIF 619 ENDIF ! IF (freedust) 646 620 647 621 c Opacity computation … … 666 640 DO l=1,nlayer 667 641 DO ig=1,ngrid 642 #ifdef DUSTSTORM 643 !! recalculate opacity because storm perturbation has been added 644 IF (firstcall) THEN 645 aerosol(ig,l,iaer) = 646 & ( 0.75 * QREFvis3d(ig,l,iaer) / 647 & ( rho_dust * reffrad(ig,l,iaer) ) ) * 648 & pq(ig,l,igcm_dust_mass) * 649 & ( pplev(ig,l) - pplev(ig,l+1) ) / g 650 ENDIF 651 #endif 668 652 tauref(ig) = tauref(ig) + 669 653 & aerosol(ig,l,iaerdust(iaer)) -
trunk/LMDZ.MARS/libf/phymars/physiq.F
r1380 r1410 664 664 665 665 c Note: Dustopacity.F has been transferred to callradite.F 666 667 #ifdef DUSTSTORM 668 !! specific case: save the quantity of dust before adding perturbation 669 if (firstcall) then 670 pq_tmp(1:ngrid,1:nlayer,1)=pq(1:ngrid,1:nlayer,igcm_dust_mass) 671 pq_tmp(1:ngrid,1:nlayer,2)=pq(1:ngrid,1:nlayer,igcm_dust_number) 672 endif 673 #endif 666 674 667 675 c Call main radiative transfer scheme … … 673 681 c ------------------ 674 682 675 #ifdef DUSTSTORM676 pq_tmp(1:ngrid,1:nlayer,1)=677 & pq(1:ngrid,1:nlayer,igcm_dust_mass)678 679 pq_tmp(1:ngrid,1:nlayer,2)=680 & pq(1:ngrid,1:nlayer,igcm_dust_number)681 682 #endif683 684 683 CALL callradite(icount,ngrid,nlayer,nq,zday,zls,pq,albedo, 685 684 $ emis,mu0,zplev,zplay,pt,tsurf,fract,dist_sol,igout, … … 688 687 $ nuice,co2ice) 689 688 689 690 690 #ifdef DUSTSTORM 691 pdq(1:ngrid,1:nlayer,igcm_dust_mass)= 692 & pdq(1:ngrid,1:nlayer,igcm_dust_mass) 693 & - pq_tmp(1:ngrid,1:nlayer,1) 694 & +pq(1:ngrid,1:nlayer,igcm_dust_mass) 695 696 697 pdq(1:ngrid,1:nlayer,igcm_dust_number)= 698 & pdq(1:ngrid,1:nlayer,igcm_dust_number) 699 & - pq_tmp(1:ngrid,1:nlayer,2) 700 & +pq(1:ngrid,1:nlayer,igcm_dust_number) 691 !! specific case: compute the added quantity of dust for perturbation 692 if (firstcall) then 693 pdq(1:ngrid,1:nlayer,igcm_dust_mass)= 694 & pdq(1:ngrid,1:nlayer,igcm_dust_mass) 695 & - pq_tmp(1:ngrid,1:nlayer,1) 696 & + pq(1:ngrid,1:nlayer,igcm_dust_mass) 697 pdq(1:ngrid,1:nlayer,igcm_dust_number)= 698 & pdq(1:ngrid,1:nlayer,igcm_dust_number) 699 & - pq_tmp(1:ngrid,1:nlayer,2) 700 & + pq(1:ngrid,1:nlayer,igcm_dust_number) 701 endif 701 702 #endif 702 703
Note: See TracChangeset
for help on using the changeset viewer.