Changeset 1005
- Timestamp:
- Jul 18, 2013, 8:33:04 AM (11 years ago)
- Location:
- trunk/LMDZ.MARS
- Files:
-
- 8 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.MARS/README
r1001 r1005 1880 1880 Gnome) 1881 1881 1882 1882 == 18/07/2013 == EM 1883 - Bug fix: when running with photochemistry, ccns did not sediment! Fixed 1884 initracer.F. Also added that callsedim/newsedim use updated temperatures. 1885 - Converted run0 and run_mcd scripts to bash. 1886 -
trunk/LMDZ.MARS/deftank/run0
r758 r1005 1 #!/bin/ csh1 #!/bin/bash 2 2 ########################################################################### 3 3 # Script to perform several chained LMD Mars GCM simulations 4 4 # SET HERE the maximum total number of simulations 5 5 6 setnummax=16 nummax=1 7 7 8 8 ########################################################################### … … 12 12 echo "starting run0" 13 13 14 setdir=`pwd`15 setmachine=`hostname`16 setaddress=`whoami`14 dir=`pwd` 15 machine=`hostname` 16 address=`whoami` 17 17 18 18 # Look for file "num_run" which should contain 19 19 # the value of the previously computed season 20 20 # (defaults to 0 if file "num_run" does not exist) 21 if ( -f num_run )then22 echo "found file num_run"23 setnumold=`cat num_run`21 if [[ -r num_run ]] ; then 22 echo "found file num_run" 23 numold=`cat num_run` 24 24 else 25 setnumold=026 endif 25 numold=0 26 fi 27 27 echo "numold is set to" ${numold} 28 28 29 29 30 30 # Set value of current season 31 set numnew=${numold} 32 @ numnew = ${numnew} + 1 31 (( numnew = ${numold} + 1 )) 33 32 echo "numnew is set to" ${numnew} 34 33 35 34 # Look for initialization data files (exit if none found) 36 if ( ( -f start${numold}.nc ) && ( -f startfi${numold}.nc ) )then35 if [[ ( -r start${numold}.nc && -r startfi${numold}.nc ) ]] ; then 37 36 \cp -f start${numold}.nc start.nc 38 37 \cp -f startfi${numold}.nc startfi.nc 39 else if ( ${numold} == 99999 ) then 38 else 39 if (( ${numold} == 99999 )) ; then 40 40 echo "No run because previous run crashed ! (99999 in num_run)" 41 41 exit 42 else42 else 43 43 echo "Where is file start"${numold}".nc??" 44 44 exit 45 endif 45 fi 46 fi 46 47 47 48 48 49 # Run GCM 49 gcm.e > !lrun${numnew}50 gcm.e > lrun${numnew} 50 51 51 52 52 53 # Check if run ended normaly and copy datafiles 53 if ( ( -f restartfi.nc ) && ( -f restart.nc ) )then54 if [[ ( -r restartfi.nc && -r restart.nc ) ]] ; then 54 55 echo "Run seems to have ended normaly" 55 56 \mv -f restartfi.nc startfi${numnew}.nc 56 57 \mv -f restart.nc start${numnew}.nc 57 58 else 58 if ( -f num_run )then59 if [[ -r num_run ]] ; then 59 60 \mv -f num_run num_run.crash 60 61 else 61 62 echo "No file num_run to build num_run.crash from !!" 62 63 # Impose a default value of 0 for num_run 63 echo 0 > !num_run.crash64 endif65 echo 99999 > !num_run64 echo 0 > num_run.crash 65 fi 66 echo 99999 > num_run 66 67 ############## To receive an Email message if the run crashes ######## 67 68 mail -s "crash run GCM" $address <<ENDMAIL … … 70 71 ############################################"" 71 72 exit 72 endif 73 fi 73 74 74 75 # Copy other datafiles that may have been generated 75 if ( -f diagfi.nc )then76 if [[ -r diagfi.nc ]] ; then 76 77 \mv -f diagfi.nc diagfi${numnew}.nc 77 endif 78 if ( -f diagsoil.nc )then78 fi 79 if [[ -r diagsoil.nc ]] ; then 79 80 \mv -f diagsoil.nc diagsoil${numnew}.nc 80 endif 81 if ( -f stats.nc )then81 fi 82 if [[ -r stats.nc ]] ; then 82 83 \mv -f stats.nc stats${numnew}.nc 83 endif 84 if ( -f profiles.dat )then84 fi 85 if [[ -f profiles.dat ]] ; then 85 86 \mv -f profiles.dat profiles${numnew}.dat 86 87 \mv -f profiles.hdr profiles${numnew}.hdr 87 endif 88 fi 88 89 89 90 # Prepare things for upcoming runs by writing 90 91 # value of computed season in file num_run 91 echo ${numnew} > !num_run92 echo ${numnew} > num_run 92 93 93 94 # If we are over nummax : stop 94 if ( `expr $numnew + 1 \> $nummax ` == 1)then95 if (( $numnew + 1 > $nummax )) ; then 95 96 exit 96 97 else 97 98 \cp -f run0 exe_mars 98 exe_mars99 endif99 ./exe_mars 100 fi 100 101 101 102 -
trunk/LMDZ.MARS/deftank/run_mcd
r38 r1005 1 #!/bin/ csh1 #!/bin/bash 2 2 ############################################################################## 3 3 # Script to run successive monthly (a month spans 30 deg. in Ls) … … 26 26 27 27 # 12 martian months (=30°deg Ls) of unequal length (excentric orbit) 28 sed s/9999/61/ run.def.ref > ! run.def ; run0 >>&error #129 sed s/9999/66/ run.def.ref > ! run.def ; run0 >>&error #230 sed s/9999/66/ run.def.ref > ! run.def ; run0 >>&error #331 sed s/9999/65/ run.def.ref > ! run.def ; run0 >>&error #432 sed s/9999/60/ run.def.ref > ! run.def ; run0 >>&error #533 sed s/9999/54/ run.def.ref > ! run.def ; run0 >>&error #634 sed s/9999/50/ run.def.ref > ! run.def ; run0 >>&error #735 sed s/9999/46/ run.def.ref > ! run.def ; run0 >>&error #836 sed s/9999/47/ run.def.ref > ! run.def ; run0 >>&error #937 sed s/9999/47/ run.def.ref > ! run.def ; run0 >>&error #1038 sed s/9999/51/ run.def.ref > ! run.def ; run0 >>&error #1139 sed s/9999/56/ run.def.ref > ! run.def ; run0 >>&error #1228 sed s/9999/61/ run.def.ref > run.def ; run0 >> error #1 29 sed s/9999/66/ run.def.ref > run.def ; run0 >> error #2 30 sed s/9999/66/ run.def.ref > run.def ; run0 >> error #3 31 sed s/9999/65/ run.def.ref > run.def ; run0 >> error #4 32 sed s/9999/60/ run.def.ref > run.def ; run0 >> error #5 33 sed s/9999/54/ run.def.ref > run.def ; run0 >> error #6 34 sed s/9999/50/ run.def.ref > run.def ; run0 >> error #7 35 sed s/9999/46/ run.def.ref > run.def ; run0 >> error #8 36 sed s/9999/47/ run.def.ref > run.def ; run0 >> error #9 37 sed s/9999/47/ run.def.ref > run.def ; run0 >> error #10 38 sed s/9999/51/ run.def.ref > run.def ; run0 >> error #11 39 sed s/9999/56/ run.def.ref > run.def ; run0 >> error #12 40 40 # 41 41 # 12 martian months (=30°deg Ls) of unequal length (excentric orbit) 42 # sed s/9999/61/ run.def.ref > ! run.def ; run0 >>&error #1343 # sed s/9999/66/ run.def.ref > ! run.def ; run0 >>&error #1444 # sed s/9999/66/ run.def.ref > ! run.def ; run0 >>&error #1545 # sed s/9999/65/ run.def.ref > ! run.def ; run0 >>&error #1646 # sed s/9999/60/ run.def.ref > ! run.def ; run0 >>&error #1747 # sed s/9999/54/ run.def.ref > ! run.def ; run0 >>&error #1848 # sed s/9999/50/ run.def.ref > ! run.def ; run0 >>&error #1949 # sed s/9999/46/ run.def.ref > ! run.def ; run0 >>&error #2050 # sed s/9999/47/ run.def.ref > ! run.def ; run0 >>&error #2151 # sed s/9999/47/ run.def.ref > ! run.def ; run0 >>&error #2252 # sed s/9999/51/ run.def.ref > ! run.def ; run0 >>&error #2353 # sed s/9999/56/ run.def.ref > ! run.def ; run0 >>&error #2442 # sed s/9999/61/ run.def.ref > run.def ; run0 >> error #13 43 # sed s/9999/66/ run.def.ref > run.def ; run0 >> error #14 44 # sed s/9999/66/ run.def.ref > run.def ; run0 >> error #15 45 # sed s/9999/65/ run.def.ref > run.def ; run0 >> error #16 46 # sed s/9999/60/ run.def.ref > run.def ; run0 >> error #17 47 # sed s/9999/54/ run.def.ref > run.def ; run0 >> error #18 48 # sed s/9999/50/ run.def.ref > run.def ; run0 >> error #19 49 # sed s/9999/46/ run.def.ref > run.def ; run0 >> error #20 50 # sed s/9999/47/ run.def.ref > run.def ; run0 >> error #21 51 # sed s/9999/47/ run.def.ref > run.def ; run0 >> error #22 52 # sed s/9999/51/ run.def.ref > run.def ; run0 >> error #23 53 # sed s/9999/56/ run.def.ref > run.def ; run0 >> error #24 54 54 # 55 55 # 12 martian months (=30°deg Ls) of unequal length (excentric orbit) 56 # sed s/9999/61/ run.def.ref > ! run.def ; run0 >>&error #2557 # sed s/9999/66/ run.def.ref > ! run.def ; run0 >>&error #2658 # sed s/9999/66/ run.def.ref > ! run.def ; run0 >>&error #2759 # sed s/9999/65/ run.def.ref > ! run.def ; run0 >>&error #2860 # sed s/9999/60/ run.def.ref > ! run.def ; run0 >>&error #2961 # sed s/9999/54/ run.def.ref > ! run.def ; run0 >>&error #3062 # sed s/9999/50/ run.def.ref > ! run.def ; run0 >>&error #3163 # sed s/9999/46/ run.def.ref > ! run.def ; run0 >>&error #3264 # sed s/9999/47/ run.def.ref > ! run.def ; run0 >>&error #3365 # sed s/9999/47/ run.def.ref > ! run.def ; run0 >>&error #3466 # sed s/9999/51/ run.def.ref > ! run.def ; run0 >>&error #3567 # sed s/9999/56/ run.def.ref > ! run.def ; run0 >>&error #3656 # sed s/9999/61/ run.def.ref > run.def ; run0 >> error #25 57 # sed s/9999/66/ run.def.ref > run.def ; run0 >> error #26 58 # sed s/9999/66/ run.def.ref > run.def ; run0 >> error #27 59 # sed s/9999/65/ run.def.ref > run.def ; run0 >> error #28 60 # sed s/9999/60/ run.def.ref > run.def ; run0 >> error #29 61 # sed s/9999/54/ run.def.ref > run.def ; run0 >> error #30 62 # sed s/9999/50/ run.def.ref > run.def ; run0 >> error #31 63 # sed s/9999/46/ run.def.ref > run.def ; run0 >> error #32 64 # sed s/9999/47/ run.def.ref > run.def ; run0 >> error #33 65 # sed s/9999/47/ run.def.ref > run.def ; run0 >> error #34 66 # sed s/9999/51/ run.def.ref > run.def ; run0 >> error #35 67 # sed s/9999/56/ run.def.ref > run.def ; run0 >> error #36 68 68 69 69 # These last lines allow to reconstruct the last num_run after a model crash 70 70 # (because after crash, num_run was set to 9999 so that no further simulation 71 71 # Could be performed 72 setnumber=`cat num_run`73 if ( $number == 99999)then72 number=`cat num_run` 73 if (( $number == 99999)) ; then 74 74 set numold=`cat num_run.crash` 75 echo '-----' >> &error76 echo 'Seasonal simulation aborted after starting from start'$numold >> &error75 echo '-----' >> error 76 echo 'Seasonal simulation aborted after starting from start'$numold >> error 77 77 \mv -f num_run.crash num_run 78 endif78 fi -
trunk/LMDZ.MARS/libf/dyn3d/test_period.F
r38 r1005 25 25 PRINT *,'STOP dans test_period car --- UCOV --- n est pas', 26 26 , ' periodique en longitude ! ' 27 PRINT *,' l, ij = ', l, ij, ij+iim 27 PRINT *,' l, ij, ij+iim = ', l, ij, ij+iim 28 write(*,*) "ucov(ij,l)=",ucov(ij,l)," ucov(ij+iim,l)=", 29 & ucov(ij+iim,l) 28 30 STOP 29 31 ENDIF … … 31 33 PRINT *,'STOP dans test_period car --- TETA --- n est pas', 32 34 , ' periodique en longitude ! ' 33 PRINT *,' l, ij = ', l, ij, ij+iim 35 PRINT *,' l, ij, ij+iim = ', l, ij, ij+iim 36 write(*,*) "teta(ij,l)=",teta(ij,l)," teta(ij+iim,l)=", 37 & teta(ij+iim,l) 34 38 STOP 35 39 ENDIF … … 43 47 PRINT *,'STOP dans test_period car --- VCOV --- n est pas', 44 48 , ' periodique en longitude !' 45 PRINT *,' l, ij = ', l, ij, ij+iim,vcov(ij+iim,l),vcov(ij,l) 46 vcov(ij+iim,l)=vcov(ij,l) 49 PRINT *,' l, ij, ij+iim = ', l, ij, ij+iim 50 write(*,*) "vcov(ij,l)=",vcov(ij,l), 51 & " vcov(ij+iim,l)",vcov(ij+iim,l) 47 52 STOP 48 53 ENDIF -
trunk/LMDZ.MARS/libf/phymars/callsedim.F
r740 r1005 1 1 SUBROUTINE callsedim(ngrid,nlay, ptimestep, 2 & pplev,zlev, zlay, pt, rdust, rice,2 & pplev,zlev, zlay, pt, pdt, rdust, rice, 3 3 & rsedcloud,rhocloud, 4 4 & pq, pdqfi, pdqsed,pdqs_sed,nq, … … 6 6 ! to use 'getin' 7 7 USE ioipsl_getincom 8 USE updaterad 8 USE updaterad,only: updaterdust,updaterice_micro,updaterice_typ 9 9 IMPLICIT NONE 10 10 … … 35 35 c ---------- 36 36 37 INTEGER ngrid ! number of horizontal grid points 38 INTEGER nlay ! number of atmospheric layers 39 REAL ptimestep ! physics time step (s) 40 REAL pplev(ngrid,nlay+1) ! pressure at inter-layers (Pa) 41 REAL pt(ngrid,nlay) ! temperature at mid-layer (K) 42 REAL zlev(ngrid,nlay+1) ! altitude at layer boundaries 37 integer,intent(in) :: ngrid ! number of horizontal grid points 38 integer,intent(in) :: nlay ! number of atmospheric layers 39 real,intent(in) :: ptimestep ! physics time step (s) 40 real,intent(in) :: pplev(ngrid,nlay+1) ! pressure at inter-layers (Pa) 41 real,intent(in) :: zlev(ngrid,nlay+1) ! altitude at layer boundaries 42 real,intent(in) :: zlay(ngrid,nlay) ! altitude at the middle of the layers 43 real,intent(in) :: pt(ngrid,nlay) ! temperature at mid-layer (K) 44 real,intent(in) :: pdt(ngrid,nlay) ! tendency on temperature, from 45 ! previous processes (K/s) 43 46 c Aerosol radius provided by the water ice microphysical scheme: 44 REAL rdust(ngrid,nlay) ! Dust geometric mean radius (m) 45 REAL rice(ngrid,nlay) ! Ice geometric mean radius (m) 46 47 real,intent(out) :: rdust(ngrid,nlay) ! Dust geometric mean radius (m) 48 real,intent(out) :: rice(ngrid,nlay) ! H2O Ice geometric mean radius (m) 49 c Sedimentation radius of water ice 50 real,intent(in) :: rsedcloud(ngridmx,nlayermx) 51 c Cloud density (kg.m-3) 52 real,intent(inout) :: rhocloud(ngridmx,nlayermx) 47 53 c Traceurs : 48 integer nq ! number of tracers 49 real pq(ngrid,nlay,nq) ! tracers (kg/kg) 50 real pdqfi(ngrid,nlay,nq) ! tendency before sedimentation (kg/kg.s-1) 51 real pdqsed(ngrid,nlay,nq) ! tendency due to sedimentation (kg/kg.s-1) 52 real pdqs_sed(ngrid,nq) ! flux at surface (kg.m-2.s-1) 54 real,intent(in) :: pq(ngrid,nlay,nq) ! tracers (kg/kg) 55 real,intent(in) :: pdqfi(ngrid,nlay,nq) ! tendency before sedimentation (kg/kg.s-1) 56 real,intent(out) :: pdqsed(ngrid,nlay,nq) ! tendency due to sedimentation (kg/kg.s-1) 57 real,intent(out) :: pdqs_sed(ngrid,nq) ! flux at surface (kg.m-2.s-1) 58 integer,intent(in) :: nq ! number of tracers 59 real,intent(in) :: tau(ngrid,nlay) ! dust opacity 60 real,intent(in) :: tauscaling(ngrid) 53 61 54 62 c local: … … 57 65 INTEGER l,ig, iq 58 66 59 real zqi(ngridmx,nlayermx,nqmx) ! to locally store tracers 60 real masse (ngridmx,nlayermx) ! Layer mass (kg.m-2) 61 real epaisseur (ngridmx,nlayermx) ! Layer thickness (m) 62 real wq(ngridmx,nlayermx+1) ! displaced tracer mass (kg.m-2) 63 real r0(ngridmx,nlayermx) ! geometric mean radius used for 67 real zqi(ngrid,nlay,nq) ! to locally store tracers 68 real zt(ngrid,nlay) ! to locally store temperature 69 real masse (ngrid,nlay) ! Layer mass (kg.m-2) 70 real epaisseur (ngrid,nlay) ! Layer thickness (m) 71 real wq(ngrid,nlay+1) ! displaced tracer mass (kg.m-2) 72 real r0(ngrid,nlay) ! geometric mean radius used for 64 73 ! sedimentation (m) 65 real r0dust(ngrid mx,nlayermx) ! geometric mean radius used for74 real r0dust(ngrid,nlay) ! geometric mean radius used for 66 75 ! dust (m) 67 ! real r0ccn(ngrid mx,nlayermx) ! geometric mean radius used for76 ! real r0ccn(ngrid,nlay) ! geometric mean radius used for 68 77 ! ! CCNs (m) 69 c Sedimentation radius of water ice 70 real rsedcloud(ngridmx,nlayermx) 71 real beta ! correction for the shape of the ice particles (cf. newsedim) 72 save beta 73 c Cloud density (kg.m-3) 74 real rhocloud(ngridmx,nlayermx) 75 78 real,save :: beta ! correction for the shape of the ice particles (cf. newsedim) 79 76 80 c for ice radius computation 77 81 REAL Mo,No 78 REAL tau(ngrid,nlay), tauscaling(ngrid)79 REAL zlay(ngrid,nlay) ! altitude at the middle of the layers80 82 REAl ccntyp 81 83 … … 86 88 c 1) Parameters used to represent the changes in fall 87 89 c velocity as a function of particle size; 88 integer nr,ir 89 parameter (nr=12) !(nr=7) ! number of bins 90 real rd(nr),qr(ngridmx,nlayermx,nr) 91 real rdi(nr+1) ! extreme and intermediate radii 92 real Sq(ngridmx,nlayermx) 93 real rdmin,rdmax,rdimin,rdimax 94 data rdmin/1.e-8/ !/1.e-7/ 95 data rdmax/30.e-6/ 96 data rdimin/1.e-10/ 97 data rdimax/1e-4/ 98 save rd, rdi 90 integer ir 91 integer,parameter :: nr=12 !(nr=7) ! number of bins 92 real,save :: rd(nr) 93 real qr(ngrid,nlay,nr) 94 real,save :: rdi(nr+1) ! extreme and intermediate radii 95 real Sq(ngrid,nlay) 96 real,parameter :: rdmin=1.e-8 97 real,parameter :: rdmax=30.e-6 98 real,parameter :: rdimin=1.e-8 ! 1.e-7 99 real,parameter :: rdimax=1.e-4 99 100 100 101 c 2) Second size distribution for the log-normal integration 101 102 c (the mass mixing ratio is computed for each radius) 102 103 103 integer ninter, iint 104 parameter (ninter=4) ! nombre de point entre chaque rayon rdi 105 real rr(ninter,nr) 106 save rr 104 integer iint 105 integer,parameter :: ninter=4 ! number of points between each rdi radii 106 real,save :: rr(ninter,nr) 107 107 integer radpower 108 108 real sigma0 … … 110 110 c 3) Other local variables used in doubleq 111 111 112 INTEGER idust_mass ! index of tracer containing dust mass 113 ! mix. ratio 114 INTEGER idust_number ! index of tracer containing dust number 115 ! mix. ratio 116 INTEGER iccn_mass ! index of tracer containing CCN mass 117 ! mix. ratio 118 INTEGER iccn_number ! index of tracer containing CCN number 119 ! mix. ratio 120 SAVE idust_mass,idust_number 121 SAVE iccn_mass,iccn_number 122 123 124 c Firstcall: 125 126 LOGICAL firstcall 127 SAVE firstcall 128 DATA firstcall/.true./ 112 INTEGER,SAVE :: idust_mass ! index of tracer containing dust mass 113 ! mix. ratio 114 INTEGER,SAVE :: idust_number ! index of tracer containing dust number 115 ! mix. ratio 116 INTEGER,SAVE :: iccn_mass ! index of tracer containing CCN mass 117 ! mix. ratio 118 INTEGER,SAVE :: iccn_number ! index of tracer containing CCN number 119 ! mix. ratio 120 121 LOGICAL,SAVE :: firstcall=.true. 129 122 130 123 c ** un petit test de coherence … … 169 162 if (noms(iq).eq."dust_mass") then 170 163 idust_mass=iq 164 write(*,*)"callsedim: idust_mass=",idust_mass 171 165 endif 172 166 if (noms(iq).eq."dust_number") then 173 167 idust_number=iq 168 write(*,*)"callsedim: idust_number=",idust_number 174 169 endif 175 170 enddo … … 190 185 if (noms(iq).eq."ccn_mass") then 191 186 iccn_mass=iq 187 write(*,*)"callsedim: iccn_mass=",iccn_mass 192 188 endif 193 189 if (noms(iq).eq."ccn_number") then 194 190 iccn_number=iq 191 write(*,*)"callsedim: iccn_number=",iccn_number 195 192 endif 196 193 enddo … … 223 220 c ----------------- 224 221 225 zqi(1:ngrid,1:nlay,1:nqmx) = 0.226 c Updat ing the mass mixing ratiowith the tendencies coming222 ! zqi(1:ngrid,1:nlay,1:nqmx) = 0. 223 c Update the mass mixing ratio and temperature with the tendencies coming 227 224 c from other parameterizations: 228 225 c ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 229 230 do iq=1,nq 231 do l=1,nlay 232 do ig=1,ngrid 233 zqi(ig,l,iq)=pq(ig,l,iq)+pdqfi(ig,l,iq)*ptimestep 234 enddo 235 enddo 236 enddo 226 zqi(1:ngrid,1:nlay,1:nq)=pq(1:ngrid,1:nlay,1:nq) 227 & +pdqfi(1:ngrid,1:nlay,1:nq)*ptimestep 228 zt(1:ngrid,1:nlay)=pt(1:ngrid,1:nlay) 229 & +pdt(1:ngrid,1:nlay)*ptimestep 230 237 231 238 232 c Computing the different layer properties … … 342 336 343 337 call newsedim(ngrid,nlay,1,1,ptimestep, 344 & pplev,masse,epaisseur, pt,rd(ir),rho_dust,qr(1,1,ir),338 & pplev,masse,epaisseur,zt,rd(ir),rho_dust,qr(1,1,ir), 345 339 & wq,0.5) 346 340 … … 365 359 ! water ice sedimentation 366 360 call newsedim(ngrid,nlay,ngrid*nlay,ngrid*nlay, 367 & ptimestep,pplev,masse,epaisseur, pt,rsedcloud,rhocloud,361 & ptimestep,pplev,masse,epaisseur,zt,rsedcloud,rhocloud, 368 362 & zqi(1,1,iq),wq,beta) 369 363 else 370 364 ! water ice sedimentation 371 365 call newsedim(ngrid,nlay,ngrid*nlay,1, 372 & ptimestep,pplev,masse,epaisseur, pt,rsedcloud,rho_q(iq),366 & ptimestep,pplev,masse,epaisseur,zt,rsedcloud,rho_q(iq), 373 367 & zqi(1,1,iq),wq,beta) 374 368 endif ! of if (microphys) … … 383 377 else 384 378 call newsedim(ngrid,nlay,1,1,ptimestep, 385 & pplev,masse,epaisseur, pt,radius(iq),rho_q(iq),379 & pplev,masse,epaisseur,zt,radius(iq),rho_q(iq), 386 380 & zqi(1,1,iq),wq,1.0) 387 381 c Tendencies … … 405 399 c ================================================================= 406 400 enddo ! of do iq=1,nq 407 401 408 402 c Update the dust particle size "rdust" 409 403 c ------------------------------------- … … 451 445 endif ! of if (water) 452 446 453 RETURN454 447 END 455 448 -
trunk/LMDZ.MARS/libf/phymars/initracer.F
r740 r1005 14 14 c by the dynamics in "advtrac.h" 15 15 c 16 c Old conventions: (not used any more)17 c18 c If water=T : q(iq=nqmx) is the water mass mixing ratio19 c and q(iq=nqmx-1) is the ice mass mixing ratio20 21 c If there is transported dust, it uses iq=1 to iq=dustbin22 c If there is no transported dust : dustbin=023 c If doubleq=T : q(iq=1) is the dust mass mixing ratio24 c q(iq=2) is the dust number mixing ratio25 26 16 c 27 17 c author: F.Forget … … 380 370 381 371 c------------------------------------------------------------ 382 c Initiali sation tracers ....372 c Initialize tracers .... (in tracer.h) 383 373 c------------------------------------------------------------ 384 call zerophys(nqmx,rho_q) 385 374 ! start by setting everything to (default) zero 375 rho_q(1:nqmx)=0 ! tracer density (kg.m-3) 376 radius(1:nqmx)=0. ! tracer particle radius (m) 377 alpha_lift(1:nqmx) =0. ! tracer saltation vertical flux/horiz flux ratio (m-1) 378 alpha_devil(1:nqmx)=0. ! tracer lifting coefficient by dust devils 379 380 381 ! some reference values 386 382 rho_dust=2500. ! Mars dust density (kg.m-3) 387 383 rho_ice=920. ! Water ice density (kg.m-3) … … 497 493 end if ! (submicron) 498 494 499 c Initialization for photochemistry:500 c ---------------------------------501 if (photochem) then502 ! initialize chemistry+water (water will be correctly initialized below)503 ! by initializing everything which is not dust ...504 do iq=1,nqmx505 txt=noms(iq)506 if (txt(1:4).ne."dust") then507 radius(iq)=0.508 alpha_lift(iq) =0.509 alpha_devil(iq)=0.510 endif511 enddo ! do iq=1,nqmx512 endif513 514 495 c Initialization for water vapor 515 496 c ------------------------------ -
trunk/LMDZ.MARS/libf/phymars/physiq.F
r999 r1005 1172 1172 1173 1173 call callsedim(ngrid,nlayer, ptimestep, 1174 & zplev,zzlev, zzlay, pt, rdust, rice,1174 & zplev,zzlev, zzlay, pt, pdt, rdust, rice, 1175 1175 & rsedcloud,rhocloud, 1176 1176 & pq, pdq, zdqsed, zdqssed,nq, -
trunk/LMDZ.MARS/libf/phymars/writediagfi.F
r410 r1005 92 92 integer,save :: n_nom_def 93 93 integer :: n 94 integer,parameter :: n_nom_def_max= 9995 character(len= 20),save :: nom_def(n_nom_def_max)94 integer,parameter :: n_nom_def_max=199 95 character(len=120),save :: nom_def(n_nom_def_max) 96 96 logical,save :: firstcall=.true. 97 97
Note: See TracChangeset
for help on using the changeset viewer.