Changeset 234 for trunk/MESOSCALE/LMDZ.MARS.new/in_lmdz_mars_newphys
- Timestamp:
- Jul 19, 2011, 5:25:58 PM (13 years ago)
- Location:
- trunk/MESOSCALE/LMDZ.MARS.new/in_lmdz_mars_newphys
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/MESOSCALE/LMDZ.MARS.new/in_lmdz_mars_newphys/compile
r226 r234 34 34 nz=25 35 35 ################## 36 37 36 scatterers=2 37 scatterers=1 38 38 39 39 … … 62 62 echo compile gcm 63 63 echo check in $PWD/libo/log_compile_gcm 64 makegcm -t ${tracers} -p mars -d ${nx}x${ny}x${nz} gcm | tee libo/log_compile_gcm | grep 'warnings' >> libo/log_compile_gcm64 makegcm -t ${tracers} -p mars -d ${nx}x${ny}x${nz} -s ${scatterers} gcm | tee libo/log_compile_gcm | grep 'warnings' >> libo/log_compile_gcm 65 65 66 66 echo well, OK. -
trunk/MESOSCALE/LMDZ.MARS.new/in_lmdz_mars_newphys/physiq.F
r226 r234 7 7 $ ,pw 8 8 $ ,pdu,pdv,pdt,pdq,pdpsrf,tracerdyn 9 #ifdef MESOSCALE 10 #include "meso_inc/meso_inc_invar.F" 11 #endif 9 12 $ ) 10 13 … … 61 64 c Radiatively active tracers: J.-B. Madeleine (10/2008-06/2009) 62 65 c Nb: See callradite.F for more information. 66 c Mesoscale lines: Aymeric Spiga (2007 - 2011) -- check MESOSCALE flags 63 67 c 64 68 c arguments: … … 131 135 #include "netcdf.inc" 132 136 133 137 #include "slope.h" 138 139 #ifdef MESOSCALE 140 #include "wrf_output_2d.h" 141 #include "wrf_output_3d.h" 142 #include "advtrac.h" !!! this is necessary for tracers (in dyn3d) 143 #include "meso_inc/meso_inc_var.F" 144 #endif 134 145 135 146 c Arguments : … … 181 192 REAL qsurf(ngridmx,nqmx) ! tracer on surface (e.g. kg.m-2) 182 193 REAL q2(ngridmx,nlayermx+1) ! Turbulent Kinetic Energy 183 INTEGER ig_vl1 ! Grid Point near VL1 (for diagnostic)184 194 185 195 c Variables used by the water ice microphysical scheme: … … 191 201 REAL, PARAMETER :: alb_surfice = 0.45 !!TESTS_JB 192 202 203 c Variables used by the slope model 204 REAL sl_ls, sl_lct, sl_lat 205 REAL sl_tau, sl_alb, sl_the, sl_psi 206 REAL sl_fl0, sl_flu 207 REAL sl_ra, sl_di0 208 REAL sky 209 193 210 SAVE day_ini, icount 194 211 SAVE aerosol, tsurf,tsoil 195 212 SAVE co2ice,albedo,emis, q2 196 213 SAVE capcal,fluxgrd,dtrad,fluxrad,fluxrad_sky,qsurf 197 SAVE ig_vl1198 214 199 215 REAL stephan … … 306 322 REAL lmax_th_out(ngridmx),zmax_th(ngridmx) 307 323 REAL wmax_th(ngridmx) 308 REAL ,SAVE :: hfmax_th(ngridmx)324 REAL, SAVE :: hfmax_th(ngridmx) 309 325 REAL pdu_th(ngridmx,nlayermx),pdv_th(ngridmx,nlayermx) 310 326 REAL pdt_th(ngridmx,nlayermx),pdq_th(ngridmx,nlayermx,nqmx) … … 330 346 c read startfi 331 347 c ~~~~~~~~~~~~ 332 348 #ifndef MESOSCALE 333 349 ! Read netcdf initial physical parameters. 334 350 CALL phyetat0 ("startfi.nc",0,0, … … 336 352 & day_ini,time_phys, 337 353 & tsurf,tsoil,emis,q2,qsurf,co2ice) 354 #else 355 #include "meso_inc/meso_inc_ini.F" 356 #endif 338 357 339 358 if (pday.ne.day_ini) then … … 375 394 ENDIF ! end tracer 376 395 377 c Determining gridpoint near Viking Lander 1 (used for diagnostic only) 378 c ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 379 380 if(ngrid.ne.1) then 381 latvl1= 22.27 382 lonvl1= -47.94 383 ig_vl1= 1+ int( (1.5-(latvl1-90.)*jjm/180.) -2 )*iim + 384 & int(1.5+(lonvl1+180)*iim/360.) 385 write(*,*) 'Viking Lander 1 GCM point: lat,lon', 386 & lati(ig_vl1)*180/pi, long(ig_vl1)*180/pi 387 end if 388 396 #ifdef MESOSCALE 397 #include "meso_inc/meso_inc_caps.F" 398 #endif 399 400 #ifndef MESOSCALE 389 401 c Initialize thermospheric parameters 390 402 c ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 391 403 392 404 if (callthermos) call param_read 393 405 #endif 394 406 c Initialize R and Cp as constant 395 407 … … 478 490 ENDDO 479 491 492 #ifndef MESOSCALE 480 493 c----------------------------------------------------------------------- 481 494 c 1.2.5 Compute mean mass, cp, and R … … 485 498 call concentrations(pplay,pt,pdt,pq,pdq,ptimestep) 486 499 endif 500 #endif 487 501 c----------------------------------------------------------------------- 488 502 c 2. Compute radiative tendencies : … … 532 546 $ zdtlw,zdtsw,fluxsurf_lw,fluxsurf_sw,fluxtop_lw,fluxtop_sw, 533 547 & tauref,tau,aerosol,ccn,rdust,rice,nuice) 548 549 c Outputs for basic check (middle of domain) 550 c ------------------------------------------ 551 print*, 'check lat lon', lati(igout)*180/pi, 552 . long(igout)*180/pi 553 print*, 'Ls =',zls*180./pi 554 print*, 'tauref(700 Pa) =',tauref(igout) 555 print*, 'tau(700 Pa) =',tau(igout,1)*700./pplev(igout,1) 556 557 c --------------------------------------------------------- 558 c Call slope parameterization for direct and scattered flux 559 c --------------------------------------------------------- 560 IF(callslope) THEN 561 print *, 'Slope scheme is on and computing...' 562 DO ig=1,ngrid 563 sl_the = theta_sl(ig) 564 IF (sl_the .ne. 0.) THEN 565 ztim1=fluxsurf_sw(ig,1)+fluxsurf_sw(ig,2) 566 DO l=1,2 567 sl_lct = ptime*24. + 180.*long(ig)/pi/15. 568 sl_ra = pi*(1.0-sl_lct/12.) 569 sl_lat = 180.*lati(ig)/pi 570 sl_tau = tau(ig,1) 571 sl_alb = albedo(ig,l) 572 sl_psi = psi_sl(ig) 573 sl_fl0 = fluxsurf_sw(ig,l) 574 sl_di0 = 0. 575 if (mu0(ig) .gt. 0.) then 576 sl_di0 = mu0(ig)*(exp(-sl_tau/mu0(ig))) 577 sl_di0 = sl_di0*1370./dist_sol/dist_sol 578 sl_di0 = sl_di0/ztim1 579 sl_di0 = fluxsurf_sw(ig,l)*sl_di0 580 endif 581 ! you never know (roundup concern...) 582 if (sl_fl0 .lt. sl_di0) sl_di0=sl_fl0 583 !!!!!!!!!!!!!!!!!!!!!!!!!! 584 CALL param_slope( mu0(ig), declin, sl_ra, sl_lat, 585 & sl_tau, sl_alb, sl_the, sl_psi, 586 & sl_di0, sl_fl0, sl_flu ) 587 !!!!!!!!!!!!!!!!!!!!!!!!!! 588 fluxsurf_sw(ig,l) = sl_flu 589 ENDDO 590 !!! compute correction on IR flux as well 591 sky= (1.+cos(pi*theta_sl(ig)/180.))/2. 592 fluxsurf_lw(ig)= fluxsurf_lw(ig)*sky 593 ENDIF 594 ENDDO 595 ENDIF 534 596 535 597 c CO2 near infrared absorption … … 577 639 $ stephan*zplanck(ig)*zplanck(ig) 578 640 fluxrad(ig)=fluxrad_sky(ig)-zplanck(ig) 641 IF(callslope) THEN 642 sky= (1.+cos(pi*theta_sl(ig)/180.))/2. 643 fluxrad(ig)=fluxrad(ig)+(1.-sky)*zplanck(ig) 644 ENDIF 579 645 ENDDO 580 646 … … 633 699 & zdqdif,zdqsdif) 634 700 701 #ifdef MESOSCALE 702 #include "meso_inc/meso_inc_les.F" 703 #endif 635 704 DO l=1,nlayer 636 705 DO ig=1,ngrid … … 668 737 s (fluxrad(ig)+fluxgrd(ig))/capcal(ig) 669 738 ENDDO 739 #ifdef MESOSCALE 740 IF (flag_LES) THEN 741 write(*,*) 'LES mode !' 742 write(*,*) 'Please set calldifv to T in callphys.def' 743 STOP 744 ENDIF 745 #endif 670 746 ENDIF ! of IF (calldifv) 671 747 … … 840 916 c ------------------ 841 917 918 #ifndef MESOSCALE 842 919 c -------------- 843 920 c photochemistry : … … 884 961 885 962 END IF ! of IF (photochem.or.thermochem) 963 #endif 886 964 887 965 c 7c. Aerosol particles … … 955 1033 endif ! of if (tracer) 956 1034 957 1035 #ifndef MESOSCALE 958 1036 c----------------------------------------------------------------------- 959 1037 c 8. THERMOSPHERE CALCULATION … … 980 1058 981 1059 endif ! of if (callthermos) 1060 #endif 982 1061 983 1062 c----------------------------------------------------------------------- … … 998 1077 999 1078 IF (tracer.AND.water.AND.(ngridmx.NE.1)) THEN 1079 #ifndef MESOSCALE 1000 1080 if (caps.and.(obliquit.lt.27.)) then 1001 1081 ! NB: Updated surface pressure, at grid point 'ngrid', is … … 1004 1084 & (pplev(ngrid,1)+pdpsrf(ngrid)*ptimestep))) 1005 1085 endif 1086 #endif 1006 1087 c ------------------------------------------------------------- 1007 1088 c Change of surface albedo (set to 0.4) in case of ground frost … … 1095 1176 ENDDO 1096 1177 ENDDO 1097 if(min(pt(igmin,lmin),zt(igmin,lmin)).lt.70.) then 1178 if(min(pt(igmin,lmin),zt(igmin,lmin)).lt.70.) then 1098 1179 write(*,*) 'PHYSIQ: stability WARNING :' 1099 1180 write(*,*) 'pt, zt Tmin = ', pt(igmin,lmin), zt(igmin,lmin), … … 1122 1203 1123 1204 IF (ngrid.NE.1) THEN 1124 print*,'Ls =',zls*180./pi 1125 & ,' tauref(700 Pa,lat=0) =',tauref(ngrid/2) 1126 & ,' tau(Viking1) =',tau(ig_vl1,1) 1127 1128 1205 1206 #ifndef MESOSCALE 1129 1207 c ------------------------------------------------------------------- 1130 1208 c Writing NetCDF file "RESTARTFI" at the end of the run … … 1145 1223 . zgam,zthe) 1146 1224 ENDIF 1225 #endif 1147 1226 1148 1227 c ------------------------------------------------------------------- … … 1300 1379 CALL eofdump(ngrid, nlayer, zu, zv, zt, rho, ps) 1301 1380 ENDIF 1381 1382 1383 #ifdef MESOSCALE 1384 !!! 1385 !!! OUTPUT FIELDS 1386 !!! 1387 wtsurf(1:ngrid) = tsurf(1:ngrid) !! surface temperature 1388 wco2ice(1:ngrid) = co2ice(1:ngrid) !! co2 ice 1389 mtot(1:ngrid) = mtot(1:ngrid) * 1.e6 / rho_ice 1390 IF (igcm_h2o_ice .ne. 0) THEN 1391 qsurfice(1:ngrid) = qsurf(1:ngrid,igcm_h2o_ice) 1392 vmr=1.e6 * zq(1:ngrid,1:nlayer,igcm_h2o_ice) 1393 . * mugaz / mmol(igcm_h2o_ice) 1394 ENDIF 1395 c AUTOMATICALLY GENERATED FROM REGISTRY 1396 #include "fill_save.inc" 1397 #else 1302 1398 1303 1399 c ========================================================== … … 1526 1622 c END OF WRITEDIAGFI 1527 1623 c ========================================================== 1624 #endif 1528 1625 1529 1626 ELSE ! if(ngrid.eq.1)
Note: See TracChangeset
for help on using the changeset viewer.