Changeset 6 for trunk/libf/dyn3d
- Timestamp:
- Oct 22, 2010, 12:47:12 PM (14 years ago)
- Location:
- trunk/libf/dyn3d
- Files:
-
- 11 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/libf/dyn3d/addfi.F
r1 r6 27 27 c pdufi(ip1jmp1,llm) | 28 28 c pdvfi(ip1jm,llm) | respective 29 c pdhfi(ip1jmp1) | tendencies 29 c pdhfi(ip1jmp1) | tendencies (unit/s) 30 30 c pdtsfi(ip1jmp1) | 31 31 c … … 116 116 ENDDO 117 117 118 DO iq = 1, 2 118 DO iq = 1, nqtot 119 IF ((planet_type.eq.'earth').and.(iq.le.2)) THEN 119 120 DO k = 1,llm 120 121 DO j = 1,ip1jmp1 … … 123 124 ENDDO 124 125 ENDDO 125 ENDDO 126 127 DO iq = 3, nqtot 126 ELSE 128 127 DO k = 1,llm 129 128 DO j = 1,ip1jmp1 … … 133 132 ENDDO 134 133 ENDDO 135 136 134 137 135 DO ij = 1, iim -
trunk/libf/dyn3d/bilan_dyn.F
r1 r6 2 2 ! $Id: bilan_dyn.F 1403 2010-07-01 09:02:53Z fairhead $ 3 3 ! 4 SUBROUTINE bilan_dyn (ntrac,dt_app,dt_cum, 5 s ps,masse,pk,flux_u,flux_v,teta,phi,ucov,vcov,trac) 4 SUBROUTINE bilan_dyn (dt_app,dt_cum, 5 s ps,masse,pk,flux_u,flux_v,teta,phi,ucov,vcov, 6 s ducovdyn,ducovdis,ducovspg,ducovphy) 7 c si besoin des traceurs: 8 c SUBROUTINE bilan_dyn (ntrac,dt_app,dt_cum, 9 c s ps,masse,pk,flux_u,flux_v,teta,phi,ucov,vcov,trac, 10 c s ducovdyn,ducovdis,ducovspg,ducovphy) 6 11 7 12 c AFAIRE … … 39 44 c =========== 40 45 41 integer ntrac46 c integer ntrac 42 47 real dt_app,dt_cum 43 48 real ps(iip1,jjp1) … … 49 54 real ucov(iip1,jjp1,llm) 50 55 real vcov(iip1,jjm,llm) 51 real trac(iip1,jjp1,llm,ntrac) 56 c real trac(iip1,jjp1,llm,ntrac) 57 c Tendances en m/s2 : 58 real ducovdyn(iip1,jjp1,llm) 59 real ducovdis(iip1,jjp1,llm) 60 real ducovspg(iip1,jjp1,llm) 61 real ducovphy(iip1,jjp1,llm) 52 62 53 63 c Local : … … 55 65 56 66 integer icum,ncum 67 save icum,ncum 68 69 integer i,j,l,iQ,num 70 real zz,zqy,zfactv(jjm,llm),zfactw(jjm,llm) 71 character*2 strd2 72 real ww 73 57 74 logical first 58 real zz,zqy,zfactv(jjm,llm) 59 60 integer nQ 61 parameter (nQ=7) 62 63 64 cym character*6 nom(nQ) 65 cym character*6 unites(nQ) 66 character*6,save :: nom(nQ) 67 character*6,save :: unites(nQ) 68 69 character*10 file 70 integer ifile 71 parameter (ifile=4) 72 73 integer itemp,igeop,iecin,iang,iu,iovap,iun 75 save first 76 data first/.true./ 77 74 78 integer i_sortie 75 76 save first,icum,ncum77 save itemp,igeop,iecin,iang,iu,iovap,iun78 79 save i_sortie 80 data i_sortie/1/ 79 81 80 82 real time … … 83 85 data time,itau/0.,0/ 84 86 85 data first/.true./ 86 data itemp,igeop,iecin,iang,iu,iovap,iun/1,2,3,4,5,6,7/ 87 data i_sortie/1/ 88 89 real ww 87 ! facteur = -1. pour Venus 88 real fact_geovenus 89 save fact_geovenus 90 90 91 91 c variables dynamiques intermédiaires 92 c ----------------------------------- 92 93 REAL vcont(iip1,jjm,llm),ucont(iip1,jjp1,llm) 93 94 REAL ang(iip1,jjp1,llm),unat(iip1,jjp1,llm) … … 95 96 REAL vorpot(iip1,jjm,llm) 96 97 REAL w(iip1,jjp1,llm),ecin(iip1,jjp1,llm),convm(iip1,jjp1,llm) 97 REAL bern(iip1,jjp1,llm) 98 real temp(iip1,jjp1,llm) 99 real dudyn(iip1,jjp1,llm) 100 real dudis(iip1,jjp1,llm) 101 real duspg(iip1,jjp1,llm) 102 real duphy(iip1,jjp1,llm) 103 104 c CHAMPS SCALAIRES Q ADVECTES 105 c ---------------------------- 106 integer nQ 107 c avec tous les composes, ca fait trop.... Je les enleve 108 c parameter (nQ=6+nqmx) 109 parameter (nQ=6) 110 111 character*6,save :: nom(nQ) 112 character*6,save :: unites(nQ) 113 114 integer itemp,igeop,iecin,iang,iu,iun 115 save itemp,igeop,iecin,iang,iu,iun 116 data itemp,igeop,iecin,iang,iu,iun/1,2,3,4,5,6/ 98 117 99 118 c champ contenant les scalaires advectés. … … 105 124 real flux_u_cum(iip1,jjp1,llm) 106 125 real flux_v_cum(iip1,jjm,llm) 126 real flux_w_cum(iip1,jjp1,llm) 107 127 real Q_cum(iip1,jjp1,llm,nQ) 108 128 real flux_uQ_cum(iip1,jjp1,llm,nQ) … … 113 133 save ps_cum,masse_cum,flux_u_cum,flux_v_cum 114 134 save Q_cum,flux_uQ_cum,flux_vQ_cum 115 116 c champs de tansport en moyenne zonale 135 save flux_w_cum,flux_wQ_cum 136 137 c champs de transport en moyenne zonale 117 138 integer ntr,itr 118 139 parameter (ntr=5) 119 140 120 cym character*10 znom(ntr,nQ)121 cym character*20 znoml(ntr,nQ)122 cym character*10 zunites(ntr,nQ)123 141 character*10,save :: znom(ntr,nQ) 124 142 character*20,save :: znoml(ntr,nQ) 125 143 character*10,save :: zunites(ntr,nQ) 144 character*10,save :: znom2(ntr,nQ) 145 character*20,save :: znom2l(ntr,nQ) 146 character*10,save :: zunites2(ntr,nQ) 147 character*10,save :: znom3(ntr,nQ) 148 character*20,save :: znom3l(ntr,nQ) 149 character*10,save :: zunites3(ntr,nQ) 126 150 127 151 integer iave,itot,immc,itrs,istn … … 131 155 132 156 real zvQ(jjm,llm,ntr,nQ),zvQtmp(jjm,llm) 157 real zwQ(jjm,llm,ntr,nQ),zwQtmp(jjm,llm) 133 158 real zavQ(jjm,ntr,nQ),psiQ(jjm,llm+1,nQ) 134 real zmasse(jjm,llm),zamasse(jjm) 135 136 real zv(jjm,llm),psi(jjm,llm+1) 137 138 integer i,j,l,iQ 139 159 real zawQ(jjm,llm,ntr,nQ) 160 real zdQ(jjm,llm,nQ) 161 real zmasse(jjm,llm),zavmasse(jjm),zawmasse(llm) 162 real psbar(jjm) 163 164 real zv(jjm,llm),zw(jjp1,llm),psi(jjm,llm+1) 165 166 c TENDANCES POUR MOMENT CINETIQUE 167 c ------------------------------- 168 169 integer ntdc,itdc 170 parameter (ntdc=4) 171 172 integer itdcdyn,itdcdis,itdcspg,itdcphy 173 data itdcdyn,itdcdis,itdcspg,itdcphy/1,2,3,4/ 174 175 character*6,save :: nomtdc(ntdc) 176 177 c champ contenant les tendances du moment cinetique. 178 real tdc(iip1,jjp1,llm,ntdc) 179 real ztdc(jjm,llm,ntdc) ! moyenne zonale 180 181 c champs cumulés 182 real tdc_cum(iip1,jjp1,llm,ntdc) 183 save tdc_cum 184 185 c integrations completes 186 real mtot,mctot,dmctot(ntdc) 140 187 141 188 c Initialisation du fichier contenant les moyennes zonales. … … 149 196 150 197 integer ndex3d(jjm*llm) 198 real ztmp3d(jjm,llm) 151 199 152 200 C Variables locales … … 154 202 integer tau0 155 203 real zjulian 156 character*3 str157 character*10 ctrac158 integer ii,jj159 204 integer zan, dayref 160 205 C … … 167 212 c===================================================================== 168 213 169 time=time+dt_app170 itau=itau+1171 cIM172 214 ndex3d=0 173 215 174 216 if (first) then 175 217 218 if (planet_type.eq."venus") then 219 fact_geovenus = -1. 220 else 221 fact_geovenus = 1. 222 endif 176 223 177 224 icum=0 … … 180 227 c ncum est la frequence de stokage en pas de temps 181 228 ncum=dt_cum/dt_app 182 if (abs(ncum*dt_app-dt_cum).gt.1.e-5*dt_app) then 229 if (abs(ncum*dt_app-dt_cum).gt.1.e-2*dt_app) then 230 if (abs((ncum+1)*dt_app-dt_cum).lt.1.e-2*dt_app) then 231 ncum = ncum+1 232 elseif (abs((ncum-1)*dt_app-dt_cum).lt.1.e-2*dt_app) then 233 ncum = ncum-1 234 else 183 235 WRITE(lunout,*) 184 236 . 'Pb : le pas de cumule doit etre multiple du pas' 185 237 WRITE(lunout,*)'dt_app=',dt_app 186 238 WRITE(lunout,*)'dt_cum=',dt_cum 239 WRITE(lunout,*)'ncum*dt_app=',ncum*dt_app 240 WRITE(lunout,*)'ncum=',ncum 187 241 stop 242 endif 188 243 endif 189 244 190 if (i_sortie.eq.1) then 191 file='dynzon' 192 call inigrads(ifile,1 193 s ,0.,180./pi,0.,0.,jjm,rlatv,-90.,90.,180./pi 194 s ,llm,presnivs,1. 195 s ,dt_cum,file,'dyn_zon ') 196 endif 197 198 nom(itemp)='T' 245 c VARIABLES ADVECTEES: 246 247 nom(itemp)='temp' 199 248 nom(igeop)='gz' 200 nom(iecin)=' K'249 nom(iecin)='ecin' 201 250 nom(iang)='ang' 202 251 nom(iu)='u' 203 nom(iovap)='ovap'204 252 nom(iun)='un' 205 253 … … 209 257 unites(iang)='ang' 210 258 unites(iu)='m/s' 211 unites(iovap)='kg/kg'212 259 unites(iun)='un' 213 260 261 c avec tous les composes, ca fait trop.... Je les enleve 262 c do num=1,ntrac 263 c write(strd2,'(i2.2)') num 264 c nom(6+num)='trac'//strd2 265 c unites(6+num)='kg/kg' 266 c enddo 267 268 c TENDANCES MOMENT CIN: 269 270 nomtdc(itdcdyn) ='dmcdyn' 271 nomtdc(itdcdis) ='dmcdis' 272 nomtdc(itdcspg) ='dmcspg' 273 nomtdc(itdcphy) ='dmcphy' 214 274 215 275 c Initialisation du fichier contenant les moyennes zonales. … … 221 281 dayref = day_ref 222 282 CALL ymds2ju(zan, 1, dayref, 0.0, zjulian) 223 tau0 = itau_dyn 283 c tau0 = itau_dyn 284 tau0 = 0 285 itau = tau0 224 286 225 287 rlong=0. 226 rlatg=rlatv*180./pi 288 rlatg=rlatv*180./pi*fact_geovenus 227 289 228 290 call histbeg(infile, 1, rlong, jjm, rlatg, … … 237 299 C 238 300 C Appels a histdef pour la definition des variables a sauvegarder 301 239 302 do iQ=1,nQ 240 303 do itr=1,ntr 241 304 if(itr.eq.1) then 242 znom(itr,iQ) =nom(iQ)243 znoml(itr,iQ) =nom(iQ)244 zunites(itr,iQ) =unites(iQ)305 znom(itr,iQ) =nom(iQ) 306 znoml(itr,iQ) =nom(iQ) 307 zunites(itr,iQ) =unites(iQ) 245 308 else 246 znom(itr,iQ)=ctrs(itr)//'v'//nom(iQ) 247 znoml(itr,iQ)='transport : v * '//nom(iQ)//' '//ctrs(itr) 248 zunites(itr,iQ)='m/s * '//unites(iQ) 309 znom(itr,iQ) =ctrs(itr)//'v'//nom(iQ) 310 znoml(itr,iQ) ='transport : v * '//nom(iQ)//' '//ctrs(itr) 311 zunites(itr,iQ) ='m/s * '//unites(iQ) 312 znom2(itr,iQ) =ctrs(itr)//'w'//nom(iQ) 313 znom2l(itr,iQ) ='transport: w * '//nom(iQ)//' '//ctrs(itr) 314 zunites2(itr,iQ)='Pa/s * '//unites(iQ) 249 315 endif 250 316 enddo 317 znom3(iQ)='d'//nom(iQ) 318 znom3l(iQ)='convergence: '//nom(iQ) 319 zunites3(iQ)=unites(iQ)//' /s' 320 c print*,'DEBUG:',znom3(iQ),znom3l(iQ),zunites3(iQ) 251 321 enddo 252 322 253 323 c Declarations des champs avec dimension verticale 254 c print*,'1HISTDEF' 255 do iQ=1,nQ 324 325 if (1.eq.0) then ! on les sort, ou pas... 326 327 c do iQ=1,nQ 328 c !!!! JE NE SORS ICI QUE temp et ang POUR CAUSE DE PLACE ! 329 do iQ=1,4,3 256 330 do itr=1,ntr 257 331 IF (prt_level > 5) … … 262 336 . 32,'ave(X)',dt_cum,dt_cum) 263 337 enddo 338 c transport vertical: 339 do itr=2,ntr 340 IF (prt_level > 5) 341 . WRITE(lunout,*)'var ',itr,iQ 342 . ,znom2(itr,iQ),znom2l(itr,iQ),zunites2(itr,iQ) 343 call histdef(fileid,znom2(itr,iQ),znom2l(itr,iQ), 344 . zunites2(itr,iQ),1,jjm,thoriid,llm,1,llm,zvertiid, 345 . 32,'ins(X)',dt_cum,dt_cum) 346 enddo 347 348 c Declarations pour convergences 349 IF (prt_level > 5) 350 . WRITE(lunout,*)'var ',iQ 351 . ,znom3(iQ),znom3l(iQ),zunites3(iQ) 352 call histdef(fileid,znom3(iQ),znom3l(iQ), 353 . zunites3(iQ),1,jjm,thoriid,llm,1,llm,zvertiid, 354 . 32,'ins(X)',dt_cum,dt_cum) 355 264 356 c Declarations pour les fonctions de courant 265 c print*,'2HISTDEF' 266 call histdef(fileid,'psi'//nom(iQ) 267 . ,'stream fn. '//znoml(itot,iQ), 268 . zunites(itot,iQ),1,jjm,thoriid,llm,1,llm,zvertiid, 269 . 32,'ave(X)',dt_cum,dt_cum) 270 enddo 271 357 c Non sorties ici... 358 c call histdef(fileid,'psi'//nom(iQ) 359 c . ,'stream fn. '//znoml(itot,iQ), 360 c . zunites(itot,iQ),1,jjm,thoriid,llm,1,llm,zvertiid, 361 c . 32,'ave(X)',dt_cum,dt_cum) 362 363 enddo ! iQ 364 365 endif ! 1=1 sortie ou non... 272 366 273 367 c Declarations pour les champs de transport d'air 274 c print*,'3HISTDEF'275 368 call histdef(fileid, 'masse', 'masse', 276 369 . 'kg', 1, jjm, thoriid, llm, 1, llm, zvertiid, … … 279 372 . 'm/s', 1, jjm, thoriid, llm, 1, llm, zvertiid, 280 373 . 32, 'ave(X)', dt_cum, dt_cum) 281 c Declarations pour les fonctions de courant 282 c print*,'4HISTDEF' 374 call histdef(fileid, 'w', 'w', 375 . 'Pa/s', 1, jjm, thoriid, llm, 1, llm, zvertiid, 376 . 32, 'ins(X)', dt_cum, dt_cum) 377 378 c Declarations pour la fonction de courant 283 379 call histdef(fileid,'psi','stream fn. MMC ','mega t/s', 284 380 . 1,jjm,thoriid,llm,1,llm,zvertiid, … … 286 382 287 383 384 c Declarations pour les tendances de moment cinetique 385 do itdc=1,ntdc 386 call histdef(fileid, nomtdc(itdc), nomtdc(itdc), 387 . 'ang/s', 1, jjm, thoriid, llm, 1, llm, zvertiid, 388 . 32, 'ins(X)', dt_cum, dt_cum) 389 enddo 390 288 391 c Declaration des champs 1D de transport en latitude 289 c print*,'5HISTDEF' 290 do iQ=1,nQ 392 c do iQ=1,nQ 393 c !!!! JE NE SORS ICI QUE temp et ang POUR CAUSE DE PLACE ! 394 do iQ=1,4,3 291 395 do itr=2,ntr 292 396 call histdef(fileid,'a'//znom(itr,iQ),znoml(itr,iQ), 293 397 . zunites(itr,iQ),1,jjm,thoriid,1,1,1,-99, 294 398 . 32,'ave(X)',dt_cum,dt_cum) 295 enddo 296 enddo 297 298 299 c print*,'8HISTDEF' 399 c JE VIRE LE VERTICAL POUR L'INSTANT 400 c call histdef(fileid,'a'//znom2(itr,iQ),znom2l(itr,iQ), 401 c . zunites2(itr,iQ),1,jjm,thoriid,llm,1,llm,zvertiid, 402 c . 32,'ins(X)',dt_cum,dt_cum) 403 enddo 404 enddo 405 300 406 CALL histend(fileid) 301 407 302 408 303 endif 409 endif ! first 304 410 305 411 … … 313 419 CALL enercin(vcov,ucov,vcont,ucont,ecin) 314 420 315 c moment cinétique 421 c moment cinétique et tendances 422 dudyn = 0. 423 dudis = 0. 424 duspg = 0. 425 duphy = 0. 316 426 do l=1,llm 317 ang(:,:,l)=ucov(:,:,l)+constang(:,:)318 427 unat(:,:,l)=ucont(:,:,l)*cu(:,:) 319 enddo 320 321 Q(:,:,:,itemp)=teta(:,:,:)*pk(:,:,:)/cpp 322 Q(:,:,:,igeop)=phi(:,:,:) 323 Q(:,:,:,iecin)=ecin(:,:,:) 324 Q(:,:,:,iang)=ang(:,:,:) 325 Q(:,:,:,iu)=unat(:,:,:) 326 Q(:,:,:,iovap)=trac(:,:,:,1) 327 Q(:,:,:,iun)=1. 328 428 dudyn(:,2:jjm,l) = ducovdyn(:,2:jjm,l)/cu(:,2:jjm) 429 dudis(:,2:jjm,l) = ducovdis(:,2:jjm,l)/cu(:,2:jjm) 430 duspg(:,2:jjm,l) = ducovspg(:,2:jjm,l)/cu(:,2:jjm) 431 duphy(:,2:jjm,l) = ducovphy(:,2:jjm,l)/cu(:,2:jjm) 432 do j=1,jjp1 433 ang(:,j,l)= rad*cos(rlatu(j))* 434 . ( unat(:,j,l) + rad*cos(rlatu(j))*omeg ) 435 tdc(:,j,l,1) = rad*cos(rlatu(j))*dudyn(:,j,l) 436 tdc(:,j,l,2) = rad*cos(rlatu(j))*dudis(:,j,l) 437 tdc(:,j,l,3) = rad*cos(rlatu(j))*duspg(:,j,l) 438 tdc(:,j,l,4) = rad*cos(rlatu(j))*duphy(:,j,l) 439 enddo 440 enddo 441 c Normalisation: 442 ang = ang / (2./3. *rad*rad*omeg) 443 do itdc=1,ntdc 444 tdc(:,:,:,itdc)=tdc(:,:,:,itdc) / (2./3. *rad*rad*omeg) 445 enddo 446 447 ! ADAPTATION GCM POUR CP(T) 448 call tpot2t(ip1jmp1*llm,teta,temp,pk) 449 Q(:,:,:,itemp) = temp(:,:,:) 450 Q(:,:,:,igeop) =phi(:,:,:) 451 Q(:,:,:,iecin) =ecin(:,:,:) 452 Q(:,:,:,iang) =ang(:,:,:) 453 Q(:,:,:,iu) =unat(:,:,:) 454 Q(:,:,:,iun) =1. 455 c avec tous les composes, ca fait trop.... Je les enleve 456 c do num=1,ntrac 457 c Q(:,:,:,6+num)=trac(:,:,:,num) 458 c enddo 459 460 c calcul du flux de masse vertical (+ vers le bas) 461 call convmas(flux_u,flux_v,convm) 462 CALL vitvert(convm,w) 329 463 330 464 c===================================================================== … … 333 467 c 334 468 if(icum.EQ.0) then 335 ps_cum=0. 336 masse_cum=0. 337 flux_u_cum=0. 338 flux_v_cum=0. 339 Q_cum=0. 340 flux_vQ_cum=0. 341 flux_uQ_cum=0. 469 ps_cum = 0. 470 masse_cum = 0. 471 flux_u_cum = 0. 472 flux_v_cum = 0. 473 flux_w_cum = 0. 474 Q_cum = 0. 475 flux_vQ_cum = 0. 476 flux_uQ_cum = 0. 477 flux_wQ_cum = 0. 478 tdc_cum = 0. 342 479 endif 343 480 … … 347 484 348 485 c accumulation des flux de masse horizontaux 349 ps_cum=ps_cum+ps 350 masse_cum=masse_cum+masse 351 flux_u_cum=flux_u_cum+flux_u 352 flux_v_cum=flux_v_cum+flux_v 486 ps_cum = ps_cum + ps 487 masse_cum = masse_cum + masse 488 flux_u_cum = flux_u_cum + flux_u 489 flux_v_cum = flux_v_cum + flux_v 490 flux_w_cum = flux_w_cum + w 353 491 do iQ=1,nQ 354 Q_cum(:,:,:,iQ)=Q_cum(:,:,:,iQ)+Q(:,:,:,iQ)*masse(:,:,:) 492 Q_cum(:,:,:,iQ) = Q_cum(:,:,:,iQ) + Q(:,:,:,iQ)*masse(:,:,:) 493 enddo 494 do itdc=1,ntdc 495 tdc_cum(:,:,:,itdc) = 496 . tdc_cum(:,:,:,itdc) + tdc(:,:,:,itdc)*masse(:,:,:) 355 497 enddo 356 498 … … 386 528 enddo 387 529 530 c Flux vertical 531 c ------------- 532 do iQ=1,nQ 533 do l=2,llm 534 do j=1,jjp1 535 do i=1,iip1 536 flux_wQ_cum(i,j,l,iQ)=flux_wQ_cum(i,j,l,iQ) 537 s +w(i,j,l)*0.5*(Q(i,j,l-1,iQ)+Q(i,j,l,iQ)) 538 enddo 539 enddo 540 enddo 541 flux_wQ_cum(:,:,1,iQ)=0.0e0 542 enddo 388 543 389 544 c tendances … … 397 552 CALL vitvert(convm,w) 398 553 554 c ajustement tendances (vitesse verticale) 399 555 do iQ=1,nQ 400 556 do l=1,llm-1 … … 410 566 IF (prt_level > 5) 411 567 . WRITE(lunout,*)'Apres les calculs fait a chaque pas' 568 412 569 c===================================================================== 413 570 c PAS DE TEMPS D'ECRITURE … … 415 572 if (icum.eq.ncum) then 416 573 c===================================================================== 574 575 time=time+dt_cum 576 itau=itau+1 417 577 418 578 IF (prt_level > 5) … … 421 581 c Normalisation 422 582 do iQ=1,nQ 423 Q_cum(:,:,:,iQ)=Q_cum(:,:,:,iQ)/masse_cum(:,:,:) 424 enddo 583 Q_cum(:,:,:,iQ) = Q_cum(:,:,:,iQ)/masse_cum(:,:,:) 584 dQ(:,:,:,iQ) = dQ(:,:,:,iQ) /masse_cum(:,:,:) 585 enddo 586 do itdc=1,ntdc 587 tdc_cum(:,:,:,itdc) = tdc_cum(:,:,:,itdc)/masse_cum(:,:,:) 588 enddo 589 425 590 zz=1./REAL(ncum) 426 ps_cum=ps_cum*zz 427 masse_cum=masse_cum*zz 428 flux_u_cum=flux_u_cum*zz 429 flux_v_cum=flux_v_cum*zz 430 flux_uQ_cum=flux_uQ_cum*zz 431 flux_vQ_cum=flux_vQ_cum*zz 432 dQ=dQ*zz 433 434 435 c A retravailler eventuellement 436 c division de dQ par la masse pour revenir aux bonnes grandeurs 437 do iQ=1,nQ 438 dQ(:,:,:,iQ)=dQ(:,:,:,iQ)/masse_cum(:,:,:) 439 enddo 440 591 ps_cum = ps_cum *zz 592 masse_cum = masse_cum *zz 593 flux_u_cum = flux_u_cum *zz 594 flux_v_cum = flux_v_cum *zz 595 flux_w_cum = flux_w_cum *zz 596 flux_uQ_cum = flux_uQ_cum *zz 597 flux_vQ_cum = flux_vQ_cum *zz 598 flux_wQ_cum = flux_wQ_cum *zz 599 600 c Integration complete 601 mtot = 0. 602 mctot = 0. 603 dmctot = 0. 604 do l=1,llm 605 do j=2,jjm 606 do i=1,iim 607 mtot = mtot + masse_cum(i,j,l) 608 mctot = mctot + Q_cum(i,j,l,iang)*masse_cum(i,j,l) 609 enddo 610 enddo 611 enddo 612 mctot = mctot/mtot 613 do itdc=1,ntdc 614 do l=1,llm 615 do j=2,jjm 616 do i=1,iim 617 dmctot(itdc) = dmctot(itdc) 618 . + tdc_cum(i,j,l,itdc)*masse_cum(i,j,l)/mtot 619 enddo 620 enddo 621 enddo 622 enddo 623 441 624 c===================================================================== 442 625 c Transport méridien … … 446 629 c ---------------------------------- 447 630 zv=0. 631 zw=0. 448 632 zmasse=0. 449 633 call massbar(masse_cum,massebx,masseby) 634 635 c moy zonale de la ps cumulee 636 do j=1,jjm 637 psbar(j)=0. 638 do i=1,iim 639 psbar(j)=psbar(j)+ps_cum(i,j)/iim 640 enddo 641 enddo 642 450 643 do l=1,llm 451 644 do j=1,jjm … … 453 646 zmasse(j,l)=zmasse(j,l)+masseby(i,j,l) 454 647 zv(j,l)=zv(j,l)+flux_v_cum(i,j,l) 648 zw(j,l)=zw(j,l)+flux_w_cum(i,j,l) 455 649 enddo 456 650 zfactv(j,l)=cv(1,j)/zmasse(j,l) 457 enddo 651 zfactw(j,l)=((ap(l)-ap(l+1))+psbar(j)*(bp(l)-bp(l+1))) 652 . /zmasse(j,l) 653 enddo 654 do i=1,iim 655 zw(jjp1,l)=zw(jjp1,l)+flux_w_cum(i,jjp1,l) 656 enddo 458 657 enddo 459 658 … … 480 679 c la variable zfactv transforme un transport meridien cumule 481 680 c en kg/s * unte-du-champ-transporte en m/s * unite-du-champ-transporte 681 c la variable zfactw transforme un transport vertical cumule 682 c en kg/s * unte-du-champ-transporte en Pa/s * unite-du-champ-transporte 482 683 c 483 684 c -------------------------------------------------------------- … … 489 690 490 691 zvQ=0. 692 zwQ=0. 693 zdQ=0. 491 694 psiQ=0. 695 492 696 do iQ=1,nQ 697 698 c transport meridien 493 699 zvQtmp=0. 494 700 do l=1,llm 495 701 do j=1,jjm 496 702 c print*,'j,l,iQ=',j,l,iQ 497 c Calcul des moyennes zonales du trans ort total et de zvQtmp703 c Calcul des moyennes zonales du transport total et de zvQtmp 498 704 do i=1,iim 499 705 zvQ(j,l,itot,iQ)=zvQ(j,l,itot,iQ) … … 518 724 do l=llm,1,-1 519 725 do j=1,jjm 520 psiQ(j,l,iQ)=psiQ(j,l+1,iQ)+zvQ(j,l,itot,iQ) 726 psiQ(j,l,iQ)=psiQ(j,l+1,iQ)+zvQ(j,l,itot,iQ)/zfactv(j,l) 727 enddo 728 enddo 729 enddo 730 731 c transport vertical 732 zwQtmp=0. 733 do l=1,llm 734 do j=1,jjm 735 c print*,'j,l,iQ=',j,l,iQ 736 c Calcul des moyennes zonales du transport vertical total et de zwQtmp 737 do i=1,iim 738 zwQ(j,l,itot,iQ)=zwQ(j,l,itot,iQ) 739 s +flux_wQ_cum(i,j,l,iQ) 740 zqy= 0.5*(Q_cum(i,j,l,iQ)*masse_cum(i,j,l)+ 741 s Q_cum(i,j+1,l,iQ)*masse_cum(i,j+1,l)) 742 zwQtmp(j,l)=zwQtmp(j,l)+flux_w_cum(i,j,l)*zqy 743 s /(0.5*(masse_cum(i,j,l)+masse_cum(i,j+1,l))) 744 zwQ(j,l,iave,iQ)=zwQ(j,l,iave,iQ)+zqy 745 enddo 746 c Decomposition 747 zwQ(j,l,iave,iQ)=zwQ(j,l,iave,iQ)/zmasse(j,l) 748 zwQ(j,l,itot,iQ)=zwQ(j,l,itot,iQ)*zfactw(j,l) 749 zwQtmp(j,l)=zwQtmp(j,l)*zfactw(j,l) 750 zwQ(j,l,immc,iQ)=zw(j,l)*zwQ(j,l,iave,iQ)*zfactw(j,l) 751 zwQ(j,l,itrs,iQ)=zwQ(j,l,itot,iQ)-zwQtmp(j,l) 752 zwQ(j,l,istn,iQ)=zwQtmp(j,l)-zwQ(j,l,immc,iQ) 753 enddo 754 enddo 755 756 c convergence 757 c Calcul moyenne zonale de la convergence totale 758 do l=1,llm 759 do j=1,jjm 760 c print*,'j,l,iQ=',j,l,iQ 761 do i=1,iim 762 zdQ(j,l,iQ)=zdQ(j,l,iQ) + 763 . ( dQ(i,j,l,iQ) * masse_cum(i,j,l) 764 . + dQ(i,j+1,l,iQ) * masse_cum(i,j+1,l)) 765 . / ( masse_cum(i,j,l)+masse_cum(i,j+1,l)) 766 enddo 521 767 enddo 522 768 enddo … … 527 773 do l=llm,1,-1 528 774 do j=1,jjm 529 psi(j,l)=psi(j,l+1)+zv(j,l) 530 zv(j,l)=zv(j,l)*zfactv(j,l) 775 psi(j,l)= psi(j,l+1)+zv(j,l) 776 zv(j,l) = zv(j,l)*zfactv(j,l) 777 zw(j,l) = 0.5*(zw(j,l)+zw(j+1,l))*zfactw(j,l) 778 enddo 779 enddo 780 781 c Calcul moyenne zonale des tendances moment cin. 782 ztdc=0. 783 do itdc=1,ntdc 784 do l=1,llm 785 do j=1,jjm 786 do i=1,iim 787 ztdc(j,l,itdc)=ztdc(j,l,itdc) + 788 . ( tdc_cum(i,j,l,itdc) * masse_cum(i,j,l) 789 . + tdc_cum(i,j+1,l,itdc) * masse_cum(i,j+1,l)) 790 . / ( masse_cum(i,j,l)+masse_cum(i,j+1,l)) 791 enddo 792 enddo 531 793 enddo 532 794 enddo 533 795 534 796 c print*,'4OK' 797 798 c-------------------------------------- 799 c-------------------------------------- 535 800 c sorties proprement dites 801 c-------------------------------------- 802 c-------------------------------------- 803 536 804 if (i_sortie.eq.1) then 537 do iQ=1,nQ 538 do itr=1,ntr 539 call histwrite(fileid,znom(itr,iQ),itau,zvQ(:,:,itr,iQ) 805 806 c sortie des integrations completes dans le listing 807 write(*,'(A12,5(1PE11.4,X))') "BILANMCDYN ",mctot,dmctot 808 809 c sorties dans fichier dynzon 810 811 if (1.eq.0) then ! on les sort, ou pas... 812 813 c avec tous les composes, ca fait trop.... Je les enleve 814 c do iQ=1,nQ 815 c do iQ=1,6 816 c !!!! JE NE SORS ICI QUE temp et ang POUR CAUSE DE PLACE ! 817 do iQ=1,4,3 818 819 ztmp3d(:,:)= zvQ(:,:,1,iQ) ! valeur moyenne 820 call histwrite(fileid,znom(1,iQ),itau,ztmp3d 540 821 s ,jjm*llm,ndex3d) 541 enddo 542 call histwrite(fileid,'psi'//nom(iQ),itau,psiQ(:,1:llm,iQ) 822 do itr=2,ntr 823 ztmp3d(:,:)= zvQ(:,:,itr,iQ)*fact_geovenus ! transport horizontal 824 call histwrite(fileid,znom(itr,iQ),itau,ztmp3d 543 825 s ,jjm*llm,ndex3d) 544 enddo 545 546 call histwrite(fileid,'masse',itau,zmasse 826 enddo 827 828 do itr=2,ntr 829 ztmp3d(:,:)=zwQ(:,:,itr,iQ) 830 call histwrite(fileid,znom2(itr,iQ),itau,ztmp3d 831 s ,jjm*llm,ndex3d) 832 enddo 833 834 ztmp3d(:,:)= zdQ(:,:,iQ) 835 call histwrite(fileid,znom3(iQ),itau,ztmp3d 836 s ,jjm*llm,ndex3d) 837 838 c ztmp3d(:,:)= psiQ(:,1:llm,iQ)*fact_geovenus 839 c call histwrite(fileid,'psi'//nom(iQ),itau,ztmp3d 840 c s ,jjm*llm,ndex3d) 841 enddo 842 843 endif ! 1=1 sortie ou non... 844 845 ztmp3d=zmasse 846 call histwrite(fileid,'masse',itau,ztmp3d 547 847 s ,jjm*llm,ndex3d) 548 call histwrite(fileid,'v',itau,zv 848 849 ztmp3d= zv*fact_geovenus 850 call histwrite(fileid,'v',itau,ztmp3d 549 851 s ,jjm*llm,ndex3d) 550 psi=psi*1.e-9 551 call histwrite(fileid,'psi',itau,psi(:,1:llm),jjm*llm,ndex3d) 552 553 endif 852 ztmp3d(:,:)=zw(1:jjm,:) 853 call histwrite(fileid,'w',itau,ztmp3d 854 s ,jjm*llm,ndex3d) 855 ztmp3d= psi(:,1:llm)*1.e-9*fact_geovenus 856 call histwrite(fileid,'psi',itau,ztmp3d,jjm*llm,ndex3d) 857 858 do itdc=1,ntdc 859 ztmp3d(:,:)= ztdc(:,:,itdc) 860 call histwrite(fileid,nomtdc(itdc),itau,ztmp3d 861 s ,jjm*llm,ndex3d) 862 enddo 863 864 endif ! i_sortie 554 865 555 866 … … 558 869 c ----------------- 559 870 560 za masse=0.871 zavmasse=0. 561 872 do l=1,llm 562 za masse(:)=zamasse(:)+zmasse(:,l)873 zavmasse(:)=zavmasse(:)+zmasse(:,l) 563 874 enddo 564 875 zavQ=0. 565 do iQ=1,nQ 876 877 c avec tous les composes, ca fait trop.... Je les enleve 878 c do iQ=1,nQ 879 c do iQ=1,6 880 c !!!! JE NE SORS ICI QUE temp et ang POUR CAUSE DE PLACE ! 881 do iQ=1,4,3 566 882 do itr=2,ntr 567 883 do l=1,llm 568 884 zavQ(:,itr,iQ)=zavQ(:,itr,iQ)+zvQ(:,l,itr,iQ)*zmasse(:,l) 569 885 enddo 570 zavQ(:,itr,iQ)=zavQ(:,itr,iQ)/zamasse(:) 571 call histwrite(fileid,'a'//znom(itr,iQ),itau,zavQ(:,itr,iQ) 572 s ,jjm*llm,ndex3d) 573 enddo 574 enddo 575 576 c on doit pouvoir tracer systematiquement la fonction de courant. 886 zavQ(:,itr,iQ)=zavQ(:,itr,iQ)/zavmasse(:) 887 if (i_sortie.eq.1) then 888 ztmp3d=0.0 889 ztmp3d(:,1)= zavQ(:,itr,iQ)*fact_geovenus 890 call histwrite(fileid,'a'//znom(itr,iQ),itau,ztmp3d 891 . ,jjm*llm,ndex3d) 892 endif 893 enddo 894 enddo 895 896 c ------------------ 897 c Moyenne meridienne 898 c ------------------ 899 900 zawmasse=0. 901 do j=1,jjm 902 do l=1,llm 903 zawmasse(l)=zawmasse(l)+zmasse(j,l) 904 enddo 905 enddo 906 zawQ=0. 907 908 c avec tous les composes, ca fait trop.... Je les enleve 909 c do iQ=1,nQ 910 c do iQ=1,6 911 c !!!! JE NE SORS ICI QUE temp et ang POUR CAUSE DE PLACE ! 912 do iQ=1,4,3 913 do itr=2,ntr 914 do l=1,llm 915 do j=1,jjp1 916 zawQ(1,l,itr,iQ)=zawQ(1,l,itr,iQ)+zwQ(j,l,itr,iQ)*zmasse(j,l) 917 enddo 918 zawQ(1,l,itr,iQ)=zawQ(1,l,itr,iQ)/zawmasse(l) 919 enddo 920 if (i_sortie.eq.1) then 921 ztmp3d=0.0 922 do l=1,llm 923 ztmp3d(1,l)=zawQ(1,l,itr,iQ) 924 enddo 925 c JE VIRE LE VERTICAL POUR L'INSTANT 926 c call histwrite(fileid,'a'//znom2(itr,iQ),itau,ztmp3d 927 c . ,jjm*llm,ndex3d) 928 endif 929 enddo 930 enddo 931 932 call histsync(fileid) 577 933 578 934 c===================================================================== -
trunk/libf/dyn3d/caladvtrac.F
r1 r6 52 52 dq = 0. 53 53 54 IF (planet_type.eq."earth") THEN 55 ! Earth-specific treatment of first 2 tracers (water) 56 54 57 CALL SCOPY( 2 * ijp1llm, q, 1, dq, 1 ) 55 58 … … 78 81 ENDDO 79 82 80 if (planet_type.eq."earth") then 81 ! Earth-specific treatment of first 2 tracers (water) 82 CALL qminimum( q, 2, finmasse ) 83 endif 83 CALL qminimum( q, 2, finmasse ) 84 84 85 85 CALL SCOPY ( ip1jmp1*llm, masse, 1, finmasse, 1 ) … … 100 100 ENDDO 101 101 c 102 ELSE 102 ELSE 103 103 DO iq = 1 , 2 104 104 DO l = 1, llm … … 110 110 111 111 112 ENDIF 112 ENDIF ! iapptrac VS iapp_tracvl 113 114 ELSE ! not Earth 115 116 c advection 117 118 CALL advtrac( pbaru,pbarv, 119 * p, masse,q,iapptrac, teta, 120 . flxw, pk) 121 c 122 123 ENDIF ! planet_type 113 124 114 125 c -
trunk/libf/dyn3d/calfis.F
r5 r6 116 116 REAL pducov(iip1,jjp1,llm) 117 117 REAL pdteta(iip1,jjp1,llm) 118 ! commentaire SL: pdq ne sert que pour le calcul de pcvgq, 119 ! qui lui meme ne sert a rien dans la routine telle qu'elle est 120 ! ecrite, et que j'ai donc commente.... 118 121 REAL pdq(iip1,jjp1,llm,nqtot) 119 122 c … … 122 125 REAL ppk(iip1,jjp1,llm) 123 126 c 127 c TENDENCIES in */s 124 128 REAL pdvfi(iip1,jjm,llm) 125 129 REAL pdufi(iip1,jjp1,llm) … … 476 480 c --------------------- 477 481 478 #ifdef CPP_EARTH 482 ! Appel de la physique: pose probleme quand on tourne 483 ! SANS physique, car physiq.F est dans le repertoire phy[]... 484 ! Il faut une cle CPP_PHYS 485 486 ! Le fait que les arguments de physiq soient differents selon les planetes 487 ! ne pose pas de probleme a priori. 488 489 ! #ifdef CPP_PHYS 479 490 480 491 ! write(lunout,*) 'PHYSIQUE AVEC NSPLIT_PHYS=',nsplit_phys … … 491 502 lafin_split=lafin.and.isplit==nsplit_phys 492 503 504 if (planet_type.eq."earth") then 493 505 CALL physiq (ngridmx, 494 506 . llm, … … 518 530 . PVteta) 519 531 520 zufi(:,:)=zufi(:,:)+zdufi(:,:)*zdt_split 521 zvfi(:,:)=zvfi(:,:)+zdvfi(:,:)*zdt_split 522 ztfi(:,:)=ztfi(:,:)+zdtfi(:,:)*zdt_split 523 zqfi(:,:,:)=zqfi(:,:,:)+zdqfi(:,:,:)*zdt_split 524 525 zdufic(:,:)=zdufic(:,:)+zdufi(:,:) 526 zdvfic(:,:)=zdvfic(:,:)+zdvfi(:,:) 527 zdtfic(:,:)=zdtfic(:,:)+zdtfi(:,:) 528 zdqfic(:,:,:)=zdqfic(:,:,:)+zdqfi(:,:,:) 529 530 enddo 531 zdufi(:,:)=zdufic(:,:)/nsplit_phys 532 zdvfi(:,:)=zdvfic(:,:)/nsplit_phys 533 zdtfi(:,:)=zdtfic(:,:)/nsplit_phys 534 zdqfi(:,:,:)=zdqfic(:,:,:)/nsplit_phys 535 536 #else 537 ! si il n'y a pas la cle CPP_EARTH 538 539 ! ADAPTATION GCM POUR CP(T) 540 CALL physiq (ngridmx, 532 else ! a moduler pour Mars !! 533 534 CALL physiq (ngridmx, 541 535 . llm, 542 536 . nqtot, 543 . debut ,544 . lafin ,537 . debut_split, 538 . lafin_split, 545 539 . jD_cur, 546 . jH_cur ,547 . dtphys,540 . jH_cur_split, 541 . zdt_split, 548 542 . zplev, 549 543 . zplay, … … 564 558 . zdpsrf) 565 559 566 #endif 560 endif ! planet_type 561 562 zufi(:,:)=zufi(:,:)+zdufi(:,:)*zdt_split 563 zvfi(:,:)=zvfi(:,:)+zdvfi(:,:)*zdt_split 564 ztfi(:,:)=ztfi(:,:)+zdtfi(:,:)*zdt_split 565 zqfi(:,:,:)=zqfi(:,:,:)+zdqfi(:,:,:)*zdt_split 566 567 zdufic(:,:)=zdufic(:,:)+zdufi(:,:) 568 zdvfic(:,:)=zdvfic(:,:)+zdvfi(:,:) 569 zdtfic(:,:)=zdtfic(:,:)+zdtfi(:,:) 570 zdqfic(:,:,:)=zdqfic(:,:,:)+zdqfi(:,:,:) 571 572 enddo 573 zdufi(:,:)=zdufic(:,:)/nsplit_phys 574 zdvfi(:,:)=zdvfic(:,:)/nsplit_phys 575 zdtfi(:,:)=zdtfic(:,:)/nsplit_phys 576 zdqfi(:,:,:)=zdqfic(:,:,:)/nsplit_phys 577 578 ! #endif ! CPP_PHYS 567 579 568 580 500 CONTINUE … … 622 634 pdqfi(:,:,:,:)=0. 623 635 C 624 DO iq=1,nqtot636 DO iq=1,nqtot 625 637 iiq=niadv(iq) 626 638 DO l=1,llm … … 637 649 ENDDO 638 650 ENDDO 639 ENDDO651 ENDDO 640 652 641 653 c 65. champ u: -
trunk/libf/dyn3d/clesph0.h
r1 r6 2 2 ! $Header$ 3 3 ! 4 ! NE SERT A RIEN !! A VIRER... PAS A JOUR !!! 5 4 6 c..include clesph0.h 5 7 c -
trunk/libf/dyn3d/conf_gcm.F
r1 r6 164 164 165 165 !Config Key = nsplit_phys 166 !Config Desc = nombre de pas par jour166 !Config Desc = nombre de subdivisions par pas physique 167 167 !Config Def = 1 168 !Config Help = nombre de pas par jour (multiple de iperiod) ( 169 !Config ici pour dt = 1 min ) 168 !Config Help = nombre de subdivisions par pas physique 170 169 nsplit_phys = 1 171 170 CALL getin('nsplit_phys',nsplit_phys) … … 361 360 ip_ebil_dyn = 0 362 361 CALL getin('ip_ebil_dyn',ip_ebil_dyn) 363 !364 362 365 363 DO i = 1, longcles … … 815 813 !Config Help = active la version stratosphérique de LMDZ de F. Lott 816 814 817 ok_strato=. FALSE.815 ok_strato=.TRUE. 818 816 CALL getin('ok_strato',ok_strato) 819 817 -
trunk/libf/dyn3d/defrun.F
r1 r6 6 6 SUBROUTINE defrun( tapedef, etatinit, clesphy0 ) 7 7 c 8 ! ========================== ATTENTION ============================= 9 ! COMMENTAIRE SL : 10 ! NE SERT PLUS APPAREMMENT 11 ! DONC PAS MIS A JOUR POUR L'UTILISATION AVEC LES PLANETES 12 ! ================================================================== 13 8 14 USE control_mod 9 15 -
trunk/libf/dyn3d/dynredem.F
r1 r6 136 136 c 137 137 ierr = NF_PUT_ATT_TEXT (nid, NF_GLOBAL, "title", 27, 138 . "Fichier dem marage dynamique")138 . "Fichier demarrage dynamique") 139 139 c 140 140 c Definir les dimensions du fichiers: … … 536 536 #include "iniprint.h" 537 537 538 539 538 INTEGER l 540 539 REAL vcov(ip1jm,llm),ucov(ip1jmp1,llm) -
trunk/libf/dyn3d/gcm.F
r5 r6 253 253 endif 254 254 255 if (planet_type.eq."earth") then 256 #ifdef CPP_EARTH 257 ! Load an Earth-format start file 255 if (planet_type.eq."mars") then 256 ! POUR MARS, METTRE UNE FONCTION A PART, genre dynetat0_mars 257 abort_message = 'dynetat0_mars A FAIRE' 258 call abort_gcm(modname,abort_message,0) 259 else 258 260 CALL dynetat0("start.nc",vcov,ucov, 259 261 & teta,q,masse,ps,phis, time_0) 260 #else 261 ! SW model also has Earth-format start files 262 ! (but can be used without the CPP_EARTH directive) 263 if (iflag_phys.eq.0) then 264 CALL dynetat0("start.nc",vcov,ucov, 265 & teta,q,masse,ps,phis, time_0) 266 endif 267 #endif 268 endif ! of if (planet_type.eq."earth") 262 endif ! of if (planet_type.eq."mars") 269 263 270 264 c write(73,*) 'ucov',ucov … … 441 435 WRITE(lunout,*) 442 436 . 'GCM: WARNING!!! vitesse verticale nulle dans la physique' 443 ! Earth: 444 if (planet_type.eq."earth") then 445 #ifdef CPP_EARTH 437 438 ! Initialisation de la physique: pose probleme quand on tourne 439 ! SANS physique, car iniphysiq.F est dans le repertoire phy[]... 440 ! Il faut une cle CPP_PHYS 441 ! #ifdef CPP_PHYS 446 442 CALL iniphysiq(ngridmx,llm,daysec,day_ini,dtphys/nsplit_phys , 447 443 , latfi,lonfi,airefi,zcufi,zcvfi,rad,g,r,cpp ) 448 #endif 449 endif ! of if (planet_type.eq."earth") 444 ! #endif ! CPP_PHYS 450 445 call_iniphys=.false. 451 446 ENDIF ! of IF (call_iniphys.and.(iflag_phys.eq.1)) … … 472 467 #endif 473 468 474 if (planet_type.eq."earth") then 469 if (planet_type.eq."mars") then 470 ! POUR MARS, METTRE UNE FONCTION A PART, genre dynredem0_mars 471 abort_message = 'dynredem0_mars A FAIRE' 472 call abort_gcm(modname,abort_message,0) 473 else 475 474 CALL dynredem0("restart.nc", day_end, phis) 476 endif 475 endif ! of if (planet_type.eq."mars") 477 476 478 477 ecripar = .TRUE. -
trunk/libf/dyn3d/infotrac.F90
r1 r6 86 86 descrq(30)='PRA' 87 87 88 89 IF (config_inca=='none') THEN88 IF (planet_type=='earth') THEN 89 IF (config_inca=='none') THEN 90 90 type_trac='lmdz' 91 ELSE 92 type_trac='inca' 93 END IF 91 94 ELSE 92 type_trac='inca'93 END 95 type_trac='plnt' ! planets... May want to dissociate between each later. 96 ENDIF 94 97 95 98 !----------------------------------------------------------------------- … … 99 102 ! 100 103 !----------------------------------------------------------------------- 101 IF (type_trac == 'lmdz') THEN 104 IF (planet_type=='earth') THEN 105 IF (type_trac == 'lmdz') THEN 102 106 OPEN(90,file='traceur.def',form='formatted',status='old', iostat=ierr) 103 107 IF(ierr.EQ.0) THEN … … 109 113 nqtrue=4 ! Defaut value 110 114 END IF 111 ! Attention! Only for planet_type=='earth'112 115 nbtr=nqtrue-2 113 ELSE116 ELSE 114 117 ! nbtr has been read from INCA by init_cont_lmdz() in gcm.F 115 118 nqtrue=nbtr+2 116 END IF117 118 IF (nqtrue < 2) THEN119 END IF 120 121 IF (nqtrue < 2) THEN 119 122 WRITE(lunout,*) 'nqtrue=',nqtrue, ' is not allowded. 2 tracers is the minimum' 120 123 CALL abort_gcm('infotrac_init','Not enough tracers',1) 121 END IF 124 END IF 125 126 ELSE ! not Earth 127 OPEN(90,file='traceur.def',form='formatted',status='old', iostat=ierr) 128 IF(ierr.EQ.0) THEN 129 WRITE(lunout,*) 'Open traceur.def : ok' 130 READ(90,*) nqtrue 131 ELSE 132 WRITE(lunout,*) 'Problem in opening traceur.def' 133 WRITE(lunout,*) 'ATTENTION using defaut values: nqtrue=1' 134 nqtrue=1 ! Defaut value 135 END IF 136 nbtr=nqtrue 137 138 ENDIF ! planet_type 122 139 ! 123 140 ! Allocate variables depending on nqtrue and nbtr … … 154 171 ! Get choice of advection schema from file tracer.def or from INCA 155 172 !--------------------------------------------------------------------- 156 IF (type_trac == 'lmdz') THEN 173 IF (planet_type=='earth') THEN 174 IF (type_trac == 'lmdz') THEN 157 175 IF(ierr.EQ.0) THEN 158 176 ! Continue to read tracer.def … … 182 200 END DO 183 201 184 ELSE ! type_trac=inca : config_inca='aero' ou 'chem'202 ELSE ! type_trac=inca : config_inca='aero' ou 'chem' 185 203 ! le module de chimie fournit les noms des traceurs 186 204 ! et les schemas d'advection associes. … … 201 219 END DO 202 220 203 END IF ! type_trac 221 END IF ! type_trac 222 223 ELSE ! not Earth 224 IF(ierr.EQ.0) THEN 225 ! Continue to read tracer.def 226 DO iq=1,nqtrue 227 READ(90,999) hadv(iq),vadv(iq),tnom_0(iq) 228 END DO 229 CLOSE(90) 230 ELSE ! Without tracer.def 231 hadv(1) = 10 232 vadv(1) = 10 233 tnom_0(1) = 'dummy' 234 END IF 235 236 WRITE(lunout,*) 'Valeur de traceur.def :' 237 WRITE(lunout,*) 'nombre de traceurs ',nqtrue 238 DO iq=1,nqtrue 239 WRITE(lunout,*) hadv(iq),vadv(iq),tnom_0(iq) 240 END DO 241 242 ENDIF ! planet_type 204 243 205 244 !----------------------------------------------------------------------- -
trunk/libf/dyn3d/leapfrog.F
r5 r6 99 99 REAL massem1(ip1jmp1,llm) 100 100 101 c tendances dynamiques 101 c tendances dynamiques en */s 102 102 REAL dv(ip1jm,llm),du(ip1jmp1,llm) 103 103 REAL dteta(ip1jmp1,llm),dq(ip1jmp1,llm,nqtot),dp(ip1jmp1) 104 104 105 c tendances de la dissipation 105 c tendances de la dissipation en */s 106 106 REAL dvdis(ip1jm,llm),dudis(ip1jmp1,llm) 107 107 REAL dtetadis(ip1jmp1,llm) 108 108 109 c tendances physiques 109 c tendances de la couche superieure */s 110 REAL dvtop(ip1jm,llm),dutop(ip1jmp1,llm) 111 REAL dtetatop(ip1jmp1,llm) 112 REAL dqtop(ip1jmp1,llm,nqtot),dptop(ip1jmp1) 113 114 c tendances physiques */s 110 115 REAL dvfi(ip1jm,llm),dufi(ip1jmp1,llm) 111 116 REAL dtetafi(ip1jmp1,llm),dqfi(ip1jmp1,llm,nqtot),dpfi(ip1jmp1) … … 182 187 data dissip_conservative/.true./ 183 188 184 LOGICAL prem185 save prem186 DATA prem/.true./187 189 INTEGER testita 188 190 PARAMETER (testita = 9) … … 190 192 logical , parameter :: flag_verif = .false. 191 193 192 193 integer itau_w ! pas de temps ecriture = itap + itau_phy194 195 194 196 195 itaufin = nday*day_step … … 198 197 modname="leapfrog" 199 198 199 c INITIALISATIONS 200 dudis(:,:) =0. 201 dvdis(:,:) =0. 202 dtetadis(:,:)=0. 203 dutop(:,:) =0. 204 dvtop(:,:) =0. 205 dtetatop(:,:)=0. 206 dqtop(:,:,:) =0. 207 dptop(:) =0. 208 dufi(:,:) =0. 209 dvfi(:,:) =0. 210 dtetafi(:,:)=0. 211 dqfi(:,:,:) =0. 212 dpfi(:) =0. 200 213 201 214 itau = 0 … … 382 395 383 396 384 c In bterface avec les routines de phylmd (phymars ... )397 c Interface avec les routines de phylmd (phymars ... ) 385 398 c ----------------------------------------------------- 386 399 … … 400 413 cIM : pour sortir les param. du modele dans un fis. netcdf 110106 401 414 IF (first) THEN 402 first=.false.403 415 #include "ini_paramLMDZ_dyn.h" 404 416 ENDIF … … 408 420 #endif 409 421 ! #endif of #ifdef CPP_IOIPSL 422 410 423 CALL calfis( lafin , jD_cur, jH_cur, 411 424 $ ucov,vcov,teta,q,masse,ps,p,pk,phis,phi , … … 414 427 $ clesphy0, dufi,dvfi,dtetafi,dqfi,dpfi ) 415 428 429 c ajout des tendances physiques: 430 c ------------------------------ 431 CALL addfi( dtphys, leapf, forward , 432 $ ucov, vcov, teta , q ,ps , 433 $ dufi, dvfi, dtetafi , dqfi ,dpfi ) 434 435 c Couche superieure : 436 c ------------------- 416 437 IF (ok_strato) THEN 417 CALL top_bound( vcov,ucov,teta,masse,du fi,dvfi,dtetafi)438 CALL top_bound( vcov,ucov,teta,masse,dutop,dvtop,dtetatop) 418 439 ENDIF 440 c dqtop=0, dptop=0 419 441 420 442 c ajout des tendances physiques: … … 422 444 CALL addfi( dtphys, leapf, forward , 423 445 $ ucov, vcov, teta , q ,ps , 424 $ du fi, dvfi, dtetafi , dqfi ,dpfi)446 $ dutop, dvtop, dtetatop , dqtop ,dptop ) 425 447 c 426 448 c Diagnostique de conservation de l'énergie : difference … … 448 470 ! Sponge layer (if any) 449 471 IF (ok_strato) THEN 450 dufi(:,:)=0. 451 dvfi(:,:)=0. 452 dtetafi(:,:)=0. 453 dqfi(:,:,:)=0. 454 dpfi(:)=0. 455 CALL top_bound(vcov,ucov,teta,masse,dufi,dvfi,dtetafi) 472 CALL top_bound(vcov,ucov,teta,masse,dutop,dvtop,dtetatop) 456 473 CALL addfi( dtvr, leapf, forward , 457 474 $ ucov, vcov, teta , q ,ps , 458 $ du fi, dvfi, dtetafi , dqfi ,dpfi)475 $ dutop, dvtop, dtetatop , dqtop ,dptop ) 459 476 ENDIF ! of IF (ok_strato) 460 477 ENDIF ! of IF (iflag_phys.EQ.2) … … 485 502 ucov=ucov+dudis 486 503 vcov=vcov+dvdis 487 c teta=teta+dtetadis488 504 dudis=dudis/dtdiss ! passage en (m/s)/s 505 dvdis=dvdis/dtdiss ! passage en (m/s)/s 489 506 490 507 c------------------------------------------------------------------------ … … 506 523 endif 507 524 teta=teta+dtetadis 525 dtetadis=dtetadis/dtdiss ! passage en K/s 508 526 c------------------------------------------------------------------------ 509 527 … … 600 618 IF (ok_dynzon) THEN 601 619 #ifdef CPP_IOIPSL 602 CALL bilan_dyn(2,dtvr*iperiod,dtvr*day_step*periodav, 603 & ps,masse,pk,pbaru,pbarv,teta,phi,ucov,vcov,q) 620 c les traceurs ne sont pas sortis, trop lourd. 621 c Peut changer eventuellement si besoin. 622 CALL bilan_dyn(dtvr*iperiod,dtvr*day_step*periodav, 623 & ps,masse,pk,pbaru,pbarv,teta,phi,ucov,vcov, 624 & du,dudis,duspg,dufi) 604 625 #endif 605 626 END IF … … 651 672 652 673 653 if (planet_type.eq."earth") then 654 ! Write an Earth-format restart file 674 if (planet_type.eq."mars") then 675 ! POUR MARS, METTRE UNE FONCTION A PART, genre dynredem1_mars 676 abort_message = 'dynredem1_mars A FAIRE' 677 call abort_gcm(modname,abort_message,0) 678 else 655 679 CALL dynredem1("restart.nc",0.0, 656 680 & vcov,ucov,teta,q,masse,ps) 657 endif ! of if (planet_type.eq." earth")681 endif ! of if (planet_type.eq."mars") 658 682 659 683 CLOSE(99) … … 726 750 IF (ok_dynzon) THEN 727 751 #ifdef CPP_IOIPSL 728 CALL bilan_dyn(2,dtvr*iperiod,dtvr*day_step*periodav, 729 & ps,masse,pk,pbaru,pbarv,teta,phi,ucov,vcov,q) 752 c les traceurs ne sont pas sortis, trop lourd. 753 c Peut changer eventuellement si besoin. 754 CALL bilan_dyn(dtvr*iperiod,dtvr*day_step*periodav, 755 & ps,masse,pk,pbaru,pbarv,teta,phi,ucov,vcov, 756 & du,dudis,duspg,dufi) 730 757 #endif 731 758 ENDIF … … 766 793 767 794 IF(itau.EQ.itaufin) THEN 768 if (planet_type.eq."earth") then 795 if (planet_type.eq."mars") then 796 ! POUR MARS, METTRE UNE FONCTION A PART, genre dynredem1_mars 797 abort_message = 'dynredem1_mars A FAIRE' 798 call abort_gcm(modname,abort_message,0) 799 else 769 800 CALL dynredem1("restart.nc",0.0, 770 & 771 endif ! of if (planet_type.eq." earth")801 & vcov,ucov,teta,q,masse,ps) 802 endif ! of if (planet_type.eq."mars") 772 803 ENDIF ! of IF(itau.EQ.itaufin) 773 804 … … 779 810 END IF ! of IF(.not.purmats) 780 811 812 first=.false. 813 781 814 STOP 782 815 END
Note: See TracChangeset
for help on using the changeset viewer.