Changeset 2298 for LMDZ5/branches/testing/libf
- Timestamp:
- Jun 14, 2015, 9:13:32 PM (10 years ago)
- Location:
- LMDZ5/branches/testing
- Files:
-
- 55 deleted
- 90 edited
- 166 copied
Legend:
- Unmodified
- Added
- Removed
-
LMDZ5/branches/testing
- Property svn:mergeinfo changed
/LMDZ5/trunk merged: 2238-2257,2259-2271,2273,2277-2282,2284-2288,2290-2291
- Property svn:mergeinfo changed
-
LMDZ5/branches/testing/libf/dyn3d/advtrac.F90
r1999 r2298 9 9 ! M.A Filiberti (04/2002) 10 10 ! 11 USE infotrac, ONLY: nqtot, iadv 11 USE infotrac, ONLY: nqtot, iadv,nqperes,ok_iso_verif 12 12 USE control_mod, ONLY: iapp_tracvl, day_step 13 13 … … 79 79 80 80 IF(iadvtr.EQ.0) THEN 81 CALL initial0(ijp1llm,pbaruc)82 CALL initial0(ijmllm,pbarvc)81 pbaruc(:,:)=0 82 pbarvc(:,:)=0 83 83 ENDIF 84 84 … … 223 223 ! Appel des sous programmes d'advection 224 224 !----------------------------------------------------------- 225 do iq=1,nqtot 225 226 if (ok_iso_verif) then 227 write(*,*) 'advtrac 227' 228 call check_isotopes_seq(q,ip1jmp1,'advtrac 162') 229 endif !if (ok_iso_verif) then 230 231 do iq=1,nqperes 226 232 ! call clock(t_initial) 227 233 if(iadv(iq) == 0) cycle … … 230 236 ! ---------------------------------------------------------------- 231 237 if(iadv(iq).eq.10) THEN 232 call vlsplt(q(1,1,iq),2.,massem,wg,pbarug,pbarvg,dtvr) 233 238 ! CRisi: on fait passer tout q pour avoir acces aux fils 239 240 !write(*,*) 'advtrac 239: iq,q(1721,19,:)=',iq,q(1721,19,:) 241 call vlsplt(q,2.,massem,wg,pbarug,pbarvg,dtvr,iq) 242 234 243 ! ---------------------------------------------------------------- 235 244 ! Schema "pseudo amont" + test sur humidite specifique … … 238 247 else if(iadv(iq).eq.14) then 239 248 ! 240 CALL vlspltqs( q(1,1,1), 2., massem, wg , & 241 pbarug,pbarvg,dtvr,p,pk,teta ) 249 !write(*,*) 'advtrac 248: iq,q(1721,19,:)=',iq,q(1721,19,:) 250 CALL vlspltqs( q, 2., massem, wg , & 251 pbarug,pbarvg,dtvr,p,pk,teta,iq) 252 242 253 ! ---------------------------------------------------------------- 243 254 ! Schema de Frederic Hourdin … … 388 399 end DO 389 400 401 if (ok_iso_verif) then 402 write(*,*) 'advtrac 402' 403 call check_isotopes_seq(q,ip1jmp1,'advtrac 397') 404 endif !if (ok_iso_verif) then 390 405 391 406 !------------------------------------------------------------------ -
LMDZ5/branches/testing/libf/dyn3d/caladvtrac.F
r1910 r2298 53 53 if (planet_type.eq."earth") then 54 54 C initialisation 55 dq(:,:,1:2)=q(:,:,1:2) 55 ! CRisi: il faut gérer tous les traceurs si on veut pouvoir faire des 56 ! isotopes 57 ! dq(:,:,1:2)=q(:,:,1:2) 58 dq(:,:,1:nqtot)=q(:,:,1:nqtot) 56 59 57 60 c test des valeurs minmax … … 81 84 ENDDO 82 85 ENDDO 83 84 CALL qminimum( q, 2, finmasse ) 86 87 !write(*,*) 'caladvtrac 87' 88 CALL qminimum( q, nqtot, finmasse ) 89 !write(*,*) 'caladvtrac 89' 85 90 86 91 CALL SCOPY ( ip1jmp1*llm, masse, 1, finmasse, 1 ) … … 92 97 dtvrtrac = iapp_tracvl * dtvr 93 98 c 94 DO iq = 1 , 299 DO iq = 1 , nqtot 95 100 DO l = 1 , llm 96 101 DO ij = 1,ip1jmp1 … … 105 110 if (planet_type.eq."earth") then 106 111 ! Earth-specific treatment for the first 2 tracers (water) 107 dq(:,:,1: 2)=0.112 dq(:,:,1:nqtot)=0. 108 113 endif ! of if (planet_type.eq."earth") 109 114 ENDIF ! of IF( iapptrac.EQ.iapp_tracvl ) -
LMDZ5/branches/testing/libf/dyn3d/conf_gcm.F90
r2258 r2298 46 46 LOGICAL fxyhypbb, ysinuss 47 47 INTEGER i 48 LOGICAL use_filtre_fft49 48 50 49 ! ------------------------------------------------------------------- … … 89 88 90 89 !Config Key = prt_level 91 !Config Desc = niveau d'impressions de d ébogage90 !Config Desc = niveau d'impressions de d\'ebogage 92 91 !Config Def = 0 93 !Config Help = Niveau d'impression pour le d ébogage92 !Config Help = Niveau d'impression pour le d\'ebogage 94 93 !Config (0 = minimum d'impression) 95 94 prt_level = 0 … … 733 732 dzoomy = 0.2 734 733 CALL getin('dzoomy',dzoomy) 735 call assert(dzoomy < 1, "conf_gcm: dzoomy must be < 1")734 call assert(dzoomy < 1, "conf_gcm: dzoomy must be < 1") 736 735 737 736 !Config Key = taux … … 810 809 CALL getin('ok_dyn_ave',ok_dyn_ave) 811 810 812 !Config Key = use_filtre_fft813 !Config Desc = flag d'activation des FFT pour le filtre814 !Config Def = false815 !Config Help = permet d'activer l'utilisation des FFT pour effectuer816 !Config le filtrage aux poles.817 ! Le filtre fft n'est pas implemente dans dyn3d818 use_filtre_fft=.FALSE.819 CALL getin('use_filtre_fft',use_filtre_fft)820 821 IF (use_filtre_fft) THEN822 write(lunout,*)'STOP !!!'823 write(lunout,*)'use_filtre_fft n est pas implemente dans dyn3d'824 STOP 1825 ENDIF826 827 811 !Config key = ok_strato 828 812 !Config Desc = activation de la version strato 829 813 !Config Def = .FALSE. 830 !Config Help = active la version stratosph érique de LMDZ de F. Lott814 !Config Help = active la version stratosph\'erique de LMDZ de F. Lott 831 815 832 816 ok_strato=.FALSE. -
LMDZ5/branches/testing/libf/dyn3d/dynetat0.F
r1999 r2298 297 297 write(lunout,*)" Il est donc initialise a zero" 298 298 q(:,:,:,iq)=0. 299 300 ! CRisi: pour les isotopes, on peut faire init théorique 301 ! distill de Rayleigh très simplifiée 302 if (ok_isotopes) then 303 if ((iso_num(iq).gt.0).and.(zone_num(iq).eq.0)) then 304 q(:,:,:,iq)=q(:,:,:,iqpere(iq)) 305 & *tnat(iso_num(iq)) 306 & *(q(:,:,:,iqpere(iq))/30.e-3) 307 & **(alpha_ideal(iso_num(iq))-1) 308 endif 309 if ((iso_num(iq).gt.0).and.(zone_num(iq).eq.1)) then 310 q(:,:,:,iq)=q(:,:,:,iqiso(iso_indnum(iq), 311 & phase_num(iq))) 312 endif 313 endif !if (ok_isotopes) then 299 314 ELSE 300 315 ierr = NF90_GET_VAR(nid, nvarid, q(:,:,:,iq)) -
LMDZ5/branches/testing/libf/dyn3d/fluxstokenc.F
r1910 r2298 83 83 84 84 IF(iadvtr.EQ.0) THEN 85 CALL initial0(ijp1llm,phic)86 CALL initial0(ijp1llm,tetac)87 CALL initial0(ijp1llm,pbaruc)88 CALL initial0(ijmllm,pbarvc)85 phic(:,:)=0 86 tetac(:,:)=0 87 pbaruc(:,:)=0 88 pbarvc(:,:)=0 89 89 ENDIF 90 90 -
LMDZ5/branches/testing/libf/dyn3d/guide_mod.F90
r2160 r2298 81 81 ! Lecture des parametres: 82 82 ! --------------------------------------------- 83 call ini_getparam("nudging_parameters_out.txt") 83 84 ! Variables guidees 84 85 CALL getpar('guide_u',.true.,guide_u,'guidage de u') … … 109 110 CALL getpar('gamma4',.false.,gamma4,'Zone sans rappel elargie') 110 111 CALL getpar('guide_BL',.true.,guide_BL,'guidage dans C.Lim') 111 112 112 113 ! Sauvegarde du for�age 113 114 CALL getpar('guide_sav',.false.,guide_sav,'sauvegarde guidage') … … 147 148 CALL getpar('guide_2D',.false.,guide_2D,'fichier guidage lat-P') 148 149 150 call fin_getparam 151 149 152 ! --------------------------------------------- 150 153 ! Determination du nombre de niveaux verticaux … … 156 159 rcod=nf90_open('apbp.nc',Nf90_NOWRITe, ncidpl) 157 160 if (rcod.NE.NF_NOERR) THEN 158 print *,'Guide: probleme -> pas de fichier apbp.nc'159 CALL abort_gcm(modname,abort_message,1)161 CALL abort_gcm(modname, & 162 'Guide: probleme -> pas de fichier apbp.nc',1) 160 163 endif 161 164 endif … … 165 168 rcod=nf90_open('u.nc',Nf90_NOWRITe,ncidpl) 166 169 if (rcod.NE.NF_NOERR) THEN 167 print *,'Guide: probleme -> pas de fichier u.nc'168 CALL abort_gcm(modname,abort_message,1)170 CALL abort_gcm(modname, & 171 'Guide: probleme -> pas de fichier u.nc',1) 169 172 endif 170 173 endif … … 173 176 rcod=nf90_open('v.nc',nf90_nowrite,ncidpl) 174 177 if (rcod.NE.NF_NOERR) THEN 175 print *,'Guide: probleme -> pas de fichier v.nc'176 CALL abort_gcm(modname,abort_message,1)178 CALL abort_gcm(modname, & 179 'Guide: probleme -> pas de fichier v.nc',1) 177 180 endif 178 181 endif … … 181 184 rcod=nf90_open('T.nc',nf90_nowrite,ncidpl) 182 185 if (rcod.NE.NF_NOERR) THEN 183 print *,'Guide: probleme -> pas de fichier T.nc'184 CALL abort_gcm(modname,abort_message,1)186 CALL abort_gcm(modname, & 187 'Guide: probleme -> pas de fichier T.nc',1) 185 188 endif 186 189 endif … … 189 192 rcod=nf90_open('hur.nc',nf90_nowrite, ncidpl) 190 193 if (rcod.NE.NF_NOERR) THEN 191 print *,'Guide: probleme -> pas de fichier hur.nc'192 CALL abort_gcm(modname,abort_message,1)194 CALL abort_gcm(modname, & 195 'Guide: probleme -> pas de fichier hur.nc',1) 193 196 endif 194 197 endif … … 198 201 IF (error.NE.NF_NOERR) error=NF_INQ_DIMID(ncidpl,'PRESSURE',rid) 199 202 IF (error.NE.NF_NOERR) THEN 200 print *,'Guide: probleme lecture niveaux pression' 201 CALL abort_gcm(modname,abort_message,1) 203 CALL abort_gcm(modname,'Guide: probleme lecture niveaux pression',1) 202 204 ENDIF 203 205 error=NF_INQ_DIMLEN(ncidpl,rid,nlevnc) -
LMDZ5/branches/testing/libf/dyn3d/iniacademic.F90
r2160 r2298 5 5 6 6 USE filtreg_mod, ONLY: inifilr 7 USE infotrac , ONLY : nqtot7 USE infotrac 8 8 USE control_mod, ONLY: day_step,planet_type 9 9 #ifdef CPP_IOIPSL … … 262 262 if (i == 2) q(:,:,i)=1.e-15 263 263 if (i.gt.2) q(:,:,i)=0. 264 265 ! CRisi: init des isotopes 266 ! distill de Rayleigh très simplifiée 267 if (ok_isotopes) then 268 if ((iso_num(i).gt.0).and.(zone_num(i).eq.0)) then 269 q(:,:,i)=q(:,:,iqpere(i)) & 270 & *tnat(iso_num(i)) & 271 & *(q(:,:,iqpere(i))/30.e-3) & 272 & **(alpha_ideal(iso_num(i))-1) 273 endif 274 if ((iso_num(i).gt.0).and.(zone_num(i).eq.1)) then 275 q(:,:,i)=q(:,:,iqiso(iso_indnum(i),phase_num(i))) 276 endif 277 endif !if (ok_isotopes) then 278 264 279 enddo 265 280 else 266 281 q(:,:,:)=0 267 282 endif ! of if (planet_type=="earth") 283 284 if (ok_iso_verif) then 285 call check_isotopes_seq(q,1,ip1jmp1,'iniacademic_loc') 286 endif !if (ok_iso_verif) then 268 287 269 288 ! add random perturbation to temperature -
LMDZ5/branches/testing/libf/dyn3d/leapfrog.F
r2258 r2298 11 11 use IOIPSL 12 12 #endif 13 USE infotrac, ONLY: nqtot 13 USE infotrac, ONLY: nqtot,ok_iso_verif 14 14 USE guide_mod, ONLY : guide_main 15 15 USE write_field, ONLY: writefield … … 235 235 jH_cur = jH_cur - int(jH_cur) 236 236 237 if (ok_iso_verif) then 238 call check_isotopes_seq(q,ip1jmp1,'leapfrog 321') 239 endif !if (ok_iso_verif) then 237 240 238 241 #ifdef CPP_IOIPSL … … 265 268 ! CALL SCOPY ( ijp1llm, masse, 1, finvmaold, 1 ) 266 269 ! CALL filtreg ( finvmaold ,jjp1, llm, -2,2, .TRUE., 1 ) 270 271 if (ok_iso_verif) then 272 call check_isotopes_seq(q,ip1jmp1,'leapfrog 400') 273 endif !if (ok_iso_verif) then 267 274 268 275 2 CONTINUE ! Matsuno backward or leapfrog step begins here … … 305 312 endif 306 313 314 315 if (ok_iso_verif) then 316 call check_isotopes_seq(q,ip1jmp1,'leapfrog 589') 317 endif !if (ok_iso_verif) then 318 307 319 c----------------------------------------------------------------------- 308 320 c calcul des tendances dynamiques: … … 321 333 c calcul des tendances advection des traceurs (dont l'humidite) 322 334 c ------------------------------------------------------------- 335 336 if (ok_iso_verif) then 337 call check_isotopes_seq(q,ip1jmp1, 338 & 'leapfrog 686: avant caladvtrac') 339 endif !if (ok_iso_verif) then 323 340 324 341 IF( forward. OR . leapf ) THEN … … 327 344 * p, masse, dq, teta, 328 345 . flxw, pk) 346 !write(*,*) 'caladvtrac 346' 347 329 348 330 349 IF (offline) THEN … … 346 365 c ---------------------------------- 347 366 348 349 CALL integrd ( 2,vcovm1,ucovm1,tetam1,psm1,massem1 , 367 if (ok_iso_verif) then 368 write(*,*) 'leapfrog 720' 369 call check_isotopes_seq(q,ip1jmp1,'leapfrog 756') 370 endif !if (ok_iso_verif) then 371 372 CALL integrd ( nqtot,vcovm1,ucovm1,tetam1,psm1,massem1 , 350 373 $ dv,du,dteta,dq,dp,vcov,ucov,teta,q,ps,masse,phis ) 351 374 ! $ finvmaold ) 352 375 376 if (ok_iso_verif) then 377 write(*,*) 'leapfrog 724' 378 call check_isotopes_seq(q,ip1jmp1,'leapfrog 762') 379 endif !if (ok_iso_verif) then 353 380 354 381 c .P.Le Van (26/04/94 ajout de finvpold dans l'appel d'integrd) … … 437 464 #endif 438 465 ! #endif of #ifdef CPP_IOIPSL 466 #ifdef CPP_PHYS 439 467 CALL calfis( lafin , jD_cur, jH_cur, 440 468 $ ucov,vcov,teta,q,masse,ps,p,pk,phis,phi , 441 469 $ du,dv,dteta,dq, 442 470 $ flxw,dufi,dvfi,dtetafi,dqfi,dpfi ) 443 471 #endif 444 472 c ajout des tendances physiques: 445 473 c ------------------------------ … … 515 543 CALL massdair(p,masse) 516 544 545 if (ok_iso_verif) then 546 call check_isotopes_seq(q,ip1jmp1,'leapfrog 1196') 547 endif !if (ok_iso_verif) then 517 548 518 549 c----------------------------------------------------------------------- … … 599 630 c preparation du pas d'integration suivant ...... 600 631 632 if (ok_iso_verif) then 633 call check_isotopes_seq(q,ip1jmp1,'leapfrog 1509') 634 endif !if (ok_iso_verif) then 635 601 636 IF ( .NOT.purmats ) THEN 602 637 c ........................................................ … … 656 691 ENDIF ! of IF((MOD(itau,iperiod).EQ.0).OR.(itau.EQ.itaufin)) 657 692 693 if (ok_iso_verif) then 694 call check_isotopes_seq(q,ip1jmp1,'leapfrog 1584') 695 endif !if (ok_iso_verif) then 696 658 697 c----------------------------------------------------------------------- 659 698 c ecriture de la bande histoire: … … 734 773 ELSE ! of IF (.not.purmats) 735 774 775 if (ok_iso_verif) then 776 call check_isotopes_seq(q,ip1jmp1,'leapfrog 1664') 777 endif !if (ok_iso_verif) then 778 736 779 c ........................................................ 737 780 c .............. schema matsuno ............... … … 756 799 757 800 ELSE ! of IF(forward) i.e. backward step 801 802 if (ok_iso_verif) then 803 call check_isotopes_seq(q,ip1jmp1,'leapfrog 1698') 804 endif !if (ok_iso_verif) then 758 805 759 806 IF(MOD(itau,iperiod).EQ.0 .OR. itau.EQ.itaufin) THEN -
LMDZ5/branches/testing/libf/dyn3d/qminimum.F
r1910 r2298 2 2 ! $Header$ 3 3 ! 4 SUBROUTINE qminimum( q,nq ,deltap )4 SUBROUTINE qminimum( q,nqtot,deltap ) 5 5 6 USE infotrac, ONLY: ok_isotopes,ntraciso,iqiso,ok_iso_verif 6 7 IMPLICIT none 7 8 c … … 13 14 #include "comvert.h" 14 15 c 15 INTEGER nq 16 REAL q(ip1jmp1,llm,nq ), deltap(ip1jmp1,llm)16 INTEGER nqtot 17 REAL q(ip1jmp1,llm,nqtot), deltap(ip1jmp1,llm) 17 18 c 18 19 INTEGER iq_vap, iq_liq … … 30 31 INTEGER i, k, iq 31 32 REAL zx_defau, zx_abc, zx_pump(ip1jmp1), pompe 33 34 real zx_defau_diag(ip1jmp1,llm,2) 35 real q_follow(ip1jmp1,llm,2) 32 36 c 33 37 REAL SSUM … … 36 40 SAVE imprim 37 41 DATA imprim /0/ 42 !INTEGER ijb,ije 43 !INTEGER Index_pump(ij_end-ij_begin+1) 44 !INTEGER nb_pump 45 INTEGER ixt 38 46 c 39 47 c Quand l'eau liquide est trop petite (ou negative), on prend … … 41 49 c (sans changer la temperature !) 42 50 c 51 52 if (ok_iso_verif) then 53 call check_isotopes_seq(q,ip1jmp1,'qminimum 52') 54 endif !if (ok_iso_verif) then 55 56 zx_defau_diag(:,:,:)=0.0 57 q_follow(:,:,1:2)=q(:,:,1:2) 43 58 DO 1000 k = 1, llm 44 59 DO 1040 i = 1, ip1jmp1 45 60 if (seuil_liq - q(i,k,iq_liq) .gt. 0.d0 ) then 61 62 if (ok_isotopes) then 63 zx_defau_diag(i,k,iq_liq)=AMAX1 64 : ( seuil_liq - q(i,k,iq_liq), 0.0 ) 65 endif !if (ok_isotopes) then 66 46 67 q(i,k,iq_vap) = q(i,k,iq_vap) + q(i,k,iq_liq) - seuil_liq 47 68 q(i,k,iq_liq) = seuil_liq … … 59 80 DO i = 1, ip1jmp1 60 81 if ( seuil_vap - q(i,k,iq) .gt. 0.d0 ) then 82 83 if (ok_isotopes) then 84 zx_defau_diag(i,k,iq)=AMAX1( seuil_vap - q(i,k,iq), 0.0 ) 85 endif !if (ok_isotopes) then 86 61 87 q(i,k-1,iq) = q(i,k-1,iq) - ( seuil_vap - q(i,k,iq) ) * 62 88 & deltap(i,k) / deltap(i,k-1) … … 83 109 ENDDO 84 110 ENDIF 111 112 !write(*,*) 'qminimum 128' 113 if (ok_isotopes) then 114 ! CRisi: traiter de même les traceurs d'eau 115 ! Mais il faut les prendre à l'envers pour essayer de conserver la 116 ! masse. 117 ! 1) pompage dans le sol 118 ! On suppose que ce pompage se fait sans isotopes -> on ne modifie 119 ! rien ici et on croise les doigts pour que ça ne soit pas trop 120 ! génant 121 DO i = 1,ip1jmp1 122 if (zx_pump(i).gt.0.0) then 123 q_follow(i,1,iq_vap)=q_follow(i,1,iq_vap)+zx_pump(i) 124 endif !if (zx_pump(i).gt.0.0) then 125 enddo !DO i = 1,ip1jmp1 126 127 ! 2) transfert de vap vers les couches plus hautes 128 !write(*,*) 'qminimum 139' 129 do k=2,llm 130 DO i = 1,ip1jmp1 131 if (zx_defau_diag(i,k,iq_vap).gt.0.0) then 132 ! on ajoute la vapeur en k 133 do ixt=1,ntraciso 134 q(i,k,iqiso(ixt,iq_vap))=q(i,k,iqiso(ixt,iq_vap)) 135 : +zx_defau_diag(i,k,iq_vap) 136 : *q(i,k-1,iqiso(ixt,iq_vap))/q_follow(i,k-1,iq_vap) 137 138 ! et on la retranche en k-1 139 q(i,k-1,iqiso(ixt,iq_vap))=q(i,k-1,iqiso(ixt,iq_vap)) 140 : -zx_defau_diag(i,k,iq_vap) 141 : *deltap(i,k)/deltap(i,k-1) 142 : *q(i,k-1,iqiso(ixt,iq_vap))/q_follow(i,k-1,iq_vap) 143 144 enddo !do ixt=1,niso 145 q_follow(i,k,iq_vap)= q_follow(i,k,iq_vap) 146 : +zx_defau_diag(i,k,iq_vap) 147 q_follow(i,k-1,iq_vap)= q_follow(i,k-1,iq_vap) 148 : -zx_defau_diag(i,k,iq_vap) 149 : *deltap(i,k)/deltap(i,k-1) 150 endif !if (zx_defau_diag(i,k,iq_vap).gt.0.0) then 151 enddo !DO i = 1, ip1jmp1 152 enddo !do k=2,llm 153 154 if (ok_iso_verif) then 155 call check_isotopes_seq(q,ip1jmp1,'qminimum 168') 156 endif !if (ok_iso_verif) then 157 158 159 ! 3) transfert d'eau de la vapeur au liquide 160 !write(*,*) 'qminimum 164' 161 do k=1,llm 162 DO i = 1,ip1jmp1 163 if (zx_defau_diag(i,k,iq_liq).gt.0.0) then 164 165 ! on ajoute eau liquide en k en k 166 do ixt=1,ntraciso 167 q(i,k,iqiso(ixt,iq_liq))=q(i,k,iqiso(ixt,iq_liq)) 168 : +zx_defau_diag(i,k,iq_liq) 169 : *q(i,k,iqiso(ixt,iq_vap))/q_follow(i,k,iq_vap) 170 ! et on la retranche à la vapeur en k 171 q(i,k,iqiso(ixt,iq_vap))=q(i,k,iqiso(ixt,iq_vap)) 172 : -zx_defau_diag(i,k,iq_liq) 173 : *q(i,k,iqiso(ixt,iq_vap))/q_follow(i,k,iq_vap) 174 enddo !do ixt=1,niso 175 q_follow(i,k,iq_liq)= q_follow(i,k,iq_liq) 176 : +zx_defau_diag(i,k,iq_liq) 177 q_follow(i,k,iq_vap)= q_follow(i,k,iq_vap) 178 : -zx_defau_diag(i,k,iq_liq) 179 endif !if (zx_defau_diag(i,k,iq_vap).gt.0.0) then 180 enddo !DO i = 1, ip1jmp1 181 enddo !do k=2,llm 182 183 if (ok_iso_verif) then 184 call check_isotopes_seq(q,ip1jmp1,'qminimum 197') 185 endif !if (ok_iso_verif) then 186 187 endif !if (ok_isotopes) then 188 !write(*,*) 'qminimum 188' 189 85 190 c 86 191 RETURN -
LMDZ5/branches/testing/libf/dyn3d/vlsplt.F
r1910 r2298 3 3 c 4 4 5 SUBROUTINE vlsplt(q,pente_max,masse,w,pbaru,pbarv,pdt) 5 SUBROUTINE vlsplt(q,pente_max,masse,w,pbaru,pbarv,pdt,iq) 6 USE infotrac, ONLY: nqtot,nqdesc,iqfils 6 7 c 7 8 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 32 33 c REAL masse(iip1,jjp1,llm),pente_max 33 34 REAL pbaru( ip1jmp1,llm ),pbarv( ip1jm,llm) 34 REAL q(ip1jmp1,llm )35 REAL q(ip1jmp1,llm,nqtot) 35 36 c REAL q(iip1,jjp1,llm) 36 37 REAL w(ip1jmp1,llm),pdt 38 INTEGER iq ! CRisi 37 39 c 38 40 c Local … … 42 44 INTEGER ijlqmin,iqmin,jqmin,lqmin 43 45 c 44 REAL zm(ip1jmp1,llm ),newmasse46 REAL zm(ip1jmp1,llm,nqtot),newmasse 45 47 REAL mu(ip1jmp1,llm) 46 48 REAL mv(ip1jm,llm) 47 49 REAL mw(ip1jmp1,llm+1) 48 REAL zq(ip1jmp1,llm ),zz50 REAL zq(ip1jmp1,llm,nqtot),zz 49 51 REAL dqx(ip1jmp1,llm),dqy(ip1jmp1,llm),dqz(ip1jmp1,llm) 50 52 REAL second,temps0,temps1,temps2,temps3 … … 55 57 SAVE temps1,temps2,temps3 56 58 INTEGER iminn,imaxx 59 INTEGER ifils,iq2 ! CRisi 57 60 58 61 REAL qmin,qmax … … 79 82 mw(ij,llm+1)=0. 80 83 ENDDO 81 82 CALL SCOPY(ijp1llm,q,1,zq,1) 83 CALL SCOPY(ijp1llm,masse,1,zm,1) 84 85 CALL SCOPY(ijp1llm,q(1,1,iq),1,zq(1,1,iq),1) 86 CALL SCOPY(ijp1llm,masse,1,zm(1,1,iq),1) 87 88 if (nqdesc(iq).gt.0) then 89 do ifils=1,nqdesc(iq) 90 iq2=iqfils(ifils,iq) 91 CALL SCOPY(ijp1llm,q(1,1,iq2),1,zq(1,1,iq2),1) 92 enddo 93 endif !if (nqfils(iq).gt.0) then 84 94 85 95 cprint*,'Entree vlx1' 86 96 c call minmaxq(zq,qmin,qmax,'avant vlx ') 87 call vlx(zq,pente_max,zm,mu )97 call vlx(zq,pente_max,zm,mu,iq) 88 98 cprint*,'Sortie vlx1' 89 99 c call minmaxq(zq,qmin,qmax,'apres vlx1 ') 90 100 91 101 c print*,'Entree vly1' 92 call vly(zq,pente_max,zm,mv) 102 103 call vly(zq,pente_max,zm,mv,iq) 93 104 c call minmaxq(zq,qmin,qmax,'apres vly1 ') 94 105 cprint*,'Sortie vly1' 95 call vlz(zq,pente_max,zm,mw )106 call vlz(zq,pente_max,zm,mw,iq) 96 107 c call minmaxq(zq,qmin,qmax,'apres vlz ') 97 108 98 109 99 call vly(zq,pente_max,zm,mv )110 call vly(zq,pente_max,zm,mv,iq) 100 111 c call minmaxq(zq,qmin,qmax,'apres vly ') 101 112 102 113 103 call vlx(zq,pente_max,zm,mu )114 call vlx(zq,pente_max,zm,mu,iq) 104 115 c call minmaxq(zq,qmin,qmax,'apres vlx2 ') 105 116 … … 107 118 DO l=1,llm 108 119 DO ij=1,ip1jmp1 109 q(ij,l )=zq(ij,l)120 q(ij,l,iq)=zq(ij,l,iq) 110 121 ENDDO 111 122 DO ij=1,ip1jm+1,iip1 112 q(ij+iim,l)=q(ij,l) 113 ENDDO 114 ENDDO 123 q(ij+iim,l,iq)=q(ij,l,iq) 124 ENDDO 125 ENDDO 126 ! CRisi: aussi pour les fils 127 if (nqdesc(iq).gt.0) then 128 do ifils=1,nqdesc(iq) 129 iq2=iqfils(ifils,iq) 130 DO l=1,llm 131 DO ij=1,ip1jmp1 132 q(ij,l,iq2)=zq(ij,l,iq2) 133 ENDDO 134 DO ij=1,ip1jm+1,iip1 135 q(ij+iim,l,iq2)=q(ij,l,iq2) 136 ENDDO 137 ENDDO 138 enddo !do ifils=1,nqdesc(iq) 139 endif ! if (nqdesc(iq).gt.0) then 115 140 116 141 RETURN 117 142 END 118 SUBROUTINE vlx(q,pente_max,masse,u_m) 143 RECURSIVE SUBROUTINE vlx(q,pente_max,masse,u_m,iq) 144 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 119 145 120 146 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 139 165 c Arguments: 140 166 c ---------- 141 REAL masse(ip1jmp1,llm ),pente_max167 REAL masse(ip1jmp1,llm,nqtot),pente_max 142 168 REAL u_m( ip1jmp1,llm ),pbarv( iip1,jjm,llm) 143 REAL q(ip1jmp1,llm )169 REAL q(ip1jmp1,llm,nqtot) 144 170 REAL w(ip1jmp1,llm) 171 INTEGER iq ! CRisi 145 172 c 146 173 c Local … … 155 182 REAL adxqu(ip1jmp1),dxqmax(ip1jmp1,llm) 156 183 REAL u_mq(ip1jmp1,llm) 184 185 ! CRisi 186 REAL masseq(ip1jmp1,llm,nqtot),Ratio(ip1jmp1,llm,nqtot) 187 INTEGER ifils,iq2 ! CRisi 157 188 158 189 Logical extremum,first,testcpu … … 188 219 DO l = 1, llm 189 220 DO ij=iip2,ip1jm-1 190 dxqu(ij)=q(ij+1,l )-q(ij,l)221 dxqu(ij)=q(ij+1,l,iq)-q(ij,l,iq) 191 222 c IF(u_m(ij,l).lt.0.) stop'limx n admet pas les U<0' 192 c sigu(ij)=u_m(ij,l)/masse(ij,l )223 c sigu(ij)=u_m(ij,l)/masse(ij,l,iq) 193 224 ENDDO 194 225 DO ij=iip1+iip1,ip1jm,iip1 … … 243 274 DO l = 1, llm 244 275 DO ij=iip2,ip1jm-1 245 dxqu(ij)=q(ij+1,l )-q(ij,l)276 dxqu(ij)=q(ij+1,l,iq)-q(ij,l,iq) 246 277 ENDDO 247 278 DO ij=iip1+iip1,ip1jm,iip1 … … 285 316 DO l=1,llm 286 317 DO ij=iip2,ip1jm-1 287 zdum(ij,l)=cvmgp(1.-u_m(ij,l)/masse(ij,l ),288 , 1.+u_m(ij,l)/masse(ij+1,l ),318 zdum(ij,l)=cvmgp(1.-u_m(ij,l)/masse(ij,l,iq), 319 , 1.+u_m(ij,l)/masse(ij+1,l,iq), 289 320 , u_m(ij,l)) 290 321 zdum(ij,l)=0.5*zdum(ij,l) 291 322 u_mq(ij,l)=cvmgp( 292 , q(ij,l )+zdum(ij,l)*dxq(ij,l),293 , q(ij+1,l )-zdum(ij,l)*dxq(ij+1,l),323 , q(ij,l,iq)+zdum(ij,l)*dxq(ij,l), 324 , q(ij+1,l,iq)-zdum(ij,l)*dxq(ij+1,l), 294 325 , u_m(ij,l)) 295 326 u_mq(ij,l)=u_m(ij,l)*u_mq(ij,l) … … 303 334 DO l=1,llm 304 335 DO ij=iip2,ip1jm-1 305 c print*,'masse(',ij,')=',masse(ij,l )336 c print*,'masse(',ij,')=',masse(ij,l,iq) 306 337 IF (u_m(ij,l).gt.0.) THEN 307 zdum(ij,l)=1.-u_m(ij,l)/masse(ij,l )308 u_mq(ij,l)=u_m(ij,l)*(q(ij,l )+0.5*zdum(ij,l)*dxq(ij,l))338 zdum(ij,l)=1.-u_m(ij,l)/masse(ij,l,iq) 339 u_mq(ij,l)=u_m(ij,l)*(q(ij,l,iq)+0.5*zdum(ij,l)*dxq(ij,l)) 309 340 ELSE 310 zdum(ij,l)=1.+u_m(ij,l)/masse(ij+1,l) 311 u_mq(ij,l)=u_m(ij,l)*(q(ij+1,l)-0.5*zdum(ij,l)*dxq(ij+1,l)) 341 zdum(ij,l)=1.+u_m(ij,l)/masse(ij+1,l,iq) 342 u_mq(ij,l)=u_m(ij,l)*(q(ij+1,l,iq) 343 & -0.5*zdum(ij,l)*dxq(ij+1,l)) 312 344 ENDIF 313 345 ENDDO … … 379 411 i=ijq-(j-1)*iip1 380 412 c accumulation pour les mailles completements advectees 381 do while(zu_m.gt.masse(ijq,l)) 382 u_mq(ij,l)=u_mq(ij,l)+q(ijq,l)*masse(ijq,l) 383 zu_m=zu_m-masse(ijq,l) 413 do while(zu_m.gt.masse(ijq,l,iq)) 414 u_mq(ij,l)=u_mq(ij,l)+q(ijq,l,iq) 415 & *masse(ijq,l,iq) 416 zu_m=zu_m-masse(ijq,l,iq) 384 417 i=mod(i-2+iim,iim)+1 385 418 ijq=(j-1)*iip1+i … … 387 420 c ajout de la maille non completement advectee 388 421 u_mq(ij,l)=u_mq(ij,l)+zu_m* 389 & (q(ijq,l)+0.5*(1.-zu_m/masse(ijq,l))*dxq(ijq,l)) 422 & (q(ijq,l,iq)+0.5*(1.-zu_m/masse(ijq,l,iq)) 423 & *dxq(ijq,l)) 390 424 ELSE 391 425 ijq=ij+1 392 426 i=ijq-(j-1)*iip1 393 427 c accumulation pour les mailles completements advectees 394 do while(-zu_m.gt.masse(ijq,l)) 395 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l)*masse(ijq,l) 396 zu_m=zu_m+masse(ijq,l) 428 do while(-zu_m.gt.masse(ijq,l,iq)) 429 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l,iq) 430 & *masse(ijq,l,iq) 431 zu_m=zu_m+masse(ijq,l,iq) 397 432 i=mod(i,iim)+1 398 433 ijq=(j-1)*iip1+i 399 434 ENDDO 400 435 c ajout de la maille non completement advectee 401 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l )-402 & 0.5*(1.+zu_m/masse(ijq,l ))*dxq(ijq,l))436 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l,iq)- 437 & 0.5*(1.+zu_m/masse(ijq,l,iq))*dxq(ijq,l)) 403 438 ENDIF 404 439 ENDDO … … 417 452 ENDDO 418 453 454 ! CRisi: appel récursif de l'advection sur les fils. 455 ! Il faut faire ça avant d'avoir mis à jour q et masse 456 !write(*,*) 'vlsplt 326: iq,nqfils(iq)=',iq,nqfils(iq) 457 458 if (nqdesc(iq).gt.0) then 459 do ifils=1,nqdesc(iq) 460 iq2=iqfils(ifils,iq) 461 DO l=1,llm 462 DO ij=iip2,ip1jm 463 ! On a besoin de q et masse seulement entre iip2 et ip1jm 464 masseq(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 465 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 466 enddo 467 enddo 468 enddo !do ifils=1,nqdesc(iq) 469 do ifils=1,nqfils(iq) 470 iq2=iqfils(ifils,iq) 471 call vlx(Ratio,pente_max,masseq,u_mq,iq2) 472 enddo !do ifils=1,nqfils(iq) 473 endif !if (nqfils(iq).gt.0) then 474 ! end CRisi 475 419 476 420 477 c calcul des tENDances … … 422 479 DO l=1,llm 423 480 DO ij=iip2+1,ip1jm 424 new_m=masse(ij,l )+u_m(ij-1,l)-u_m(ij,l)425 q(ij,l )=(q(ij,l)*masse(ij,l)+481 new_m=masse(ij,l,iq)+u_m(ij-1,l)-u_m(ij,l) 482 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+ 426 483 & u_mq(ij-1,l)-u_mq(ij,l)) 427 484 & /new_m 428 masse(ij,l )=new_m485 masse(ij,l,iq)=new_m 429 486 ENDDO 430 487 c ModIF Fred 22 03 96 correction d'un bug (les scopy ci-dessous) 431 488 DO ij=iip1+iip1,ip1jm,iip1 432 q(ij-iim,l)=q(ij,l) 433 masse(ij-iim,l)=masse(ij,l) 434 ENDDO 435 ENDDO 489 q(ij-iim,l,iq)=q(ij,l,iq) 490 masse(ij-iim,l,iq)=masse(ij,l,iq) 491 ENDDO 492 ENDDO 493 494 ! retablir les fils en rapport de melange par rapport a l'air: 495 ! On calcule q entre iip2+1,ip1jm -> on fait pareil pour ratio 496 ! puis on boucle en longitude 497 if (nqdesc(iq).gt.0) then 498 do ifils=1,nqdesc(iq) 499 iq2=iqfils(ifils,iq) 500 DO l=1,llm 501 DO ij=iip2+1,ip1jm 502 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 503 enddo 504 DO ij=iip1+iip1,ip1jm,iip1 505 q(ij-iim,l,iq2)=q(ij,l,iq2) 506 enddo ! DO ij=ijb+iip1-1,ije,iip1 507 enddo !DO l=1,llm 508 enddo !do ifils=1,nqdesc(iq) 509 endif !if (nqfils(iq).gt.0) then 510 436 511 c CALL SCOPY((jjm-1)*llm,q(iip1+iip1,1),iip1,q(iip2,1),iip1) 437 512 c CALL SCOPY((jjm-1)*llm,masse(iip1+iip1,1),iip1,masse(iip2,1),iip1) … … 440 515 RETURN 441 516 END 442 SUBROUTINE vly(q,pente_max,masse,masse_adv_v) 517 RECURSIVE SUBROUTINE vly(q,pente_max,masse,masse_adv_v,iq) 518 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 443 519 c 444 520 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 464 540 c Arguments: 465 541 c ---------- 466 REAL masse(ip1jmp1,llm ),pente_max542 REAL masse(ip1jmp1,llm,nqtot),pente_max 467 543 REAL masse_adv_v( ip1jm,llm) 468 REAL q(ip1jmp1,llm), dq( ip1jmp1,llm) 544 REAL q(ip1jmp1,llm,nqtot), dq( ip1jmp1,llm) 545 INTEGER iq ! CRisi 469 546 c 470 547 c Local … … 491 568 SAVE sinlon,coslon,sinlondlon,coslondlon 492 569 SAVE airej2,airejjm 570 571 REAL masseq(ip1jmp1,llm,nqtot),Ratio(ip1jmp1,llm,nqtot) ! CRisi 572 INTEGER ifils,iq2 ! CRisi 573 493 574 c 494 575 c … … 497 578 DATA first,testcpu/.true.,.false./ 498 579 DATA temps0,temps1,temps2,temps3,temps4,temps5/0.,0.,0.,0.,0.,0./ 580 581 !write(*,*) 'vly 578: entree, iq=',iq 499 582 500 583 IF(first) THEN … … 529 612 530 613 DO i = 1, iim 531 airescb(i) = aire(i+ iip1) * q(i+ iip1,l )532 airesch(i) = aire(i+ ip1jm- iip1) * q(i+ ip1jm- iip1,l )614 airescb(i) = aire(i+ iip1) * q(i+ iip1,l,iq) 615 airesch(i) = aire(i+ ip1jm- iip1) * q(i+ ip1jm- iip1,l,iq) 533 616 ENDDO 534 617 qpns = SSUM( iim, airescb ,1 ) / airej2 … … 538 621 539 622 DO ij=1,ip1jm 540 dyqv(ij)=q(ij,l )-q(ij+iip1,l)623 dyqv(ij)=q(ij,l,iq)-q(ij+iip1,l,iq) 541 624 adyqv(ij)=abs(dyqv(ij)) 542 625 ENDDO … … 553 636 554 637 DO ij=1,iip1 555 dyq(ij,l)=qpns-q(ij+iip1,l )556 dyq(ip1jm+ij,l)=q(ip1jm+ij-iip1,l )-qpsn638 dyq(ij,l)=qpns-q(ij+iip1,l,iq) 639 dyq(ip1jm+ij,l)=q(ip1jm+ij-iip1,l,iq)-qpsn 557 640 ENDDO 558 641 … … 675 758 ENDDO 676 759 760 !write(*,*) 'vly 756' 677 761 DO l=1,llm 678 762 DO ij=1,ip1jm 679 763 IF(masse_adv_v(ij,l).gt.0) THEN 680 qbyv(ij,l)=q(ij+iip1,l)+dyq(ij+iip1,l)* 681 , 0.5*(1.-masse_adv_v(ij,l)/masse(ij+iip1,l)) 764 qbyv(ij,l)=q(ij+iip1,l,iq)+dyq(ij+iip1,l)* 765 , 0.5*(1.-masse_adv_v(ij,l) 766 , /masse(ij+iip1,l,iq)) 682 767 ELSE 683 qbyv(ij,l)=q(ij,l)-dyq(ij,l)* 684 , 0.5*(1.+masse_adv_v(ij,l)/masse(ij,l)) 768 qbyv(ij,l)=q(ij,l,iq)-dyq(ij,l)* 769 , 0.5*(1.+masse_adv_v(ij,l) 770 , /masse(ij,l,iq)) 685 771 ENDIF 686 772 qbyv(ij,l)=masse_adv_v(ij,l)*qbyv(ij,l) … … 688 774 ENDDO 689 775 776 ! CRisi: appel récursif de l'advection sur les fils. 777 ! Il faut faire ça avant d'avoir mis à jour q et masse 778 !write(*,*) 'vly 689: iq,nqfils(iq)=',iq,nqfils(iq) 779 780 if (nqfils(iq).gt.0) then 781 do ifils=1,nqdesc(iq) 782 iq2=iqfils(ifils,iq) 783 DO l=1,llm 784 DO ij=1,ip1jmp1 785 ! attention, chaque fils doit avoir son masseq, sinon, le 1er 786 ! fils ecrase le masseq de ses freres. 787 masseq(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 788 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 789 enddo 790 enddo 791 enddo !do ifils=1,nqdesc(iq) 792 793 do ifils=1,nqfils(iq) 794 iq2=iqfils(ifils,iq) 795 call vly(Ratio,pente_max,masseq,qbyv,iq2) 796 enddo !do ifils=1,nqfils(iq) 797 endif !if (nqfils(iq).gt.0) then 690 798 691 799 DO l=1,llm 692 800 DO ij=iip2,ip1jm 693 newmasse=masse(ij,l )801 newmasse=masse(ij,l,iq) 694 802 & +masse_adv_v(ij,l)-masse_adv_v(ij-iip1,l) 695 q(ij,l )=(q(ij,l)*masse(ij,l)+qbyv(ij,l)-qbyv(ij-iip1,l))696 & /newmasse697 masse(ij,l )=newmasse803 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+qbyv(ij,l) 804 & -qbyv(ij-iip1,l))/newmasse 805 masse(ij,l,iq)=newmasse 698 806 ENDDO 699 807 c.-. ancienne version … … 703 811 convpn=SSUM(iim,qbyv(1,l),1) 704 812 convmpn=ssum(iim,masse_adv_v(1,l),1) 705 massepn=ssum(iim,masse(1,l ),1)813 massepn=ssum(iim,masse(1,l,iq),1) 706 814 qpn=0. 707 815 do ij=1,iim 708 qpn=qpn+masse(ij,l )*q(ij,l)816 qpn=qpn+masse(ij,l,iq)*q(ij,l,iq) 709 817 enddo 710 818 qpn=(qpn+convpn)/(massepn+convmpn) 711 819 do ij=1,iip1 712 q(ij,l )=qpn820 q(ij,l,iq)=qpn 713 821 enddo 714 822 … … 718 826 convps=-SSUM(iim,qbyv(ip1jm-iim,l),1) 719 827 convmps=-ssum(iim,masse_adv_v(ip1jm-iim,l),1) 720 masseps=ssum(iim, masse(ip1jm+1,l ),1)828 masseps=ssum(iim, masse(ip1jm+1,l,iq),1) 721 829 qps=0. 722 830 do ij = ip1jm+1,ip1jmp1-1 723 qps=qps+masse(ij,l )*q(ij,l)831 qps=qps+masse(ij,l,iq)*q(ij,l,iq) 724 832 enddo 725 833 qps=(qps+convps)/(masseps+convmps) 726 834 do ij=ip1jm+1,ip1jmp1 727 q(ij,l )=qps835 q(ij,l,iq)=qps 728 836 enddo 729 837 … … 739 847 c DO ij = 1,iip1 740 848 c q(ij,l)=newq 741 c masse(ij,l )=newmasse*aire(ij)849 c masse(ij,l,iq)=newmasse*aire(ij) 742 850 c ENDDO 743 851 c convps=-SSUM(iim,qbyv(ip1jm-iim,l),1) … … 749 857 c DO ij = ip1jm+1,ip1jmp1 750 858 c q(ij,l)=newq 751 c masse(ij,l )=newmasse*aire(ij)859 c masse(ij,l,iq)=newmasse*aire(ij) 752 860 c ENDDO 753 861 c._. fin nouvelle version 754 862 ENDDO 863 864 ! retablir les fils en rapport de melange par rapport a l'air: 865 if (nqfils(iq).gt.0) then 866 do ifils=1,nqdesc(iq) 867 iq2=iqfils(ifils,iq) 868 DO l=1,llm 869 DO ij=1,ip1jmp1 870 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 871 enddo 872 enddo 873 enddo !do ifils=1,nqdesc(iq) 874 endif !if (nqfils(iq).gt.0) then 875 876 !write(*,*) 'vly 853: sortie' 755 877 756 878 RETURN 757 879 END 758 SUBROUTINE vlz(q,pente_max,masse,w) 880 RECURSIVE SUBROUTINE vlz(q,pente_max,masse,w,iq) 881 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 759 882 c 760 883 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 779 902 c Arguments: 780 903 c ---------- 781 REAL masse(ip1jmp1,llm ),pente_max782 REAL q(ip1jmp1,llm )904 REAL masse(ip1jmp1,llm,nqtot),pente_max 905 REAL q(ip1jmp1,llm,nqtot) 783 906 REAL w(ip1jmp1,llm+1) 907 INTEGER iq 784 908 c 785 909 c Local … … 792 916 REAL dzq(ip1jmp1,llm),dzqw(ip1jmp1,llm),adzqw(ip1jmp1,llm),dzqmax 793 917 REAL sigw 918 919 REAL masseq(ip1jmp1,llm,nqtot),Ratio(ip1jmp1,llm,nqtot) ! CRisi 920 INTEGER ifils,iq2 ! CRisi 794 921 795 922 LOGICAL testcpu … … 805 932 c On oriente tout dans le sens de la pression c'est a dire dans le 806 933 c sens de W 934 935 !write(*,*) 'vlz 923: entree' 807 936 808 937 #ifdef BIDON … … 813 942 DO l=2,llm 814 943 DO ij=1,ip1jmp1 815 dzqw(ij,l)=q(ij,l-1 )-q(ij,l)944 dzqw(ij,l)=q(ij,l-1,iq)-q(ij,l,iq) 816 945 adzqw(ij,l)=abs(dzqw(ij,l)) 817 946 ENDDO … … 835 964 ENDDO 836 965 966 !write(*,*) 'vlz 954' 837 967 DO ij=1,ip1jmp1 838 968 dzq(ij,1)=0. … … 851 981 c calcul de - d( q * w )/ d(sigma) qu'on ajoute a dq pour calculer dq 852 982 983 !write(*,*) 'vlz 969' 853 984 DO l = 1,llm-1 854 985 do ij = 1,ip1jmp1 855 986 IF(w(ij,l+1).gt.0.) THEN 856 sigw=w(ij,l+1)/masse(ij,l+1) 857 wq(ij,l+1)=w(ij,l+1)*(q(ij,l+1)+0.5*(1.-sigw)*dzq(ij,l+1)) 987 sigw=w(ij,l+1)/masse(ij,l+1,iq) 988 wq(ij,l+1)=w(ij,l+1)*(q(ij,l+1,iq) 989 & +0.5*(1.-sigw)*dzq(ij,l+1)) 858 990 ELSE 859 sigw=w(ij,l+1)/masse(ij,l )860 wq(ij,l+1)=w(ij,l+1)*(q(ij,l )-0.5*(1.+sigw)*dzq(ij,l))991 sigw=w(ij,l+1)/masse(ij,l,iq) 992 wq(ij,l+1)=w(ij,l+1)*(q(ij,l,iq)-0.5*(1.+sigw)*dzq(ij,l)) 861 993 ENDIF 862 994 ENDDO … … 868 1000 ENDDO 869 1001 1002 ! CRisi: appel récursif de l'advection sur les fils. 1003 ! Il faut faire ça avant d'avoir mis à jour q et masse 1004 !write(*,*) 'vlsplt 942: iq,nqfils(iq)=',iq,nqfils(iq) 1005 if (nqfils(iq).gt.0) then 1006 do ifils=1,nqdesc(iq) 1007 iq2=iqfils(ifils,iq) 1008 DO l=1,llm 1009 DO ij=1,ip1jmp1 1010 masseq(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 1011 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 1012 enddo 1013 enddo 1014 enddo !do ifils=1,nqdesc(iq) 1015 1016 do ifils=1,nqfils(iq) 1017 iq2=iqfils(ifils,iq) 1018 call vlz(Ratio,pente_max,masseq,wq,iq2) 1019 enddo !do ifils=1,nqfils(iq) 1020 endif !if (nqfils(iq).gt.0) then 1021 ! end CRisi 1022 870 1023 DO l=1,llm 871 1024 DO ij=1,ip1jmp1 872 newmasse=masse(ij,l )+w(ij,l+1)-w(ij,l)873 q(ij,l )=(q(ij,l)*masse(ij,l)+wq(ij,l+1)-wq(ij,l))1025 newmasse=masse(ij,l,iq)+w(ij,l+1)-w(ij,l) 1026 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+wq(ij,l+1)-wq(ij,l)) 874 1027 & /newmasse 875 masse(ij,l)=newmasse 876 ENDDO 877 ENDDO 878 1028 masse(ij,l,iq)=newmasse 1029 ENDDO 1030 ENDDO 1031 1032 ! retablir les fils en rapport de melange par rapport a l'air: 1033 if (nqfils(iq).gt.0) then 1034 do ifils=1,nqdesc(iq) 1035 iq2=iqfils(ifils,iq) 1036 DO l=1,llm 1037 DO ij=1,ip1jmp1 1038 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 1039 enddo 1040 enddo 1041 enddo !do ifils=1,nqdesc(iq) 1042 endif !if (nqfils(iq).gt.0) then 1043 !write(*,*) 'vlsplt 1032' 879 1044 880 1045 RETURN -
LMDZ5/branches/testing/libf/dyn3d/vlspltqs.F
r1910 r2298 3 3 c 4 4 SUBROUTINE vlspltqs ( q,pente_max,masse,w,pbaru,pbarv,pdt, 5 , p,pk,teta ) 5 , p,pk,teta,iq ) 6 USE infotrac, ONLY: nqtot,nqdesc,iqfils 6 7 c 7 8 c Auteurs: P.Le Van, F.Hourdin, F.Forget, F.Codron … … 35 36 REAL masse(ip1jmp1,llm),pente_max 36 37 REAL pbaru( ip1jmp1,llm ),pbarv( ip1jm,llm) 37 REAL q(ip1jmp1,llm )38 REAL q(ip1jmp1,llm,nqtot) 38 39 REAL w(ip1jmp1,llm),pdt 39 40 REAL p(ip1jmp1,llmp1),teta(ip1jmp1,llm),pk(ip1jmp1,llm) 41 INTEGER iq ! CRisi 40 42 c 41 43 c Local … … 43 45 c 44 46 INTEGER i,ij,l,j,ii 47 INTEGER ifils,iq2 ! CRisi 45 48 c 46 49 REAL qsat(ip1jmp1,llm) 47 REAL zm(ip1jmp1,llm )50 REAL zm(ip1jmp1,llm,nqtot) 48 51 REAL mu(ip1jmp1,llm) 49 52 REAL mv(ip1jm,llm) 50 53 REAL mw(ip1jmp1,llm+1) 51 REAL zq(ip1jmp1,llm )54 REAL zq(ip1jmp1,llm,nqtot) 52 55 REAL temps1,temps2,temps3 53 56 REAL zzpbar, zzw … … 116 119 ENDDO 117 120 118 CALL SCOPY(ijp1llm,q,1,zq,1) 119 CALL SCOPY(ijp1llm,masse,1,zm,1) 121 CALL SCOPY(ijp1llm,q(1,1,iq),1,zq(1,1,iq),1) 122 CALL SCOPY(ijp1llm,masse,1,zm(1,1,iq),1) 123 if (nqdesc(iq).gt.0) then 124 do ifils=1,nqdesc(iq) 125 iq2=iqfils(ifils,iq) 126 CALL SCOPY(ijp1llm,q(1,1,iq2),1,zq(1,1,iq2),1) 127 enddo 128 endif !if (nqfils(iq).gt.0) then 120 129 121 130 c call minmaxq(zq,qmin,qmax,'avant vlxqs ') 122 call vlxqs(zq,pente_max,zm,mu,qsat) 123 131 call vlxqs(zq,pente_max,zm,mu,qsat,iq) 124 132 125 133 c call minmaxq(zq,qmin,qmax,'avant vlyqs ') 126 134 127 call vlyqs(zq,pente_max,zm,mv,qsat) 128 135 call vlyqs(zq,pente_max,zm,mv,qsat,iq) 129 136 130 137 c call minmaxq(zq,qmin,qmax,'avant vlz ') 131 138 132 call vlz(zq,pente_max,zm,mw) 133 139 call vlz(zq,pente_max,zm,mw,iq) 134 140 135 141 c call minmaxq(zq,qmin,qmax,'avant vlyqs ') 136 142 c call minmaxq(zm,qmin,qmax,'M avant vlyqs ') 137 143 138 call vlyqs(zq,pente_max,zm,mv,qsat) 139 144 call vlyqs(zq,pente_max,zm,mv,qsat,iq) 140 145 141 146 c call minmaxq(zq,qmin,qmax,'avant vlxqs ') 142 147 c call minmaxq(zm,qmin,qmax,'M avant vlxqs ') 143 148 144 call vlxqs(zq,pente_max,zm,mu,qsat )149 call vlxqs(zq,pente_max,zm,mu,qsat,iq) 145 150 146 151 c call minmaxq(zq,qmin,qmax,'apres vlxqs ') … … 150 155 DO l=1,llm 151 156 DO ij=1,ip1jmp1 152 q(ij,l )=zq(ij,l)157 q(ij,l,iq)=zq(ij,l,iq) 153 158 ENDDO 154 159 DO ij=1,ip1jm+1,iip1 155 q(ij+iim,l)=q(ij,l) 156 ENDDO 157 ENDDO 160 q(ij+iim,l,iq)=q(ij,l,iq) 161 ENDDO 162 ENDDO 163 ! CRisi: aussi pour les fils 164 if (nqdesc(iq).gt.0) then 165 do ifils=1,nqdesc(iq) 166 iq2=iqfils(ifils,iq) 167 DO l=1,llm 168 DO ij=1,ip1jmp1 169 q(ij,l,iq2)=zq(ij,l,iq2) 170 ENDDO 171 DO ij=1,ip1jm+1,iip1 172 q(ij+iim,l,iq2)=q(ij,l,iq2) 173 ENDDO 174 ENDDO 175 enddo !do ifils=1,nqdesc(iq) 176 endif ! if (nqfils(iq).gt.0) then 177 !write(*,*) 'vlspltqs 183: fin de la routine' 158 178 159 179 RETURN 160 180 END 161 SUBROUTINE vlxqs(q,pente_max,masse,u_m,qsat) 181 SUBROUTINE vlxqs(q,pente_max,masse,u_m,qsat,iq) 182 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 183 162 184 c 163 185 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 179 201 c Arguments: 180 202 c ---------- 181 REAL masse(ip1jmp1,llm ),pente_max203 REAL masse(ip1jmp1,llm,nqtot),pente_max 182 204 REAL u_m( ip1jmp1,llm ) 183 REAL q(ip1jmp1,llm )205 REAL q(ip1jmp1,llm,nqtot) 184 206 REAL qsat(ip1jmp1,llm) 207 INTEGER iq ! CRisi 185 208 c 186 209 c Local … … 195 218 REAL adxqu(ip1jmp1),dxqmax(ip1jmp1,llm) 196 219 REAL u_mq(ip1jmp1,llm) 220 221 ! CRisi 222 REAL masseq(ip1jmp1,llm,nqtot),Ratio(ip1jmp1,llm,nqtot) 223 INTEGER ifils,iq2 ! CRisi 197 224 198 225 Logical first,testcpu … … 227 254 DO l = 1, llm 228 255 DO ij=iip2,ip1jm-1 229 dxqu(ij)=q(ij+1,l )-q(ij,l)256 dxqu(ij)=q(ij+1,l,iq)-q(ij,l,iq) 230 257 c IF(u_m(ij,l).lt.0.) stop'limx n admet pas les U<0' 231 c sigu(ij)=u_m(ij,l)/masse(ij,l )258 c sigu(ij)=u_m(ij,l)/masse(ij,l,iq) 232 259 ENDDO 233 260 DO ij=iip1+iip1,ip1jm,iip1 … … 281 308 DO l = 1, llm 282 309 DO ij=iip2,ip1jm-1 283 dxqu(ij)=q(ij+1,l )-q(ij,l)310 dxqu(ij)=q(ij+1,l,iq)-q(ij,l,iq) 284 311 ENDDO 285 312 DO ij=iip1+iip1,ip1jm,iip1 … … 323 350 DO l=1,llm 324 351 DO ij=iip2,ip1jm-1 325 zdum(ij,l)=cvmgp(1.-u_m(ij,l)/masse(ij,l ),326 , 1.+u_m(ij,l)/masse(ij+1,l ),352 zdum(ij,l)=cvmgp(1.-u_m(ij,l)/masse(ij,l,iq), 353 , 1.+u_m(ij,l)/masse(ij+1,l,iq), 327 354 , u_m(ij,l)) 328 355 zdum(ij,l)=0.5*zdum(ij,l) 329 356 u_mq(ij,l)=cvmgp( 330 , q(ij,l )+zdum(ij,l)*dxq(ij,l),331 , q(ij+1,l )-zdum(ij,l)*dxq(ij+1,l),357 , q(ij,l,iq)+zdum(ij,l)*dxq(ij,l), 358 , q(ij+1,l,iq)-zdum(ij,l)*dxq(ij+1,l), 332 359 , u_m(ij,l)) 333 360 u_mq(ij,l)=u_m(ij,l)*u_mq(ij,l) … … 341 368 DO ij=iip2,ip1jm-1 342 369 IF (u_m(ij,l).gt.0.) THEN 343 zdum(ij,l)=1.-u_m(ij,l)/masse(ij,l )370 zdum(ij,l)=1.-u_m(ij,l)/masse(ij,l,iq) 344 371 u_mq(ij,l)=u_m(ij,l)* 345 $ min(q(ij,l )+0.5*zdum(ij,l)*dxq(ij,l),qsat(ij+1,l))372 $ min(q(ij,l,iq)+0.5*zdum(ij,l)*dxq(ij,l),qsat(ij+1,l)) 346 373 ELSE 347 zdum(ij,l)=1.+u_m(ij,l)/masse(ij+1,l )374 zdum(ij,l)=1.+u_m(ij,l)/masse(ij+1,l,iq) 348 375 u_mq(ij,l)=u_m(ij,l)* 349 $ min(q(ij+1,l )-0.5*zdum(ij,l)*dxq(ij+1,l),qsat(ij,l))376 $ min(q(ij+1,l,iq)-0.5*zdum(ij,l)*dxq(ij+1,l),qsat(ij,l)) 350 377 ENDIF 351 378 ENDDO … … 416 443 i=ijq-(j-1)*iip1 417 444 c accumulation pour les mailles completements advectees 418 do while(zu_m.gt.masse(ijq,l)) 419 u_mq(ij,l)=u_mq(ij,l)+q(ijq,l)*masse(ijq,l) 420 zu_m=zu_m-masse(ijq,l) 445 do while(zu_m.gt.masse(ijq,l,iq)) 446 u_mq(ij,l)=u_mq(ij,l)+q(ijq,l,iq) 447 & *masse(ijq,l,iq) 448 zu_m=zu_m-masse(ijq,l,iq) 421 449 i=mod(i-2+iim,iim)+1 422 450 ijq=(j-1)*iip1+i … … 424 452 c ajout de la maille non completement advectee 425 453 u_mq(ij,l)=u_mq(ij,l)+zu_m* 426 & (q(ijq,l)+0.5*(1.-zu_m/masse(ijq,l))*dxq(ijq,l)) 454 & (q(ijq,l,iq)+0.5*(1.-zu_m/masse(ijq,l,iq)) 455 & *dxq(ijq,l)) 427 456 ELSE 428 457 ijq=ij+1 429 458 i=ijq-(j-1)*iip1 430 459 c accumulation pour les mailles completements advectees 431 do while(-zu_m.gt.masse(ijq,l)) 432 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l)*masse(ijq,l) 433 zu_m=zu_m+masse(ijq,l) 460 do while(-zu_m.gt.masse(ijq,l,iq)) 461 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l,iq) 462 & *masse(ijq,l,iq) 463 zu_m=zu_m+masse(ijq,l,iq) 434 464 i=mod(i,iim)+1 435 465 ijq=(j-1)*iip1+i 436 466 ENDDO 437 467 c ajout de la maille non completement advectee 438 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l )-439 & 0.5*(1.+zu_m/masse(ijq,l ))*dxq(ijq,l))468 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l,iq)- 469 & 0.5*(1.+zu_m/masse(ijq,l,iq))*dxq(ijq,l)) 440 470 ENDIF 441 471 ENDDO … … 454 484 ENDDO 455 485 486 ! CRisi: appel récursif de l'advection sur les fils. 487 ! Il faut faire ça avant d'avoir mis à jour q et masse 488 !write(*,*) 'vlspltqs 326: iq,nqfils(iq)=',iq,nqfils(iq) 489 490 if (nqfils(iq).gt.0) then 491 do ifils=1,nqdesc(iq) 492 iq2=iqfils(ifils,iq) 493 DO l=1,llm 494 DO ij=iip2,ip1jm 495 ! On a besoin de q et masse seulement entre iip2 et ip1jm 496 masseq(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 497 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 498 enddo 499 enddo 500 enddo !do ifils=1,nqdesc(iq) 501 do ifils=1,nqfils(iq) 502 iq2=iqfils(ifils,iq) 503 call vlx(Ratio,pente_max,masseq,u_mq,iq2) 504 enddo !do ifils=1,nqfils(iq) 505 endif !if (nqfils(iq).gt.0) then 506 ! end CRisi 456 507 457 508 c calcul des tendances … … 459 510 DO l=1,llm 460 511 DO ij=iip2+1,ip1jm 461 new_m=masse(ij,l )+u_m(ij-1,l)-u_m(ij,l)462 q(ij,l )=(q(ij,l)*masse(ij,l)+512 new_m=masse(ij,l,iq)+u_m(ij-1,l)-u_m(ij,l) 513 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+ 463 514 & u_mq(ij-1,l)-u_mq(ij,l)) 464 515 & /new_m 465 masse(ij,l )=new_m516 masse(ij,l,iq)=new_m 466 517 ENDDO 467 518 c Modif Fred 22 03 96 correction d'un bug (les scopy ci-dessous) 468 519 DO ij=iip1+iip1,ip1jm,iip1 469 q(ij-iim,l)=q(ij,l) 470 masse(ij-iim,l)=masse(ij,l) 471 ENDDO 472 ENDDO 520 q(ij-iim,l,iq)=q(ij,l,iq) 521 masse(ij-iim,l,iq)=masse(ij,l,iq) 522 ENDDO 523 ENDDO 524 525 ! retablir les fils en rapport de melange par rapport a l'air: 526 ! On calcule q entre iip2+1,ip1jm -> on fait pareil pour ratio 527 ! puis on boucle en longitude 528 if (nqdesc(iq).gt.0) then 529 do ifils=1,nqdesc(iq) 530 iq2=iqfils(ifils,iq) 531 DO l=1,llm 532 DO ij=iip2+1,ip1jm 533 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 534 enddo 535 DO ij=iip1+iip1,ip1jm,iip1 536 q(ij-iim,l,iq2)=q(ij,l,iq2) 537 enddo ! DO ij=ijb+iip1-1,ije,iip1 538 enddo !DO l=1,llm 539 enddo !do ifils=1,nqdesc(iq) 540 endif !if (nqfils(iq).gt.0) then 473 541 474 542 c CALL SCOPY((jjm-1)*llm,q(iip1+iip1,1),iip1,q(iip2,1),iip1) … … 478 546 RETURN 479 547 END 480 SUBROUTINE vlyqs(q,pente_max,masse,masse_adv_v,qsat) 548 SUBROUTINE vlyqs(q,pente_max,masse,masse_adv_v,qsat,iq) 549 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 481 550 c 482 551 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 502 571 c Arguments: 503 572 c ---------- 504 REAL masse(ip1jmp1,llm ),pente_max573 REAL masse(ip1jmp1,llm,nqtot),pente_max 505 574 REAL masse_adv_v( ip1jm,llm) 506 REAL q(ip1jmp1,llm )575 REAL q(ip1jmp1,llm,nqtot) 507 576 REAL qsat(ip1jmp1,llm) 577 INTEGER iq ! CRisi 508 578 c 509 579 c Local … … 529 599 SAVE sinlon,coslon,sinlondlon,coslondlon 530 600 SAVE airej2,airejjm 601 602 REAL masseq(ip1jmp1,llm,nqtot),Ratio(ip1jmp1,llm,nqtot) ! CRisi 603 INTEGER ifils,iq2 ! CRisi 531 604 c 532 605 c … … 567 640 568 641 DO i = 1, iim 569 airescb(i) = aire(i+ iip1) * q(i+ iip1,l )570 airesch(i) = aire(i+ ip1jm- iip1) * q(i+ ip1jm- iip1,l )642 airescb(i) = aire(i+ iip1) * q(i+ iip1,l,iq) 643 airesch(i) = aire(i+ ip1jm- iip1) * q(i+ ip1jm- iip1,l,iq) 571 644 ENDDO 572 645 qpns = SSUM( iim, airescb ,1 ) / airej2 … … 576 649 577 650 DO ij=1,ip1jm 578 dyqv(ij)=q(ij,l )-q(ij+iip1,l)651 dyqv(ij)=q(ij,l,iq)-q(ij+iip1,l,iq) 579 652 adyqv(ij)=abs(dyqv(ij)) 580 653 ENDDO … … 591 664 592 665 DO ij=1,iip1 593 dyq(ij,l)=qpns-q(ij+iip1,l )594 dyq(ip1jm+ij,l)=q(ip1jm+ij-iip1,l )-qpsn666 dyq(ij,l)=qpns-q(ij+iip1,l,iq) 667 dyq(ip1jm+ij,l)=q(ip1jm+ij-iip1,l,iq)-qpsn 595 668 ENDDO 596 669 … … 710 783 DO ij=1,ip1jm 711 784 IF( masse_adv_v(ij,l).GT.0. ) THEN 712 qbyv(ij,l)= MIN( qsat(ij+iip1,l), q(ij+iip1,l ) + 713 , dyq(ij+iip1,l)*0.5*(1.-masse_adv_v(ij,l)/masse(ij+iip1,l))) 785 qbyv(ij,l)= MIN( qsat(ij+iip1,l), q(ij+iip1,l,iq ) + 786 , dyq(ij+iip1,l)*0.5*(1.-masse_adv_v(ij,l) 787 , /masse(ij+iip1,l,iq))) 714 788 ELSE 715 qbyv(ij,l)= MIN( qsat(ij,l), q(ij,l ) - dyq(ij,l) *716 , 0.5*(1.+masse_adv_v(ij,l)/masse(ij,l )) )789 qbyv(ij,l)= MIN( qsat(ij,l), q(ij,l,iq) - dyq(ij,l) * 790 , 0.5*(1.+masse_adv_v(ij,l)/masse(ij,l,iq)) ) 717 791 ENDIF 718 792 qbyv(ij,l) = masse_adv_v(ij,l)*qbyv(ij,l) … … 721 795 722 796 797 ! CRisi: appel récursif de l'advection sur les fils. 798 ! Il faut faire ça avant d'avoir mis à jour q et masse 799 !write(*,*) 'vlyqs 689: iq,nqfils(iq)=',iq,nqfils(iq) 800 801 if (nqfils(iq).gt.0) then 802 do ifils=1,nqdesc(iq) 803 iq2=iqfils(ifils,iq) 804 DO l=1,llm 805 DO ij=1,ip1jmp1 806 masseq(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 807 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 808 enddo 809 enddo 810 enddo !do ifils=1,nqdesc(iq) 811 812 do ifils=1,nqfils(iq) 813 iq2=iqfils(ifils,iq) 814 !write(*,*) 'vlyqs 783: appel rec de vly, iq2=',iq2 815 call vly(Ratio,pente_max,masseq,qbyv,iq2) 816 enddo !do ifils=1,nqfils(iq) 817 endif !if (nqfils(iq).gt.0) then 818 723 819 DO l=1,llm 724 820 DO ij=iip2,ip1jm 725 newmasse=masse(ij,l )821 newmasse=masse(ij,l,iq) 726 822 & +masse_adv_v(ij,l)-masse_adv_v(ij-iip1,l) 727 q(ij,l )=(q(ij,l)*masse(ij,l)+qbyv(ij,l)-qbyv(ij-iip1,l))728 & /newmasse729 masse(ij,l )=newmasse823 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+qbyv(ij,l) 824 & -qbyv(ij-iip1,l))/newmasse 825 masse(ij,l,iq)=newmasse 730 826 ENDDO 731 827 c.-. ancienne version … … 733 829 convmpn=ssum(iim,masse_adv_v(1,l),1)/apoln 734 830 DO ij = 1,iip1 735 newmasse=masse(ij,l )+convmpn*aire(ij)736 q(ij,l )=(q(ij,l)*masse(ij,l)+convpn*aire(ij))/831 newmasse=masse(ij,l,iq)+convmpn*aire(ij) 832 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+convpn*aire(ij))/ 737 833 & newmasse 738 masse(ij,l )=newmasse834 masse(ij,l,iq)=newmasse 739 835 ENDDO 740 836 convps = -SSUM(iim,qbyv(ip1jm-iim,l),1)/apols 741 837 convmps = -SSUM(iim,masse_adv_v(ip1jm-iim,l),1)/apols 742 838 DO ij = ip1jm+1,ip1jmp1 743 newmasse=masse(ij,l )+convmps*aire(ij)744 q(ij,l )=(q(ij,l)*masse(ij,l)+convps*aire(ij))/839 newmasse=masse(ij,l,iq)+convmps*aire(ij) 840 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+convps*aire(ij))/ 745 841 & newmasse 746 masse(ij,l )=newmasse842 masse(ij,l,iq)=newmasse 747 843 ENDDO 748 844 c.-. fin ancienne version … … 757 853 c DO ij = 1,iip1 758 854 c q(ij,l)=newq 759 c masse(ij,l )=newmasse*aire(ij)855 c masse(ij,l,iq)=newmasse*aire(ij) 760 856 c ENDDO 761 857 c convps=-SSUM(iim,qbyv(ip1jm-iim,l),1) … … 767 863 c DO ij = ip1jm+1,ip1jmp1 768 864 c q(ij,l)=newq 769 c masse(ij,l )=newmasse*aire(ij)865 c masse(ij,l,iq)=newmasse*aire(ij) 770 866 c ENDDO 771 867 c._. fin nouvelle version 772 868 ENDDO 773 869 870 !write(*,*) 'vly 866' 871 872 ! retablir les fils en rapport de melange par rapport a l'air: 873 if (nqdesc(iq).gt.0) then 874 do ifils=1,nqdesc(iq) 875 iq2=iqfils(ifils,iq) 876 DO l=1,llm 877 DO ij=1,ip1jmp1 878 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 879 enddo 880 enddo 881 enddo !do ifils=1,nqdesc(iq) 882 endif !if (nqfils(iq).gt.0) then 883 !write(*,*) 'vly 879' 884 774 885 RETURN 775 886 END -
LMDZ5/branches/testing/libf/dyn3d_common/diagedyn.F
r1999 r2298 53 53 c====================================================================== 54 54 55 USE control_mod, ONLY : planet_type 56 55 57 IMPLICIT NONE 56 58 C … … 60 62 #include "iniprint.h" 61 63 62 #ifdef CPP_EARTH 63 #include "../phylmd/YOMCST.h" 64 #include "../phylmd/YOETHF.h" 65 #endif 64 !#ifdef CPP_EARTH 65 !#include "../phylmd/YOMCST.h" 66 !#include "../phylmd/YOETHF.h" 67 !#endif 68 ! Ehouarn: for now set these parameters to what is in Earth physics... 69 ! (cf ../phylmd/suphel.h) 70 ! this should be generalized... 71 REAL,PARAMETER :: RCPD= 72 & 3.5*(1000.*(6.0221367E+23*1.380658E-23)/28.9644) 73 REAL,PARAMETER :: RCPV= 74 & 4.*(1000.*(6.0221367E+23*1.380658E-23)/18.0153) 75 REAL,PARAMETER :: RCS=RCPV 76 REAL,PARAMETER :: RCW=RCPV 77 REAL,PARAMETER :: RLSTT=2.8345E+6 78 REAL,PARAMETER :: RLVTT=2.5008E+6 79 ! 66 80 C 67 81 INTEGER imjmp1 … … 140 154 141 155 142 #ifdef CPP_EARTH 156 !#ifdef CPP_EARTH 157 IF (planet_type=="earth") THEN 158 143 159 c====================================================================== 144 160 C Compute Kinetic enrgy … … 314 330 ec_pre (idiag) = ec_tot 315 331 C 316 #else 317 write(lunout,*)'diagedyn: Needs Earth physics to function' 318 #endif 332 !#else 333 ELSE 334 write(lunout,*)'diagedyn: set to function with Earth parameters' 335 ENDIF ! of if (planet_type=="earth") 336 !#endif 319 337 ! #endif of #ifdef CPP_EARTH 320 338 RETURN -
LMDZ5/branches/testing/libf/dyn3d_common/infotrac.F90
r2187 r2298 12 12 INTEGER, SAVE :: nbtr 13 13 14 ! CRisi: nb traceurs pères= directement advectés par l'air 15 INTEGER, SAVE :: nqperes 16 14 17 ! Name variables 15 18 CHARACTER(len=20), ALLOCATABLE, DIMENSION(:), SAVE :: tname ! tracer short name for restart and diagnostics … … 22 25 ! dynamic part of the code and the tracers (nbtr+2) used in the physics part of the code. 23 26 INTEGER, ALLOCATABLE, DIMENSION(:), SAVE :: niadv ! equivalent dyn / physique 27 28 ! CRisi: tableaux de fils 29 INTEGER, ALLOCATABLE, DIMENSION(:), SAVE :: nqfils 30 INTEGER, ALLOCATABLE, DIMENSION(:), SAVE :: nqdesc ! nombres de fils + nombre de tous les petits fils sur toutes les générations 31 INTEGER, SAVE :: nqdesc_tot 32 INTEGER, ALLOCATABLE, DIMENSION(:,:), SAVE :: iqfils 33 INTEGER, ALLOCATABLE, DIMENSION(:), SAVE :: iqpere 24 34 25 35 ! conv_flg(it)=0 : convection desactivated for tracer number it … … 30 40 CHARACTER(len=4),SAVE :: type_trac 31 41 CHARACTER(len=8),DIMENSION(:),ALLOCATABLE, SAVE :: solsym 42 43 ! CRisi: cas particulier des isotopes 44 LOGICAL,SAVE :: ok_isotopes,ok_iso_verif,ok_isotrac,ok_init_iso 45 INTEGER :: niso_possibles 46 PARAMETER ( niso_possibles=5) 47 real, DIMENSION (niso_possibles),SAVE :: tnat,alpha_ideal 48 LOGICAL, DIMENSION(niso_possibles),SAVE :: use_iso 49 INTEGER, ALLOCATABLE, DIMENSION(:,:), SAVE :: iqiso ! donne indice iq en fn de (ixt,phase) 50 INTEGER, ALLOCATABLE, DIMENSION(:), SAVE :: iso_num ! donne numéro iso entre 1 et niso_possibles en fn de nqtot 51 INTEGER, ALLOCATABLE, DIMENSION(:), SAVE :: iso_indnum ! donne numéro iso entre 1 et niso effectif en fn de nqtot 52 INTEGER, ALLOCATABLE, DIMENSION(:), SAVE :: zone_num ! donne numéro de la zone de tracage en fn de nqtot 53 INTEGER, ALLOCATABLE, DIMENSION(:), SAVE :: phase_num ! donne numéro de la zone de tracage en fn de nqtot 54 INTEGER, DIMENSION(niso_possibles), SAVE :: indnum_fn_num ! donne indice entre entre 1 et niso en fonction du numéro d isotope entre 1 et niso_possibles 55 INTEGER, ALLOCATABLE, DIMENSION(:,:), SAVE :: index_trac ! numéro ixt en fn izone, indnum entre 1 et niso 56 INTEGER,SAVE :: niso,ntraceurs_zone,ntraciso 32 57 33 58 CONTAINS … … 63 88 64 89 CHARACTER(len=15), ALLOCATABLE, DIMENSION(:) :: tnom_0 ! tracer short name 90 CHARACTER(len=15), ALLOCATABLE, DIMENSION(:) :: tnom_transp ! transporting fluid short name: CRisi 65 91 CHARACTER(len=3), DIMENSION(30) :: descrq 66 92 CHARACTER(len=1), DIMENSION(3) :: txts … … 70 96 INTEGER :: nqtrue ! number of tracers read from tracer.def, without higer order of moment 71 97 INTEGER :: iq, new_iq, iiq, jq, ierr 98 INTEGER :: ifils,ipere,generation ! CRisi 99 LOGICAL :: continu,nouveau_traceurdef 100 INTEGER :: IOstatus ! gestion de la retrocompatibilite de traceur.def 101 CHARACTER(len=15) :: tchaine 72 102 73 103 character(len=*),parameter :: modname="infotrac_init" … … 134 164 WRITE(lunout,*) trim(modname),': Open traceur.def : ok' 135 165 READ(90,*) nqtrue 166 write(lunout,*) 'nqtrue=',nqtrue 136 167 ELSE 137 168 WRITE(lunout,*) trim(modname),': Problem in opening traceur.def' … … 143 174 endif 144 175 END IF 145 if ( planet_type=='earth') then 146 ! For Earth, water vapour & liquid tracers are not in the physics 147 nbtr=nqtrue-2 148 else 149 ! Other planets (for now); we have the same number of tracers 150 ! in the dynamics than in the physics 151 nbtr=nqtrue 152 endif 176 !jyg< 177 !! if ( planet_type=='earth') then 178 !! ! For Earth, water vapour & liquid tracers are not in the physics 179 !! nbtr=nqtrue-2 180 !! else 181 !! ! Other planets (for now); we have the same number of tracers 182 !! ! in the dynamics than in the physics 183 !! nbtr=nqtrue 184 !! endif 185 !>jyg 153 186 ELSE ! type_trac=inca 187 !jyg< 188 ! The traceur.def file is used to define the number "nqo" of water phases 189 ! present in the simulation. Default : nqo = 2. 190 OPEN(90,file='traceur.def',form='formatted',status='old', iostat=ierr) 191 IF(ierr.EQ.0) THEN 192 WRITE(lunout,*) trim(modname),': Open traceur.def : ok' 193 READ(90,*) nqo 194 ELSE 195 WRITE(lunout,*) trim(modname),': Using default value for nqo' 196 nqo=2 197 ENDIF 198 IF (nqo /= 2 .OR. nqo /= 3 ) THEN 199 WRITE(lunout,*) trim(modname),': nqo=',nqo, ' is not allowded. Only 2 or 3 water phases allowed' 200 CALL abort_gcm('infotrac_init','Bad number of water phases',1) 201 END IF 154 202 ! nbtr has been read from INCA by init_const_lmdz() in gcm.F 155 nqtrue=nbtr+2 156 END IF 203 nqtrue=nbtr+nqo 204 !! nqtrue=nbtr+2 205 END IF ! type_trac 206 !>jyg 157 207 158 208 IF ((planet_type=="earth").and.(nqtrue < 2)) THEN … … 161 211 END IF 162 212 213 !jyg< 163 214 ! Transfert number of tracers to Reprobus 164 IF (type_trac == 'repr') THEN 165 #ifdef REPROBUS 166 CALL Init_chem_rep_trac(nbtr) 167 #endif 168 END IF 215 !! IF (type_trac == 'repr') THEN 216 !!#ifdef REPROBUS 217 !! CALL Init_chem_rep_trac(nbtr) 218 !!#endif 219 !! END IF 220 !>jyg 169 221 170 222 ! 171 ! Allocate variables depending on nqtrue and nbtr 172 ! 173 ALLOCATE(tnom_0(nqtrue), hadv(nqtrue), vadv(nqtrue)) 174 ALLOCATE(conv_flg(nbtr), pbl_flg(nbtr), solsym(nbtr)) 175 conv_flg(:) = 1 ! convection activated for all tracers 176 pbl_flg(:) = 1 ! boundary layer activated for all tracers 223 ! Allocate variables depending on nqtrue 224 ! 225 ALLOCATE(tnom_0(nqtrue), hadv(nqtrue), vadv(nqtrue),tnom_transp(nqtrue)) 226 ! 227 !jyg< 228 !! ALLOCATE(conv_flg(nbtr), pbl_flg(nbtr), solsym(nbtr)) 229 !! conv_flg(:) = 1 ! convection activated for all tracers 230 !! pbl_flg(:) = 1 ! boundary layer activated for all tracers 231 !>jyg 177 232 178 233 !----------------------------------------------------------------------- … … 206 261 ! Continue to read tracer.def 207 262 DO iq=1,nqtrue 208 READ(90,*) hadv(iq),vadv(iq),tnom_0(iq) 209 END DO 263 264 write(*,*) 'infotrac 237: iq=',iq 265 ! CRisi: ajout du nom du fluide transporteur 266 ! mais rester retro compatible 267 READ(90,'(I2,X,I2,X,A)',IOSTAT=IOstatus) hadv(iq),vadv(iq),tchaine 268 write(lunout,*) 'iq,hadv(iq),vadv(iq)=',iq,hadv(iq),vadv(iq) 269 write(lunout,*) 'tchaine=',trim(tchaine) 270 write(*,*) 'infotrac 238: IOstatus=',IOstatus 271 if (IOstatus.ne.0) then 272 CALL abort_gcm('infotrac_init','Pb dans la lecture de traceur.def',1) 273 endif 274 ! Y-a-t-il 1 ou 2 noms de traceurs? -> On regarde s'il y a un 275 ! espace ou pas au milieu de la chaine. 276 continu=1 277 nouveau_traceurdef=0 278 iiq=1 279 do while (continu) 280 if (tchaine(iiq:iiq).eq.' ') then 281 nouveau_traceurdef=1 282 continu=0 283 else if (iiq.lt.LEN_TRIM(tchaine)) then 284 iiq=iiq+1 285 else 286 continu=0 287 endif 288 enddo 289 write(*,*) 'iiq,nouveau_traceurdef=',iiq,nouveau_traceurdef 290 if (nouveau_traceurdef) then 291 write(lunout,*) 'C''est la nouvelle version de traceur.def' 292 tnom_0(iq)=tchaine(1:iiq-1) 293 tnom_transp(iq)=tchaine(iiq+1:15) 294 else 295 write(lunout,*) 'C''est l''ancienne version de traceur.def' 296 write(lunout,*) 'On suppose que les traceurs sont tous d''air' 297 tnom_0(iq)=tchaine 298 tnom_transp(iq) = 'air' 299 endif 300 write(lunout,*) 'tnom_0(iq)=<',trim(tnom_0(iq)),'>' 301 write(lunout,*) 'tnom_transp(iq)=<',trim(tnom_transp(iq)),'>' 302 303 END DO !DO iq=1,nqtrue 210 304 CLOSE(90) 305 211 306 ELSE ! Without tracer.def, set default values 212 307 if (planet_type=="earth") then … … 215 310 vadv(1) = 14 216 311 tnom_0(1) = 'H2Ov' 312 tnom_transp(1) = 'air' 217 313 hadv(2) = 10 218 314 vadv(2) = 10 219 315 tnom_0(2) = 'H2Ol' 316 tnom_transp(2) = 'air' 220 317 hadv(3) = 10 221 318 vadv(3) = 10 222 319 tnom_0(3) = 'RN' 320 tnom_transp(3) = 'air' 223 321 hadv(4) = 10 224 322 vadv(4) = 10 225 323 tnom_0(4) = 'PB' 324 tnom_transp(4) = 'air' 226 325 else ! default for other planets 227 326 hadv(1) = 10 228 327 vadv(1) = 10 229 328 tnom_0(1) = 'dummy' 329 tnom_transp(1) = 'dummy' 230 330 endif ! of if (planet_type=="earth") 231 331 END IF 232 233 !CR: nombre de traceurs de l eau234 if (tnom_0(3) == 'H2Oi') then235 nqo=3236 else237 nqo=2238 endif239 332 240 333 WRITE(lunout,*) trim(modname),': Valeur de traceur.def :' 241 334 WRITE(lunout,*) trim(modname),': nombre de traceurs ',nqtrue 242 335 DO iq=1,nqtrue 243 WRITE(lunout,*) hadv(iq),vadv(iq),tnom_0(iq) 336 WRITE(lunout,*) hadv(iq),vadv(iq),tnom_0(iq),tnom_transp(iq) 244 337 END DO 245 338 246 ELSE ! type_trac=inca : config_inca='aero' ou 'chem' 339 if ( planet_type=='earth') then 340 !CR: nombre de traceurs de l eau 341 if (tnom_0(3) == 'H2Oi') then 342 nqo=3 343 else 344 nqo=2 345 endif 346 ! For Earth, water vapour & liquid tracers are not in the physics 347 nbtr=nqtrue-nqo 348 else 349 ! Other planets (for now); we have the same number of tracers 350 ! in the dynamics than in the physics 351 nbtr=nqtrue 352 endif 353 354 ENDIF ! (type_trac == 'lmdz' .OR. type_trac == 'repr') 355 !jyg< 356 ! 357 ! Transfert number of tracers to Reprobus 358 IF (type_trac == 'repr') THEN 359 #ifdef REPROBUS 360 CALL Init_chem_rep_trac(nbtr) 361 #endif 362 END IF 363 ! 364 ! Allocate variables depending on nbtr 365 ! 366 ALLOCATE(conv_flg(nbtr), pbl_flg(nbtr), solsym(nbtr)) 367 conv_flg(:) = 1 ! convection activated for all tracers 368 pbl_flg(:) = 1 ! boundary layer activated for all tracers 369 ! 370 !! ELSE ! type_trac=inca : config_inca='aero' ou 'chem' 371 ! 372 IF (type_trac == 'inca') THEN ! config_inca='aero' ou 'chem' 373 !>jyg 247 374 ! le module de chimie fournit les noms des traceurs 248 375 ! et les schemas d'advection associes. … … 258 385 tnom_0(1)='H2Ov' 259 386 tnom_0(2)='H2Ol' 260 261 DO iq =3,nqtrue 262 tnom_0(iq)=solsym(iq-2) 387 IF (nqo == 3) tnom_0(3)='H2Oi' !! jyg 388 389 !jyg< 390 DO iq = nqo+1, nqtrue 391 tnom_0(iq)=solsym(iq-nqo) 263 392 END DO 264 nqo = 2 265 266 END IF ! type_trac 393 !! DO iq =3,nqtrue 394 !! tnom_0(iq)=solsym(iq-2) 395 !! END DO 396 !! nqo = 2 397 !>jyg 398 399 END IF ! (type_trac == 'inca') 267 400 268 401 !----------------------------------------------------------------------- … … 390 523 END DO 391 524 525 526 ! CRisi: quels sont les traceurs fils et les traceurs pères. 527 ! initialiser tous les tableaux d'indices liés aux traceurs familiaux 528 ! + vérifier que tous les pères sont écrits en premières positions 529 ALLOCATE(nqfils(nqtot),nqdesc(nqtot)) 530 ALLOCATE(iqfils(nqtot,nqtot)) 531 ALLOCATE(iqpere(nqtot)) 532 nqperes=0 533 nqfils(:)=0 534 nqdesc(:)=0 535 iqfils(:,:)=0 536 iqpere(:)=0 537 nqdesc_tot=0 538 DO iq=1,nqtot 539 if (tnom_transp(iq) == 'air') then 540 ! ceci est un traceur père 541 WRITE(lunout,*) 'Le traceur',iq,', appele ',trim(tnom_0(iq)),', est un pere' 542 nqperes=nqperes+1 543 iqpere(iq)=0 544 else !if (tnom_transp(iq) == 'air') then 545 ! ceci est un fils. Qui est son père? 546 WRITE(lunout,*) 'Le traceur',iq,', appele ',trim(tnom_0(iq)),', est un fils' 547 continu=.true. 548 ipere=1 549 do while (continu) 550 if (tnom_transp(iq) == tnom_0(ipere)) then 551 ! Son père est ipere 552 WRITE(lunout,*) 'Le traceur',iq,'appele ', & 553 & trim(tnom_0(iq)),' est le fils de ',ipere,'appele ',trim(tnom_0(ipere)) 554 nqfils(ipere)=nqfils(ipere)+1 555 iqfils(nqfils(ipere),ipere)=iq 556 iqpere(iq)=ipere 557 continu=.false. 558 else !if (tnom_transp(iq) == tnom_0(ipere)) then 559 ipere=ipere+1 560 if (ipere.gt.nqtot) then 561 WRITE(lunout,*) 'Le traceur',iq,'appele ', & 562 & trim(tnom_0(iq)),', est orpelin.' 563 CALL abort_gcm('infotrac_init','Un traceur est orphelin',1) 564 endif !if (ipere.gt.nqtot) then 565 endif !if (tnom_transp(iq) == tnom_0(ipere)) then 566 enddo !do while (continu) 567 endif !if (tnom_transp(iq) == 'air') then 568 enddo !DO iq=1,nqtot 569 WRITE(lunout,*) 'infotrac: nqperes=',nqperes 570 WRITE(lunout,*) 'nqfils=',nqfils 571 WRITE(lunout,*) 'iqpere=',iqpere 572 WRITE(lunout,*) 'iqfils=',iqfils 573 574 ! Calculer le nombre de descendants à partir de iqfils et de nbfils 575 DO iq=1,nqtot 576 generation=0 577 continu=.true. 578 ifils=iq 579 do while (continu) 580 ipere=iqpere(ifils) 581 if (ipere.gt.0) then 582 nqdesc(ipere)=nqdesc(ipere)+1 583 nqdesc_tot=nqdesc_tot+1 584 iqfils(nqdesc(ipere),ipere)=iq 585 ifils=ipere 586 generation=generation+1 587 else !if (ipere.gt.0) then 588 continu=.false. 589 endif !if (ipere.gt.0) then 590 enddo !do while (continu) 591 WRITE(lunout,*) 'Le traceur ',iq,', appele ',trim(tnom_0(iq)),' est un traceur de generation: ',generation 592 enddo !DO iq=1,nqtot 593 WRITE(lunout,*) 'infotrac: nqdesc=',nqdesc 594 WRITE(lunout,*) 'iqfils=',iqfils 595 WRITE(lunout,*) 'nqdesc_tot=',nqdesc_tot 596 597 ! Interdire autres schémas que 10 pour les traceurs fils, et autres schémas 598 ! que 10 et 14 si des pères ont des fils 599 do iq=1,nqtot 600 if (iqpere(iq).gt.0) then 601 ! ce traceur a un père qui n'est pas l'air 602 ! Seul le schéma 10 est autorisé 603 if (iadv(iq)/=10) then 604 WRITE(lunout,*)trim(modname),' STOP : The option iadv=',iadv(iq),' is not implemented for sons' 605 CALL abort_gcm('infotrac_init','Sons should be advected by scheme 10',1) 606 endif 607 ! Le traceur père ne peut être advecté que par schéma 10 ou 14: 608 IF (iadv(iqpere(iq))/=10 .AND. iadv(iqpere(iq))/=14) THEN 609 WRITE(lunout,*)trim(modname),' STOP : The option iadv=',iadv(iq),' is not implemented for fathers' 610 CALL abort_gcm('infotrac_init','Fathers should be advected by scheme 10 ou 14',1) 611 endif !IF (iadv(iqpere(iq))/=10 .AND. iadv(iqpere(iq))/=14) THEN 612 endif !if (iqpere(iq).gt.0) the 613 enddo !do iq=1,nqtot 614 615 616 ! detecter quels sont les traceurs isotopiques parmi des traceurs 617 call infotrac_isoinit(tnom_0,nqtrue) 618 392 619 !----------------------------------------------------------------------- 393 620 ! Finalize : 394 621 ! 395 DEALLOCATE(tnom_0, hadv, vadv )622 DEALLOCATE(tnom_0, hadv, vadv,tnom_transp) 396 623 397 624 398 625 END SUBROUTINE infotrac_init 399 626 627 SUBROUTINE infotrac_isoinit(tnom_0,nqtrue) 628 629 #ifdef CPP_IOIPSL 630 use IOIPSL 631 #else 632 ! if not using IOIPSL, we still need to use (a local version of) getin 633 use ioipsl_getincom 634 #endif 635 implicit none 636 637 ! inputs 638 INTEGER nqtrue 639 CHARACTER(len=15) tnom_0(nqtrue) 640 641 ! locals 642 CHARACTER(len=3), DIMENSION(niso_possibles) :: tnom_iso 643 INTEGER, ALLOCATABLE,DIMENSION(:,:) :: nb_iso,nb_traciso 644 INTEGER, ALLOCATABLE,DIMENSION(:) :: nb_isoind 645 INTEGER :: ntraceurs_zone_prec,iq,phase,ixt,iiso,izone 646 CHARACTER(len=19) :: tnom_trac 647 INCLUDE "iniprint.h" 648 649 tnom_iso=(/'eau','HDO','O18','O17','HTO'/) 650 651 ALLOCATE(nb_iso(niso_possibles,nqo)) 652 ALLOCATE(nb_isoind(nqo)) 653 ALLOCATE(nb_traciso(niso_possibles,nqo)) 654 ALLOCATE(iso_num(nqtot)) 655 ALLOCATE(iso_indnum(nqtot)) 656 ALLOCATE(zone_num(nqtot)) 657 ALLOCATE(phase_num(nqtot)) 658 659 iso_num(:)=0 660 iso_indnum(:)=0 661 zone_num(:)=0 662 phase_num(:)=0 663 indnum_fn_num(:)=0 664 use_iso(:)=.false. 665 nb_iso(:,:)=0 666 nb_isoind(:)=0 667 nb_traciso(:,:)=0 668 niso=0 669 ntraceurs_zone=0 670 ntraceurs_zone_prec=0 671 ntraciso=0 672 673 do iq=nqo+1,nqtot 674 write(lunout,*) 'infotrac 569: iq,tnom_0(iq)=',iq,tnom_0(iq) 675 do phase=1,nqo 676 do ixt= 1,niso_possibles 677 tnom_trac=trim(tnom_0(phase))//'_' 678 tnom_trac=trim(tnom_trac)//trim(tnom_iso(ixt)) 679 write(*,*) 'phase,ixt,tnom_trac=',phase,ixt,tnom_trac 680 IF (tnom_0(iq) == tnom_trac) then 681 write(lunout,*) 'Ce traceur est un isotope' 682 nb_iso(ixt,phase)=nb_iso(ixt,phase)+1 683 nb_isoind(phase)=nb_isoind(phase)+1 684 iso_num(iq)=ixt 685 iso_indnum(iq)=nb_isoind(phase) 686 indnum_fn_num(ixt)=iso_indnum(iq) 687 phase_num(iq)=phase 688 write(lunout,*) 'iso_num(iq)=',iso_num(iq) 689 write(lunout,*) 'iso_indnum(iq)=',iso_indnum(iq) 690 write(lunout,*) 'indnum_fn_num(ixt)=',indnum_fn_num(ixt) 691 write(lunout,*) 'phase_num(iq)=',phase_num(iq) 692 goto 20 693 else if (iqpere(iq).gt.0) then 694 if (tnom_0(iqpere(iq)) == tnom_trac) then 695 write(lunout,*) 'Ce traceur est le fils d''un isotope' 696 ! c'est un traceur d'isotope 697 nb_traciso(ixt,phase)=nb_traciso(ixt,phase)+1 698 iso_num(iq)=ixt 699 iso_indnum(iq)=indnum_fn_num(ixt) 700 zone_num(iq)=nb_traciso(ixt,phase) 701 phase_num(iq)=phase 702 write(lunout,*) 'iso_num(iq)=',iso_num(iq) 703 write(lunout,*) 'phase_num(iq)=',phase_num(iq) 704 write(lunout,*) 'zone_num(iq)=',zone_num(iq) 705 goto 20 706 endif !if (tnom_0(iqpere(iq)) == trim(tnom_0(phase))//trim(tnom_iso(ixt))) then 707 endif !IF (tnom_0(iq) == trim(tnom_0(phase))//trim(tnom_iso(ixt))) then 708 enddo !do ixt= niso_possibles 709 enddo !do phase=1,nqo 710 20 continue 711 enddo !do iq=1,nqtot 712 713 write(lunout,*) 'iso_num=',iso_num 714 write(lunout,*) 'iso_indnum=',iso_indnum 715 write(lunout,*) 'zone_num=',zone_num 716 write(lunout,*) 'phase_num=',phase_num 717 write(lunout,*) 'indnum_fn_num=',indnum_fn_num 718 719 do ixt= 1,niso_possibles 720 721 if (nb_iso(ixt,1).eq.1) then 722 ! on vérifie que toutes les phases ont le même nombre de 723 ! traceurs 724 do phase=2,nqo 725 if (nb_iso(ixt,phase).ne.nb_iso(ixt,1)) then 726 write(lunout,*) 'ixt,phase,nb_iso=',ixt,phase,nb_iso(ixt,phase) 727 CALL abort_gcm('infotrac_init','Phases must have same number of isotopes',1) 728 endif 729 enddo !do phase=2,nqo 730 731 niso=niso+1 732 use_iso(ixt)=.true. 733 ntraceurs_zone=nb_traciso(ixt,1) 734 735 ! on vérifie que toutes les phases ont le même nombre de 736 ! traceurs 737 do phase=2,nqo 738 if (nb_traciso(ixt,phase).ne.ntraceurs_zone) then 739 write(lunout,*) 'ixt,phase,nb_traciso=',ixt,phase,nb_traciso(ixt,phase) 740 write(lunout,*) 'ntraceurs_zone=',ntraceurs_zone 741 CALL abort_gcm('infotrac_init','Phases must have same number of tracers',1) 742 endif 743 enddo !do phase=2,nqo 744 ! on vérifie que tous les isotopes ont le même nombre de 745 ! traceurs 746 if (ntraceurs_zone_prec.gt.0) then 747 if (ntraceurs_zone.eq.ntraceurs_zone_prec) then 748 ntraceurs_zone_prec=ntraceurs_zone 749 else !if (ntraceurs_zone.eq.ntraceurs_zone_prec) then 750 write(*,*) 'ntraceurs_zone_prec,ntraceurs_zone=',ntraceurs_zone_prec,ntraceurs_zone 751 CALL abort_gcm('infotrac_init', & 752 &'Isotope tracers are not well defined in traceur.def',1) 753 endif !if (ntraceurs_zone.eq.ntraceurs_zone_prec) then 754 endif !if (ntraceurs_zone_prec.gt.0) then 755 756 else if (nb_iso(ixt,1).ne.0) then 757 WRITE(lunout,*) 'nqo,ixt=',nqo,ixt 758 WRITE(lunout,*) 'nb_iso(ixt,1)=',nb_iso(ixt,1) 759 CALL abort_gcm('infotrac_init','Isotopes are not well defined in traceur.def',1) 760 endif !if (nb_iso(ixt,1).eq.1) then 761 enddo ! do ixt= niso_possibles 762 763 ! dimensions isotopique: 764 ntraciso=niso*(ntraceurs_zone+1) 765 WRITE(lunout,*) 'niso=',niso 766 WRITE(lunout,*) 'ntraceurs_zone,ntraciso=',ntraceurs_zone,ntraciso 767 768 ! flags isotopiques: 769 if (niso.gt.0) then 770 ok_isotopes=.true. 771 else 772 ok_isotopes=.false. 773 endif 774 WRITE(lunout,*) 'ok_isotopes=',ok_isotopes 775 776 if (ok_isotopes) then 777 ok_iso_verif=.false. 778 call getin('ok_iso_verif',ok_iso_verif) 779 ok_init_iso=.false. 780 call getin('ok_init_iso',ok_init_iso) 781 tnat=(/1.0,155.76e-6,2005.2e-6,0.004/100.,0.0/) 782 alpha_ideal=(/1.0,1.01,1.006,1.003,1.0/) 783 endif !if (ok_isotopes) then 784 WRITE(lunout,*) 'ok_iso_verif=',ok_iso_verif 785 WRITE(lunout,*) 'ok_init_iso=',ok_init_iso 786 787 if (ntraceurs_zone.gt.0) then 788 ok_isotrac=.true. 789 else 790 ok_isotrac=.false. 791 endif 792 WRITE(lunout,*) 'ok_isotrac=',ok_isotrac 793 794 ! remplissage du tableau iqiso(ntraciso,phase) 795 ALLOCATE(iqiso(ntraciso,nqo)) 796 iqiso(:,:)=0 797 do iq=1,nqtot 798 if (iso_num(iq).gt.0) then 799 ixt=iso_indnum(iq)+zone_num(iq)*niso 800 iqiso(ixt,phase_num(iq))=iq 801 endif 802 enddo 803 WRITE(lunout,*) 'iqiso=',iqiso 804 805 ! replissage du tableau index_trac(ntraceurs_zone,niso) 806 ALLOCATE(index_trac(ntraceurs_zone,niso)) 807 if (ok_isotrac) then 808 do iiso=1,niso 809 do izone=1,ntraceurs_zone 810 index_trac(izone,iiso)=iiso+izone*niso 811 enddo 812 enddo 813 else !if (ok_isotrac) then 814 index_trac(:,:)=0.0 815 endif !if (ok_isotrac) then 816 write(lunout,*) 'index_trac=',index_trac 817 818 ! Finalize : 819 DEALLOCATE(nb_iso) 820 821 END SUBROUTINE infotrac_isoinit 822 400 823 END MODULE infotrac -
LMDZ5/branches/testing/libf/dyn3dmem/advtrac_loc.F
r1999 r2298 24 24 USE Vampir 25 25 USE times 26 USE infotrac, ONLY: nqtot, iadv 26 USE infotrac, ONLY: nqtot, iadv, ok_iso_verif 27 27 USE control_mod, ONLY: iapp_tracvl, day_step, planet_type 28 28 USE advtrac_mod, ONLY: finmasse … … 82 82 !$OMP THREADPRIVATE(testRequest) 83 83 84 c test sur l' eventuelle creation de valeurs negatives de la masse84 c test sur l''eventuelle creation de valeurs negatives de la masse 85 85 ijb=ij_begin 86 86 ije=ij_end … … 155 155 c$OMP BARRIER 156 156 157 !write(*,*) 'advtrac 157: appel de vlspltgen_loc' 157 158 call vlspltgen_loc( q,iadv, 2., massem, wg , 158 159 * pbarug,pbarvg,dtvr,p, 159 160 * pk,teta ) 161 162 !write(*,*) 'advtrac 162: apres appel vlspltgen_loc' 163 if (ok_iso_verif) then 164 call check_isotopes(q,ijb_u,ije_u,'advtrac 162') 165 endif !if (ok_iso_verif) then 160 166 161 167 #ifdef DEBUG_IO … … 356 362 c$OMP END DO 357 363 358 CALL qminimum_loc( q, 2, finmasse ) 364 ! CRisi: on passe nqtot et non nq 365 CALL qminimum_loc( q, nqtot, finmasse ) 359 366 360 367 endif ! of if (planet_type=="earth") -
LMDZ5/branches/testing/libf/dyn3dmem/caladvtrac_loc.F
r1910 r2298 56 56 !$OMP THREADPRIVATE(Request_vanleer) 57 57 58 58 !write(*,*) 'caladvtrac 58: entree' 59 59 ijbu=ij_begin 60 60 ijeu=ij_end … … 109 109 110 110 IF ( iadvtr.EQ.iapp_tracvl ) THEN 111 !write(*,*) 'caladvtrac 133' 111 112 c$OMP MASTER 112 113 call suspend_timer(timer_caldyn) … … 183 184 CALL WriteField_u('wg1',wg_adv) 184 185 #endif 186 !write(*,*) 'caladvtrac 185' 185 187 CALL advtrac_loc( pbarug_adv,pbarvg_adv,wg_adv, 186 188 * p_adv, massem_adv,q_adv, teta_adv, 187 . pk_adv) 189 . pk_adv) 190 !write(*,*) 'caladvtrac 189' 188 191 189 192 -
LMDZ5/branches/testing/libf/dyn3dmem/call_calfis_mod.F90
r2258 r2298 227 227 !$OMP BARRIER 228 228 229 #ifdef CPP_PHYS 229 230 CALL calfis_loc(lafin ,jD_cur, jH_cur, & 230 231 ucov,vcov,teta,q,masse,ps,p,pk,phis,phi , & 231 232 du,dv,dteta,dq, & 232 233 flxw, dufi,dvfi,dtetafi,dqfi,dpfi ) 233 234 #endif 234 235 ijb=ij_begin 235 236 ije=ij_end -
LMDZ5/branches/testing/libf/dyn3dmem/dynetat0_loc.F
r1999 r2298 366 366 write(lunout,*)"Il est donc initialise a zero" 367 367 q(:,:,iq)=0. 368 369 ! CRisi: pour les isotopes, on peut faire init théorique 370 ! distill de Rayleigh très simplifiée 371 if (ok_isotopes) then 372 if ((iso_num(iq).gt.0).and.(zone_num(iq).eq.0)) then 373 q(:,:,iq)=q(:,:,iqpere(iq)) & 374 & *tnat(iso_num(iq)) & 375 & *(q(:,:,iqpere(iq))/30.e-3) & 376 & **(alpha_ideal(iso_num(iq))-1) 377 endif 378 if ((iso_num(iq).gt.0).and.(zone_num(iq).eq.1)) then 379 q(:,:,iq)=q(:,:,iqiso(iso_indnum(iq),phase_num(iq))) 380 endif 381 endif !if (ok_isotopes) then 382 368 383 ELSE 369 384 #ifdef NC_DOUBLE … … 380 395 381 396 ENDIF 382 ENDDO 397 ENDDO !DO iq=1,nqtot 398 399 if (ok_iso_verif) then 400 call check_isotopes(q,ijb_u,ije_u,'dynetat0_loc') 401 endif !if (ok_iso_verif) then 383 402 384 403 DEALLOCATE(q_glo) -
LMDZ5/branches/testing/libf/dyn3dmem/guide_loc_mod.F90
r2160 r2298 87 87 ! Lecture des parametres: 88 88 ! --------------------------------------------- 89 call ini_getparam("nudging_parameters_out.txt") 89 90 ! Variables guidees 90 91 CALL getpar('guide_u',.true.,guide_u,'guidage de u') … … 159 160 CALL getpar('guide_2D',.false.,guide_2D,'fichier guidage lat-P') 160 161 162 call fin_getparam 163 161 164 ! --------------------------------------------- 162 165 ! Determination du nombre de niveaux verticaux -
LMDZ5/branches/testing/libf/dyn3dmem/iniacademic_loc.F90
r2160 r2298 7 7 use exner_hyb_m, only: exner_hyb 8 8 use exner_milieu_m, only: exner_milieu 9 USE infotrac, ONLY : nqtot 9 USE infotrac, ONLY: nqtot,niso_possibles,ok_isotopes,iqpere,ok_iso_verif,tnat,alpha_ideal, & 10 & iqiso,phase_num,iso_indnum,iso_num,zone_num 10 11 USE control_mod, ONLY: day_step,planet_type 11 12 USE parallel_lmdz, ONLY: ijb_u, ije_u, ijb_v, ije_v … … 110 111 ztot0 = 0. 111 112 stot0 = 0. 112 ang0 = 0. 113 ang0 = 0. 113 114 114 115 if (llm == 1) then … … 269 270 if (planet_type=="earth") then 270 271 ! Earth: first two tracers will be water 272 271 273 do i=1,nqtot 272 274 if (i == 1) q(ijb_u:ije_u,:,i)=1.e-10 273 275 if (i == 2) q(ijb_u:ije_u,:,i)=1.e-15 274 276 if (i.gt.2) q(ijb_u:ije_u,:,i)=0. 277 278 ! CRisi: init des isotopes 279 ! distill de Rayleigh très simplifiée 280 if (ok_isotopes) then 281 if ((iso_num(i).gt.0).and.(zone_num(i).eq.0)) then 282 q(ijb_u:ije_u,:,i)=q(ijb_u:ije_u,:,iqpere(i)) & 283 & *tnat(iso_num(i)) & 284 & *(q(ijb_u:ije_u,:,iqpere(i))/30.e-3) & 285 & **(alpha_ideal(iso_num(i))-1) 286 endif 287 if ((iso_num(i).gt.0).and.(zone_num(i).eq.1)) then 288 q(ijb_u:ije_u,:,i)=q(ijb_u:ije_u,:,iqiso(iso_indnum(i),phase_num(i))) 289 endif 290 endif !if (ok_isotopes) then 291 275 292 enddo 276 293 else 277 294 q(ijb_u:ije_u,:,:)=0 278 295 endif ! of if (planet_type=="earth") 296 297 if (ok_iso_verif) then 298 call check_isotopes(q,ijb_u,ije_u,'iniacademic_loc') 299 endif !if (ok_iso_verif) then 279 300 280 301 ! add random perturbation to temperature -
LMDZ5/branches/testing/libf/dyn3dmem/integrd_loc.F
r2160 r2298 11 11 USE write_field 12 12 USE integrd_mod 13 USE infotrac, ONLY: ok_iso_verif ! ajout CRisi 13 14 IMPLICIT NONE 14 15 … … 86 87 INTEGER :: ierr 87 88 89 !write(*,*) 'integrd 88: entree, nq=',nq 88 90 c----------------------------------------------------------------------- 91 89 92 c$OMP BARRIER 90 93 if (pole_nord) THEN … … 125 128 DO 2 ij = ijb,ije 126 129 pscr (ij) = ps0(ij) 127 ps (ij) = psm1(ij) + dt * dp(ij) 130 ps (ij) = psm1(ij) + dt * dp(ij) 131 128 132 2 CONTINUE 133 129 134 c$OMP END DO 130 135 c$OMP BARRIER … … 159 164 c$OMP END MASTER 160 165 c$OMP BARRIER 166 !write(*,*) 'integrd 170' 161 167 IF (.NOT. Checksum_all) THEN 162 168 call WriteField_v('int_vcov',vcov) … … 188 194 189 195 c 196 !write(*,*) 'integrd 200' 190 197 C$OMP MASTER 191 198 if (pole_nord) THEN … … 214 221 c$OMP END MASTER 215 222 c$OMP BARRIER 223 !write(*,*) 'integrd 217' 216 224 c 217 225 c ... Calcul de la nouvelle masse d'air au dernier temps integre t+1 ... … … 219 227 220 228 CALL pression_loc ( ip1jmp1, ap, bp, ps, p ) 229 221 230 c$OMP BARRIER 222 231 CALL massdair_loc ( p , masse ) … … 276 285 c 277 286 c 287 !write(*,*) 'integrd 291' 278 288 IF (pole_nord) THEN 279 289 … … 334 344 ENDDO 335 345 ENDDO 346 336 347 c$OMP END DO NOWAIT 337 348 c$OMP BARRIER 338 349 339 CALL qminimum_loc( q, nq, deltap ) 350 if (ok_iso_verif) then 351 call check_isotopes(q,ijb,ije,'integrd 342') 352 endif !if (ok_iso_verif) then 353 354 !write(*,*) 'integrd 341' 355 CALL qminimum_loc( q, nq, deltap ) 356 !write(*,*) 'integrd 343' 357 358 if (ok_iso_verif) then 359 call check_isotopes(q,ijb,ije,'integrd 346') 360 endif !if (ok_iso_verif) then 340 361 c 341 362 c ..... Calcul de la valeur moyenne, unique aux poles pour q ..... … … 387 408 388 409 ENDIF 410 411 if (ok_iso_verif) then 412 call check_isotopes(q,ijb,ije,'integrd 409') 413 endif !if (ok_iso_verif) then 389 414 390 415 ! Ehouarn: forget about finvmaold … … 404 429 405 430 15 continue 431 !write(*,*) 'integrd 410' 406 432 407 433 c$OMP DO SCHEDULE(STATIC) -
LMDZ5/branches/testing/libf/dyn3dmem/leapfrog_loc.F
r2258 r2298 200 200 LOGICAL, SAVE :: firstcall=.TRUE. 201 201 TYPE(distrib),SAVE :: new_dist 202 203 if (ok_iso_verif) then 204 call check_isotopes(q0,ijb_u,ije_u,'leapfrog204: debut') 205 endif !if (ok_iso_verif) then 202 206 203 207 c$OMP MASTER … … 219 223 itaufinp1 = itaufin +1 220 224 225 if (ok_iso_verif) then 226 call check_isotopes(q0,ijb_u,ije_u,'leapfrog 226') 227 endif !if (ok_iso_verif) then 228 221 229 itau = 0 222 230 physic=.true. … … 231 239 phis=phis0 232 240 q=q0 241 242 if (ok_iso_verif) then 243 call check_isotopes(q,ijb_u,ije_u,'leapfrog 239') 244 endif !if (ok_iso_verif) then 233 245 234 246 ! iday = day_ini+itau/day_step … … 296 308 297 309 1 CONTINUE ! Matsuno Forward step begins here 298 310 !write(*,*) 'leapfrog 298: itau=',itau 299 311 jD_cur = jD_ref + day_ini - day_ref + & 300 312 & itau/day_step … … 306 318 endif 307 319 320 if (ok_iso_verif) then 321 call check_isotopes(q,ijb_u,ije_u,'leapfrog 321') 322 endif !if (ok_iso_verif) then 308 323 309 324 #ifdef CPP_IOIPSL … … 384 399 cym call minmax(ijp1llm,q(:,:,3),zqmin,zqmax) 385 400 401 402 if (ok_iso_verif) then 403 call check_isotopes(q,ijb_u,ije_u,'leapfrog 400') 404 endif !if (ok_iso_verif) then 405 386 406 2 CONTINUE ! Matsuno backward or leapfrog step begins here 407 408 409 if (ok_iso_verif) then 410 call check_isotopes(q,ijb_u,ije_u,'leapfrog 402') 411 endif !if (ok_iso_verif) then 387 412 388 413 c$OMP MASTER … … 455 480 c$OMP END MASTER 456 481 482 483 if (ok_iso_verif) then 484 call check_isotopes(q,ijb_u,ije_u,'leapfrog 471') 485 endif !if (ok_iso_verif) then 457 486 458 487 !ym PAS D'AJUSTEMENT POUR LE MOMENT … … 574 603 575 604 605 if (ok_iso_verif) then 606 call check_isotopes(q,ijb_u,ije_u,'leapfrog 589') 607 endif !if (ok_iso_verif) then 576 608 577 609 c----------------------------------------------------------------------- … … 635 667 ! compute geopotential phi() 636 668 CALL geopot_loc ( ip1jmp1, teta , pk , pks, phis , phi ) 637 669 670 if (ok_iso_verif) then 671 call check_isotopes(q,ijb_u,ije_u,'leapfrog 651') 672 endif !if (ok_iso_verif) then 638 673 639 674 call VTb(VTcaldyn) … … 644 679 ! CALL FTRACE_REGION_BEGIN("caldyn") 645 680 time = jD_cur + jH_cur 681 646 682 CALL caldyn_loc 647 683 $ ( itau,ucov,vcov,teta,ps,masse,pk,pkf,phis , … … 670 706 c ------------------------------------------------------------- 671 707 708 if (ok_iso_verif) then 709 call check_isotopes(q,ijb_u,ije_u, 710 & 'leapfrog 686: avant caladvtrac') 711 endif !if (ok_iso_verif) then 672 712 673 713 IF( forward. OR . leapf ) THEN 674 714 ! Ehouarn: NB: fields sent to advtrac are those at the beginning of the time step 715 !write(*,*) 'leapfrog 679: avant CALL caladvtrac_loc' 675 716 CALL caladvtrac_loc(q,pbaru,pbarv, 676 717 * p, masse, dq, teta, 677 718 . flxw,pk, iapptrac) 719 720 !write(*,*) 'leapfrog 719' 721 if (ok_iso_verif) then 722 call check_isotopes(q,ijb_u,ije_u, 723 & 'leapfrog 698: apres caladvtrac') 724 endif !if (ok_iso_verif) then 678 725 679 726 ! do j=1,nqtot … … 708 755 ! CALL FTRACE_REGION_BEGIN("integrd") 709 756 710 CALL integrd_loc ( 2,vcovm1,ucovm1,tetam1,psm1,massem1 , 757 !write(*,*) 'leapfrog 720' 758 if (ok_iso_verif) then 759 call check_isotopes(q,ijb_u,ije_u,'leapfrog 756') 760 endif !if (ok_iso_verif) then 761 762 ! CRisi: pourquoi aller jusqu'à 2 et non pas jusqu'à nqtot?? 763 CALL integrd_loc ( nqtot,vcovm1,ucovm1,tetam1,psm1,massem1 , 711 764 $ dv,du,dteta,dq,dp,vcov,ucov,teta,q,ps,masse,phis) 712 765 ! $ finvmaold ) 713 766 767 !write(*,*) 'leapfrog 724' 768 if (ok_iso_verif) then 769 call check_isotopes(q,ijb_u,ije_u,'leapfrog 762') 770 endif !if (ok_iso_verif) then 771 714 772 ! CALL FTRACE_REGION_END("integrd") 715 773 c$OMP BARRIER … … 724 782 call WriteField_u('ps_int',ps) 725 783 #endif 784 785 if (ok_iso_verif) then 786 call check_isotopes(q,ijb_u,ije_u,'leapfrog 775') 787 endif !if (ok_iso_verif) then 788 726 789 c do j=1,nqtot 727 790 c call WriteField_p('q'//trim(int2str(j)), … … 1082 1145 ENDIF ! of IF( apphys ) 1083 1146 1147 if (ok_iso_verif) then 1148 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1132') 1149 endif !if (ok_iso_verif) then 1150 !write(*,*) 'leapfrog 1134: iflag_phys=',iflag_phys 1151 1084 1152 IF(iflag_phys.EQ.2) THEN ! "Newtonian" case 1085 1153 c$OMP MASTER … … 1146 1214 1147 1215 cc$OMP END PARALLEL 1216 if (ok_iso_verif) then 1217 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1196') 1218 endif !if (ok_iso_verif) then 1148 1219 1149 1220 c----------------------------------------------------------------------- 1150 1221 c dissipation horizontale et verticale des petites echelles: 1151 1222 c ---------------------------------------------------------- 1152 1223 !write(*,*) 'leapfrog 1163: apdiss=',apdiss 1153 1224 IF(apdiss) THEN 1154 1225 … … 1379 1450 c call abort_gcm(modname,abort_message,0) 1380 1451 c ENDIF 1381 1452 1453 if (ok_iso_verif) then 1454 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1430') 1455 endif !if (ok_iso_verif) then 1456 1382 1457 c ******************************************************************** 1383 1458 c ******************************************************************** … … 1455 1530 ENDIF 1456 1531 1532 if (ok_iso_verif) then 1533 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1509') 1534 endif !if (ok_iso_verif) then 1535 1457 1536 IF ( .NOT.purmats ) THEN 1458 1537 c ........................................................ … … 1526 1605 ENDIF 1527 1606 1607 if (ok_iso_verif) then 1608 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1584') 1609 endif !if (ok_iso_verif) then 1610 1528 1611 c----------------------------------------------------------------------- 1529 1612 c ecriture de la bande histoire: … … 1562 1645 ENDIF ! of IF (itau.EQ.itaufin) 1563 1646 1647 if (ok_iso_verif) then 1648 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1624') 1649 endif !if (ok_iso_verif) then 1650 1564 1651 c----------------------------------------------------------------------- 1565 1652 c gestion de l'integration temporelle: … … 1596 1683 1597 1684 ELSE ! of IF (.not.purmats) 1685 1686 1687 if (ok_iso_verif) then 1688 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1664') 1689 endif !if (ok_iso_verif) then 1598 1690 1599 1691 c ........................................................ … … 1631 1723 1632 1724 ELSE ! of IF(forward) i.e. backward step 1725 1726 1727 if (ok_iso_verif) then 1728 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1698') 1729 endif !if (ok_iso_verif) then 1633 1730 1634 1731 IF(MOD(itau,iperiod).EQ.0 .OR. itau.EQ.itaufin) THEN … … 1683 1780 ENDIF ! of IF (forward) 1684 1781 1782 1783 if (ok_iso_verif) then 1784 call check_isotopes(q,ijb_u,ije_u,'leapfrog 1750') 1785 endif !if (ok_iso_verif) then 1786 1685 1787 END IF ! of IF(.not.purmats) 1686 1788 c$OMP MASTER -
LMDZ5/branches/testing/libf/dyn3dmem/qminimum_loc.F
r1910 r2298 1 SUBROUTINE qminimum_loc( q,nq ,deltap )1 SUBROUTINE qminimum_loc( q,nqtot,deltap ) 2 2 USE parallel_lmdz 3 USE infotrac, ONLY: ok_isotopes,ntraciso,iqiso,ok_iso_verif 3 4 IMPLICIT none 4 5 c … … 10 11 #include "comvert.h" 11 12 c 12 INTEGER nq 13 REAL q(ijb_u:ije_u,llm,nq ), deltap(ijb_u:ije_u,llm)13 INTEGER nqtot ! CRisi: on remplace nq par nqtot 14 REAL q(ijb_u:ije_u,llm,nqtot), deltap(ijb_u:ije_u,llm) 14 15 c 15 16 INTEGER iq_vap, iq_liq … … 27 28 INTEGER i, k, iq 28 29 REAL zx_defau, zx_abc, zx_pump(ijb_u:ije_u), pompe 30 31 real zx_defau_diag(ijb_u:ije_u,llm,2) 32 real q_follow(ijb_u:ije_u,llm,2) 29 33 c 30 34 REAL SSUM … … 38 42 INTEGER Index_pump(ij_end-ij_begin+1) 39 43 INTEGER nb_pump 44 INTEGER ixt 45 INTEGER iso_verif_noNaN_nostop 40 46 c 41 47 c Quand l'eau liquide est trop petite (ou negative), on prend … … 44 50 c 45 51 52 !write(*,*) 'qminimum 52: entree' 53 if (ok_iso_verif) then 54 call check_isotopes(q,ij_begin,ij_end,'qminimum 52') 55 endif !if (ok_iso_verif) then 56 46 57 ijb=ij_begin 47 58 ije=ij_end 48 59 60 zx_defau_diag(ijb:ije,:,:)=0.0 61 q_follow(ijb:ije,:,1:2)=q(ijb:ije,:,1:2) 62 63 !write(*,*) 'qminimum 57' 49 64 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 50 65 DO 1000 k = 1, llm 51 66 DO 1040 i = ijb, ije 52 67 if (seuil_liq - q(i,k,iq_liq) .gt. 0.d0 ) then 68 69 if (ok_isotopes) then 70 zx_defau_diag(i,k,iq_liq)=AMAX1 71 : ( seuil_liq - q(i,k,iq_liq), 0.0 ) 72 endif !if (ok_isotopes) then 73 53 74 q(i,k,iq_vap) = q(i,k,iq_vap) + q(i,k,iq_liq) - seuil_liq 54 75 q(i,k,iq_liq) = seuil_liq … … 60 81 c ---> SYNCHRO OPENMP ICI 61 82 83 62 84 c 63 85 c Quand l'eau vapeur est trop faible (ou negative), on complete 64 86 c le defaut en prennant de l'eau vapeur de la couche au-dessous. 65 87 c 88 !write(*,*) 'qminimum 81' 66 89 iq = iq_vap 67 90 c … … 70 93 c$OMP DO SCHEDULE(STATIC) 71 94 DO i = ijb, ije 95 72 96 if ( seuil_vap - q(i,k,iq) .gt. 0.d0 ) then 97 98 if (ok_isotopes) then 99 zx_defau_diag(i,k,iq)=AMAX1( seuil_vap - q(i,k,iq), 0.0 ) 100 endif !if (ok_isotopes) then 101 73 102 q(i,k-1,iq) = q(i,k-1,iq) - ( seuil_vap - q(i,k,iq) ) * 74 103 & deltap(i,k) / deltap(i,k-1) 75 104 q(i,k,iq) = seuil_vap 105 76 106 endif 77 107 ENDDO … … 79 109 ENDDO 80 110 c$OMP BARRIER 111 81 112 c 82 113 c Quand il s'agit de la premiere couche au-dessus du sol, on 83 114 c doit imprimer un message d'avertissement (saturation possible). 84 115 c 116 !write(*,*) 'qminimum 106' 85 117 nb_pump=0 86 118 c$OMP DO SCHEDULE(STATIC) … … 103 135 ENDDO 104 136 ENDIF 137 138 !write(*,*) 'qminimum 128' 139 if (ok_isotopes) then 140 ! CRisi: traiter de même les traceurs d'eau 141 ! Mais il faut les prendre à l'envers pour essayer de conserver la 142 ! masse. 143 ! 1) pompage dans le sol 144 ! On suppose que ce pompage se fait sans isotopes -> on ne modifie 145 ! rien ici et on croise les doigts pour que ça ne soit pas trop 146 ! génant 147 DO i = ijb, ije 148 if (zx_pump(i).gt.0.0) then 149 q_follow(i,1,iq_vap)=q_follow(i,1,iq_vap)+zx_pump(i) 150 endif !if (zx_pump(i).gt.0.0) then 151 enddo !DO i = ijb, ije 152 153 ! 2) transfert de vap vers les couches plus hautes 154 !write(*,*) 'qminimum 139' 155 do k=2,llm 156 DO i = ijb, ije 157 if (zx_defau_diag(i,k,iq_vap).gt.0.0) then 158 ! on ajoute la vapeur en k 159 do ixt=1,ntraciso 160 q(i,k,iqiso(ixt,iq_vap))=q(i,k,iqiso(ixt,iq_vap)) 161 : +zx_defau_diag(i,k,iq_vap) 162 : *q(i,k-1,iqiso(ixt,iq_vap))/q_follow(i,k-1,iq_vap) 163 164 if (ok_iso_verif) then 165 if (iso_verif_noNaN_nostop(q(i,k,iqiso(ixt,iq_vap)), 166 : 'qminimum 155').eq.1) then 167 write(*,*) 'i,k,ixt=',i,k,ixt 168 write(*,*) 'q_follow(i,k-1,iq_vap)=', 169 : q_follow(i,k-1,iq_vap) 170 write(*,*) 'q(i,k,iqiso(ixt,iq_vap))=', 171 : q(i,k,iqiso(ixt,iq_vap)) 172 write(*,*) 'zx_defau_diag(i,k,iq_vap)=', 173 : zx_defau_diag(i,k,iq_vap) 174 write(*,*) 'q(i,k-1,iqiso(ixt,iq_vap))=', 175 : q(i,k-1,iqiso(ixt,iq_vap)) 176 stop 177 endif 178 endif 179 180 ! et on la retranche en k-1 181 q(i,k-1,iqiso(ixt,iq_vap))=q(i,k-1,iqiso(ixt,iq_vap)) 182 : -zx_defau_diag(i,k,iq_vap) 183 : *deltap(i,k)/deltap(i,k-1) 184 : *q(i,k-1,iqiso(ixt,iq_vap))/q_follow(i,k-1,iq_vap) 185 186 if (ok_iso_verif) then 187 if (iso_verif_noNaN_nostop(q(i,k-1,iqiso(ixt,iq_vap)), 188 : 'qminimum 175').eq.1) then 189 write(*,*) 'k,i,ixt=',k,i,ixt 190 write(*,*) 'q_follow(i,k-1,iq_vap)=', 191 : q_follow(i,k-1,iq_vap) 192 write(*,*) 'q(i,k,iqiso(ixt,iq_vap))=', 193 : q(i,k,iqiso(ixt,iq_vap)) 194 write(*,*) 'zx_defau_diag(i,k,iq_vap)=', 195 : zx_defau_diag(i,k,iq_vap) 196 write(*,*) 'q(i,k-1,iqiso(ixt,iq_vap))=', 197 : q(i,k-1,iqiso(ixt,iq_vap)) 198 stop 199 endif 200 endif 201 202 enddo !do ixt=1,niso 203 q_follow(i,k,iq_vap)= q_follow(i,k,iq_vap) 204 : +zx_defau_diag(i,k,iq_vap) 205 q_follow(i,k-1,iq_vap)= q_follow(i,k-1,iq_vap) 206 : -zx_defau_diag(i,k,iq_vap) 207 : *deltap(i,k)/deltap(i,k-1) 208 endif !if (zx_defau_diag(i,k,iq_vap).gt.0.0) then 209 enddo !DO i = 1, ip1jmp1 210 enddo !do k=2,llm 211 212 if (ok_iso_verif) then 213 call check_isotopes(q,ijb,ije,'qminimum 168') 214 endif !if (ok_iso_verif) then 215 216 217 ! 3) transfert d'eau de la vapeur au liquide 218 !write(*,*) 'qminimum 164' 219 do k=1,llm 220 DO i = ijb, ije 221 if (zx_defau_diag(i,k,iq_liq).gt.0.0) then 222 223 ! on ajoute eau liquide en k en k 224 do ixt=1,ntraciso 225 q(i,k,iqiso(ixt,iq_liq))=q(i,k,iqiso(ixt,iq_liq)) 226 : +zx_defau_diag(i,k,iq_liq) 227 : *q(i,k,iqiso(ixt,iq_vap))/q_follow(i,k,iq_vap) 228 ! et on la retranche à la vapeur en k 229 q(i,k,iqiso(ixt,iq_vap))=q(i,k,iqiso(ixt,iq_vap)) 230 : -zx_defau_diag(i,k,iq_liq) 231 : *q(i,k,iqiso(ixt,iq_vap))/q_follow(i,k,iq_vap) 232 enddo !do ixt=1,niso 233 q_follow(i,k,iq_liq)= q_follow(i,k,iq_liq) 234 : +zx_defau_diag(i,k,iq_liq) 235 q_follow(i,k,iq_vap)= q_follow(i,k,iq_vap) 236 : -zx_defau_diag(i,k,iq_liq) 237 endif !if (zx_defau_diag(i,k,iq_vap).gt.0.0) then 238 enddo !DO i = 1, ip1jmp1 239 enddo !do k=2,llm 240 241 if (ok_iso_verif) then 242 call check_isotopes(q,ijb,ije,'qminimum 197') 243 endif !if (ok_iso_verif) then 244 245 endif !if (ok_isotopes) then 246 !write(*,*) 'qminimum 188' 105 247 c 106 248 RETURN -
LMDZ5/branches/testing/libf/dyn3dmem/vlsplt_loc.F
r1910 r2298 2 2 ! $Id$ 3 3 ! 4 SUBROUTINE vlx_loc(q,pente_max,masse,u_m,ijb_x,ije_x)4 RECURSIVE SUBROUTINE vlx_loc(q,pente_max,masse,u_m,ijb_x,ije_x,iq) 5 5 6 6 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 14 14 c -------------------------------------------------------------------- 15 15 USE parallel_lmdz 16 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 16 17 IMPLICIT NONE 17 18 c … … 25 26 c Arguments: 26 27 c ---------- 27 REAL masse(ijb_u:ije_u,llm),pente_max 28 REAL u_m( ijb_u:ije_u,llm ),pbarv( iip1,jjb_v:jje_v,llm) 29 REAL q(ijb_u:ije_u,llm) 30 REAL w(ijb_u:ije_u,llm) 28 REAL masse(ijb_u:ije_u,llm,nqtot),pente_max 29 REAL u_m( ijb_u:ije_u,llm),pbarv( iip1,jjb_v:jje_v,llm) 30 REAL q(ijb_u:ije_u,llm,nqtot) ! CRisi: ajout dimension nqtot 31 REAL w(ijb_u:ije_u,llm) 32 INTEGER iq ! CRisi 31 33 c 32 34 c Local … … 42 44 REAL u_mq(ijb_u:ije_u,llm) 43 45 46 REAL Ratio(ijb_u:ije_u,llm,nqtot) ! CRisi 47 INTEGER ifils,iq2 ! CRisi 48 44 49 Logical extremum 45 50 … … 51 56 INTEGER ijb,ije,ijb_x,ije_x 52 57 58 !write(*,*) 'vlsplt 58: entree dans vlx_loc, iq,ijb_x=', 59 ! & iq,ijb_x 53 60 c calcul de la pente a droite et a gauche de la maille 54 61 … … 64 71 c calcul des pentes avec limitation, Van Leer scheme I: 65 72 c ----------------------------------------------------- 66 73 ! on a besoin de q entre ijb et ije 67 74 c calcul de la pente aux points u 68 75 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) … … 70 77 71 78 DO ij=ijb,ije-1 72 dxqu(ij)=q(ij+1,l )-q(ij,l)79 dxqu(ij)=q(ij+1,l,iq)-q(ij,l,iq) 73 80 c IF(u_m(ij,l).lt.0.) stop'limx n admet pas les U<0' 74 c sigu(ij)=u_m(ij,l)/masse(ij,l )81 c sigu(ij)=u_m(ij,l)/masse(ij,l,iq) 75 82 ENDDO 76 83 DO ij=ijb+iip1-1,ije,iip1 … … 126 133 DO l = 1, llm 127 134 DO ij=ijb,ije-1 128 dxqu(ij)=q(ij+1,l )-q(ij,l)135 dxqu(ij)=q(ij+1,l,iq)-q(ij,l,iq) 129 136 ENDDO 130 137 DO ij=ijb+iip1-1,ije,iip1 … … 147 154 ENDIF ! (pente_max.lt.-1.e-5) 148 155 156 !write(*,*) 'vlx 156: iq,ijb_x=',iq,ijb_x 157 149 158 c bouclage de la pente en iip1: 150 159 c ----------------------------- … … 168 177 DO l=1,llm 169 178 DO ij=ijb,ije-1 170 zdum(ij,l)=cvmgp(1.-u_m(ij,l)/masse(ij,l ),171 , 1.+u_m(ij,l)/masse(ij+1,l ),172 , u_m(ij,l ))179 zdum(ij,l)=cvmgp(1.-u_m(ij,l)/masse(ij,l,iq), 180 , 1.+u_m(ij,l)/masse(ij+1,l,iq), 181 , u_m(ij,l,iq)) 173 182 zdum(ij,l)=0.5*zdum(ij,l) 174 183 u_mq(ij,l)=cvmgp( 175 , q(ij,l )+zdum(ij,l)*dxq(ij,l),176 , q(ij+1,l )-zdum(ij,l)*dxq(ij+1,l),184 , q(ij,l,iq)+zdum(ij,l)*dxq(ij,l), 185 , q(ij+1,l,iq)-zdum(ij,l)*dxq(ij+1,l), 177 186 , u_m(ij,l)) 178 187 u_mq(ij,l)=u_m(ij,l)*u_mq(ij,l) … … 185 194 c print*,'Cumule ....' 186 195 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 196 ! on a besoin de masse entre ijb et ije 187 197 DO l=1,llm 188 198 DO ij=ijb,ije-1 189 c print*,'masse(',ij,')=',masse(ij,l )199 c print*,'masse(',ij,')=',masse(ij,l,iq) 190 200 IF (u_m(ij,l).gt.0.) THEN 191 zdum(ij,l)=1.-u_m(ij,l)/masse(ij,l) 192 u_mq(ij,l)=u_m(ij,l)*(q(ij,l)+0.5*zdum(ij,l)*dxq(ij,l)) 201 zdum(ij,l)=1.-u_m(ij,l)/masse(ij,l,iq) 202 u_mq(ij,l)=u_m(ij,l)*(q(ij,l,iq) 203 : +0.5*zdum(ij,l)*dxq(ij,l)) 193 204 ELSE 194 zdum(ij,l)=1.+u_m(ij,l)/masse(ij+1,l) 195 u_mq(ij,l)=u_m(ij,l)*(q(ij+1,l)-0.5*zdum(ij,l)*dxq(ij+1,l)) 205 zdum(ij,l)=1.+u_m(ij,l)/masse(ij+1,l,iq) 206 u_mq(ij,l)=u_m(ij,l)*(q(ij+1,l,iq) 207 : -0.5*zdum(ij,l)*dxq(ij+1,l)) 196 208 ENDIF 197 209 ENDDO … … 215 227 c$OMP END DO NOWAIT 216 228 c print*,'Ok test 1' 229 217 230 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 218 231 DO l=1,llm … … 223 236 c$OMP END DO NOWAIT 224 237 c print*,'Ok test 2' 225 238 226 239 227 240 c traitement special pour le cas ou on advecte en longitude plus que le … … 247 260 c & ,'contenu de la maille : ',n0 248 261 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 262 263 249 264 DO l=1,llm 250 265 IF(nl(l).gt.0) THEN … … 258 273 ENDDO 259 274 niju=iju 260 c PRINT*,'niju,nl',niju,nl(l)275 !PRINT*,'vlx 278, niju,nl',niju,nl(l) 261 276 262 277 c traitement des mailles … … 270 285 i=ijq-(j-1)*iip1 271 286 c accumulation pour les mailles completements advectees 272 do while(zu_m.gt.masse(ijq,l)) 273 u_mq(ij,l)=u_mq(ij,l)+q(ijq,l)*masse(ijq,l) 274 zu_m=zu_m-masse(ijq,l) 287 do while(zu_m.gt.masse(ijq,l,iq)) 288 u_mq(ij,l)=u_mq(ij,l) 289 & +q(ijq,l,iq)*masse(ijq,l,iq) 290 zu_m=zu_m-masse(ijq,l,iq) 275 291 i=mod(i-2+iim,iim)+1 276 292 ijq=(j-1)*iip1+i … … 278 294 c ajout de la maille non completement advectee 279 295 u_mq(ij,l)=u_mq(ij,l)+zu_m* 280 & (q(ijq,l)+0.5*(1.-zu_m/masse(ijq,l))*dxq(ijq,l)) 296 & (q(ijq,l,iq)+0.5* 297 & (1.-zu_m/masse(ijq,l,iq))*dxq(ijq,l)) 281 298 ELSE 282 299 ijq=ij+1 283 300 i=ijq-(j-1)*iip1 284 301 c accumulation pour les mailles completements advectees 285 do while(-zu_m.gt.masse(ijq,l)) 286 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l)*masse(ijq,l) 287 zu_m=zu_m+masse(ijq,l) 302 do while(-zu_m.gt.masse(ijq,l,iq)) 303 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l,iq) 304 & *masse(ijq,l,iq) 305 zu_m=zu_m+masse(ijq,l,iq) 288 306 i=mod(i,iim)+1 289 307 ijq=(j-1)*iip1+i 290 308 ENDDO 291 309 c ajout de la maille non completement advectee 292 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l )-293 & 0.5*(1.+zu_m/masse(ijq,l ))*dxq(ijq,l))310 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l,iq)- 311 & 0.5*(1.+zu_m/masse(ijq,l,iq))*dxq(ijq,l)) 294 312 ENDIF 295 313 ENDDO … … 299 317 cym ENDIF ! n0.gt.0 300 318 9999 continue 301 302 319 303 320 c bouclage en latitude … … 311 328 c$OMP END DO NOWAIT 312 329 330 ! CRisi: appel récursif de l'advection sur les fils. 331 ! Il faut faire ça avant d'avoir mis à jour q et masse 332 333 !write(*,*) 'vlsplt 326: iq,ijb_x,nqfils(iq)=',iq,ijb_x,nqfils(iq) 334 335 if (nqfils(iq).gt.0) then 336 do ifils=1,nqdesc(iq) 337 iq2=iqfils(ifils,iq) 338 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 339 DO l=1,llm 340 DO ij=ijb,ije 341 ! On a besoin de q et masse seulement entre ijb et ije. On ne 342 ! les calcule donc que de ijb à ije 343 masse(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 344 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 345 enddo 346 enddo 347 c$OMP END DO NOWAIT 348 enddo !do ifils=1,nqdesc(iq) 349 do ifils=1,nqfils(iq) 350 iq2=iqfils(ifils,iq) 351 call vlx_loc(Ratio,pente_max,masse,u_mq,ijb_x,ije_x,iq2) 352 enddo !do ifils=1,nqfils(iq) 353 endif !if (nqfils(iq).gt.0) then 354 ! end CRisi 355 356 !write(*,*) 'vlsplt 360: iq,ijb_x=',iq,ijb_x 357 313 358 c calcul des tENDances 314 359 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 315 360 DO l=1,llm 316 361 DO ij=ijb+1,ije 317 new_m=masse(ij,l )+u_m(ij-1,l)-u_m(ij,l)318 q(ij,l )=(q(ij,l)*masse(ij,l)+319 & u_mq(ij-1,l)-u_mq(ij,l))320 & /new_m321 masse(ij,l )=new_m362 new_m=masse(ij,l,iq)+u_m(ij-1,l)-u_m(ij,l) 363 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+ 364 & u_mq(ij-1,l)-u_mq(ij,l)) 365 & /new_m 366 masse(ij,l,iq)=new_m 322 367 ENDDO 323 368 c ModIF Fred 22 03 96 correction d'un bug (les scopy ci-dessous) 324 369 DO ij=ijb+iip1-1,ije,iip1 325 q(ij-iim,l)=q(ij,l) 326 masse(ij-iim,l)=masse(ij,l) 327 ENDDO 328 ENDDO 329 c$OMP END DO NOWAIT 370 q(ij-iim,l,iq)=q(ij,l,iq) 371 masse(ij-iim,l,iq)=masse(ij,l,iq) 372 ENDDO 373 ENDDO 374 c$OMP END DO NOWAIT 375 !write(*,*) 'vlsplt 380: iq,ijb_x=',iq,ijb_x 376 377 ! retablir les fils en rapport de melange par rapport a l'air: 378 ! On calcule q entre ijb+1 et ije -> on fait pareil pour ratio 379 ! puis on boucle en longitude 380 if (nqfils(iq).gt.0) then 381 do ifils=1,nqdesc(iq) 382 iq2=iqfils(ifils,iq) 383 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 384 DO l=1,llm 385 DO ij=ijb+1,ije 386 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 387 enddo 388 DO ij=ijb+iip1-1,ije,iip1 389 q(ij-iim,l,iq2)=q(ij,l,iq2) 390 enddo ! DO ij=ijb+iip1-1,ije,iip1 391 enddo !DO l=1,llm 392 c$OMP END DO NOWAIT 393 enddo !do ifils=1,nqdesc(iq) 394 endif !if (nqfils(iq).gt.0) then 395 396 !write(*,*) 'vlsplt 399: iq,ijb_x=',iq,ijb_x 330 397 c CALL SCOPY((jjm-1)*llm,q(iip1+iip1,1),iip1,q(iip2,1),iip1) 331 398 c CALL SCOPY((jjm-1)*llm,masse(iip1+iip1,1),iip1,masse(iip2,1),iip1) … … 336 403 337 404 338 SUBROUTINE vly_loc(q,pente_max,masse,masse_adv_v)405 RECURSIVE SUBROUTINE vly_loc(q,pente_max,masse,masse_adv_v,iq) 339 406 c 340 407 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 349 416 c -------------------------------------------------------------------- 350 417 USE parallel_lmdz 418 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 351 419 IMPLICIT NONE 352 420 c … … 361 429 c Arguments: 362 430 c ---------- 363 REAL masse(ijb_u:ije_u,llm ),pente_max431 REAL masse(ijb_u:ije_u,llm,nqtot),pente_max 364 432 REAL masse_adv_v( ijb_v:ije_v,llm) 365 REAL q(ijb_u:ije_u,llm), dq( ijb_u:ije_u,llm) 433 REAL q(ijb_u:ije_u,llm,nqtot), dq( ijb_u:ije_u,llm) 434 INTEGER iq ! CRisi 366 435 c 367 436 c Local … … 392 461 SAVE airej2,airejjm 393 462 c$OMP THREADPRIVATE(airej2,airejjm) 463 464 REAL Ratio(ijb_u:ije_u,llm,nqtot) ! CRisi 465 INTEGER ifils,iq2 ! CRisi 394 466 c 395 467 c … … 401 473 INTEGER ijb,ije 402 474 475 ijb=ij_begin-2*iip1 476 ije=ij_end+2*iip1 477 if (pole_nord) ijb=ij_begin 478 if (pole_sud) ije=ij_end 479 403 480 IF(first) THEN 404 cPRINT*,'Shema Amont nouveau appele dans Vanleer '481 PRINT*,'Shema Amont nouveau appele dans Vanleer ' 405 482 first=.false. 406 483 do i=2,iip1 … … 434 511 if (pole_nord) then 435 512 DO i = 1, iim 436 airescb(i) = aire(i+ iip1) * q(i+ iip1,l )513 airescb(i) = aire(i+ iip1) * q(i+ iip1,l,iq) 437 514 ENDDO 438 515 qpns = SSUM( iim, airescb ,1 ) / airej2 … … 441 518 if (pole_sud) then 442 519 DO i = 1, iim 443 airesch(i) = aire(i+ ip1jm- iip1) * q(i+ ip1jm- iip1,l )520 airesch(i) = aire(i+ ip1jm- iip1) * q(i+ ip1jm- iip1,l,iq) 444 521 ENDDO 445 522 qpsn = SSUM( iim, airesch ,1 ) / airejjm 446 523 endif 447 524 448 449 450 525 c calcul des pentes aux points v 451 526 … … 455 530 if (pole_sud) ije=ij_end-iip1 456 531 532 ! on a besoin de q entre ij_begin-2*iip1 et ij_end+2*iip1 533 ! Si pole sud, entre ij_begin-2*iip1 et ij_end 534 ! Si pole Nord, entre ij_begin et ij_end+2*iip1 457 535 DO ij=ijb,ije 458 dyqv(ij)=q(ij,l )-q(ij+iip1,l)536 dyqv(ij)=q(ij,l,iq)-q(ij+iip1,l,iq) 459 537 adyqv(ij)=abs(dyqv(ij)) 460 538 ENDDO 539 461 540 462 541 c calcul des pentes aux points scalaires … … 475 554 IF (pole_nord) THEN 476 555 DO ij=1,iip1 477 dyq(ij,l)=qpns-q(ij+iip1,l )556 dyq(ij,l)=qpns-q(ij+iip1,l,iq) 478 557 ENDDO 479 558 … … 497 576 498 577 DO ij=1,iip1 499 dyq(ip1jm+ij,l)=q(ip1jm+ij-iip1,l )-qpsn578 dyq(ip1jm+ij,l)=q(ip1jm+ij-iip1,l,iq)-qpsn 500 579 ENDDO 501 580 … … 633 712 DO ij=ijb,ije 634 713 IF(masse_adv_v(ij,l).gt.0) THEN 635 qbyv(ij,l)=q(ij+iip1,l)+dyq(ij+iip1,l)* 636 , 0.5*(1.-masse_adv_v(ij,l)/masse(ij+iip1,l)) 714 qbyv(ij,l)=q(ij+iip1,l,iq)+dyq(ij+iip1,l)* 715 , 0.5*(1.-masse_adv_v(ij,l) 716 , /masse(ij+iip1,l,iq)) 637 717 ELSE 638 qbyv(ij,l)=q(ij,l )-dyq(ij,l)*639 , 0.5*(1.+masse_adv_v(ij,l)/masse(ij,l ))718 qbyv(ij,l)=q(ij,l,iq)-dyq(ij,l)* 719 , 0.5*(1.+masse_adv_v(ij,l)/masse(ij,l,iq)) 640 720 ENDIF 641 721 qbyv(ij,l)=masse_adv_v(ij,l)*qbyv(ij,l) … … 643 723 ENDDO 644 724 c$OMP END DO NOWAIT 725 726 ! CRisi: appel récursif de l'advection sur les fils. 727 ! Il faut faire ça avant d'avoir mis à jour q et masse 728 !write(*,*) 'vly 689: iq,nqfils(iq)=',iq,nqfils(iq) 729 730 ijb=ij_begin-2*iip1 731 ije=ij_end+2*iip1 732 if (pole_nord) ijb=ij_begin 733 if (pole_sud) ije=ij_end 734 735 if (nqfils(iq).gt.0) then 736 do ifils=1,nqdesc(iq) 737 iq2=iqfils(ifils,iq) 738 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 739 DO l=1,llm 740 DO ij=ijb,ije 741 masse(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 742 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 743 enddo 744 enddo 745 c$OMP END DO NOWAIT 746 enddo !do ifils=1,nqdesc(iq) 747 748 do ifils=1,nqfils(iq) 749 iq2=iqfils(ifils,iq) 750 call vly_loc(Ratio,pente_max,masse,qbyv,iq2) 751 enddo !do ifils=1,nqfils(iq) 752 endif !if (nqfils(iq).gt.0) then 753 ! end CRisi 645 754 646 755 ijb=ij_begin … … 652 761 DO l=1,llm 653 762 DO ij=ijb,ije 654 newmasse=masse(ij,l) 655 & +masse_adv_v(ij,l)-masse_adv_v(ij-iip1,l) 656 657 q(ij,l)=(q(ij,l)*masse(ij,l)+qbyv(ij,l)-qbyv(ij-iip1,l)) 658 & /newmasse 659 masse(ij,l)=newmasse 660 ENDDO 763 newmasse=masse(ij,l,iq) 764 & +masse_adv_v(ij,l)-masse_adv_v(ij-iip1,l) 765 766 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+qbyv(ij,l) 767 & -qbyv(ij-iip1,l))/newmasse 768 769 masse(ij,l,iq)=newmasse 770 771 ENDDO 772 773 661 774 c.-. ancienne version 662 775 c convpn=SSUM(iim,qbyv(1,l),1)/apoln … … 665 778 convpn=SSUM(iim,qbyv(1,l),1) 666 779 convmpn=ssum(iim,masse_adv_v(1,l),1) 667 massepn=ssum(iim,masse(1,l ),1)780 massepn=ssum(iim,masse(1,l,iq),1) 668 781 qpn=0. 669 782 do ij=1,iim 670 qpn=qpn+masse(ij,l )*q(ij,l)783 qpn=qpn+masse(ij,l,iq)*q(ij,l,iq) 671 784 enddo 672 785 qpn=(qpn+convpn)/(massepn+convmpn) 673 786 do ij=1,iip1 674 q(ij,l )=qpn787 q(ij,l,iq)=qpn 675 788 enddo 676 789 endif … … 683 796 convps=-SSUM(iim,qbyv(ip1jm-iim,l),1) 684 797 convmps=-ssum(iim,masse_adv_v(ip1jm-iim,l),1) 685 masseps=ssum(iim, masse(ip1jm+1,l ),1)798 masseps=ssum(iim, masse(ip1jm+1,l,iq),1) 686 799 qps=0. 687 800 do ij = ip1jm+1,ip1jmp1-1 688 qps=qps+masse(ij,l )*q(ij,l)801 qps=qps+masse(ij,l,iq)*q(ij,l,iq) 689 802 enddo 690 803 qps=(qps+convps)/(masseps+convmps) 691 804 do ij=ip1jm+1,ip1jmp1 692 q(ij,l )=qps805 q(ij,l,iq)=qps 693 806 enddo 694 807 endif … … 704 817 c DO ij = 1,iip1 705 818 c q(ij,l)=newq 706 c masse(ij,l )=newmasse*aire(ij)819 c masse(ij,l,iq)=newmasse*aire(ij) 707 820 c ENDDO 708 821 c convps=-SSUM(iim,qbyv(ip1jm-iim,l),1) … … 714 827 c DO ij = ip1jm+1,ip1jmp1 715 828 c q(ij,l)=newq 716 c masse(ij,l )=newmasse*aire(ij)829 c masse(ij,l,iq)=newmasse*aire(ij) 717 830 c ENDDO 718 831 c._. fin nouvelle version … … 720 833 c$OMP END DO NOWAIT 721 834 835 ! retablir les fils en rapport de melange par rapport a l'air: 836 ijb=ij_begin 837 ije=ij_end 838 ! if (pole_nord) ijb=ij_begin 839 ! if (pole_sud) ije=ij_end 840 841 if (nqfils(iq).gt.0) then 842 do ifils=1,nqdesc(iq) 843 iq2=iqfils(ifils,iq) 844 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 845 DO l=1,llm 846 DO ij=ijb,ije 847 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 848 enddo 849 enddo 850 c$OMP END DO NOWAIT 851 enddo !do ifils=1,nqdesc(iq) 852 endif !if (nqfils(iq).gt.0) then 853 854 722 855 RETURN 723 856 END … … 725 858 726 859 727 SUBROUTINE vlz_loc(q,pente_max,masse,w,ijb_x,ije_x)860 RECURSIVE SUBROUTINE vlz_loc(q,pente_max,masse,w,ijb_x,ije_x,iq) 728 861 c 729 862 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 739 872 USE parallel_lmdz 740 873 USE vlz_mod 874 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 741 875 IMPLICIT NONE 742 876 c … … 750 884 c Arguments: 751 885 c ---------- 752 REAL masse(ijb_u:ije_u,llm),pente_max 753 REAL q(ijb_u:ije_u,llm) 754 REAL w(ijb_u:ije_u,llm+1) 886 REAL masse(ijb_u:ije_u,llm,nqtot),pente_max 887 REAL q(ijb_u:ije_u,llm,nqtot) 888 REAL w(ijb_u:ije_u,llm+1,nqtot) 889 INTEGER iq 755 890 c 756 891 c Local … … 779 914 LOGICAL,SAVE :: first=.TRUE. 780 915 !$OMP THREADPRIVATE(first) 781 916 917 !REAL masseq(ijb_u:ije_u,llm,nqtot),Ratio(ijb_u:ije_u,llm,nqtot) ! CRisi 918 ! Ces varibles doivent être déclarées en pointer et en save dans 919 ! vlz_loc si on veut qu'elles soient vues par tous les threads. 920 INTEGER ifils,iq2 ! CRisi 782 921 783 922 IF (first) THEN … … 787 926 c sens de W 788 927 928 !write(*,*) 'vlsplt 926: entree dans vlz_loc, iq=',iq 789 929 #ifdef BIDON 790 930 IF(testcpu) THEN … … 799 939 DO l=2,llm 800 940 DO ij=ijb,ije 801 dzqw(ij,l)=q(ij,l-1 )-q(ij,l)941 dzqw(ij,l)=q(ij,l-1,iq)-q(ij,l,iq) 802 942 adzqw(ij,l)=abs(dzqw(ij,l)) 803 943 ENDDO … … 842 982 c calcul de - d( q * w )/ d(sigma) qu'on ajoute a dq pour calculer dq 843 983 984 !write(*,*) 'vlz 982,ijb,ije=',ijb,ije 844 985 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 845 986 DO l = 1,llm-1 846 987 do ij = ijb,ije 847 IF(w(ij,l+1).gt.0.) THEN 848 sigw=w(ij,l+1)/masse(ij,l+1) 849 wq(ij,l+1)=w(ij,l+1)*(q(ij,l+1)+0.5*(1.-sigw)*dzq(ij,l+1)) 988 IF(w(ij,l+1,iq).gt.0.) THEN 989 sigw=w(ij,l+1,iq)/masse(ij,l+1,iq) 990 wq(ij,l+1,iq)=w(ij,l+1,iq)*(q(ij,l+1,iq) 991 : +0.5*(1.-sigw)*dzq(ij,l+1)) 850 992 ELSE 851 sigw=w(ij,l+1)/masse(ij,l) 852 wq(ij,l+1)=w(ij,l+1)*(q(ij,l)-0.5*(1.+sigw)*dzq(ij,l)) 993 sigw=w(ij,l+1,iq)/masse(ij,l,iq) 994 wq(ij,l+1,iq)=w(ij,l+1,iq)*(q(ij,l,iq) 995 : -0.5*(1.+sigw)*dzq(ij,l)) 853 996 ENDIF 854 997 ENDDO 855 998 ENDDO 856 c$OMP END DO NOWAIT 999 c$OMP END DO NOWAIT 1000 !write(*,*) 'vlz 1001' 857 1001 858 1002 c$OMP MASTER 859 1003 DO ij=ijb,ije 860 wq(ij,llm+1 )=0.861 wq(ij,1 )=0.1004 wq(ij,llm+1,iq)=0. 1005 wq(ij,1,iq)=0. 862 1006 ENDDO 863 1007 c$OMP END MASTER 864 1008 c$OMP BARRIER 865 1009 1010 ! CRisi: appel récursif de l'advection sur les fils. 1011 ! Il faut faire ça avant d'avoir mis à jour q et masse 1012 !write(*,*) 'vlsplt 942: iq,nqfils(iq)=',iq,nqfils(iq) 1013 if (nqfils(iq).gt.0) then 1014 do ifils=1,nqdesc(iq) 1015 iq2=iqfils(ifils,iq) 1016 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 1017 DO l=1,llm 1018 DO ij=ijb,ije 1019 masse(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 1020 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 1021 !wq(ij,l,iq2)=wq(ij,l,iq) ! correction bug le 15mai2015 1022 w(ij,l,iq2)=wq(ij,l,iq) 1023 enddo 1024 enddo 1025 c$OMP END DO NOWAIT 1026 enddo !do ifils=1,nqdesc(iq) 1027 c$OMP BARRIER 1028 1029 do ifils=1,nqfils(iq) 1030 iq2=iqfils(ifils,iq) 1031 call vlz_loc(Ratio,pente_max,masse,w,ijb_x,ije_x,iq2) 1032 enddo !do ifils=1,nqfils(iq) 1033 endif !if (nqfils(iq).gt.0) then 1034 ! end CRisi 1035 1036 ! CRisi: On rajoute ici une barrière car on veut être sur que tous les 1037 ! wq soient synchronisés 1038 1039 c$OMP BARRIER 866 1040 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 867 1041 DO l=1,llm 868 1042 DO ij=ijb,ije 869 newmasse=masse(ij,l)+w(ij,l+1)-w(ij,l) 870 q(ij,l)=(q(ij,l)*masse(ij,l)+wq(ij,l+1)-wq(ij,l)) 1043 newmasse=masse(ij,l,iq)+w(ij,l+1,iq)-w(ij,l,iq) 1044 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq) 1045 & +wq(ij,l+1,iq)-wq(ij,l,iq)) 871 1046 & /newmasse 872 masse(ij,l)=newmasse 873 ENDDO 874 ENDDO 875 c$OMP END DO NOWAIT 876 1047 masse(ij,l,iq)=newmasse 1048 ENDDO 1049 ENDDO 1050 c$OMP END DO NOWAIT 1051 1052 1053 ! retablir les fils en rapport de melange par rapport a l'air: 1054 if (nqfils(iq).gt.0) then 1055 do ifils=1,nqdesc(iq) 1056 iq2=iqfils(ifils,iq) 1057 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 1058 DO l=1,llm 1059 DO ij=ijb,ije 1060 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 1061 enddo 1062 enddo 1063 c$OMP END DO NOWAIT 1064 enddo !do ifils=1,nqdesc(iq) 1065 endif !if (nqfils(iq).gt.0) then 877 1066 878 1067 RETURN -
LMDZ5/branches/testing/libf/dyn3dmem/vlspltgen_loc.F
r1910 r2298 27 27 USE Write_Field_loc 28 28 USE VAMPIR 29 USE infotrac, ONLY : nqtot 29 ! CRisi: on rajoute variables utiles d'infotrac 30 USE infotrac, ONLY : nqtot,nqperes,nqdesc,nqfils,iqfils, 31 & ok_iso_verif 30 32 USE vlspltgen_mod 31 33 IMPLICIT NONE … … 64 66 REAL ptarg,pdelarg,foeew,zdelta 65 67 REAL tempe(ijb_u:ije_u) 66 INTEGER ijb,ije,iq 68 INTEGER ijb,ije,iq,iq2,ifils 67 69 LOGICAL, SAVE :: firstcall=.TRUE. 68 70 !$OMP THREADPRIVATE(firstcall) … … 150 152 ije=ij_end 151 153 154 DO iq=1,nqtot 152 155 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 153 156 DO l=1,llm 154 157 DO ij=ijb,ije 155 mw(ij,l )=w(ij,l) * zzw158 mw(ij,l,iq)=w(ij,l) * zzw 156 159 ENDDO 157 160 ENDDO 158 161 c$OMP END DO NOWAIT 159 162 ENDDO 163 164 DO iq=1,nqtot 160 165 c$OMP MASTER 161 166 DO ij=ijb,ije 162 mw(ij,llm+1 )=0.167 mw(ij,llm+1,iq)=0. 163 168 ENDDO 164 169 c$OMP END MASTER 170 ENDDO 165 171 166 172 c CALL SCOPY(ijp1llm,q,1,zq,1) … … 170 176 ije=ij_end 171 177 172 DO iq=1,nqtot 178 DO iq=1,nqtot 173 179 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 174 180 DO l=1,llm … … 179 185 ENDDO 180 186 181 #ifdef DEBUG_IO 187 #ifdef DEBUG_IO 182 188 CALL WriteField_u('mu',mu) 183 189 CALL WriteField_v('mv',mv) … … 186 192 #endif 187 193 194 ! verif temporaire 195 ijb=ij_begin 196 ije=ij_end 197 if (ok_iso_verif) then 198 call check_isotopes(zq,ijb,ije,'vlspltgen_loc 191') 199 endif !if (ok_iso_verif) then 200 188 201 c$OMP BARRIER 189 DO iq=1,nqtot 190 202 ! DO iq=1,nqtot 203 DO iq=1,nqperes ! CRisi: on ne boucle que sur les pères= ceux qui sont transportés directement par l'air 204 !write(*,*) 'vlspltgen 192: iq,iadv=',iq,iadv(iq) 205 #ifdef DEBUG_IO 206 CALL WriteField_u('zq',zq(:,:,iq)) 207 CALL WriteField_u('zm',zm(:,:,iq)) 208 #endif 209 if(iadv(iq) == 0) then 210 211 cycle 212 213 else if (iadv(iq)==10) then 214 215 #ifdef _ADV_HALO 216 ! CRisi: on ajoute les nombres de fils et tableaux des fils 217 ! On suppose qu'on ne peut advecter les fils que par le schéma 10. 218 call vlx_loc(zq,pente_max,zm,mu, 219 & ij_begin,ij_begin+2*iip1-1,iq) 220 call vlx_loc(zq,pente_max,zm,mu, 221 & ij_end-2*iip1+1,ij_end,iq) 222 #else 223 call vlx_loc(zq,pente_max,zm,mu, 224 & ij_begin,ij_end,iq) 225 #endif 226 227 c$OMP MASTER 228 call VTb(VTHallo) 229 c$OMP END MASTER 230 call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest1) 231 call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest1) 232 ! CRisi 233 do ifils=1,nqdesc(iq) 234 iq2=iqfils(ifils,iq) 235 call Register_Hallo_u(zq(:,:,iq2),llm,2,2,2,2,MyRequest1) 236 call Register_Hallo_u(zm(:,:,iq2),llm,1,1,1,1,MyRequest1) 237 enddo 238 239 c$OMP MASTER 240 call VTe(VTHallo) 241 c$OMP END MASTER 242 else if (iadv(iq)==14) then 243 244 #ifdef _ADV_HALO 245 call vlxqs_loc(zq,pente_max,zm,mu, 246 & qsat,ij_begin,ij_begin+2*iip1-1,iq) 247 call vlxqs_loc(zq,pente_max,zm,mu, 248 & qsat,ij_end-2*iip1+1,ij_end,iq) 249 #else 250 call vlxqs_loc(zq,pente_max,zm,mu, 251 & qsat,ij_begin,ij_end,iq) 252 #endif 253 254 c$OMP MASTER 255 call VTb(VTHallo) 256 c$OMP END MASTER 257 258 call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest1) 259 call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest1) 260 do ifils=1,nqdesc(iq) 261 iq2=iqfils(ifils,iq) 262 call Register_Hallo_u(zq(:,:,iq2),llm,2,2,2,2,MyRequest1) 263 call Register_Hallo_u(zm(:,:,iq2),llm,1,1,1,1,MyRequest1) 264 enddo 265 266 c$OMP MASTER 267 call VTe(VTHallo) 268 c$OMP END MASTER 269 else 270 271 stop 'vlspltgen_p : schema non parallelise' 272 273 endif 274 275 enddo !DO iq=1,nqperes 276 277 278 c$OMP BARRIER 279 c$OMP MASTER 280 call VTb(VTHallo) 281 c$OMP END MASTER 282 283 call SendRequest(MyRequest1) 284 285 c$OMP MASTER 286 call VTe(VTHallo) 287 c$OMP END MASTER 288 c$OMP BARRIER 289 290 ! verif temporaire 291 ijb=ij_begin-2*iip1 292 ije=ij_end+2*iip1 293 if (pole_nord) ijb=ij_begin 294 if (pole_sud) ije=ij_end 295 if (ok_iso_verif) then 296 call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 280') 297 endif !if (ok_iso_verif) then 298 299 do iq=1,nqperes 300 !write(*,*) 'vlspltgen 279: iq=',iq 301 302 if(iadv(iq) == 0) then 303 304 cycle 305 306 else if (iadv(iq)==10) then 307 308 #ifdef _ADV_HALLO 309 call vlx_loc(zq,pente_max,zm,mu, 310 & ij_begin+2*iip1,ij_end-2*iip1,iq) 311 #endif 312 else if (iadv(iq)==14) then 313 #ifdef _ADV_HALLO 314 call vlxqs_loc(zq,pente_max,zm,mu, 315 & qsat,ij_begin+2*iip1,ij_end-2*iip1,iq) 316 #endif 317 else 318 319 stop 'vlspltgen_p : schema non parallelise' 320 321 endif 322 323 enddo 324 c$OMP BARRIER 325 c$OMP MASTER 326 call VTb(VTHallo) 327 c$OMP END MASTER 328 329 ! call WaitRecvRequest(MyRequest1) 330 ! call WaitSendRequest(MyRequest1) 331 c$OMP BARRIER 332 call WaitRequest(MyRequest1) 333 334 335 c$OMP MASTER 336 call VTe(VTHallo) 337 c$OMP END MASTER 338 c$OMP BARRIER 339 340 341 if (ok_iso_verif) then 342 call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 326') 343 endif !if (ok_iso_verif) then 344 if (ok_iso_verif) then 345 ijb=ij_begin-2*iip1 346 ije=ij_end+2*iip1 347 if (pole_nord) ijb=ij_begin 348 if (pole_sud) ije=ij_end 349 call check_isotopes(zq,ijb,ije,'vlspltgen_loc 336') 350 endif !if (ok_iso_verif) then 351 352 do iq=1,nqperes 353 !write(*,*) 'vlspltgen 321: iq=',iq 191 354 #ifdef DEBUG_IO 192 355 CALL WriteField_u('zq',zq(:,:,iq)) 193 356 CALL WriteField_u('zm',zm(:,:,iq)) 194 357 #endif 358 195 359 if(iadv(iq) == 0) then 196 360 … … 198 362 199 363 else if (iadv(iq)==10) then 200 201 #ifdef _ADV_HALO 202 call vlx_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 203 & ij_begin,ij_begin+2*iip1-1) 204 call vlx_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 205 & ij_end-2*iip1+1,ij_end) 206 #else 207 call vlx_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 208 & ij_begin,ij_end) 209 #endif 210 211 c$OMP MASTER 212 call VTb(VTHallo) 213 c$OMP END MASTER 214 call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest1) 215 call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest1) 216 217 c$OMP MASTER 218 call VTe(VTHallo) 219 c$OMP END MASTER 364 365 call vly_loc(zq,pente_max,zm,mv,iq) 366 220 367 else if (iadv(iq)==14) then 221 222 #ifdef _ADV_HALO 223 call vlxqs_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 224 & qsat,ij_begin,ij_begin+2*iip1-1) 225 call vlxqs_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 226 & qsat,ij_end-2*iip1+1,ij_end) 227 #else 228 229 call vlxqs_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 230 & qsat,ij_begin,ij_end) 231 #endif 232 233 c$OMP MASTER 234 call VTb(VTHallo) 235 c$OMP END MASTER 236 237 call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest1) 238 call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest1) 239 240 c$OMP MASTER 241 call VTe(VTHallo) 242 c$OMP END MASTER 368 369 call vlyqs_loc(zq,pente_max,zm,mv, 370 & qsat,iq) 371 243 372 else 244 373 … … 246 375 247 376 endif 248 249 enddo 250 251 252 c$OMP BARRIER 253 c$OMP MASTER 254 call VTb(VTHallo) 255 c$OMP END MASTER 256 257 call SendRequest(MyRequest1) 258 259 c$OMP MASTER 260 call VTe(VTHallo) 261 c$OMP END MASTER 262 c$OMP BARRIER 263 do iq=1,nqtot 264 265 if(iadv(iq) == 0) then 266 267 cycle 268 269 else if (iadv(iq)==10) then 270 271 #ifdef _ADV_HALLO 272 call vlx_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 273 & ij_begin+2*iip1,ij_end-2*iip1) 274 #endif 275 else if (iadv(iq)==14) then 276 #ifdef _ADV_HALLO 277 call vlxqs_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 278 & qsat,ij_begin+2*iip1,ij_end-2*iip1) 279 #endif 280 else 281 282 stop 'vlspltgen_p : schema non parallelise' 283 284 endif 285 286 enddo 287 c$OMP BARRIER 288 c$OMP MASTER 289 call VTb(VTHallo) 290 c$OMP END MASTER 291 292 ! call WaitRecvRequest(MyRequest1) 293 ! call WaitSendRequest(MyRequest1) 294 c$OMP BARRIER 295 call WaitRequest(MyRequest1) 296 297 298 c$OMP MASTER 299 call VTe(VTHallo) 300 c$OMP END MASTER 301 c$OMP BARRIER 302 303 304 do iq=1,nqtot 377 378 enddo 379 380 if (ok_iso_verif) then 381 call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 357') 382 endif !if (ok_iso_verif) then 383 384 do iq=1,nqperes 385 !write(*,*) 'vlspltgen 349: iq=',iq 305 386 #ifdef DEBUG_IO 306 387 CALL WriteField_u('zq',zq(:,:,iq)) 307 388 CALL WriteField_u('zm',zm(:,:,iq)) 308 389 #endif 390 if(iadv(iq) == 0) then 391 392 cycle 393 394 else if (iadv(iq)==10 .or. iadv(iq)==14 ) then 395 396 c$OMP BARRIER 397 #ifdef _ADV_HALLO 398 call vlz_loc(zq,pente_max,zm,mw, 399 & ij_begin,ij_begin+2*iip1-1,iq) 400 call vlz_loc(zq,pente_max,zm,mw, 401 & ij_end-2*iip1+1,ij_end,iq) 402 #else 403 call vlz_loc(zq,pente_max,zm,mw, 404 & ij_begin,ij_end,iq) 405 #endif 406 c$OMP BARRIER 407 408 c$OMP MASTER 409 call VTb(VTHallo) 410 c$OMP END MASTER 411 412 call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest2) 413 call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest2) 414 ! CRisi 415 do ifils=1,nqdesc(iq) 416 iq2=iqfils(ifils,iq) 417 call Register_Hallo_u(zq(:,:,iq2),llm,2,2,2,2,MyRequest2) 418 call Register_Hallo_u(zm(:,:,iq2),llm,1,1,1,1,MyRequest2) 419 enddo 420 c$OMP MASTER 421 call VTe(VTHallo) 422 c$OMP END MASTER 423 c$OMP BARRIER 424 else 425 426 stop 'vlspltgen_p : schema non parallelise' 427 428 endif 429 430 enddo 431 c$OMP BARRIER 432 433 c$OMP MASTER 434 call VTb(VTHallo) 435 c$OMP END MASTER 436 437 call SendRequest(MyRequest2) 438 439 c$OMP MASTER 440 call VTe(VTHallo) 441 c$OMP END MASTER 442 443 444 if (ok_iso_verif) then 445 call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 429') 446 endif !if (ok_iso_verif) then 447 448 c$OMP BARRIER 449 do iq=1,nqperes 450 !write(*,*) 'vlspltgen 409: iq=',iq 451 309 452 if(iadv(iq) == 0) then 310 453 311 454 cycle 312 455 313 else if (iadv(iq)==10 ) then314 315 call vly_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mv) 316 317 else if (iadv(iq)==14) then 318 319 call vlyqs_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mv, 320 & qsat) 321 456 else if (iadv(iq)==10 .or. iadv(iq)==14 ) then 457 c$OMP BARRIER 458 459 #ifdef _ADV_HALLO 460 call vlz_loc(zq,pente_max,zm,mw, 461 & ij_begin+2*iip1,ij_end-2*iip1,iq) 462 #endif 463 464 c$OMP BARRIER 322 465 else 323 466 … … 325 468 326 469 endif 327 328 enddo 329 330 331 do iq=1,nqtot 470 471 enddo 472 !write(*,*) 'vlspltgen_loc 476' 473 474 c$OMP BARRIER 475 !write(*,*) 'vlspltgen_loc 477' 476 c$OMP MASTER 477 call VTb(VTHallo) 478 c$OMP END MASTER 479 480 ! call WaitRecvRequest(MyRequest2) 481 ! call WaitSendRequest(MyRequest2) 482 c$OMP BARRIER 483 CALL WaitRequest(MyRequest2) 484 485 c$OMP MASTER 486 call VTe(VTHallo) 487 c$OMP END MASTER 488 c$OMP BARRIER 489 490 491 !write(*,*) 'vlspltgen_loc 494' 492 if (ok_iso_verif) then 493 call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 461') 494 endif !if (ok_iso_verif) then 495 496 do iq=1,nqperes 497 !write(*,*) 'vlspltgen 449: iq=',iq 332 498 #ifdef DEBUG_IO 333 499 CALL WriteField_u('zq',zq(:,:,iq)) 334 500 CALL WriteField_u('zm',zm(:,:,iq)) 335 501 #endif 502 if(iadv(iq) == 0) then 503 504 cycle 505 506 else if (iadv(iq)==10) then 507 508 call vly_loc(zq,pente_max,zm,mv,iq) 509 510 else if (iadv(iq)==14) then 511 512 call vlyqs_loc(zq,pente_max,zm,mv, 513 & qsat,iq) 514 515 else 516 517 stop 'vlspltgen_p : schema non parallelise' 518 519 endif 520 521 enddo !do iq=1,nqperes 522 523 if (ok_iso_verif) then 524 call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 493') 525 endif !if (ok_iso_verif) then 526 527 do iq=1,nqperes 528 !write(*,*) 'vlspltgen 477: iq=',iq 529 #ifdef DEBUG_IO 530 CALL WriteField_u('zq',zq(:,:,iq)) 531 CALL WriteField_u('zm',zm(:,:,iq)) 532 #endif 336 533 if(iadv(iq) == 0) then 337 534 338 535 cycle 339 536 340 else if (iadv(iq)==10 .or. iadv(iq)==14 ) then341 342 c$OMP BARRIER343 #ifdef _ADV_HALLO344 call vlz_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mw,345 & ij_begin,ij_begin+2*iip1-1)346 call vlz_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mw,347 & ij_end-2*iip1+1,ij_end)348 #else349 call vlz_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mw,350 & ij_begin,ij_end)351 #endif352 c$OMP BARRIER353 354 c$OMP MASTER355 call VTb(VTHallo)356 c$OMP END MASTER357 358 call Register_Hallo_u(zq(:,:,iq),llm,2,2,2,2,MyRequest2)359 call Register_Hallo_u(zm(:,:,iq),llm,1,1,1,1,MyRequest2)360 361 c$OMP MASTER362 call VTe(VTHallo)363 c$OMP END MASTER364 c$OMP BARRIER365 else366 367 stop 'vlspltgen_p : schema non parallelise'368 369 endif370 371 enddo372 c$OMP BARRIER373 374 c$OMP MASTER375 call VTb(VTHallo)376 c$OMP END MASTER377 378 call SendRequest(MyRequest2)379 380 c$OMP MASTER381 call VTe(VTHallo)382 c$OMP END MASTER383 384 c$OMP BARRIER385 do iq=1,nqtot386 387 if(iadv(iq) == 0) then388 389 cycle390 391 else if (iadv(iq)==10 .or. iadv(iq)==14 ) then392 c$OMP BARRIER393 394 #ifdef _ADV_HALLO395 call vlz_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mw,396 & ij_begin+2*iip1,ij_end-2*iip1)397 #endif398 399 c$OMP BARRIER400 else401 402 stop 'vlspltgen_p : schema non parallelise'403 404 endif405 406 enddo407 408 c$OMP BARRIER409 c$OMP MASTER410 call VTb(VTHallo)411 c$OMP END MASTER412 413 ! call WaitRecvRequest(MyRequest2)414 ! call WaitSendRequest(MyRequest2)415 c$OMP BARRIER416 CALL WaitRequest(MyRequest2)417 418 c$OMP MASTER419 call VTe(VTHallo)420 c$OMP END MASTER421 c$OMP BARRIER422 423 424 do iq=1,nqtot425 #ifdef DEBUG_IO426 CALL WriteField_u('zq',zq(:,:,iq))427 CALL WriteField_u('zm',zm(:,:,iq))428 #endif429 if(iadv(iq) == 0) then430 431 cycle432 433 537 else if (iadv(iq)==10) then 434 538 435 call vly_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mv) 539 call vlx_loc(zq,pente_max,zm,mu, 540 & ij_begin,ij_end,iq) 436 541 437 542 else if (iadv(iq)==14) then 438 543 439 call vl yqs_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mv,440 & qsat)544 call vlxqs_loc(zq,pente_max,zm,mu, 545 & qsat, ij_begin,ij_end,iq) 441 546 442 547 else 443 548 444 549 stop 'vlspltgen_p : schema non parallelise' 445 550 446 551 endif 447 552 448 enddo 449 450 451 do iq=1,nqtot 452 #ifdef DEBUG_IO 453 CALL WriteField_u('zq',zq(:,:,iq)) 454 CALL WriteField_u('zm',zm(:,:,iq)) 455 #endif 456 if(iadv(iq) == 0) then 457 458 cycle 459 460 else if (iadv(iq)==10) then 461 462 call vlx_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 463 & ij_begin,ij_end) 464 465 else if (iadv(iq)==14) then 466 467 call vlxqs_loc(zq(ijb_u,1,iq),pente_max,zm(ijb_u,1,iq),mu, 468 & qsat, ij_begin,ij_end) 469 470 else 471 472 stop 'vlspltgen_p : schema non parallelise' 473 474 endif 475 476 enddo 477 553 enddo !do iq=1,nqperes 554 555 !write(*,*) 'vlspltgen 550: apres derniere serie de call vlx' 556 if (ok_iso_verif) then 557 call check_isotopes(zq,ij_begin,ij_end,'vlspltgen_loc 521') 558 endif !if (ok_iso_verif) then 478 559 479 560 ijb=ij_begin 480 561 ije=ij_end 562 !write(*,*) 'vlspltgen_loc 557' 481 563 c$OMP BARRIER 482 564 483 565 !write(*,*) 'vlspltgen_loc 559' 484 566 DO iq=1,nqtot 567 !write(*,*) 'vlspltgen_loc 561, iq=',iq 485 568 #ifdef DEBUG_IO 486 569 CALL WriteField_u('zq',zq(:,:,iq)) … … 495 578 ENDDO 496 579 ENDDO 497 c$OMP END DO NOWAIT 580 c$OMP END DO NOWAIT 581 !write(*,*) 'vlspltgen_loc 575' 498 582 499 583 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) … … 504 588 ENDDO 505 589 c$OMP END DO NOWAIT 506 507 ENDDO 590 !write(*,*) 'vlspltgen_loc 583' 591 ENDDO !DO iq=1,nqtot 508 592 509 593 if (ok_iso_verif) then 594 call check_isotopes(q,ij_begin,ij_end,'vlspltgen_loc 557') 595 endif !if (ok_iso_verif) then 596 510 597 c$OMP BARRIER 511 598 … … 516 603 cc$OMP BARRIER 517 604 605 !write(*,*) 'vlspltgen 597: sortie' 518 606 RETURN 519 607 END -
LMDZ5/branches/testing/libf/dyn3dmem/vlspltgen_mod.F90
r1910 r2298 2 2 3 3 REAL,POINTER,SAVE :: qsat(:,:) 4 REAL,POINTER,SAVE :: mu(:,:) 4 REAL,POINTER,SAVE :: mu(:,:) ! CRisi: on ajoute une dimension 5 5 REAL,POINTER,SAVE :: mv(:,:) 6 REAL,POINTER,SAVE :: mw(:,: )6 REAL,POINTER,SAVE :: mw(:,:,:) 7 7 REAL,POINTER,SAVE :: zm(:,:,:) 8 8 REAL,POINTER,SAVE :: zq(:,:,:) … … 25 25 CALL allocate_u(mu,llm,d) 26 26 CALL allocate_v(mv,llm,d) 27 CALL allocate_u(mw,llm+1, d)27 CALL allocate_u(mw,llm+1,nqtot,d) 28 28 CALL allocate_u(zm,llm,nqtot,d) 29 29 CALL allocate_u(zq,llm,nqtot,d) -
LMDZ5/branches/testing/libf/dyn3dmem/vlspltqs_loc.F
r1910 r2298 1 SUBROUTINE vlxqs_loc(q,pente_max,masse,u_m,qsat,ijb_x,ije_x )1 SUBROUTINE vlxqs_loc(q,pente_max,masse,u_m,qsat,ijb_x,ije_x,iq) 2 2 c 3 3 c Auteurs: P.Le Van, F.Hourdin, F.Forget 4 4 c 5 5 c ******************************************************************** 6 c Shema d' advection " pseudo amont " .6 c Shema d''advection " pseudo amont " . 7 7 c ******************************************************************** 8 8 c 9 9 c -------------------------------------------------------------------- 10 10 USE parallel_lmdz 11 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 11 12 IMPLICIT NONE 12 13 c … … 20 21 c Arguments: 21 22 c ---------- 22 REAL masse(ijb_u:ije_u,llm ),pente_max23 REAL masse(ijb_u:ije_u,llm,nqtot),pente_max 23 24 REAL u_m( ijb_u:ije_u,llm ) 24 REAL q(ijb_u:ije_u,llm )25 REAL q(ijb_u:ije_u,llm,nqtot) 25 26 REAL qsat(ijb_u:ije_u,llm) 27 INTEGER iq ! CRisi 26 28 c 27 29 c Local … … 36 38 REAL adxqu(ijb_u:ije_u),dxqmax(ijb_u:ije_u,llm) 37 39 REAL u_mq(ijb_u:ije_u,llm) 40 REAL Ratio(ijb_u:ije_u,llm,nqtot) ! CRisi 41 INTEGER ifils,iq2 ! CRisi 42 38 43 39 44 REAL SSUM … … 42 47 INTEGER ijb,ije,ijb_x,ije_x 43 48 49 !write(*,*) 'vlspltqs 58: entree vlxqs_loc, iq,ijb_x=', 50 ! & iq,ijb_x 44 51 45 52 c calcul de la pente a droite et a gauche de la maille … … 65 72 DO l = 1, llm 66 73 DO ij=ijb,ije-1 67 dxqu(ij)=q(ij+1,l )-q(ij,l)74 dxqu(ij)=q(ij+1,l,iq)-q(ij,l,iq) 68 75 c IF(u_m(ij,l).lt.0.) stop'limx n admet pas les U<0' 69 c sigu(ij)=u_m(ij,l)/masse(ij,l )76 c sigu(ij)=u_m(ij,l)/masse(ij,l,iq) 70 77 ENDDO 71 78 DO ij=ijb+iip1-1,ije,iip1 … … 120 127 DO l = 1, llm 121 128 DO ij=ijb,ije-1 122 dxqu(ij)=q(ij+1,l )-q(ij,l)129 dxqu(ij)=q(ij+1,l,iq)-q(ij,l,iq) 123 130 ENDDO 124 131 DO ij=ijb+iip1-1,ije,iip1 … … 179 186 DO l=1,llm 180 187 DO ij=ijb,ije-1 181 zdum(ij,l)=cvmgp(1.-u_m(ij,l)/masse(ij,l ),182 , 1.+u_m(ij,l)/masse(ij+1,l ),188 zdum(ij,l)=cvmgp(1.-u_m(ij,l)/masse(ij,l,iq), 189 , 1.+u_m(ij,l)/masse(ij+1,l,iq), 183 190 , u_m(ij,l)) 184 191 zdum(ij,l)=0.5*zdum(ij,l) 185 192 u_mq(ij,l)=cvmgp( 186 , q(ij,l )+zdum(ij,l)*dxq(ij,l),187 , q(ij+1,l )-zdum(ij,l)*dxq(ij+1,l),193 , q(ij,l,iq)+zdum(ij,l)*dxq(ij,l), 194 , q(ij+1,l,iq)-zdum(ij,l)*dxq(ij+1,l), 188 195 , u_m(ij,l)) 189 196 u_mq(ij,l)=u_m(ij,l)*u_mq(ij,l) … … 195 202 c on cumule le flux correspondant a toutes les mailles dont la masse 196 203 c au travers de la paroi pENDant le pas de temps. 197 c le rapport de melange de l' air advecte est min(q_vanleer, Qsat_downwind)204 c le rapport de melange de l''air advecte est min(q_vanleer, Qsat_downwind) 198 205 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 199 206 DO l=1,llm 200 207 DO ij=ijb,ije-1 201 208 IF (u_m(ij,l).gt.0.) THEN 202 zdum(ij,l)=1.-u_m(ij,l)/masse(ij,l )209 zdum(ij,l)=1.-u_m(ij,l)/masse(ij,l,iq) 203 210 u_mq(ij,l)=u_m(ij,l)* 204 $ min(q(ij,l )+0.5*zdum(ij,l)*dxq(ij,l),qsat(ij+1,l))211 $ min(q(ij,l,iq)+0.5*zdum(ij,l)*dxq(ij,l),qsat(ij+1,l)) 205 212 ELSE 206 zdum(ij,l)=1.+u_m(ij,l)/masse(ij+1,l )213 zdum(ij,l)=1.+u_m(ij,l)/masse(ij+1,l,iq) 207 214 u_mq(ij,l)=u_m(ij,l)* 208 $ min(q(ij+1,l )-0.5*zdum(ij,l)*dxq(ij+1,l),qsat(ij,l))215 $ min(q(ij+1,l,iq)-0.5*zdum(ij,l)*dxq(ij+1,l),qsat(ij,l)) 209 216 ENDIF 210 217 ENDDO … … 273 280 ENDDO 274 281 niju=iju 275 c PRINT*,'niju,nl',niju,nl(l)282 !PRINT*,'vlxqs 280: niju,nl',niju,nl(l) 276 283 277 284 c traitement des mailles … … 285 292 i=ijq-(j-1)*iip1 286 293 c accumulation pour les mailles completements advectees 287 do while(zu_m.gt.masse(ijq,l)) 288 u_mq(ij,l)=u_mq(ij,l)+q(ijq,l)*masse(ijq,l) 289 zu_m=zu_m-masse(ijq,l) 294 do while(zu_m.gt.masse(ijq,l,iq)) 295 u_mq(ij,l)=u_mq(ij,l)+q(ijq,l,iq) 296 & *masse(ijq,l,iq) 297 zu_m=zu_m-masse(ijq,l,iq) 290 298 i=mod(i-2+iim,iim)+1 291 299 ijq=(j-1)*iip1+i 292 300 ENDDO 293 301 c ajout de la maille non completement advectee 294 u_mq(ij,l)=u_mq(ij,l)+zu_m* 295 & (q(ijq,l)+0.5*(1.-zu_m/masse(ijq,l))*dxq(ijq,l))302 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l,iq) 303 & +0.5*(1.-zu_m/masse(ijq,l,iq))*dxq(ijq,l)) 296 304 ELSE 297 305 ijq=ij+1 298 306 i=ijq-(j-1)*iip1 299 307 c accumulation pour les mailles completements advectees 300 do while(-zu_m.gt.masse(ijq,l)) 301 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l)*masse(ijq,l) 302 zu_m=zu_m+masse(ijq,l) 308 do while(-zu_m.gt.masse(ijq,l,iq)) 309 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l,iq) 310 & *masse(ijq,l,iq) 311 zu_m=zu_m+masse(ijq,l,iq) 303 312 i=mod(i,iim)+1 304 313 ijq=(j-1)*iip1+i 305 314 ENDDO 306 315 c ajout de la maille non completement advectee 307 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l )-308 & 0.5*(1.+zu_m/masse(ijq,l ))*dxq(ijq,l))316 u_mq(ij,l)=u_mq(ij,l)+zu_m*(q(ijq,l,iq)- 317 & 0.5*(1.+zu_m/masse(ijq,l,iq))*dxq(ijq,l)) 309 318 ENDIF 310 319 ENDDO … … 325 334 c$OMP END DO NOWAIT 326 335 336 ! CRisi: appel récursif de l'advection sur les fils. 337 ! Il faut faire ça avant d'avoir mis à jour q et masse 338 !write(*,*) 'vlspltqs 336: iq,ijb_x,nqfils(iq)=', 339 ! & iq,ijb_x,nqfils(iq) 340 341 if (nqfils(iq).gt.0) then 342 do ifils=1,nqdesc(iq) 343 iq2=iqfils(ifils,iq) 344 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 345 DO l=1,llm 346 DO ij=ijb,ije 347 masse(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 348 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 349 enddo 350 enddo 351 c$OMP END DO NOWAIT 352 enddo !do ifils=1,nqfils(iq) 353 do ifils=1,nqfils(iq) 354 iq2=iqfils(ifils,iq) 355 !write(*,*) 'vlxqs 349: on appelle vlx pour iq2=',iq2 356 call vlx_loc(Ratio,pente_max,masse,u_mq,ijb_x,ije_x,iq2) 357 enddo !do ifils=1,nqfils(iq) 358 endif !if (nqfils(iq).gt.0) then 359 ! end CRisi 360 361 !write(*,*) 'vlspltqs 360: iq,ijb_x=',iq,ijb_x 362 327 363 c calcul des tendances 328 364 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 329 365 DO l=1,llm 330 366 DO ij=ijb+1,ije 331 new_m=masse(ij,l )+u_m(ij-1,l)-u_m(ij,l)332 q(ij,l )=(q(ij,l)*masse(ij,l)+367 new_m=masse(ij,l,iq)+u_m(ij-1,l)-u_m(ij,l) 368 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+ 333 369 & u_mq(ij-1,l)-u_mq(ij,l)) 334 370 & /new_m 335 masse(ij,l )=new_m336 ENDDO 337 c Modif Fred 22 03 96 correction d' un bug (les scopy ci-dessous)371 masse(ij,l,iq)=new_m 372 ENDDO 373 c Modif Fred 22 03 96 correction d''un bug (les scopy ci-dessous) 338 374 DO ij=ijb+iip1-1,ije,iip1 339 q(ij-iim,l)=q(ij,l) 340 masse(ij-iim,l)=masse(ij,l) 341 ENDDO 342 ENDDO 343 c$OMP END DO NOWAIT 375 q(ij-iim,l,iq)=q(ij,l,iq) 376 masse(ij-iim,l,iq)=masse(ij,l,iq) 377 ENDDO 378 ENDDO 379 c$OMP END DO NOWAIT 380 381 !write(*,*) 'vlspltqs 380: iq,ijb_x=',iq,ijb_x 382 383 ! retablir les fils en rapport de melange par rapport a l'air: 384 if (nqfils(iq).gt.0) then 385 do ifils=1,nqdesc(iq) 386 iq2=iqfils(ifils,iq) 387 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 388 DO l=1,llm 389 DO ij=ijb+1,ije 390 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 391 enddo 392 DO ij=ijb+iip1-1,ije,iip1 393 q(ij-iim,l,iq2)=q(ij,l,iq2) 394 enddo ! DO ij=ijb+iip1-1,ije,iip1 395 enddo 396 c$OMP END DO NOWAIT 397 enddo !do ifils=1,nqdesc(iq) 398 endif !if (nqfils(iq).gt.0) then 399 400 !write(*,*) 'vlspltqs 399: iq,ijb_x=',iq,ijb_x 401 344 402 c CALL SCOPY((jjm-1)*llm,q(iip1+iip1,1),iip1,q(iip2,1),iip1) 345 c CALL SCOPY((jjm-1)*llm,masse(iip1+iip1,1 ),iip1,masse(iip2,1),iip1)403 c CALL SCOPY((jjm-1)*llm,masse(iip1+iip1,1,iq),iip1,masse(iip2,1,iq),iip1) 346 404 347 405 348 406 RETURN 349 407 END 350 SUBROUTINE vlyqs_loc(q,pente_max,masse,masse_adv_v,qsat )408 SUBROUTINE vlyqs_loc(q,pente_max,masse,masse_adv_v,qsat,iq) 351 409 c 352 410 c Auteurs: P.Le Van, F.Hourdin, F.Forget … … 361 419 c -------------------------------------------------------------------- 362 420 USE parallel_lmdz 421 USE infotrac, ONLY : nqtot,nqfils,nqdesc,iqfils ! CRisi 363 422 IMPLICIT NONE 364 423 c … … 373 432 c Arguments: 374 433 c ---------- 375 REAL masse(ijb_u:ije_u,llm ),pente_max434 REAL masse(ijb_u:ije_u,llm,nqtot),pente_max 376 435 REAL masse_adv_v( ijb_v:ije_v,llm) 377 REAL q(ijb_u:ije_u,llm )436 REAL q(ijb_u:ije_u,llm,nqtot) 378 437 REAL qsat(ijb_u:ije_u,llm) 438 INTEGER iq ! CRisi 379 439 c 380 440 c Local … … 386 446 REAL dyq(ijb_u:ije_u,llm),dyqv(ijb_v:ije_v) 387 447 REAL adyqv(ijb_v:ije_v),dyqmax(ijb_u:ije_u) 388 REAL qbyv(ijb_v:ije_v,llm )448 REAL qbyv(ijb_v:ije_v,llm,nqtot) 389 449 390 450 REAL qpns,qpsn,dyn1,dys1,dyn2,dys2,newmasse,fn,fs … … 402 462 c 403 463 c 464 REAL Ratio(ijb_u:ije_u,llm,nqtot) ! CRisi 465 INTEGER ifils,iq2 ! CRisi 466 404 467 REAL SSUM 405 468 … … 407 470 INTEGER ijb,ije 408 471 472 ijb=ij_begin-2*iip1 473 ije=ij_end+2*iip1 474 if (pole_nord) ijb=ij_begin 475 if (pole_sud) ije=ij_end 476 ij=3525 477 l=3 478 if ((ij.ge.ijb).and.(ij.le.ije)) then 479 !write(*,*) 'vlyqs 480: ij,l,iq,ijb,q(ij,l,:)=', 480 ! & ij,l,iq,ijb,q(ij,l,:) 481 endif 482 409 483 IF(first) THEN 410 484 PRINT*,'Shema Amont nouveau appele dans Vanleer ' 485 PRINT*,'vlyqs_loc, iq=',iq 411 486 first=.false. 412 487 do i=2,iip1 … … 439 514 if (pole_nord) then 440 515 DO i = 1, iim 441 airescb(i) = aire(i+ iip1) * q(i+ iip1,l )516 airescb(i) = aire(i+ iip1) * q(i+ iip1,l,iq) 442 517 ENDDO 443 518 qpns = SSUM( iim, airescb ,1 ) / airej2 … … 446 521 if (pole_sud) then 447 522 DO i = 1, iim 448 airesch(i) = aire(i+ ip1jm- iip1) * q(i+ ip1jm- iip1,l )523 airesch(i) = aire(i+ ip1jm- iip1) * q(i+ ip1jm- iip1,l,iq) 449 524 ENDDO 450 525 qpsn = SSUM( iim, airesch ,1 ) / airejjm … … 460 535 461 536 DO ij=ijb,ije 462 dyqv(ij)=q(ij,l )-q(ij+iip1,l)537 dyqv(ij)=q(ij,l,iq)-q(ij+iip1,l,iq) 463 538 adyqv(ij)=abs(dyqv(ij)) 464 539 ENDDO … … 482 557 c calcul des pentes aux poles 483 558 DO ij=1,iip1 484 dyq(ij,l)=qpns-q(ij+iip1,l )559 dyq(ij,l)=qpns-q(ij+iip1,l,iq) 485 560 ENDDO 486 561 … … 513 588 514 589 DO ij=1,iip1 515 dyq(ip1jm+ij,l)=q(ip1jm+ij-iip1,l )-qpsn590 dyq(ip1jm+ij,l)=q(ip1jm+ij-iip1,l,iq)-qpsn 516 591 ENDDO 517 592 … … 636 711 DO ij=ijb,ije 637 712 IF( masse_adv_v(ij,l).GT.0. ) THEN 638 qbyv(ij,l)= MIN( qsat(ij+iip1,l), q(ij+iip1,l ) + 639 , dyq(ij+iip1,l)*0.5*(1.-masse_adv_v(ij,l)/masse(ij+iip1,l))) 713 qbyv(ij,l,iq)= MIN( qsat(ij+iip1,l), q(ij+iip1,l,iq ) + 714 , dyq(ij+iip1,l)*0.5*(1.-masse_adv_v(ij,l) 715 , /masse(ij+iip1,l,iq))) 640 716 ELSE 641 qbyv(ij,l )= MIN( qsat(ij,l), q(ij,l) - dyq(ij,l) *642 , 0.5*(1.+masse_adv_v(ij,l)/masse(ij,l )) )717 qbyv(ij,l,iq)= MIN( qsat(ij,l), q(ij,l,iq) - dyq(ij,l) * 718 , 0.5*(1.+masse_adv_v(ij,l)/masse(ij,l,iq)) ) 643 719 ENDIF 644 qbyv(ij,l ) = masse_adv_v(ij,l)*qbyv(ij,l)720 qbyv(ij,l,iq) = masse_adv_v(ij,l)*qbyv(ij,l,iq) 645 721 ENDDO 646 722 ENDDO 647 723 c$OMP END DO NOWAIT 724 725 ! CRisi: appel récursif de l'advection sur les fils. 726 ! Il faut faire ça avant d'avoir mis à jour q et masse 727 !write(*,*) 'vlyqs 689: iq,nqfils(iq)=',iq,nqfils(iq) 728 729 ijb=ij_begin-2*iip1 730 ije=ij_end+2*iip1 731 if (pole_nord) ijb=ij_begin 732 if (pole_sud) ije=ij_end 733 734 if (nqfils(iq).gt.0) then 735 do ifils=1,nqdesc(iq) 736 iq2=iqfils(ifils,iq) 737 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 738 DO l=1,llm 739 DO ij=ijb,ije 740 masse(ij,l,iq2)=masse(ij,l,iq)*q(ij,l,iq) 741 Ratio(ij,l,iq2)=q(ij,l,iq2)/q(ij,l,iq) 742 enddo 743 enddo 744 c$OMP END DO NOWAIT 745 enddo !do ifils=1,nqdesc(iq) 746 do ifils=1,nqfils(iq) 747 iq2=iqfils(ifils,iq) 748 call vly_loc(Ratio,pente_max,masse,qbyv,iq2) 749 enddo !do ifils=1,nqfils(iq) 750 endif !if (nqfils(iq).gt.0) then 751 752 753 ! end CRisi 648 754 649 755 ijb=ij_begin … … 655 761 DO l=1,llm 656 762 DO ij=ijb,ije 657 newmasse=masse(ij,l )763 newmasse=masse(ij,l,iq) 658 764 & +masse_adv_v(ij,l)-masse_adv_v(ij-iip1,l) 659 q(ij,l )=(q(ij,l)*masse(ij,l)+qbyv(ij,l)-qbyv(ij-iip1,l))660 & /newmasse661 masse(ij,l )=newmasse765 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+qbyv(ij,l,iq) 766 & -qbyv(ij-iip1,l,iq))/newmasse 767 masse(ij,l,iq)=newmasse 662 768 ENDDO 663 769 c.-. ancienne version … … 665 771 IF (pole_nord) THEN 666 772 667 convpn=SSUM(iim,qbyv(1,l ),1)/apoln773 convpn=SSUM(iim,qbyv(1,l,iq),1)/apoln 668 774 convmpn=ssum(iim,masse_adv_v(1,l),1)/apoln 669 775 DO ij = 1,iip1 670 newmasse=masse(ij,l )+convmpn*aire(ij)671 q(ij,l )=(q(ij,l)*masse(ij,l)+convpn*aire(ij))/776 newmasse=masse(ij,l,iq)+convmpn*aire(ij) 777 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+convpn*aire(ij))/ 672 778 & newmasse 673 masse(ij,l )=newmasse779 masse(ij,l,iq)=newmasse 674 780 ENDDO 675 781 … … 678 784 IF (pole_sud) THEN 679 785 680 convps = -SSUM(iim,qbyv(ip1jm-iim,l ),1)/apols786 convps = -SSUM(iim,qbyv(ip1jm-iim,l,iq),iq,1)/apols 681 787 convmps = -SSUM(iim,masse_adv_v(ip1jm-iim,l),1)/apols 682 788 DO ij = ip1jm+1,ip1jmp1 683 newmasse=masse(ij,l )+convmps*aire(ij)684 q(ij,l )=(q(ij,l)*masse(ij,l)+convps*aire(ij))/789 newmasse=masse(ij,l,iq)+convmps*aire(ij) 790 q(ij,l,iq)=(q(ij,l,iq)*masse(ij,l,iq)+convps*aire(ij))/ 685 791 & newmasse 686 masse(ij,l )=newmasse792 masse(ij,l,iq)=newmasse 687 793 ENDDO 688 794 … … 691 797 692 798 c._. nouvelle version 693 c convpn=SSUM(iim,qbyv(1,l ),1)799 c convpn=SSUM(iim,qbyv(1,l,iq),1) 694 800 c convmpn=ssum(iim,masse_adv_v(1,l),1) 695 c oldmasse=ssum(iim,masse(1,l ),1)801 c oldmasse=ssum(iim,masse(1,l,iq),1) 696 802 c newmasse=oldmasse+convmpn 697 c newq=(q(1,l )*oldmasse+convpn)/newmasse803 c newq=(q(1,l,iq)*oldmasse+convpn)/newmasse 698 804 c newmasse=newmasse/apoln 699 805 c DO ij = 1,iip1 700 c q(ij,l )=newq701 c masse(ij,l )=newmasse*aire(ij)806 c q(ij,l,iq)=newq 807 c masse(ij,l,iq)=newmasse*aire(ij) 702 808 c ENDDO 703 c convps=-SSUM(iim,qbyv(ip1jm-iim,l ),1)809 c convps=-SSUM(iim,qbyv(ip1jm-iim,l,iq),1) 704 810 c convmps=-ssum(iim,masse_adv_v(ip1jm-iim,l),1) 705 c oldmasse=ssum(iim,masse(ip1jm-iim,l ),1)811 c oldmasse=ssum(iim,masse(ip1jm-iim,l,iq),1) 706 812 c newmasse=oldmasse+convmps 707 c newq=(q(ip1jmp1,l )*oldmasse+convps)/newmasse813 c newq=(q(ip1jmp1,l,iq)*oldmasse+convps)/newmasse 708 814 c newmasse=newmasse/apols 709 815 c DO ij = ip1jm+1,ip1jmp1 710 c q(ij,l )=newq711 c masse(ij,l )=newmasse*aire(ij)816 c q(ij,l,iq)=newq 817 c masse(ij,l,iq)=newmasse*aire(ij) 712 818 c ENDDO 713 819 c._. fin nouvelle version 714 820 ENDDO 715 821 c$OMP END DO NOWAIT 822 823 ! retablir les fils en rapport de melange par rapport a l'air: 824 ijb=ij_begin 825 ije=ij_end 826 ! if (pole_nord) ijb=ij_begin+iip1 827 ! if (pole_sud) ije=ij_end-iip1 828 829 if (nqfils(iq).gt.0) then 830 do ifils=1,nqdesc(iq) 831 iq2=iqfils(ifils,iq) 832 c$OMP DO SCHEDULE(STATIC,OMP_CHUNK) 833 DO l=1,llm 834 DO ij=ijb,ije 835 q(ij,l,iq2)=q(ij,l,iq)*Ratio(ij,l,iq2) 836 enddo 837 enddo 838 c$OMP END DO NOWAIT 839 enddo !do ifils=1,nqdesc(iq) 840 endif !if (nqfils(iq).gt.0) then 841 842 716 843 RETURN 717 844 END -
LMDZ5/branches/testing/libf/dyn3dmem/vlz_mod.F90
r1910 r2298 1 1 MODULE vlz_mod 2 2 3 REAL,POINTER,SAVE :: wq(:,: )3 REAL,POINTER,SAVE :: wq(:,:,:) 4 4 REAL,POINTER,SAVE :: dzq(:,:) 5 5 REAL,POINTER,SAVE :: dzqw(:,:) 6 6 REAL,POINTER,SAVE :: adzqw(:,:) 7 ! CRisi: pour les traceurs: 8 !REAL,POINTER,SAVE :: masseq(:,:,:) 9 REAL,POINTER,SAVE :: Ratio(:,:,:) 7 10 8 11 CONTAINS … … 18 21 19 22 d=>distrib_vanleer 20 CALL allocate_u(wq,llm+1, d)23 CALL allocate_u(wq,llm+1,nqtot,d) 21 24 CALL allocate_u(dzq,llm,d) 22 25 CALL allocate_u(dzqw,llm,d) 23 26 CALL allocate_u(adzqw,llm,d) 27 if (nqdesc_tot.gt.0) then 28 !CALL allocate_u(masseq,llm,nqtot,d) 29 CALL allocate_u(Ratio,llm,nqtot,d) 30 endif !if (nqdesc_tot.gt.0) then 24 31 25 32 END SUBROUTINE vlz_allocate … … 29 36 USE bands 30 37 USE parallel_lmdz 38 USE infotrac 31 39 IMPLICIT NONE 32 40 TYPE(distrib),INTENT(IN) :: dist … … 36 44 CALL switch_u(dzqw,distrib_vanleer,dist) 37 45 CALL switch_u(adzqw,distrib_vanleer,dist) 46 ! CRisi: 47 if (nqdesc_tot.gt.0) then 48 !CALL switch_u(masseq,distrib_vanleer,dist) 49 CALL switch_u(Ratio,distrib_vanleer,dist) 50 endif !if (nqdesc_tot.gt.0) then 38 51 39 52 END SUBROUTINE vlz_switch_vanleer -
LMDZ5/branches/testing/libf/dyn3dpar/advtrac_p.F90
r1999 r2298 10 10 ! M.A Filiberti (04/2002) 11 11 ! 12 USE parallel_lmdz 13 USE Write_Field_p 14 USE Bands 12 USE parallel_lmdz, ONLY: ij_begin,ij_end,OMP_CHUNK,pole_nord,pole_sud,& 13 setdistrib 14 USE Write_Field_p, ONLY: WriteField_p 15 USE Bands, ONLY: jj_Nb_Caldyn,jj_Nb_vanleer 15 16 USE mod_hallo 16 17 USE Vampir -
LMDZ5/branches/testing/libf/dyn3dpar/covcont_p.F
r1910 r2298 1 1 SUBROUTINE covcont_p (klevel,ucov, vcov, ucont, vcont ) 2 USE parallel_lmdz 2 USE parallel_lmdz, ONLY: ij_begin,ij_end,OMP_CHUNK, 3 & pole_nord, pole_sud 3 4 IMPLICIT NONE 4 5 -
LMDZ5/branches/testing/libf/dyn3dpar/gcm.F
r2258 r2298 14 14 USE parallel_lmdz 15 15 USE infotrac 16 USE mod_interface_dyn_phys 16 #ifdef CPP_PHYS 17 USE mod_interface_dyn_phys, ONLY: init_interface_dyn_phys 18 #endif 17 19 USE mod_hallo 18 20 USE Bands -
LMDZ5/branches/testing/libf/dyn3dpar/leapfrog_p.F
r2258 r2298 825 825 cc$OMP BARRIER 826 826 ! CALL FTRACE_REGION_BEGIN("calfis") 827 #ifdef CPP_PHYS 827 828 CALL calfis_p(lafin ,jD_cur, jH_cur, 828 829 $ ucov,vcov,teta,q,masse,ps,p,pk,phis,phi , 829 830 $ du,dv,dteta,dq, 830 831 $ flxw, dufi,dvfi,dtetafi,dqfi,dpfi ) 832 #endif 831 833 ! CALL FTRACE_REGION_END("calfis") 832 834 ijb=ij_begin -
LMDZ5/branches/testing/libf/dyn3dpar/mod_hallo.F90
r1910 r2298 1 1 module mod_Hallo 2 USE parallel_lmdz 2 USE mod_const_mpi, ONLY: COMM_LMDZ,MPI_REAL_LMDZ 3 USE parallel_lmdz, ONLY: using_mpi, mpi_size, mpi_rank, omp_chunk, omp_rank, & 4 pole_nord, pole_sud, jj_begin, jj_end, & 5 jj_begin_para, jj_end_para 3 6 implicit none 4 7 logical,save :: use_mpi_alloc -
LMDZ5/branches/testing/libf/dyn3dpar/parallel_lmdz.F90
r2056 r2298 31 31 integer, save :: omp_size 32 32 !$OMP THREADPRIVATE(omp_rank) 33 34 ! Ehouarn: add "dummy variables" (which are in dyn3d_mem/parallel_lmdz.F90) 35 ! so that calfis_loc compiles even if using dyn3dpar 36 integer,save :: jjb_u 37 integer,save :: jje_u 38 integer,save :: jjnb_u 39 integer,save :: jjb_v 40 integer,save :: jje_v 41 integer,save :: jjnb_v 42 43 integer,save :: ijb_u 44 integer,save :: ije_u 45 integer,save :: ijnb_u 46 47 integer,save :: ijb_v 48 integer,save :: ije_v 49 integer,save :: ijnb_v 33 50 34 51 contains -
LMDZ5/branches/testing/libf/grid/dimension/makdim
r2220 r2298 12 12 fi 13 13 14 if (($1 % 8 != 0)) && (( $# = 3 ))14 if (($1 % 8 != 0)) && (( $# == 3 )) 15 15 then 16 16 echo "The number of longitudes must be a multiple of 8." -
LMDZ5/branches/testing/libf/phylmd/calcul_STDlev.h
r1921 r2298 4 4 !IM on initialise les variables 5 5 ! 6 6 ! missing_val=nf90_fill_real 7 7 ! 8 8 CALL ini_undefSTD(itap,itapm1) -
LMDZ5/branches/testing/libf/phylmd/calcul_fluxs_mod.F90
r1910 r2298 5 5 CONTAINS 6 6 SUBROUTINE calcul_fluxs( knon, nisurf, dtime, & 7 tsurf, p1lay, cal, beta, c oef1lay, ps, &7 tsurf, p1lay, cal, beta, cdragh, cdragq, ps, & 8 8 precip_rain, precip_snow, snow, qsurf, & 9 radsol, dif_grnd, t1lay, q1lay, u1lay, v1lay, &10 petAcoef, peqAcoef, petBcoef, peqBcoef, &9 radsol, dif_grnd, t1lay, q1lay, u1lay, v1lay, gustiness, & 10 fqsat, petAcoef, peqAcoef, petBcoef, peqBcoef, & 11 11 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 12 12 13 13 USE dimphy, ONLY : klon 14 14 USE indice_sol_mod 15 16 INCLUDE "clesphys.h" 15 17 16 18 ! Cette routine calcule les fluxs en h et q a l'interface et eventuellement … … 26 28 ! cal capacite calorifique du sol 27 29 ! beta evap reelle 28 ! coef1lay coefficient d'echange 30 ! cdragh coefficient d'echange temperature 31 ! cdragq coefficient d'echange evaporation 29 32 ! ps pression au sol 30 33 ! precip_rain precipitations liquides … … 59 62 REAL, DIMENSION(klon), INTENT(IN) :: petBcoef, peqBcoef 60 63 REAL, DIMENSION(klon), INTENT(IN) :: ps, q1lay 61 REAL, DIMENSION(klon), INTENT(IN) :: tsurf, p1lay, cal, beta, c oef1lay64 REAL, DIMENSION(klon), INTENT(IN) :: tsurf, p1lay, cal, beta, cdragh,cdragq 62 65 REAL, DIMENSION(klon), INTENT(IN) :: precip_rain, precip_snow ! pas utiles 63 66 REAL, DIMENSION(klon), INTENT(IN) :: radsol, dif_grnd 64 REAL, DIMENSION(klon), INTENT(IN) :: t1lay, u1lay, v1lay 67 REAL, DIMENSION(klon), INTENT(IN) :: t1lay, u1lay, v1lay,gustiness 68 REAL, INTENT(IN) :: fqsat ! correction factor on qsat (generally 0.98 over salty water, 1 everywhere else) 65 69 66 70 ! Parametres entree-sorties … … 79 83 REAL, DIMENSION(klon) :: zx_mh, zx_nh, zx_oh 80 84 REAL, DIMENSION(klon) :: zx_mq, zx_nq, zx_oq 81 REAL, DIMENSION(klon) :: zx_pkh, zx_dq_s_dt, zx_qsat , zx_coef82 REAL, DIMENSION(klon) :: zx_sl, zx_ k185 REAL, DIMENSION(klon) :: zx_pkh, zx_dq_s_dt, zx_qsat 86 REAL, DIMENSION(klon) :: zx_sl, zx_coefh, zx_coefq, zx_wind 83 87 REAL, DIMENSION(klon) :: d_ts 84 88 REAL :: zdelta, zcvm5, zx_qs, zcor, zx_dq_s_dh … … 125 129 fluxlat=0. 126 130 dflux_s = 0. 127 dflux_l = 0. 131 dflux_l = 0. 128 132 ! 129 133 ! zx_qs = qsat en kg/kg … … 154 158 zx_dq_s_dt(i) = RCPD * zx_pkh(i) * zx_dq_s_dh 155 159 zx_qsat(i) = zx_qs 156 zx_coef(i) = coef1lay(i) * & 157 (1.0+SQRT(u1lay(i)**2+v1lay(i)**2)) * & 158 p1lay(i)/(RD*t1lay(i)) 159 160 zx_wind(i)=min_wind_speed+SQRT(gustiness(i)+u1lay(i)**2+v1lay(i)**2) 161 zx_coefh(i) = cdragh(i) * zx_wind(i) * p1lay(i)/(RD*t1lay(i)) 162 zx_coefq(i) = cdragq(i) * zx_wind(i) * p1lay(i)/(RD*t1lay(i)) 163 ! zx_wind(i)=min_wind_speed+SQRT(gustiness(i)+u1lay(i)**2+v1lay(i)**2) & 164 ! * p1lay(i)/(RD*t1lay(i)) 165 ! zx_coefh(i) = cdragh(i) * zx_wind(i) 166 ! zx_coefq(i) = cdragq(i) * zx_wind(i) 160 167 ENDDO 161 168 … … 168 175 zx_sl(i) = RLVTT 169 176 IF (tsurf(i) .LT. RTT) zx_sl(i) = RLSTT 170 zx_k1(i) = zx_coef(i)171 177 ENDDO 172 178 … … 174 180 DO i = 1, knon 175 181 ! Q 176 zx_oq(i) = 1. - (beta(i) * zx_k1(i) * peqBcoef(i) * dtime) 177 zx_mq(i) = beta(i) * zx_k1(i) * & 178 (peqAcoef(i) - zx_qsat(i) + & 179 zx_dq_s_dt(i) * tsurf(i)) & 182 zx_oq(i) = 1. - (beta(i) * zx_coefq(i) * peqBcoef(i) * dtime) 183 zx_mq(i) = beta(i) * zx_coefq(i) * & 184 (peqAcoef(i) - & 185 ! conv num avec precedente version 186 fqsat * zx_qsat(i) + fqsat * zx_dq_s_dt(i) * tsurf(i)) & 187 ! fqsat * ( zx_qsat(i) - zx_dq_s_dt(i) * tsurf(i)) ) & 180 188 / zx_oq(i) 181 zx_nq(i) = beta(i) * zx_ k1(i) * (-1.* zx_dq_s_dt(i)) &189 zx_nq(i) = beta(i) * zx_coefq(i) * (- fqsat * zx_dq_s_dt(i)) & 182 190 / zx_oq(i) 183 191 184 192 ! H 185 zx_oh(i) = 1. - (zx_ k1(i) * petBcoef(i) * dtime)186 zx_mh(i) = zx_ k1(i) * petAcoef(i) / zx_oh(i)187 zx_nh(i) = - (zx_ k1(i) * RCPD * zx_pkh(i))/ zx_oh(i)193 zx_oh(i) = 1. - (zx_coefh(i) * petBcoef(i) * dtime) 194 zx_mh(i) = zx_coefh(i) * petAcoef(i) / zx_oh(i) 195 zx_nh(i) = - (zx_coefh(i) * RCPD * zx_pkh(i))/ zx_oh(i) 188 196 189 197 ! Tsurface … … 244 252 ! 245 253 SUBROUTINE calcul_flux_wind(knon, dtime, & 246 u0, v0, u1, v1, cdrag_m, &254 u0, v0, u1, v1, gustiness, cdrag_m, & 247 255 AcoefU, AcoefV, BcoefU, BcoefV, & 248 256 p1lay, t1lay, & … … 251 259 USE dimphy 252 260 INCLUDE "YOMCST.h" 261 INCLUDE "clesphys.h" 253 262 254 263 ! Input arguments … … 257 266 REAL, INTENT(IN) :: dtime 258 267 REAL, DIMENSION(klon), INTENT(IN) :: u0, v0 ! u and v at niveau 0 259 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 ! u and v at niveau 1268 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness ! u and v at niveau 1 260 269 REAL, DIMENSION(klon), INTENT(IN) :: cdrag_m ! cdrag pour momentum 261 270 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV … … 277 286 !**************************************************************************************** 278 287 DO i=1,knon 279 mod_wind = 1.0 + SQRT((u1(i) - u0(i))**2 + (v1(i)-v0(i))**2)288 mod_wind = min_wind_speed + SQRT(gustiness(i)+(u1(i) - u0(i))**2 + (v1(i)-v0(i))**2) 280 289 buf = cdrag_m(i) * mod_wind * p1lay(i)/(RD*t1lay(i)) 281 290 flux_u1(i) = (AcoefU(i) - u0(i)) / (1/buf - BcoefU(i)*dtime ) -
LMDZ5/branches/testing/libf/phylmd/carbon_cycle_mod.F90
r1910 r2298 157 157 itc=0 158 158 DO it=1,nbtr 159 iiq=niadv(it+2) 159 !! iiq=niadv(it+2) ! jyg 160 iiq=niadv(it+nqo) ! jyg 160 161 161 162 SELECT CASE(tname(iiq)) -
LMDZ5/branches/testing/libf/phylmd/cdrag.F90
r2258 r2298 4 4 SUBROUTINE cdrag( knon, nsrf, & 5 5 speed, t1, q1, zgeop1, & 6 psol, tsurf, qsurf, rugos, &6 psol, tsurf, qsurf, z0m, z0h, & 7 7 pcfm, pcfh, zri, pref ) 8 8 … … 45 45 ! tsurf---input-R- temperature de l'air a la surface 46 46 ! qsurf---input-R- humidite de l'air a la surface 47 ! rugos---input-R- rugosite47 ! z0m, z0h---input-R- rugosite 48 48 !! u1, v1 are removed, speed is used. Fuxing WANG, 04/03/2015, 49 49 !! u1------input-R- vent zonal au 1er niveau du modele … … 71 71 REAL, DIMENSION(klon), INTENT(IN) :: tsurf ! Surface temperature (K) 72 72 REAL, DIMENSION(klon), INTENT(IN) :: qsurf ! Surface humidity (Kg/Kg) 73 REAL, DIMENSION(klon), INTENT(IN) :: rugos! Rugosity at surface (m)73 REAL, DIMENSION(klon), INTENT(IN) :: z0m, z0h ! Rugosity at surface (m) 74 74 ! paprs, pplay u1, v1: to be deleted 75 75 ! they were in the old clcdrag. Fuxing WANG, 04/03/2015 … … 113 113 REAL, DIMENSION(klon) :: zcfh1, zcfh2 ! Drag coefficient for heat flux 114 114 LOGICAL, PARAMETER :: zxli=.FALSE. ! calcul des cdrags selon Laurent Li 115 REAL, DIMENSION(klon) :: zcdn ! Drag coefficient in neutral conditions115 REAL, DIMENSION(klon) :: zcdn_m, zcdn_h ! Drag coefficient in neutral conditions 116 116 ! 117 117 ! Fonctions thermodynamiques et fonctions d'instabilite … … 174 174 *(1.+RETV*max(q1(i),0.0)) ! negative q1 set to zero 175 175 zri(i) = zgeop1(i)*(ztvd-ztsolv)/(zdu2*ztvd) 176 zcdn(i) = (CKAP/LOG(1.+zgeop1(i)/(RG*rugos(i))))**2 176 177 178 ! Coefficients CD neutres pour m et h 179 zcdn_m(i) = (CKAP/LOG(1.+zgeop1(i)/(RG*z0m(i))))**2 180 zcdn_h(i) = (CKAP/LOG(1.+zgeop1(i)/(RG*z0h(i))))**2 177 181 178 182 IF (zri(i) .GT. 0.) THEN ! situation stable … … 181 185 zscf = SQRT(1.+CD*ABS(zri(i))) 182 186 friv = AMAX1(1. / (1.+2.*CB*zri(i)/ZSCF), f_ri_cd_min) 183 zcfm1(i) = zcdn (i) * friv187 zcfm1(i) = zcdn_m(i) * friv 184 188 frih = AMAX1(1./ (1.+3.*CB*zri(i)*ZSCF), f_ri_cd_min ) 185 189 !!$ PB zcfh1(i) = zcdn(i) * frih 186 190 !!$ PB zcfh1(i) = f_cdrag_stable * zcdn(i) * frih 187 zcfh1(i) = f_cdrag_ter * zcdn (i) * frih188 IF(nsrf.EQ.is_oce) zcfh1(i) = f_cdrag_oce * zcdn (i) * frih191 zcfh1(i) = f_cdrag_ter * zcdn_h(i) * frih 192 IF(nsrf.EQ.is_oce) zcfh1(i) = f_cdrag_oce * zcdn_h(i) * frih 189 193 !!$ PB 190 194 pcfm(i) = zcfm1(i) 191 195 pcfh(i) = zcfh1(i) 192 196 ELSE 193 pcfm(i) = zcdn (i)* fsta(zri(i))194 pcfh(i) = zcdn (i)* fsta(zri(i))197 pcfm(i) = zcdn_m(i)* fsta(zri(i)) 198 pcfh(i) = zcdn_h(i)* fsta(zri(i)) 195 199 ENDIF 196 200 ELSE ! situation instable 197 201 IF (.NOT.zxli) THEN 198 zucf = 1./(1.+3.0*CB*CC*zcdn (i)*SQRT(ABS(zri(i)) &199 *(1.0+zgeop1(i)/(RG* rugos(i)))))200 zcfm2(i) = zcdn (i)*amax1((1.-2.0*CB*zri(i)*zucf),f_ri_cd_min)201 !!$ PB zcfh2(i) = zcdn (i)*amax1((1.-3.0*cb*zri(i)*zucf),f_ri_cd_min)202 zcfh2(i) = f_cdrag_ter*zcdn (i)*amax1((1.-3.0*CB*zri(i)*zucf),f_ri_cd_min)202 zucf = 1./(1.+3.0*CB*CC*zcdn_m(i)*SQRT(ABS(zri(i)) & 203 *(1.0+zgeop1(i)/(RG*z0m(i))))) 204 zcfm2(i) = zcdn_m(i)*amax1((1.-2.0*CB*zri(i)*zucf),f_ri_cd_min) 205 !!$ PB zcfh2(i) = zcdn_h(i)*amax1((1.-3.0*cb*zri(i)*zucf),f_ri_cd_min) 206 zcfh2(i) = f_cdrag_ter*zcdn_h(i)*amax1((1.-3.0*CB*zri(i)*zucf),f_ri_cd_min) 203 207 pcfm(i) = zcfm2(i) 204 208 pcfh(i) = zcfh2(i) 205 209 ELSE 206 pcfm(i) = zcdn (i)* fins(zri(i))207 pcfh(i) = zcdn (i)* fins(zri(i))210 pcfm(i) = zcdn_m(i)* fins(zri(i)) 211 pcfh(i) = zcdn_h(i)* fins(zri(i)) 208 212 ENDIF 209 ! cdrah sur l'ocean cf. Miller et al. (1992) 210 zcr = (0.0016/(zcdn(i)*SQRT(zdu2)))*ABS(ztvd-ztsolv)**(1./3.) 211 IF(nsrf.EQ.is_oce) pcfh(i) =f_cdrag_oce* zcdn(i)*(1.0+zcr**1.25)**(1./1.25) 213 IF(iflag_gusts==0) THEN 214 ! cdrah sur l'ocean cf. Miller et al. (1992) - only active when gustiness parameterization is not active 215 zcr = (0.0016/(zcdn_m(i)*SQRT(zdu2)))*ABS(ztvd-ztsolv)**(1./3.) 216 IF(nsrf.EQ.is_oce) pcfh(i) =f_cdrag_oce* zcdn_h(i)*(1.0+zcr**1.25)**(1./1.25) 217 ENDIF 212 218 ENDIF 213 219 END DO -
LMDZ5/branches/testing/libf/phylmd/change_srf_frac_mod.F90
r2258 r2298 12 12 13 13 SUBROUTINE change_srf_frac(itime, dtime, jour, & 14 !albedo SB >>> 15 ! pctsrf, alb1, alb2, tsurf, ustar, u10m, v10m, pbl_tke) 16 pctsrf, alb_dir, alb_dif, tsurf, ustar, u10m, v10m, pbl_tke) 17 !albedo SB <<< 14 pctsrf, evap, z0m, z0h, agesno, & 15 alb_dir, alb_dif, tsurf, ustar, u10m, v10m, pbl_tke) 18 16 19 17 … … 54 52 55 53 REAL, DIMENSION(klon,nbsrf), INTENT(INOUT) :: pctsrf ! sub-surface fraction 54 REAL, DIMENSION(klon,nbsrf), INTENT(INOUT) :: evap, agesno ! sub-surface fraction 55 REAL, DIMENSION(klon,nbsrf+1), INTENT(INOUT) :: z0m,z0h ! sub-surface fraction 56 56 !albedo SB >>> 57 ! REAL, DIMENSION(klon,nbsrf), INTENT(INOUT) :: alb1 ! albedo first interval in SW spektrum58 ! REAL, DIMENSION(klon,nbsrf), INTENT(INOUT) :: alb2 ! albedo second interval in SW spektrum59 57 REAL, DIMENSION(klon,nsw,nbsrf), INTENT(INOUT) :: alb_dir,alb_dif 60 58 !albedo SB <<< … … 176 174 !**************************************************************************************** 177 175 178 !albedo SB >>> 179 ! CALL pbl_surface_newfrac(itime, pctsrf, pctsrf_old, tsurf, alb1, alb2, ustar, 180 ! u10m, v10m, pbl_tke) 181 CALL pbl_surface_newfrac(itime, pctsrf, pctsrf_old, tsurf, alb_dir,alb_dif, ustar, u10m, v10m, pbl_tke) 182 !albedo SB <<< 183 176 CALL pbl_surface_newfrac(itime, pctsrf, pctsrf_old, & 177 evap, z0m, z0h, agesno, & 178 tsurf, alb_dir,alb_dif, ustar, u10m, v10m, pbl_tke) 184 179 185 180 -
LMDZ5/branches/testing/libf/phylmd/clcdrag.F90
r2258 r2298 129 129 pcfh(i) = zcdn(i)* fins(zri(i)) 130 130 ENDIF 131 zcr = (0.0016/(zcdn(i)*SQRT(zdu2)))*ABS(ztvd-ztsolv)**(1./3.) 132 IF(nsrf.EQ.is_oce) pcfh(i) =f_cdrag_oce* zcdn(i)*(1.0+zcr**1.25)**(1./1.25) 131 IF(iflag_gusts==0) THEN 132 ! cdrah sur l'ocean cf. Miller et al. (1992) - only active when gustiness parameterization is not active 133 zcr = (0.0016/(zcdn(i)*SQRT(zdu2)))*ABS(ztvd-ztsolv)**(1./3.) 134 IF(nsrf.EQ.is_oce) pcfh(i) =f_cdrag_oce* zcdn(i)*(1.0+zcr**1.25)**(1./1.25) 135 ENDIF 133 136 ENDIF 134 137 END DO -
LMDZ5/branches/testing/libf/phylmd/clesphys.h
r2258 r2298 44 44 ! Frottement au sol (Cdrag) 45 45 Real f_cdrag_ter,f_cdrag_oce 46 REAL min_wind_speed,f_gust_wk,f_gust_bl,f_qsat_oce,f_z0qh_oce 47 REAL z0m_seaice,z0h_seaice 48 INTEGER iflag_gusts,iflag_z0_oce 49 46 50 ! Rugoro 47 Real f_rugoro 51 Real f_rugoro,z0min 48 52 49 53 !IM lev_histhf : niveau sorties 6h … … 91 95 & , cdmmax, cdhmax, ksta, ksta_ter, f_ri_cd_min & 92 96 & , fmagic, pmagic & 93 & , f_cdrag_ter,f_cdrag_oce,f_rugoro & 97 & , f_cdrag_ter,f_cdrag_oce,f_rugoro,z0min & 98 & , min_wind_speed,f_gust_wk,f_gust_bl,f_qsat_oce,f_z0qh_oce & 99 & , z0m_seaice,z0h_seaice & 94 100 & , pasphys , freq_outNMC, freq_calNMC & 95 101 & , lonmin_ins, lonmax_ins, latmin_ins, latmax_ins & … … 115 121 & , ok_mensuelCOSP,ok_journeCOSP,ok_hfCOSP & 116 122 & , ip_ebil_phy & 123 & , iflag_gusts ,iflag_z0_oce & 117 124 & , ok_lic_melt, aer_type & 118 125 & , iflag_rrtm, ok_strato,ok_hines, ok_qch4 & -
LMDZ5/branches/testing/libf/phylmd/cloudth.F90
r2160 r2298 5 5 6 6 7 USE IOIPSL, ONLY : getin 7 8 IMPLICIT NONE 8 9 … … 39 40 40 41 41 REAL sigma1(ngrid,klev) 42 REAL sigma1(ngrid,klev) 42 43 REAL sigma2(ngrid,klev) 43 44 REAL qlth(ngrid,klev) … … 48 49 REAL ctot(ngrid,klev) 49 50 REAL rneb(ngrid,klev) 50 REAL t(ngrid,klev) 51 REAL t(ngrid,klev) 51 52 REAL qsatmmussig1,qsatmmussig2,sqrt2pi,pi 52 53 REAL rdd,cppd,Lv … … 62 63 REAL erf 63 64 64 65 66 67 68 ! print*,ngrid,klev,ind1,ind2,ztv(ind1,ind2),po(ind1),zqta(ind1,ind2), & 69 ! & fraca(ind1,ind2),zpspsk(ind1,ind2),paprs(ind1,ind2),ztla(ind1,ind2),zthl(ind1,ind2), & 70 ! & 'verif' 71 72 73 ! LOGICAL active(ngrid) 74 75 !----------------------------------------------------------------------------------------------------------------- 65 REAL, SAVE :: iflag_cloudth_vert, iflag_cloudth_vert_omp=0 66 67 68 LOGICAL, SAVE :: first=.true. 69 70 71 72 73 74 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 75 ! Astuce pour gérer deux versions de cloudth en attendant 76 ! de converger sur une version nouvelle 77 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 78 IF (first) THEN 79 !$OMP MASTER 80 CALL getin('iflag_cloudth_vert',iflag_cloudth_vert_omp) 81 !$OMP END MASTER 82 !$OMP BARRIER 83 iflag_cloudth_vert=iflag_cloudth_vert_omp 84 first=.false. 85 ENDIF 86 IF (iflag_cloudth_vert==1) THEN 87 CALL cloudth_vert(ngrid,klev,ind2, & 88 & ztv,po,zqta,fraca, & 89 & qcloud,ctot,zpspsk,paprs,ztla,zthl, & 90 & ratqs,zqs,t) 91 RETURN 92 ENDIF 93 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 94 95 96 97 !------------------------------------------------------------------------------- 76 98 ! Initialisation des variables r?elles 77 !------------------------------------------------------------------------------- ----------------------------------99 !------------------------------------------------------------------------------- 78 100 sigma1(:,:)=0. 79 101 sigma2(:,:)=0. … … 96 118 97 119 98 !------------------------------------------------------------------------------- -----------------------------------120 !------------------------------------------------------------------------------- 99 121 ! Calcul de la fraction du thermique et des ?cart-types des distributions 100 !------------------------------------------------------------------------------- -----------------------------------122 !------------------------------------------------------------------------------- 101 123 do ind1=1,ngrid 102 124 … … 139 161 140 162 141 !------------------------------------------------------------------------------ -----------------------------------163 !------------------------------------------------------------------------------ 142 164 ! Calcul des ?cart-types pour s 143 !------------------------------------------------------------------------------ -----------------------------------165 !------------------------------------------------------------------------------ 144 166 145 167 ! sigma1s=(1.1**0.5)*(fraca(ind1,ind2)**0.6)/(1-fraca(ind1,ind2))*((sth-senv)**2)**0.5+ratqs(ind1,ind2)*po(ind1) … … 155 177 ! sigma2s=0.11*((sth-senv)**2)**0.5/(fraca(ind1,ind2)+0.02)**0.4+0.00003 156 178 157 !------------------------------------------------------------------------------ -----------------------------------179 !------------------------------------------------------------------------------ 158 180 ! Calcul de l'eau condens?e et de la couverture nuageuse 159 !------------------------------------------------------------------------------ -----------------------------------181 !------------------------------------------------------------------------------ 160 182 sqrt2pi=sqrt(2.*pi) 161 183 xth=sth/(sqrt(2.)*sigma2s) … … 176 198 ! print*,senv,sth,sigma1s,sigma2s,fraca(ind1,ind2),'senv et sth et sig1 et sig2 et alpha' 177 199 178 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!200 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 179 201 if (ctot(ind1,ind2).lt.1.e-10) then 180 202 ctot(ind1,ind2)=0. … … 242 264 243 265 244 245 246 247 248 249 250 266 !=========================================================================== 267 SUBROUTINE cloudth_vert(ngrid,klev,ind2, & 268 & ztv,po,zqta,fraca, & 269 & qcloud,ctot,zpspsk,paprs,ztla,zthl, & 270 & ratqs,zqs,t) 271 272 273 IMPLICIT NONE 274 275 276 !=========================================================================== 277 ! Auteur : Arnaud Octavio Jam (LMD/CNRS) 278 ! Date : 25 Mai 2010 279 ! Objet : calcule les valeurs de qc et rneb dans les thermiques 280 !=========================================================================== 281 282 283 #include "YOMCST.h" 284 #include "YOETHF.h" 285 #include "FCTTRE.h" 286 #include "iniprint.h" 287 #include "thermcell.h" 288 289 INTEGER itap,ind1,ind2 290 INTEGER ngrid,klev,klon,l,ig 291 292 REAL ztv(ngrid,klev) 293 REAL po(ngrid) 294 REAL zqenv(ngrid) 295 REAL zqta(ngrid,klev) 296 297 REAL fraca(ngrid,klev+1) 298 REAL zpspsk(ngrid,klev) 299 REAL paprs(ngrid,klev+1) 300 REAL ztla(ngrid,klev) 301 REAL zthl(ngrid,klev) 302 303 REAL zqsatth(ngrid,klev) 304 REAL zqsatenv(ngrid,klev) 305 306 307 REAL sigma1(ngrid,klev) 308 REAL sigma2(ngrid,klev) 309 REAL qlth(ngrid,klev) 310 REAL qlenv(ngrid,klev) 311 REAL qltot(ngrid,klev) 312 REAL cth(ngrid,klev) 313 REAL cenv(ngrid,klev) 314 REAL ctot(ngrid,klev) 315 REAL rneb(ngrid,klev) 316 REAL t(ngrid,klev) 317 REAL qsatmmussig1,qsatmmussig2,sqrt2pi,pi 318 REAL rdd,cppd,Lv,sqrt2,sqrtpi 319 REAL alth,alenv,ath,aenv 320 REAL sth,senv,sigma1s,sigma2s,xth,xenv 321 REAL xth1,xth2,xenv1,xenv2,deltasth, deltasenv 322 REAL IntJ,IntI1,IntI2,IntI3,coeffqlenv,coeffqlth 323 REAL Tbef,zdelta,qsatbef,zcor 324 REAL alpha,qlbef 325 REAL ratqs(ngrid,klev) ! determine la largeur de distribution de vapeur 326 327 REAL zpdf_sig(ngrid),zpdf_k(ngrid),zpdf_delta(ngrid) 328 REAL zpdf_a(ngrid),zpdf_b(ngrid),zpdf_e1(ngrid),zpdf_e2(ngrid) 329 REAL zqs(ngrid), qcloud(ngrid) 330 REAL erf 331 332 333 334 335 336 !------------------------------------------------------------------------------ 337 ! Initialisation des variables r?elles 338 !------------------------------------------------------------------------------ 339 sigma1(:,:)=0. 340 sigma2(:,:)=0. 341 qlth(:,:)=0. 342 qlenv(:,:)=0. 343 qltot(:,:)=0. 344 rneb(:,:)=0. 345 qcloud(:)=0. 346 cth(:,:)=0. 347 cenv(:,:)=0. 348 ctot(:,:)=0. 349 qsatmmussig1=0. 350 qsatmmussig2=0. 351 rdd=287.04 352 cppd=1005.7 353 pi=3.14159 354 Lv=2.5e6 355 sqrt2pi=sqrt(2.*pi) 356 sqrt2=sqrt(2.) 357 sqrtpi=sqrt(pi) 358 359 360 361 !------------------------------------------------------------------------------- 362 ! Calcul de la fraction du thermique et des ?cart-types des distributions 363 !------------------------------------------------------------------------------- 364 do ind1=1,ngrid 365 366 if ((ztv(ind1,1).gt.ztv(ind1,2)).and.(fraca(ind1,ind2).gt.1.e-10)) then 367 368 zqenv(ind1)=(po(ind1)-fraca(ind1,ind2)*zqta(ind1,ind2))/(1.-fraca(ind1,ind2)) 369 370 371 ! zqenv(ind1)=po(ind1) 372 Tbef=zthl(ind1,ind2)*zpspsk(ind1,ind2) 373 zdelta=MAX(0.,SIGN(1.,RTT-Tbef)) 374 qsatbef= R2ES * FOEEW(Tbef,zdelta)/paprs(ind1,ind2) 375 qsatbef=MIN(0.5,qsatbef) 376 zcor=1./(1.-retv*qsatbef) 377 qsatbef=qsatbef*zcor 378 zqsatenv(ind1,ind2)=qsatbef 379 380 381 382 383 alenv=(0.622*Lv*zqsatenv(ind1,ind2))/(rdd*zthl(ind1,ind2)**2) 384 aenv=1./(1.+(alenv*Lv/cppd)) 385 senv=aenv*(po(ind1)-zqsatenv(ind1,ind2)) 386 387 388 389 390 Tbef=ztla(ind1,ind2)*zpspsk(ind1,ind2) 391 zdelta=MAX(0.,SIGN(1.,RTT-Tbef)) 392 qsatbef= R2ES * FOEEW(Tbef,zdelta)/paprs(ind1,ind2) 393 qsatbef=MIN(0.5,qsatbef) 394 zcor=1./(1.-retv*qsatbef) 395 qsatbef=qsatbef*zcor 396 zqsatth(ind1,ind2)=qsatbef 397 398 alth=(0.622*Lv*zqsatth(ind1,ind2))/(rdd*ztla(ind1,ind2)**2) 399 ath=1./(1.+(alth*Lv/cppd)) 400 sth=ath*(zqta(ind1,ind2)-zqsatth(ind1,ind2)) 401 402 403 404 !------------------------------------------------------------------------------ 405 ! Calcul des ?cart-types pour s 406 !------------------------------------------------------------------------------ 407 408 sigma1s=(0.92**0.5)*(fraca(ind1,ind2)**0.5)/(1-fraca(ind1,ind2))*((sth-senv)**2)**0.5+ratqs(ind1,ind2)*po(ind1) 409 sigma2s=0.09*((sth-senv)**2)**0.5/(fraca(ind1,ind2)+0.02)**0.5+0.002*zqta(ind1,ind2) 410 ! if (paprs(ind1,ind2).gt.90000) then 411 ! ratqs(ind1,ind2)=0.002 412 ! else 413 ! ratqs(ind1,ind2)=0.002+0.0*(90000-paprs(ind1,ind2))/20000 414 ! endif 415 ! sigma1s=(1.1**0.5)*(fraca(ind1,ind2)**0.6)/(1-fraca(ind1,ind2))*((sth-senv)**2)**0.5+0.002*po(ind1) 416 ! sigma2s=0.11*((sth-senv)**2)**0.5/(fraca(ind1,ind2)+0.01)**0.4+0.002*zqta(ind1,ind2) 417 ! sigma1s=ratqs(ind1,ind2)*po(ind1) 418 ! sigma2s=0.11*((sth-senv)**2)**0.5/(fraca(ind1,ind2)+0.02)**0.4+0.00003 419 420 !------------------------------------------------------------------------------ 421 ! Calcul de l'eau condens?e et de la couverture nuageuse 422 !------------------------------------------------------------------------------ 423 sqrt2pi=sqrt(2.*pi) 424 xth=sth/(sqrt(2.)*sigma2s) 425 xenv=senv/(sqrt(2.)*sigma1s) 426 cth(ind1,ind2)=0.5*(1.+1.*erf(xth)) 427 cenv(ind1,ind2)=0.5*(1.+1.*erf(xenv)) 428 ctot(ind1,ind2)=fraca(ind1,ind2)*cth(ind1,ind2)+(1.-1.*fraca(ind1,ind2))*cenv(ind1,ind2) 429 ! ctot(ind1,ind2)=alpha*cth(ind1,ind2)+(1.-1.*alpha)*cenv(ind1,ind2) 430 431 432 433 qlth(ind1,ind2)=sigma2s*((exp(-1.*xth**2)/sqrt2pi)+xth*sqrt(2.)*cth(ind1,ind2)) 434 qlenv(ind1,ind2)=sigma1s*((exp(-1.*xenv**2)/sqrt2pi)+xenv*sqrt(2.)*cenv(ind1,ind2)) 435 qltot(ind1,ind2)=fraca(ind1,ind2)*qlth(ind1,ind2)+(1.-1.*fraca(ind1,ind2))*qlenv(ind1,ind2) 436 ! qltot(ind1,ind2)=alpha*qlth(ind1,ind2)+(1.-1.*alpha)*qlenv(ind1,ind2) 437 438 439 ! print*,senv,sth,sigma1s,sigma2s,fraca(ind1,ind2),'senv et sth et sig1 et sig2 et alpha' 440 441 442 !------------------------------------------------------------------------------- 443 ! Version 2: Modification selon J.-Louis. On condense ?? partir de qsat-ratqs 444 !------------------------------------------------------------------------------- 445 ! deltasenv=aenv*ratqs(ind1,ind2)*po(ind1) 446 ! deltasth=ath*ratqs(ind1,ind2)*zqta(ind1,ind2) 447 deltasenv=aenv*ratqs(ind1,ind2)*zqsatenv(ind1,ind2) 448 deltasth=ath*ratqs(ind1,ind2)*zqsatth(ind1,ind2) 449 ! deltasenv=aenv*0.01*po(ind1) 450 ! deltasth=ath*0.01*zqta(ind1,ind2) 451 xenv1=(senv-deltasenv)/(sqrt(2.)*sigma1s) 452 xenv2=(senv+deltasenv)/(sqrt(2.)*sigma1s) 453 xth1=(sth-deltasth)/(sqrt(2.)*sigma2s) 454 xth2=(sth+deltasth)/(sqrt(2.)*sigma2s) 455 coeffqlenv=(sigma1s)**2/(2*sqrtpi*deltasenv) 456 coeffqlth=(sigma2s)**2/(2*sqrtpi*deltasth) 457 458 cth(ind1,ind2)=0.5*(1.+1.*erf(xth2)) 459 cenv(ind1,ind2)=0.5*(1.+1.*erf(xenv2)) 460 ctot(ind1,ind2)=fraca(ind1,ind2)*cth(ind1,ind2)+(1.-1.*fraca(ind1,ind2))*cenv(ind1,ind2) 461 462 IntJ=sigma1s*(exp(-1.*xenv1**2)/sqrt2pi)+0.5*senv*(1+erf(xenv1)) 463 IntI1=coeffqlenv*0.5*(0.5*sqrtpi*(erf(xenv2)-erf(xenv1))+xenv1*exp(-1.*xenv1**2)-xenv2*exp(-1.*xenv2**2)) 464 IntI2=coeffqlenv*xenv2*(exp(-1.*xenv2**2)-exp(-1.*xenv1**2)) 465 IntI3=coeffqlenv*0.5*sqrtpi*xenv2**2*(erf(xenv2)-erf(xenv1)) 466 467 qlenv(ind1,ind2)=IntJ+IntI1+IntI2+IntI3 468 ! qlenv(ind1,ind2)=IntJ 469 ! print*, qlenv(ind1,ind2),'VERIF EAU' 470 471 472 IntJ=sigma2s*(exp(-1.*xth1**2)/sqrt2pi)+0.5*sth*(1+erf(xth1)) 473 ! IntI1=coeffqlth*((0.5*xth1-xth2)*exp(-1.*xth1**2)+0.5*xth2*exp(-1.*xth2**2)) 474 ! IntI2=coeffqlth*0.5*sqrtpi*(0.5+xth2**2)*(erf(xth2)-erf(xth1)) 475 IntI1=coeffqlth*0.5*(0.5*sqrtpi*(erf(xth2)-erf(xth1))+xth1*exp(-1.*xth1**2)-xth2*exp(-1.*xth2**2)) 476 IntI2=coeffqlth*xth2*(exp(-1.*xth2**2)-exp(-1.*xth1**2)) 477 IntI3=coeffqlth*0.5*sqrtpi*xth2**2*(erf(xth2)-erf(xth1)) 478 qlth(ind1,ind2)=IntJ+IntI1+IntI2+IntI3 479 ! qlth(ind1,ind2)=IntJ 480 ! print*, IntJ,IntI1,IntI2,IntI3,qlth(ind1,ind2),'VERIF EAU2' 481 qltot(ind1,ind2)=fraca(ind1,ind2)*qlth(ind1,ind2)+(1.-1.*fraca(ind1,ind2))*qlenv(ind1,ind2) 482 483 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 484 if (cenv(ind1,ind2).lt.1.e-10.or.cth(ind1,ind2).lt.1.e-10) then 485 ctot(ind1,ind2)=0. 486 qcloud(ind1)=zqsatenv(ind1,ind2) 487 488 else 489 490 ctot(ind1,ind2)=ctot(ind1,ind2) 491 qcloud(ind1)=qltot(ind1,ind2)/ctot(ind1,ind2)+zqs(ind1) 492 ! qcloud(ind1)=fraca(ind1,ind2)*qlth(ind1,ind2)/cth(ind1,ind2) & 493 ! & +(1.-1.*fraca(ind1,ind2))*qlenv(ind1,ind2)/cenv(ind1,ind2)+zqs(ind1) 494 495 endif 496 497 498 499 ! print*,sth,sigma2s,qlth(ind1,ind2),ctot(ind1,ind2),qltot(ind1,ind2),'verif' 500 501 502 else ! gaussienne environnement seule 503 504 zqenv(ind1)=po(ind1) 505 Tbef=t(ind1,ind2) 506 zdelta=MAX(0.,SIGN(1.,RTT-Tbef)) 507 qsatbef= R2ES * FOEEW(Tbef,zdelta)/paprs(ind1,ind2) 508 qsatbef=MIN(0.5,qsatbef) 509 zcor=1./(1.-retv*qsatbef) 510 qsatbef=qsatbef*zcor 511 zqsatenv(ind1,ind2)=qsatbef 512 513 514 ! qlbef=Max(po(ind1)-zqsatenv(ind1,ind2),0.) 515 zthl(ind1,ind2)=t(ind1,ind2)*(101325/paprs(ind1,ind2))**(rdd/cppd) 516 alenv=(0.622*Lv*zqsatenv(ind1,ind2))/(rdd*zthl(ind1,ind2)**2) 517 aenv=1./(1.+(alenv*Lv/cppd)) 518 senv=aenv*(po(ind1)-zqsatenv(ind1,ind2)) 519 520 521 sigma1s=ratqs(ind1,ind2)*zqenv(ind1) 522 523 sqrt2pi=sqrt(2.*pi) 524 xenv=senv/(sqrt(2.)*sigma1s) 525 ctot(ind1,ind2)=0.5*(1.+1.*erf(xenv)) 526 qltot(ind1,ind2)=sigma1s*((exp(-1.*xenv**2)/sqrt2pi)+xenv*sqrt(2.)*cenv(ind1,ind2)) 527 528 if (ctot(ind1,ind2).lt.1.e-3) then 529 ctot(ind1,ind2)=0. 530 qcloud(ind1)=zqsatenv(ind1,ind2) 531 532 else 533 534 ctot(ind1,ind2)=ctot(ind1,ind2) 535 qcloud(ind1)=qltot(ind1,ind2)/ctot(ind1,ind2)+zqsatenv(ind1,ind2) 536 537 endif 538 539 540 541 542 543 544 endif 545 enddo 546 547 return 548 end -
LMDZ5/branches/testing/libf/phylmd/coef_diff_turb_mod.F90
r1999 r2298 13 13 ! 14 14 SUBROUTINE coef_diff_turb(dtime, nsrf, knon, ni, & 15 ypaprs, ypplay, yu, yv, yq, yt, yts, y rugos, yqsurf, ycdragm, &15 ypaprs, ypplay, yu, yv, yq, yt, yts, yqsurf, ycdragm, & 16 16 ycoefm, ycoefh ,yq2) 17 17 … … 34 34 REAL, DIMENSION(klon,klev), INTENT(IN) :: yu, yv 35 35 REAL, DIMENSION(klon,klev), INTENT(IN) :: yq, yt 36 REAL, DIMENSION(klon), INTENT(IN) :: yts, y rugos, yqsurf36 REAL, DIMENSION(klon), INTENT(IN) :: yts, yqsurf 37 37 REAL, DIMENSION(klon), INTENT(IN) :: ycdragm 38 38 … … 70 70 CALL coefkz(nsrf, knon, ypaprs, ypplay, & 71 71 ksta, ksta_ter, & 72 yts, y rugos, yu, yv, yt, yq, &72 yts, yu, yv, yt, yq, & 73 73 yqsurf, & 74 74 ycoefm, ycoefh) … … 181 181 SUBROUTINE coefkz(nsrf, knon, paprs, pplay, & 182 182 ksta, ksta_ter, & 183 ts, rugos,&183 ts, & 184 184 u,v,t,q, & 185 185 qsurf, & … … 200 200 ! pplay----input-R- pression au milieu de chaque couche (en Pa) 201 201 ! ts-------input-R- temperature du sol (en Kelvin) 202 ! rugos----input-R- longeur de rugosite (en m)203 202 ! u--------input-R- vitesse u 204 203 ! v--------input-R- vitesse v … … 223 222 REAL, DIMENSION(klon,klev), INTENT(IN) :: pplay 224 223 REAL, DIMENSION(klon,klev), INTENT(IN) :: u, v, t, q 225 REAL, DIMENSION(klon), INTENT(IN) :: rugos226 224 REAL, DIMENSION(klon), INTENT(IN) :: qsurf 227 225 -
LMDZ5/branches/testing/libf/phylmd/compar1d.h
r2220 r2298 9 9 real :: tsurf 10 10 real :: rugos 11 real :: qsol(1:2)11 real :: xqsol(1:2) 12 12 real :: qsurf 13 13 real :: psurf … … 32 32 common/com_par1d/ & 33 33 & nat_surf,tsurf,rugos, & 34 & qsol,qsurf,psurf,zsurf,albedo,time,time_ini,xlat,xlon,airefi,&34 & xqsol,qsurf,psurf,zsurf,albedo,time,time_ini,xlat,xlon,airefi, & 35 35 & wtsurf,wqsurf,restart_runoff,xagesno,qsolinp,zpicinp, & 36 36 & forcing_type,tend_u,tend_v,tend_w,tend_t,tend_q,tend_rayo, & -
LMDZ5/branches/testing/libf/phylmd/concvl.F90
r2220 r2298 1 1 SUBROUTINE concvl(iflag_clos, & 2 dtime, paprs, pplay, &2 dtime, paprs, pplay, k_upper_cv, & 3 3 t, q, t_wake, q_wake, s_wake, u, v, tra, ntra, & 4 4 Ale, Alp, sig1, w01, & … … 88 88 89 89 REAL dtime, paprs(klon, klev+1), pplay(klon, klev) 90 INTEGER k_upper_cv 90 91 REAL t(klon, klev), q(klon, klev), u(klon, klev), v(klon, klev) 91 92 REAL t_wake(klon, klev), q_wake(klon, klev) … … 214 215 include "FCTTRE.h" 215 216 include "iniprint.h" 217 !jyg< 218 include "conema3.h" 219 !>jyg 216 220 217 221 IF (first) THEN … … 307 311 308 312 em_sig1feed = 1. 309 em_sig2feed = 0.97 313 !jyg< 314 ! em_sig2feed = 0.97 315 em_sig2feed = cvl_sig2feed 316 !>jyg 310 317 ! em_sig2feed = 0.8 311 318 ! Relative Weight densities … … 399 406 !LF necessary for gathered fields 400 407 nloc = klon 401 CALL cva_driver(klon, klev, klev+1, ntra, nloc, &408 CALL cva_driver(klon, klev, klev+1, ntra, nloc, k_upper_cv, & 402 409 iflag_con, iflag_mix, iflag_ice_thermo, & 403 iflag_clos, ok_conserv_q, dtime, &410 iflag_clos, ok_conserv_q, dtime, cvl_comp_threshold, & 404 411 t, q, qs, t_wake, q_wake, qs_wake, s_wake, u, v, tra, & 405 412 em_p, em_ph, & -
LMDZ5/branches/testing/libf/phylmd/conema3.h
r1910 r2298 4 4 ! 5 5 real epmax ! 0.993 6 !jyg< 7 REAL cvl_comp_threshold ! 0. 8 !>jyg 6 9 logical ok_adj_ema ! F 7 10 integer iflag_clw ! 0 8 11 integer iflag_cvl_sigd 9 real sig1feed ! 1. 10 real sig2feed ! 0.95 12 real cvl_sig2feed ! 0.97 11 13 12 common/comconema1/epmax,ok_adj_ema,iflag_clw,sig1feed,sig2feed 13 common/comconema2/iflag_cvl_sigd 14 !jyg< 15 !! common/comconema1/epmax,ok_adj_ema,iflag_clw,sig1feed,sig2feed 16 !! common/comconema2/iflag_cvl_sigd 17 common/comconema1/epmax, cvl_comp_threshold, cvl_sig2feed 18 common/comconema2/iflag_cvl_sigd, iflag_clw, ok_adj_ema 19 !>jyg 14 20 15 21 ! common/comconema/epmax,ok_adj_ema,iflag_clw 16 22 !$OMP THREADPRIVATE(/comconema1/) 17 23 !$OMP THREADPRIVATE(/comconema2/) 24 -
LMDZ5/branches/testing/libf/phylmd/conf_phys_m.F90
r2258 r2298 40 40 include "thermcell.h" 41 41 include "iniprint.h" 42 42 43 43 44 !IM : on inclut/initialise les taux de CH4, N2O, CFC11 et CFC12 … … 117 118 118 119 Real,SAVE :: f_cdrag_ter_omp,f_cdrag_oce_omp 119 Real,SAVE :: f_rugoro_omp 120 Real,SAVE :: f_rugoro_omp , z0min_omp 121 Real,SAVE :: z0m_seaice_omp,z0h_seaice_omp 122 REAL,SAVE :: min_wind_speed_omp,f_gust_wk_omp,f_gust_bl_omp,f_qsat_oce_omp, f_z0qh_oce_omp 123 INTEGER,SAVE :: iflag_gusts_omp,iflag_z0_oce_omp 120 124 121 125 ! Local … … 142 146 INTEGER, SAVE :: iflag_mix_omp 143 147 real, save :: scut_omp, qqa1_omp, qqa2_omp, gammas_omp, Fmax_omp, alphas_omp 148 REAL, SAVE :: tmax_fonte_cv_omp 144 149 145 150 REAL,SAVE :: R_ecc_omp,R_peri_omp,R_incl_omp,solaire_omp … … 188 193 REAL,SAVE :: ecrit_LES_omp 189 194 REAL,SAVE :: ecrit_tra_omp 195 REAL,SAVE :: cvl_comp_threshold_omp 196 REAL,SAVE :: cvl_sig2feed_omp 190 197 REAL,SAVE :: cvl_corr_omp 191 198 LOGICAL,SAVE :: ok_lic_melt_omp … … 213 220 !----------------------------------------------------------------- 214 221 222 print*,'CONFPHYS ENTREE' 215 223 !$OMP MASTER 216 224 !Config Key = type_ocean … … 760 768 ! KE 761 769 ! 770 771 !Config key = cvl_comp_threshold 772 !Config Desc = maximum fraction of convective points enabling compression 773 !Config Def = 1.00 774 !Config Help = fields are compressed when less than a fraction cvl_comp_threshold 775 !Config Help = of the points is convective. 776 cvl_comp_threshold_omp = 1.00 777 CALL getin('cvl_comp_threshold', cvl_comp_threshold_omp) 778 779 !Config key = cvl_sig2feed 780 !Config Desc = sigma coordinate at top of feeding layer 781 !Config Def = 0.97 782 !Config Help = deep convection is fed by the layer extending from the surface (pressure ps) 783 !Config Help = and cvl_sig2feed*ps. 784 cvl_sig2feed_omp = 0.97 785 CALL getin('cvl_sig2feed', cvl_sig2feed_omp) 762 786 763 787 !Config key = cvl_corr … … 1645 1669 ! 1646 1670 ! 1671 print*,'CONFPHYS OOK avant drag_ter' 1647 1672 ! 1648 1673 ! PARAMETRES CDRAG 1649 !1650 !Config Key = f_cdrag_ter1651 !Config Desc =1652 !Config Def = 0.81653 !Config Help =1654 1674 ! 1655 1675 f_cdrag_ter_omp = 0.8 1656 1676 call getin('f_cdrag_ter',f_cdrag_ter_omp) 1657 1677 ! 1658 !Config Key = f_cdrag_oce1659 !Config Desc =1660 !Config Def = 0.81661 !Config Help =1662 !1663 1678 f_cdrag_oce_omp = 0.8 1664 1679 call getin('f_cdrag_oce',f_cdrag_oce_omp) 1665 1680 ! 1666 ! RUGORO 1667 !Config Key = f_rugoro 1668 !Config Desc = 1669 !Config Def = 0. 1670 !Config Help = 1671 ! 1681 1682 ! Gustiness flags 1683 f_z0qh_oce_omp = 1. 1684 call getin('f_z0qh_oce',f_z0qh_oce_omp) 1685 ! 1686 f_qsat_oce_omp = 1. 1687 call getin('f_qsat_oce',f_qsat_oce_omp) 1688 ! 1689 f_gust_bl_omp = 0. 1690 call getin('f_gust_bl',f_gust_bl_omp) 1691 ! 1692 f_gust_wk_omp = 0. 1693 call getin('f_gust_wk',f_gust_wk_omp) 1694 ! 1695 iflag_z0_oce_omp=0 1696 call getin('iflag_z0_oce',iflag_z0_oce_omp) 1697 ! 1698 iflag_gusts_omp=0 1699 call getin('iflag_gusts',iflag_gusts_omp) 1700 ! 1701 min_wind_speed_omp = 1. 1702 call getin('min_wind_speed',min_wind_speed_omp) 1703 1704 z0m_seaice_omp = 0.002 ; call getin('z0m_seaice',z0m_seaice_omp) 1705 z0h_seaice_omp = 0.002 ; call getin('z0h_seaice',z0h_seaice_omp) 1706 1672 1707 f_rugoro_omp = 0. 1673 1708 call getin('f_rugoro',f_rugoro_omp) 1709 1710 z0min_omp = 0.000015 1711 call getin('z0min',z0min_omp) 1712 1674 1713 1675 1714 ! PARAMETERS FOR CONVECTIVE INHIBITION BY TROPOS. DRYNESS … … 1751 1790 Fmax_omp = 0.65 1752 1791 call getin('Fmax',Fmax_omp) 1792 1793 ! 1794 !Config Key = tmax_fonte_cv 1795 !Config Desc = 1796 !Config Def = 275.15 1797 !Config Help = 1798 ! 1799 tmax_fonte_cv_omp = 275.15 1800 call getin('tmax_fonte_cv',tmax_fonte_cv_omp) 1753 1801 1754 1802 ! … … 2018 2066 ecrit_tra = ecrit_tra_omp 2019 2067 ecrit_reg = ecrit_reg_omp 2068 cvl_comp_threshold = cvl_comp_threshold_omp 2069 cvl_sig2feed = cvl_sig2feed_omp 2020 2070 cvl_corr = cvl_corr_omp 2021 2071 ok_lic_melt = ok_lic_melt_omp 2022 2072 f_cdrag_ter=f_cdrag_ter_omp 2023 2073 f_cdrag_oce=f_cdrag_oce_omp 2074 2075 f_gust_wk=f_gust_wk_omp 2076 f_gust_bl=f_gust_bl_omp 2077 f_qsat_oce=f_qsat_oce_omp 2078 f_z0qh_oce=f_z0qh_oce_omp 2079 min_wind_speed=min_wind_speed_omp 2080 iflag_gusts=iflag_gusts_omp 2081 iflag_z0_oce=iflag_z0_oce_omp 2082 2083 2084 z0m_seaice=z0m_seaice_omp 2085 z0h_seaice=z0h_seaice_omp 2086 2024 2087 f_rugoro=f_rugoro_omp 2088 2089 z0min=z0min_omp 2025 2090 supcrit1 = supcrit1_omp 2026 2091 supcrit2 = supcrit2_omp … … 2031 2096 gammas = gammas_omp 2032 2097 Fmax = Fmax_omp 2098 tmax_fonte_cv = tmax_fonte_cv_omp 2033 2099 alphas = alphas_omp 2034 2100 ok_strato = ok_strato_omp … … 2105 2171 write(lunout,*)' RN2O_per = ',RN2O_per,' RCFC11_per = ', RCFC11_per 2106 2172 write(lunout,*)' RCFC12_per = ',RCFC12_per 2173 write(lunout,*)' cvl_comp_threshold=', cvl_comp_threshold 2174 write(lunout,*)' cvl_sig2feed=', cvl_sig2feed 2107 2175 write(lunout,*)' cvl_corr=', cvl_corr 2108 2176 write(lunout,*)'ok_lic_melt=', ok_lic_melt … … 2210 2278 write(lunout,*)' f_cdrag_oce = ',f_cdrag_oce 2211 2279 write(lunout,*)' f_rugoro = ',f_rugoro 2280 write(lunout,*)' z0min = ',z0min 2212 2281 write(lunout,*)' supcrit1 = ', supcrit1 2213 2282 write(lunout,*)' supcrit2 = ', supcrit2 … … 2218 2287 write(lunout,*)' gammas = ', gammas 2219 2288 write(lunout,*)' Fmax = ', Fmax 2289 write(lunout,*)' tmax_fonte_cv = ', tmax_fonte_cv 2220 2290 write(lunout,*)' alphas = ', alphas 2221 2291 write(lunout,*)' iflag_wake = ', iflag_wake -
LMDZ5/branches/testing/libf/phylmd/cv3_routines.F90
r2220 r2298 5 5 6 6 7 SUBROUTINE cv3_param(nd, delt)7 SUBROUTINE cv3_param(nd, k_upper, delt) 8 8 9 9 use mod_phys_lmdz_para … … 36 36 include "conema3.h" 37 37 38 INTEGER nd 39 REAL delt ! timestep (seconds) 38 INTEGER, INTENT(IN) :: nd 39 INTEGER, INTENT(IN) :: k_upper 40 REAL, INTENT(IN) :: delt ! timestep (seconds) 40 41 41 42 … … 51 52 ! -- limit levels for convection: 52 53 53 noff = 1 54 !jyg< 55 ! noff is chosen such that nl = k_upper so that upmost loops end at about 22 km 56 ! 57 noff = min(max(nd-k_upper, 1), (nd+1)/2) 58 !! noff = 1 59 !>jyg 54 60 minorig = 1 55 61 nl = nd - noff … … 264 270 265 271 !inputs: 266 INTEGER len, nd 267 LOGICAL ok_conserv_q 268 REAL t(len, nd), q(len, nd), p(len, nd) 269 REAL u(len, nd), v(len, nd) 270 REAL hm(len, nd), gz(len, nd) 271 REAL ph(len, nd+1) 272 REAL p1feed(len) 273 ! , wght(len) 274 REAL wght(nd) 272 INTEGER, INTENT (IN) :: len, nd 273 LOGICAL, INTENT (IN) :: ok_conserv_q 274 REAL, DIMENSION (len, nd), INTENT (IN) :: t, q, p 275 REAL, DIMENSION (len, nd), INTENT (IN) :: u, v 276 REAL, DIMENSION (len, nd), INTENT (IN) :: hm, gz 277 REAL, DIMENSION (len, nd+1), INTENT (IN) :: ph 278 REAL, DIMENSION (len), INTENT (IN) :: p1feed 279 REAL, DIMENSION (nd), INTENT (IN) :: wght 275 280 !input-output 276 REAL p2feed(len)281 REAL, DIMENSION (len), INTENT (INOUT) :: p2feed 277 282 !outputs: 278 INTEGER iflag(len), nk(len), icb(len),icbmax279 ! real wghti(len) 280 REAL wghti(len, nd)281 REAL tnk(len), thnk(len), qnk(len), qsnk(len)282 REAL unk(len), vnk(len)283 REAL cpnk(len), hnk(len), gznk(len)284 REAL plcl(len)283 INTEGER, INTENT (OUT) :: icbmax 284 INTEGER, DIMENSION (len), INTENT (OUT) :: iflag, nk, icb 285 REAL, DIMENSION (len, nd), INTENT (OUT) :: wghti 286 REAL, DIMENSION (len), INTENT (OUT) :: tnk, thnk, qnk, qsnk 287 REAL, DIMENSION (len), INTENT (OUT) :: unk, vnk 288 REAL, DIMENSION (len), INTENT (OUT) :: cpnk, hnk, gznk 289 REAL, DIMENSION (len), INTENT (OUT) :: plcl 285 290 286 291 !local variables: … … 514 519 515 520 ! inputs: 516 INTEGER len, nd517 INTEGER icb(len)518 REAL t(len, nd), qs(len, nd), gz(len, nd)519 REAL tnk(len), qnk(len), gznk(len)520 REAL p(len, nd)521 REAL plcl(len)! convect3521 INTEGER, INTENT (IN) :: len, nd 522 INTEGER, DIMENSION (len), INTENT (IN) :: icb 523 REAL, DIMENSION (len, nd), INTENT (IN) :: t, qs, gz 524 REAL, DIMENSION (len), INTENT (IN) :: tnk, qnk, gznk 525 REAL, DIMENSION (len, nd), INTENT (IN) :: p 526 REAL, DIMENSION (len), INTENT (IN) :: plcl ! convect3 522 527 523 528 ! outputs: 524 REAL tp(len, nd), tvp(len, nd), clw(len, nd) 529 INTEGER, DIMENSION (len), INTENT (OUT) :: icbs 530 REAL, DIMENSION (len, nd), INTENT (OUT) :: tp, tvp, clw 525 531 526 532 ! local variables: 527 533 INTEGER i, k 528 INTEGER icb1(len), icbs (len), icbsmax2! convect3534 INTEGER icb1(len), icbsmax2 ! convect3 529 535 REAL tg, qg, alv, s, ahg, tc, denom, es, rg 530 536 REAL ah0(len), cpp(len) 531 537 REAL ticb(len), gzicb(len) 532 REAL qsicb(len) ! convect3533 REAL cpinv(len) ! convect3538 REAL qsicb(len) ! convect3 539 REAL cpinv(len) ! convect3 534 540 535 541 ! ------------------------------------------------------------------- … … 1051 1057 1052 1058 !inputs: 1053 INTEGER ncum, nd, nloc, j 1054 INTEGER icb(nloc), icbs(nloc), nk(nloc) 1055 REAL t(nloc, nd), q(nloc, nd), qs(nloc, nd), gz(nloc, nd) 1056 REAL p(nloc, nd) 1057 REAL tnk(nloc), qnk(nloc), gznk(nloc) 1058 REAL hnk(nloc) 1059 REAL lv(nloc, nd), lf(nloc, nd), tv(nloc, nd), h(nloc, nd) 1060 REAL pbase(nloc), buoybase(nloc), plcl(nloc) 1059 INTEGER, INTENT (IN) :: ncum, nd, nloc 1060 INTEGER, DIMENSION (nloc), INTENT (IN) :: icb, icbs, nk 1061 REAL, DIMENSION (nloc, nd), INTENT (IN) :: t, q, qs, gz 1062 REAL, DIMENSION (nloc, nd), INTENT (IN) :: p 1063 REAL, DIMENSION (nloc), INTENT (IN) :: tnk, qnk, gznk 1064 REAL, DIMENSION (nloc), INTENT (IN) :: hnk 1065 REAL, DIMENSION (nloc, nd), INTENT (IN) :: lv, lf, tv, h 1066 REAL, DIMENSION (nloc), INTENT (IN) :: pbase, buoybase, plcl 1067 1068 !input/outputs: 1069 REAL, DIMENSION (nloc, nd), INTENT (INOUT) :: tp, tvp, clw ! Input for k = 1, icb+1 (computed in cv3_undilute1) 1070 ! Output above 1061 1071 1062 1072 !outputs: 1063 INTEGER inb(nloc) 1064 REAL tp(nloc, nd), tvp(nloc, nd), clw(nloc, nd) 1065 REAL ep(nloc, nd), sigp(nloc, nd), hp(nloc, nd) 1066 REAL buoy(nloc, nd) 1073 INTEGER, DIMENSION (nloc), INTENT (OUT) :: inb 1074 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: ep, sigp, hp 1075 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: buoy 1067 1076 1068 1077 !local variables: 1069 INTEGER i, k1078 INTEGER i, j, k 1070 1079 REAL tg, qg, ahg, alv, alf, s, tc, es, esi, denom, rg, tca, elacrit 1071 1080 REAL als … … 1084 1093 DO k = 1, nl 1085 1094 DO i = 1, ncum 1086 ep(i, k) = 0.01087 sigp(i, k) = spfac1088 1095 qi(i, k) = 0. 1089 1096 END DO … … 1187 1194 END IF 1188 1195 END IF 1189 END IF 1196 !jyg< 1197 !! END IF ! Endif moved to the end of the loop 1198 !>jyg 1190 1199 1191 1200 IF (cvflag_ice) THEN … … 1258 1267 END IF 1259 1268 END IF ! (cvflag_ice) 1260 1269 !jyg< 1270 END IF ! (k>=(icbs(i)+1)) 1271 !>jyg 1261 1272 END DO 1262 1273 END DO … … 1267 1278 ! --- THESE MAY BE FUNCTIONS OF TP(I), P(I) AND CLW(I) 1268 1279 ! ===================================================================== 1269 1280 ! 1281 !jyg< 1282 DO k = 1, nl 1283 DO i = 1, ncum 1284 ep(i, k) = 0.0 1285 sigp(i, k) = spfac 1286 END DO 1287 END DO 1288 !>jyg 1289 ! 1270 1290 IF (flag_epkeorig/=1) THEN 1271 1291 DO k = 1, nl ! convect3 1272 1292 DO i = 1, ncum 1273 pden = ptcrit - pbcrit 1274 ep(i, k) = (plcl(i)-p(i,k)-pbcrit)/pden*epmax 1275 ep(i, k) = max(ep(i,k), 0.0) 1276 ep(i, k) = min(ep(i,k), epmax) 1277 sigp(i, k) = spfac 1293 !jyg< 1294 IF(k>=icb(i)) THEN 1295 !>jyg 1296 pden = ptcrit - pbcrit 1297 ep(i, k) = (plcl(i)-p(i,k)-pbcrit)/pden*epmax 1298 ep(i, k) = max(ep(i,k), 0.0) 1299 ep(i, k) = min(ep(i,k), epmax) 1300 !! sigp(i, k) = spfac ! jyg 1301 ENDIF ! (k>=icb(i)) 1278 1302 END DO 1279 1303 END DO … … 1281 1305 DO k = 1, nl 1282 1306 DO i = 1, ncum 1283 IF (k>=(nk(i)+1)) THEN 1307 IF(k>=icb(i)) THEN 1308 !! IF (k>=(nk(i)+1)) THEN 1309 !>jyg 1284 1310 tca = tp(i, k) - t0 1285 1311 IF (tca>=0.0) THEN … … 1292 1318 ep(i, k) = max(ep(i,k), 0.0) 1293 1319 ep(i, k) = min(ep(i,k), epmax) 1294 sigp(i, k) = spfac 1295 END IF 1320 !! sigp(i, k) = spfac ! jyg 1321 END IF ! (k>=icb(i)) 1296 1322 END DO 1297 1323 END DO 1298 1324 END IF 1325 ! 1299 1326 ! ===================================================================== 1300 1327 ! --- CALCULATE VIRTUAL TEMPERATURE AND LIFTED PARCEL … … 1331 1358 ! first estimate of buoyancy: 1332 1359 1333 DO i = 1, ncum 1334 DO k = 1, nl 1360 !jyg : k-loop outside i-loop (07042015) 1361 DO k = 1, nl 1362 DO i = 1, ncum 1335 1363 buoy(i, k) = tvp(i, k) - tv(i, k) 1336 1364 END DO … … 1340 1368 ! for safety, set buoy(icb)=buoybase 1341 1369 1342 DO i = 1, ncum 1343 DO k = 1, nl 1370 !jyg : k-loop outside i-loop (07042015) 1371 DO k = 1, nl 1372 DO i = 1, ncum 1344 1373 IF ((k>=icb(i)) .AND. (k<=nl) .AND. (p(i,k)>=pbase(i))) THEN 1345 1374 buoy(i, k) = buoybase(i) 1346 1375 END IF 1347 1376 END DO 1377 END DO 1378 DO i = 1, ncum 1348 1379 ! buoy(icb(i),k)=buoybase(i) 1349 1380 buoy(i, icb(i)) = buoybase(i) … … 1490 1521 END DO 1491 1522 1492 DO k = minorig + 1, nl 1493 DO i = 1, ncum 1494 IF ((k>=icb(i)) .AND. (k<=inb(i))) THEN 1495 1496 IF (cvflag_ice) THEN 1523 !jyg : cvflag_ice test outside the loops (07042015) 1524 ! 1525 IF (cvflag_ice) THEN 1526 ! 1527 DO k = minorig + 1, nl 1528 DO i = 1, ncum 1529 IF ((k>=icb(i)) .AND. (k<=inb(i))) THEN 1497 1530 frac(i, k) = 1. - (t(i,k)-243.15)/(263.15-243.15) 1498 1531 frac(i, k) = min(max(frac(i,k),0.0), 1.0) 1499 1532 hp(i, k) = hnk(i) + (lv(i,k)+(cpd-cpv)*t(i,k)+frac(i,k)*lf(i,k))* & 1500 1533 ep(i, k)*clw(i, k) 1501 1502 ELSE 1534 END IF 1535 END DO 1536 END DO 1537 ! 1538 ELSE 1539 ! 1540 DO k = minorig + 1, nl 1541 DO i = 1, ncum 1542 IF ((k>=icb(i)) .AND. (k<=inb(i))) THEN 1503 1543 hp(i, k) = hnk(i) + (lv(i,k)+(cpd-cpv)*t(i,k))*ep(i, k)*clw(i, k) 1504 1544 END IF 1505 1506 END IF1507 END DO 1508 END DO1545 END DO 1546 END DO 1547 ! 1548 END IF ! (cvflag_ice) 1509 1549 1510 1550 RETURN … … 1768 1808 1769 1809 !inputs: 1770 INTEGER ncum, nd, na, ntra, nloc1771 INTEGER icb(nloc), inb(nloc), nk(nloc)1772 REAL sig(nloc, nd)1773 REAL qnk(nloc), unk(nloc), vnk(nloc)1774 REAL ph(nloc, nd+1)1775 REAL t(nloc, nd), rr(nloc, nd), rs(nloc, nd)1776 REAL u(nloc, nd), v(nloc, nd)1777 REAL tra(nloc, nd, ntra)! input of convect31778 REAL lv(nloc, na), h(nloc, na), hp(nloc, na)1779 REAL lf(nloc, na), frac(nloc, na)1780 REAL tv(nloc, na), tvp(nloc, na), ep(nloc, na), clw(nloc, na)1781 REAL m(nloc, na)! input of convect31810 INTEGER, INTENT (IN) :: ncum, nd, na, ntra, nloc 1811 INTEGER, DIMENSION (nloc), INTENT (IN) :: icb, inb, nk 1812 REAL, DIMENSION (nloc, nd), INTENT (IN) :: sig 1813 REAL, DIMENSION (nloc), INTENT (IN) :: qnk, unk, vnk 1814 REAL, DIMENSION (nloc, nd+1), INTENT (IN) :: ph 1815 REAL, DIMENSION (nloc, nd), INTENT (IN) :: t, rr, rs 1816 REAL, DIMENSION (nloc, nd), INTENT (IN) :: u, v 1817 REAL, DIMENSION (nloc, nd, ntra), INTENT (IN) :: tra ! input of convect3 1818 REAL, DIMENSION (nloc, na), INTENT (IN) :: lv, h, hp 1819 REAL, DIMENSION (nloc, na), INTENT (IN) :: lf, frac 1820 REAL, DIMENSION (nloc, na), INTENT (IN) :: tv, tvp, ep, clw 1821 REAL, DIMENSION (nloc, na), INTENT (IN) :: m ! input of convect3 1782 1822 1783 1823 !outputs: 1784 REAL ment(nloc, na, na), qent(nloc, na, na) 1785 REAL uent(nloc, na, na), vent(nloc, na, na) 1786 REAL sij(nloc, na, na), elij(nloc, na, na) 1787 REAL traent(nloc, nd, nd, ntra) 1788 REAL ments(nloc, nd, nd), qents(nloc, nd, nd) 1789 REAL sigij(nloc, nd, nd) 1790 INTEGER nent(nloc, nd) 1824 REAL, DIMENSION (nloc, na, na), INTENT (OUT) :: ment, qent 1825 REAL, DIMENSION (nloc, na, na), INTENT (OUT) :: uent, vent 1826 REAL, DIMENSION (nloc, na, na), INTENT (OUT) :: sij, elij 1827 REAL, DIMENSION (nloc, nd, nd, ntra), INTENT (OUT) :: traent 1828 REAL, DIMENSION (nloc, nd, nd), INTENT (OUT) :: ments, qents 1829 INTEGER, DIMENSION (nloc, nd), INTENT (OUT) :: nent 1791 1830 1792 1831 !local variables: … … 1797 1836 REAL asij(nloc), smax(nloc), scrit(nloc) 1798 1837 REAL asum(nloc, nd), bsum(nloc, nd), csum(nloc, nd) 1838 REAL sigij(nloc, nd, nd) 1799 1839 REAL wgh 1800 1840 REAL zm(nloc, na) … … 2184 2224 include "cv3param.h" 2185 2225 include "cvflag.h" 2226 include "nuage.h" 2186 2227 2187 2228 !inputs: … … 2363 2404 2364 2405 IF (cvflag_ice) THEN 2365 thaw = (t(il,i)-273.15)/(275.15-273.15) 2406 !CR:tmax_fonte_cv: T for which ice is totally melted (used to be 275.15) 2407 thaw = (t(il,i)-273.15)/(tmax_fonte_cv-273.15) 2366 2408 thaw = min(max(thaw,0.0), 1.0) 2367 2409 frac(il, i) = frac(il, i)*(1.-thaw) … … 2477 2519 f6 = -100.*sigd(il)*bfac*(ph(il,i)-ph(il,i+1))*evap(il, i) 2478 2520 2479 thaw = (t(il,i)-273.15)/(275.15-273.15) 2521 !CR:tmax_fonte_cv: T for which ice is totally melted (used to be 275.15) 2522 thaw = (t(il,i)-273.15)/(tmax_fonte_cv-273.15) 2480 2523 thaw = min(max(thaw,0.0), 1.0) 2481 2524 water(il, i) = water(il, i+1) + (1-fraci(il,i))*d6 … … 2763 2806 iflag, precip, Vprecip, ft, fr, fu, fv, ftra, & 2764 2807 cbmf, upwd, dnwd, dnwd0, ma, mip, & 2765 tls, tps, qcondc, wd, & 2808 !! tls, tps, ! useless . jyg 2809 qcondc, wd, & 2766 2810 ftd, fqd, qnk, qtc, sigt, tau_cld_cv, coefw_cld_cv) 2767 2811 … … 2811 2855 REAL dnwd0(nloc, nd), mip(nloc, nd) 2812 2856 REAL Vprecip(nloc, nd+1) 2813 REAL tls(nloc, nd), tps(nloc, nd) 2857 !! REAL tls(nloc, nd), tps(nloc, nd) ! useless . jyg 2814 2858 REAL qcondc(nloc, nd) ! cld 2815 2859 REAL qtc(nloc,nd), sigt(nloc,nd) ! cld … … 2823 2867 REAL cpinv, rdcp, dpinv 2824 2868 REAL awat(nloc) 2825 REAL lvcp(nloc, na), lfcp(nloc, na) , mke(nloc, na)2869 REAL lvcp(nloc, na), lfcp(nloc, na) ! , mke(nloc, na) ! unused . jyg 2826 2870 REAL am(nloc), work(nloc), ad(nloc), amp1(nloc) 2827 2871 !! real up1(nloc), dn1(nloc) … … 3588 3632 ! *** reset counter and return *** 3589 3633 3634 ! Reset counter only for points actually convective (jyg) 3635 ! In order take into account the possibility of changing the compression, 3636 ! reset m, sig and w0 to zero for non-convecting points. 3590 3637 DO il = 1, ncum 3591 sig(il, nd) = 2.0 3638 IF (iflag(il) < 3) THEN 3639 sig(il, nd) = 2.0 3640 ENDIF 3592 3641 END DO 3593 3642 … … 3743 3792 ! ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc 3744 3793 3745 DO i = 1, nd 3746 DO il = 1, ncum 3747 mke(il, i) = upwd(il, i) + dnwd(il, i) 3748 END DO 3749 END DO 3750 3751 DO i = 1, nd 3752 DO il = 1, ncum 3753 rdcp = (rrd*(1.-rr(il,i))-rr(il,i)*rrv)/(cpd*(1.-rr(il,i))+rr(il,i)*cpv) 3754 tls(il, i) = t(il, i)*(1000.0/p(il,i))**rdcp 3755 tps(il, i) = tp(il, i) 3756 END DO 3757 END DO 3794 !! DO i = 1, nd ! unused . jyg 3795 !! DO il = 1, ncum ! unused . jyg 3796 !! mke(il, i) = upwd(il, i) + dnwd(il, i) ! unused . jyg 3797 !! END DO ! unused . jyg 3798 !! END DO ! unused . jyg 3799 3800 !! DO i = 1, nd ! unused . jyg 3801 !! DO il = 1, ncum ! unused . jyg 3802 !! rdcp = (rrd*(1.-rr(il,i))-rr(il,i)*rrv)/(cpd*(1.-rr(il,i))+rr(il,i)*cpv) ! unused . jyg 3803 !! tls(il, i) = t(il, i)*(1000.0/p(il,i))**rdcp ! unused . jyg 3804 !! tps(il, i) = tp(il, i) ! unused . jyg 3805 !! END DO ! unused . jyg 3806 !! END DO ! unused . jyg 3758 3807 3759 3808 -
LMDZ5/branches/testing/libf/phylmd/cv3a_compress.F90
r2220 r2298 1 SUBROUTINE cv3a_compress(len, nloc, ncum, nd, ntra, iflag1, nk1, icb1, icbs1, & 2 plcl1, tnk1, qnk1, gznk1, hnk1, unk1, vnk1, wghti1, pbase1, buoybase1, & 3 t1, q1, qs1, t1_wake, q1_wake, qs1_wake, s1_wake, u1, v1, gz1, th1, & 4 th1_wake, tra1, h1, lv1, lf1, cpn1, p1, ph1, tv1, tp1, tvp1, clw1, & 5 h1_wake, lv1_wake, lf1_wake, cpn1_wake, tv1_wake, sig1, w01, ptop21, & 6 ale1, alp1, omega1, iflag, nk, icb, icbs, plcl, tnk, qnk, gznk, hnk, unk, vnk, & 7 wghti, pbase, buoybase, t, q, qs, t_wake, q_wake, qs_wake, s_wake, u, v, & 8 gz, th, th_wake, tra, h, lv, lf, cpn, p, ph, tv, tp, tvp, clw, h_wake, & 9 lv_wake, lf_wake, cpn_wake, tv_wake, sig, w0, ptop2, ale, alp, omega) 1 SUBROUTINE cv3a_compress(len, nloc, ncum, nd, ntra, compress, & 2 iflag1, nk1, icb1, icbs1, & 3 plcl1, tnk1, qnk1, gznk1, hnk1, unk1, vnk1, & 4 wghti1, pbase1, buoybase1, & 5 t1, q1, qs1, t1_wake, q1_wake, qs1_wake, s1_wake, & 6 u1, v1, gz1, th1, th1_wake, & 7 tra1, & 8 h1, lv1, lf1, cpn1, p1, ph1, tv1, tp1, tvp1, clw1, & 9 h1_wake, lv1_wake, lf1_wake, cpn1_wake, tv1_wake, & 10 sig1, w01, ptop21, & 11 Ale1, Alp1, omega1, & 12 iflag, nk, icb, icbs, & 13 plcl, tnk, qnk, gznk, hnk, unk, vnk, & 14 wghti, pbase, buoybase, & 15 t, q, qs, t_wake, q_wake, qs_wake, s_wake, & 16 u, v, gz, th, th_wake, & 17 tra, & 18 h, lv, lf, cpn, p, ph, tv, tp, tvp, clw, & 19 h_wake, lv_wake, lf_wake, cpn_wake, tv_wake, & 20 sig, w0, ptop2, & 21 Ale, Alp, omega) 10 22 ! ************************************************************** 11 23 ! * … … 22 34 23 35 ! inputs: 24 INTEGER len, nloc, ncum, nd, ntra 25 INTEGER iflag1(len), nk1(len), icb1(len), icbs1(len) 26 REAL plcl1(len), tnk1(len), qnk1(len), gznk1(len) 27 REAL hnk1(len), unk1(len), vnk1(len) 28 REAL wghti1(len, nd), pbase1(len), buoybase1(len) 29 REAL t1(len, nd), q1(len, nd), qs1(len, nd) 30 REAL t1_wake(len, nd), q1_wake(len, nd), qs1_wake(len, nd) 31 REAL s1_wake(len) 32 REAL u1(len, nd), v1(len, nd) 33 REAL gz1(len, nd), th1(len, nd), th1_wake(len, nd) 34 REAL tra1(len, nd, ntra) 35 REAL h1(len, nd), lv1(len, nd), lf1(len, nd), cpn1(len, nd) 36 REAL p1(len, nd), ph1(len, nd+1), tv1(len, nd), tp1(len, nd) 37 REAL tvp1(len, nd), clw1(len, nd) 38 REAL h1_wake(len, nd), lv1_wake(len, nd), cpn1_wake(len, nd) 39 REAL tv1_wake(len, nd), lf1_wake(len, nd) 40 REAL sig1(len, nd), w01(len, nd), ptop21(len) 41 REAL ale1(len), alp1(len) 42 REAL omega1(len,nd) 43 36 INTEGER, INTENT (IN) :: len, nloc, nd, ntra 37 !jyg< 38 LOGICAL, INTENT (IN) :: compress ! compression is performed if compress is true 39 !>jyg 40 INTEGER, DIMENSION (len), INTENT (IN) :: iflag1, nk1, icb1, icbs1 41 REAL, DIMENSION (len), INTENT (IN) :: plcl1, tnk1, qnk1, gznk1 42 REAL, DIMENSION (len), INTENT (IN) :: hnk1, unk1, vnk1 43 REAL, DIMENSION (len, nd), INTENT (IN) :: wghti1(len, nd) 44 REAL, DIMENSION (len), INTENT (IN) :: pbase1, buoybase1 45 REAL, DIMENSION (len, nd), INTENT (IN) :: t1, q1, qs1 46 REAL, DIMENSION (len, nd), INTENT (IN) :: t1_wake, q1_wake, qs1_wake 47 REAL, DIMENSION (len), INTENT (IN) :: s1_wake 48 REAL, DIMENSION (len, nd), INTENT (IN) :: u1, v1 49 REAL, DIMENSION (len, nd), INTENT (IN) :: gz1, th1, th1_wake 50 REAL, DIMENSION (len, nd,ntra), INTENT (IN) :: tra1 51 REAL, DIMENSION (len, nd), INTENT (IN) :: h1, lv1, lf1, cpn1 52 REAL, DIMENSION (len, nd), INTENT (IN) :: p1 53 REAL, DIMENSION (len, nd+1), INTENT (IN) :: ph1(len, nd+1) 54 REAL, DIMENSION (len, nd), INTENT (IN) :: tv1, tp1 55 REAL, DIMENSION (len, nd), INTENT (IN) :: tvp1, clw1 56 REAL, DIMENSION (len, nd), INTENT (IN) :: h1_wake, lv1_wake, cpn1_wake 57 REAL, DIMENSION (len, nd), INTENT (IN) :: tv1_wake, lf1_wake 58 REAL, DIMENSION (len, nd), INTENT (IN) :: sig1, w01 59 REAL, DIMENSION (len), INTENT (IN) :: ptop21 60 REAL, DIMENSION (len), INTENT (IN) :: Ale1, Alp1 61 REAL, DIMENSION (len, nd), INTENT (IN) :: omega1 62 ! 63 ! in/out 64 INTEGER, INTENT (INOUT) :: ncum 65 ! 44 66 ! outputs: 45 67 ! en fait, on a nloc=len pour l'instant (cf cv_driver) 46 INTEGER iflag(len), nk(len), icb(len), icbs(len) 47 REAL plcl(len), tnk(len), qnk(len), gznk(len) 48 REAL hnk(len), unk(len), vnk(len) 49 REAL wghti(len, nd), pbase(len), buoybase(len) 50 REAL t(len, nd), q(len, nd), qs(len, nd) 51 REAL t_wake(len, nd), q_wake(len, nd), qs_wake(len, nd) 52 REAL s_wake(len) 53 REAL u(len, nd), v(len, nd) 54 REAL gz(len, nd), th(len, nd), th_wake(len, nd) 55 REAL tra(len, nd, ntra) 56 REAL h(len, nd), lv(len, nd), lf(len, nd), cpn(len, nd) 57 REAL p(len, nd), ph(len, nd+1), tv(len, nd), tp(len, nd) 58 REAL tvp(len, nd), clw(len, nd) 59 REAL h_wake(len, nd), lv_wake(len, nd), cpn_wake(len, nd) 60 REAL tv_wake(len, nd), lf_wake(len, nd) 61 REAL sig(len, nd), w0(len, nd), ptop2(len) 62 REAL ale(len), alp(len) 63 REAL omega(len,nd) 68 INTEGER, DIMENSION (nloc), INTENT (OUT) :: iflag, nk, icb, icbs 69 REAL, DIMENSION (nloc), INTENT (OUT) :: plcl, tnk, qnk, gznk 70 REAL, DIMENSION (nloc), INTENT (OUT) :: hnk, unk, vnk 71 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: wghti 72 REAL, DIMENSION (nloc), INTENT (OUT) :: pbase, buoybase 73 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: t, q, qs 74 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: t_wake, q_wake, qs_wake 75 REAL, DIMENSION (nloc), INTENT (OUT) :: s_wake 76 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: u, v 77 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: gz, th, th_wake 78 REAL, DIMENSION (nloc, nd,ntra), INTENT (OUT) :: tra 79 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: h, lv, lf, cpn 80 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: p 81 REAL, DIMENSION (nloc, nd+1), INTENT (OUT) :: ph 82 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: tv, tp 83 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: tvp, clw 84 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: h_wake, lv_wake, cpn_wake 85 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: tv_wake, lf_wake 86 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: sig, w0 87 REAL, DIMENSION (nloc), INTENT (OUT) :: ptop2 88 REAL, DIMENSION (nloc), INTENT (OUT) :: Ale, Alp 89 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: omega 64 90 65 91 ! local variables: … … 69 95 CHARACTER (LEN=80) :: abort_message 70 96 97 !jyg< 98 IF (compress) THEN 99 !>jyg 71 100 72 101 DO k = 1, nl + 1 … … 108 137 END DO 109 138 END DO 110 139 ! 111 140 ! AC! do 121 j=1,ntra 112 141 ! AC!ccccc do 111 k=1,nl+1 … … 146 175 pbase(nn) = pbase1(i) 147 176 buoybase(nn) = buoybase1(i) 177 sig(nn, nd) = sig1(i, nd) 148 178 ptop2(nn) = ptop2(i) 149 ale(nn) = ale1(i)150 alp(nn) = alp1(i)179 Ale(nn) = Ale1(i) 180 Alp(nn) = Alp1(i) 151 181 END IF 152 182 END DO … … 157 187 CALL abort_gcm(modname, abort_message, 1) 158 188 END IF 189 ! 190 !jyg< 191 ELSE !(compress) 192 ! 193 ncum = len 194 ! 195 wghti(:,1:nl+1) = wghti1(:,1:nl+1) 196 t(:,1:nl+1) = t1(:,1:nl+1) 197 q(:,1:nl+1) = q1(:,1:nl+1) 198 qs(:,1:nl+1) = qs1(:,1:nl+1) 199 t_wake(:,1:nl+1) = t1_wake(:,1:nl+1) 200 q_wake(:,1:nl+1) = q1_wake(:,1:nl+1) 201 qs_wake(:,1:nl+1) = qs1_wake(:,1:nl+1) 202 u(:,1:nl+1) = u1(:,1:nl+1) 203 v(:,1:nl+1) = v1(:,1:nl+1) 204 gz(:,1:nl+1) = gz1(:,1:nl+1) 205 th(:,1:nl+1) = th1(:,1:nl+1) 206 th_wake(:,1:nl+1) = th1_wake(:,1:nl+1) 207 h(:,1:nl+1) = h1(:,1:nl+1) 208 lv(:,1:nl+1) = lv1(:,1:nl+1) 209 lf(:,1:nl+1) = lf1(:,1:nl+1) 210 cpn(:,1:nl+1) = cpn1(:,1:nl+1) 211 p(:,1:nl+1) = p1(:,1:nl+1) 212 ph(:,1:nl+1) = ph1(:,1:nl+1) 213 tv(:,1:nl+1) = tv1(:,1:nl+1) 214 tp(:,1:nl+1) = tp1(:,1:nl+1) 215 tvp(:,1:nl+1) = tvp1(:,1:nl+1) 216 clw(:,1:nl+1) = clw1(:,1:nl+1) 217 h_wake(:,1:nl+1) = h1_wake(:,1:nl+1) 218 lv_wake(:,1:nl+1) = lv1_wake(:,1:nl+1) 219 lf_wake(:,1:nl+1) = lf1_wake(:,1:nl+1) 220 cpn_wake(:,1:nl+1) = cpn1_wake(:,1:nl+1) 221 tv_wake(:,1:nl+1) = tv1_wake(:,1:nl+1) 222 sig(:,1:nl+1) = sig1(:,1:nl+1) 223 w0(:,1:nl+1) = w01(:,1:nl+1) 224 omega(:,1:nl+1) = omega1(:,1:nl+1) 225 ! 226 s_wake(:) = s1_wake(:) 227 iflag(:) = iflag1(:) 228 nk(:) = nk1(:) 229 icb(:) = icb1(:) 230 icbs(:) = icbs1(:) 231 plcl(:) = plcl1(:) 232 tnk(:) = tnk1(:) 233 qnk(:) = qnk1(:) 234 gznk(:) = gznk1(:) 235 hnk(:) = hnk1(:) 236 unk(:) = unk1(:) 237 vnk(:) = vnk1(:) 238 pbase(:) = pbase1(:) 239 buoybase(:) = buoybase1(:) 240 sig(:, nd) = sig1(:, nd) 241 ptop2(:) = ptop2(:) 242 Ale(:) = Ale1(:) 243 Alp(:) = Alp1(:) 244 ! 245 ENDIF !(compress) 246 !>jyg 159 247 160 248 RETURN -
LMDZ5/branches/testing/libf/phylmd/cv3a_uncompress.F90
r2220 r2298 1 SUBROUTINE cv3a_uncompress(nloc, len, ncum, nd, ntra, idcum, iflag, kbas, & 2 ktop, precip, cbmf, plcl, plfc, wbeff, sig, w0, ptop2, ft, fq, fu, fv, & 3 ftra, sigd, ma, mip, vprecip, upwd, dnwd, dnwd0, qcondc, wd, cape, cin, & 4 tvp, ftd, fqd, plim1, plim2, asupmax, supmax0, asupmaxmin & 5 , da, phi, mp, phi2, d1a, dam, sigij & ! RomP+AC+jyg 6 , clw, elij, evap, ep, epmlmmm, eplamm & ! RomP 7 , wdtraina, wdtrainm & ! RomP 8 , qtc, sigt & 9 10 , iflag1, kbas1, ktop1, precip1, cbmf1, plcl1, plfc1, wbeff1, sig1, w01, & 11 ptop21, ft1, fq1, fu1, fv1, ftra1, sigd1, ma1, mip1, vprecip1, upwd1, & 12 dnwd1, dnwd01, qcondc1, wd1, cape1, cin1, tvp1, ftd1, fqd1, plim11, & 13 plim21, asupmax1, supmax01, asupmaxmin1 & 14 , da1, phi1, mp1, phi21, d1a1, dam1, sigij1 & ! RomP+AC+jyg 15 , clw1, elij1, evap1, ep1, epmlmmm1, eplamm1 & ! RomP 16 , wdtraina1, wdtrainm1 & ! RomP 17 , qtc1, sigt1) 1 SUBROUTINE cv3a_uncompress(nloc, len, ncum, nd, ntra, idcum, compress, & 2 iflag, kbas, ktop, & 3 precip, cbmf, plcl, plfc, wbeff, sig, w0, ptop2, & 4 ft, fq, fu, fv, ftra, & 5 sigd, ma, mip, vprecip, upwd, dnwd, dnwd0, & 6 qcondc, wd, cape, cin, & 7 tvp, & 8 ftd, fqd, & 9 plim1, plim2, asupmax, supmax0, & 10 asupmaxmin, & 11 da, phi, mp, phi2, d1a, dam, sigij, & ! RomP+AC+jyg 12 clw, elij, evap, ep, epmlmMm, eplaMm, & ! RomP 13 wdtrainA, wdtrainM, & ! RomP 14 qtc, sigt, & 15 16 iflag1, kbas1, ktop1, & 17 precip1, cbmf1, plcl1, plfc1, wbeff1, sig1, w01, ptop21, & 18 ft1, fq1, fu1, fv1, ftra1, & 19 sigd1, ma1, mip1, vprecip1, upwd1, dnwd1, dnwd01, & 20 qcondc1, wd1, cape1, cin1, & 21 tvp1, & 22 ftd1, fqd1, & 23 plim11, plim21, asupmax1, supmax01, & 24 asupmaxmin1, & 25 da1, phi1, mp1, phi21, d1a1, dam1, sigij1, & ! RomP+AC+jyg 26 clw1, elij1, evap1, ep1, epmlmMm1, eplaMm1, & ! RomP 27 wdtrainA1, wdtrainM1, & ! RomP 28 qtc1, sigt1) 18 29 19 30 ! ************************************************************** … … 31 42 32 43 ! inputs: 33 INTEGER nloc, len, ncum, nd, ntra 34 INTEGER idcum(nloc) 35 INTEGER iflag(nloc), kbas(nloc), ktop(nloc) 36 REAL precip(nloc), cbmf(nloc), plcl(nloc), plfc(nloc) 37 REAL wbeff(len) 38 REAL sig(nloc, nd), w0(nloc, nd), ptop2(nloc) 39 REAL ft(nloc, nd), fq(nloc, nd), fu(nloc, nd), fv(nloc, nd) 40 REAL ftra(nloc, nd, ntra) 41 REAL sigd(nloc) 42 REAL ma(nloc, nd), mip(nloc, nd), vprecip(nloc, nd+1) 43 REAL upwd(nloc, nd), dnwd(nloc, nd), dnwd0(nloc, nd) 44 REAL qcondc(nloc, nd) 45 REAL wd(nloc), cape(nloc), cin(nloc) 46 REAL tvp(nloc, nd) 47 REAL ftd(nloc, nd), fqd(nloc, nd) 48 REAL plim1(nloc), plim2(nloc) 49 REAL asupmax(nloc, nd), supmax0(nloc) 50 REAL asupmaxmin(nloc) 51 52 REAL da(nloc, nd), phi(nloc, nd, nd) !AC! 53 REAL mp(nloc, nd) !RomP 54 REAL phi2(nloc, nd, nd) !RomP 55 REAL d1a(nloc, nd), dam(nloc, nd) !RomP 56 REAL sigij(nloc, nd, nd) !RomP 57 REAL clw(nloc, nd), elij(nloc, nd, nd) !RomP 58 REAL evap(nloc, nd), ep(nloc, nd) !RomP 59 REAL epmlmmm(nloc, nd, nd), eplamm(nloc, nd) !RomP+jyg 60 REAL qtc(nloc, nd), sigt(nloc, nd) !RomP 61 REAL wdtraina(nloc, nd), wdtrainm(nloc, nd) !RomP 44 INTEGER, INTENT (IN) :: nloc, len, ncum, nd, ntra 45 INTEGER, DIMENSION (nloc), INTENT (IN) :: idcum(nloc) 46 !jyg< 47 LOGICAL, INTENT (IN) :: compress 48 !>jyg 49 INTEGER, DIMENSION (nloc), INTENT (IN) ::iflag, kbas, ktop 50 REAL, DIMENSION (nloc), INTENT (IN) :: precip, cbmf, plcl, plfc 51 REAL, DIMENSION (nloc), INTENT (IN) :: wbeff 52 REAL, DIMENSION (nloc, nd), INTENT (IN) :: sig, w0 53 REAL, DIMENSION (nloc), INTENT (IN) :: ptop2 54 REAL, DIMENSION (nloc, nd), INTENT (IN) :: ft, fq, fu, fv 55 REAL, DIMENSION (nloc, nd, ntra), INTENT (IN) :: ftra 56 REAL, DIMENSION (nloc), INTENT (IN) :: sigd 57 REAL, DIMENSION (nloc, nd), INTENT (IN) :: ma, mip 58 REAL, DIMENSION (nloc, nd+1), INTENT (IN) :: vprecip 59 REAL, DIMENSION (nloc, nd), INTENT (IN) :: upwd, dnwd, dnwd0 60 REAL, DIMENSION (nloc, nd), INTENT (IN) :: qcondc 61 REAL, DIMENSION (nloc), INTENT (IN) :: wd, cape, cin 62 REAL, DIMENSION (nloc, nd), INTENT (IN) :: tvp 63 REAL, DIMENSION (nloc, nd), INTENT (IN) :: ftd, fqd 64 REAL, DIMENSION (nloc), INTENT (IN) :: plim1, plim2 65 REAL, DIMENSION (nloc, nd), INTENT (IN) :: asupmax 66 REAL, DIMENSION (nloc), INTENT (IN) :: supmax0, asupmaxmin 67 68 REAL, DIMENSION (nloc, nd), INTENT (IN) :: da 69 REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: phi !AC! 70 REAL, DIMENSION (nloc, nd), INTENT (IN) :: mp !RomP 71 REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: phi2 !RomP 72 REAL, DIMENSION (nloc, nd), INTENT (IN) :: d1a, dam !RomP 73 REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: sigij !RomP 74 REAL, DIMENSION (nloc, nd), INTENT (IN) :: clw !RomP 75 REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: elij !RomP 76 REAL, DIMENSION (nloc, nd), INTENT (IN) :: evap, ep !RomP 77 REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: epmlmMm !RomP+jyg 78 REAL, DIMENSION (nloc, nd), INTENT (IN) :: eplamM !RomP+jyg 79 REAL, DIMENSION (nloc, nd), INTENT (IN) :: qtc, sigt !RomP 80 REAL, DIMENSION (nloc, nd), INTENT (IN) :: wdtrainA, wdtrainM !RomP 62 81 63 82 ! outputs: 64 INTEGER iflag1(len), kbas1(len), ktop1(len) 65 REAL precip1(len), cbmf1(len), plcl1(nloc), plfc1(nloc) 66 REAL wbeff1(len) 67 REAL sig1(len, nd), w01(len, nd), ptop21(len) 68 REAL ft1(len, nd), fq1(len, nd), fu1(len, nd), fv1(len, nd) 69 REAL ftra1(len, nd, ntra) 70 REAL sigd1(len) 71 REAL ma1(len, nd), mip1(len, nd), vprecip1(len, nd+1) 72 REAL upwd1(len, nd), dnwd1(len, nd), dnwd01(len, nd) 73 REAL qcondc1(len, nd) 74 REAL wd1(len), cape1(len), cin1(len) 75 REAL tvp1(len, nd) 76 REAL ftd1(len, nd), fqd1(len, nd) 77 REAL plim11(len), plim21(len) 78 REAL asupmax1(len, nd), supmax01(len) 79 REAL asupmaxmin1(len) 80 81 REAL da1(nloc, nd), phi1(nloc, nd, nd) !AC! 82 REAL mp1(nloc, nd) !RomP 83 REAL phi21(nloc, nd, nd) !RomP 84 REAL d1a1(nloc, nd), dam1(nloc, nd) !RomP 85 REAL sigij1(len, nd, nd) !RomP 86 REAL clw1(len, nd), elij1(len, nd, nd) !RomP 87 REAL evap1(len, nd), ep1(len, nd) !RomP 88 REAL epmlmmm1(len, nd, nd), eplamm1(len, nd) !RomP+jyg 89 REAL qtc1(len, nd), sigt1(len, nd) !RomP 90 REAL wdtraina1(len, nd), wdtrainm1(len, nd) !RomP 83 INTEGER, DIMENSION (len), INTENT (OUT) :: iflag1, kbas1, ktop1 84 REAL, DIMENSION (len), INTENT (OUT) :: precip1, cbmf1, plcl1, plfc1 85 REAL, DIMENSION (len), INTENT (OUT) :: wbeff1 86 REAL, DIMENSION (len, nd), INTENT (OUT) :: sig1, w01 87 REAL, DIMENSION (len), INTENT (OUT) :: ptop21 88 REAL, DIMENSION (len, nd), INTENT (OUT) :: ft1, fq1, fu1, fv1 89 REAL, DIMENSION (len, nd, ntra), INTENT (OUT) :: ftra1 90 REAL, DIMENSION (len), INTENT (OUT) :: sigd1 91 REAL, DIMENSION (len, nd), INTENT (OUT) :: ma1, mip1 92 REAL, DIMENSION (len, nd+1), INTENT (OUT) :: vprecip1 93 REAL, DIMENSION (len, nd), INTENT (OUT) :: upwd1, dnwd1, dnwd01 94 REAL, DIMENSION (len, nd), INTENT (OUT) :: qcondc1 95 REAL, DIMENSION (len), INTENT (OUT) :: wd1, cape1, cin1 96 REAL, DIMENSION (len, nd), INTENT (OUT) :: tvp1 97 REAL, DIMENSION (len, nd), INTENT (OUT) :: ftd1, fqd1 98 REAL, DIMENSION (len), INTENT (OUT) :: plim11, plim21 99 REAL, DIMENSION (len, nd), INTENT (OUT) :: asupmax1 100 REAL, DIMENSION (len), INTENT (OUT) :: supmax01, asupmaxmin1 101 102 REAL, DIMENSION (len, nd), INTENT (OUT) :: da1 103 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: phi1 !AC! 104 REAL, DIMENSION (len, nd), INTENT (OUT) :: mp1 !RomP 105 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: phi21 !RomP 106 REAL, DIMENSION (len, nd), INTENT (OUT) :: d1a1, dam1 !RomP !RomP 107 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: sigij1 !RomP 108 REAL, DIMENSION (len, nd), INTENT (OUT) :: clw1 !RomP 109 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: elij1 !RomP 110 REAL, DIMENSION (len, nd), INTENT (OUT) :: evap1, ep1 !RomP 111 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: epmlmMm1 !RomP+jyg 112 REAL, DIMENSION (len, nd), INTENT (OUT) :: eplamM1 !RomP+jyg 113 REAL, DIMENSION (len, nd), INTENT (OUT) :: qtc1, sigt1 !RomP 114 REAL, DIMENSION (len, nd), INTENT (OUT) :: wdtrainA1, wdtrainM1 !RomP 91 115 92 116 93 117 ! local variables: 94 118 INTEGER i, k, j 119 INTEGER jdcum 95 120 ! c integer k1,k2 96 121 97 DO i = 1, ncum 98 ptop21(idcum(i)) = ptop2(i) 99 sigd1(idcum(i)) = sigd(i) 100 precip1(idcum(i)) = precip(i) 101 cbmf1(idcum(i)) = cbmf(i) 102 plcl1(idcum(i)) = plcl(i) 103 plfc1(idcum(i)) = plfc(i) 104 wbeff1(idcum(i)) = wbeff(i) 105 iflag1(idcum(i)) = iflag(i) 106 kbas1(idcum(i)) = kbas(i) 107 ktop1(idcum(i)) = ktop(i) 108 wd1(idcum(i)) = wd(i) 109 cape1(idcum(i)) = cape(i) 110 cin1(idcum(i)) = cin(i) 111 plim11(idcum(i)) = plim1(i) 112 plim21(idcum(i)) = plim2(i) 113 supmax01(idcum(i)) = supmax0(i) 114 asupmaxmin1(idcum(i)) = asupmaxmin(i) 115 END DO 116 117 DO k = 1, nd 122 !jyg< 123 IF (compress) THEN 124 !>jyg 118 125 DO i = 1, ncum 119 sig1(idcum(i), k) = sig(i, k) 120 w01(idcum(i), k) = w0(i, k) 121 ft1(idcum(i), k) = ft(i, k) 122 fq1(idcum(i), k) = fq(i, k) 123 fu1(idcum(i), k) = fu(i, k) 124 fv1(idcum(i), k) = fv(i, k) 125 ma1(idcum(i), k) = ma(i, k) 126 mip1(idcum(i), k) = mip(i, k) 127 vprecip1(idcum(i), k) = vprecip(i, k) 128 upwd1(idcum(i), k) = upwd(i, k) 129 dnwd1(idcum(i), k) = dnwd(i, k) 130 dnwd01(idcum(i), k) = dnwd0(i, k) 131 qcondc1(idcum(i), k) = qcondc(i, k) 132 tvp1(idcum(i), k) = tvp(i, k) 133 ftd1(idcum(i), k) = ftd(i, k) 134 fqd1(idcum(i), k) = fqd(i, k) 135 asupmax1(idcum(i), k) = asupmax(i, k) 136 137 da1(idcum(i), k) = da(i, k) !AC! 138 mp1(idcum(i), k) = mp(i, k) !RomP 139 d1a1(idcum(i), k) = d1a(i, k) !RomP 140 dam1(idcum(i), k) = dam(i, k) !RomP 141 clw1(idcum(i), k) = clw(i, k) !RomP 142 evap1(idcum(i), k) = evap(i, k) !RomP 143 ep1(idcum(i), k) = ep(i, k) !RomP 144 eplamm(idcum(i), k) = eplamm(i, k) !RomP+jyg 145 wdtraina1(idcum(i), k) = wdtraina(i, k) !RomP 146 wdtrainm1(idcum(i), k) = wdtrainm(i, k) !RomP 147 qtc1(idcum(i), k) = qtc(i, k) 148 sigt1(idcum(i), k) = sigt(i, k) 149 126 sig1(idcum(i), nd) = sig(i, nd) 127 ptop21(idcum(i)) = ptop2(i) 128 sigd1(idcum(i)) = sigd(i) 129 precip1(idcum(i)) = precip(i) 130 cbmf1(idcum(i)) = cbmf(i) 131 plcl1(idcum(i)) = plcl(i) 132 plfc1(idcum(i)) = plfc(i) 133 wbeff1(idcum(i)) = wbeff(i) 134 iflag1(idcum(i)) = iflag(i) 135 kbas1(idcum(i)) = kbas(i) 136 ktop1(idcum(i)) = ktop(i) 137 wd1(idcum(i)) = wd(i) 138 cape1(idcum(i)) = cape(i) 139 cin1(idcum(i)) = cin(i) 140 plim11(idcum(i)) = plim1(i) 141 plim21(idcum(i)) = plim2(i) 142 supmax01(idcum(i)) = supmax0(i) 143 asupmaxmin1(idcum(i)) = asupmaxmin(i) 150 144 END DO 151 END DO 152 153 DO i = 1, ncum 154 sig1(idcum(i), nd) = sig(i, nd) 155 END DO 156 157 158 ! AC! do 2100 j=1,ntra 159 ! AC!c oct3 do 2110 k=1,nl 160 ! AC! do 2110 k=1,nd ! oct3 161 ! AC! do 2120 i=1,ncum 162 ! AC! ftra1(idcum(i),k,j)=ftra(i,k,j) 163 ! AC! 2120 continue 164 ! AC! 2110 continue 165 ! AC! 2100 continue 166 167 ! AC! 168 DO j = 1, nd 169 DO k = 1, nd 145 146 DO k = 1, nl+1 170 147 DO i = 1, ncum 171 phi1(idcum(i), k, j) = phi(i, k, j) !AC! 172 phi21(idcum(i), k, j) = phi2(i, k, j) !RomP 173 sigij1(idcum(i), k, j) = sigij(i, k, j) !RomP 174 elij1(idcum(i), k, j) = elij(i, k, j) !RomP 175 epmlmmm(idcum(i), k, j) = epmlmmm(i, k, j) !RomP+jyg 148 sig1(idcum(i), k) = sig(i, k) 149 w01(idcum(i), k) = w0(i, k) 150 ft1(idcum(i), k) = ft(i, k) 151 fq1(idcum(i), k) = fq(i, k) 152 fu1(idcum(i), k) = fu(i, k) 153 fv1(idcum(i), k) = fv(i, k) 154 ma1(idcum(i), k) = ma(i, k) 155 mip1(idcum(i), k) = mip(i, k) 156 vprecip1(idcum(i), k) = vprecip(i, k) 157 upwd1(idcum(i), k) = upwd(i, k) 158 dnwd1(idcum(i), k) = dnwd(i, k) 159 dnwd01(idcum(i), k) = dnwd0(i, k) 160 qcondc1(idcum(i), k) = qcondc(i, k) 161 tvp1(idcum(i), k) = tvp(i, k) 162 ftd1(idcum(i), k) = ftd(i, k) 163 fqd1(idcum(i), k) = fqd(i, k) 164 asupmax1(idcum(i), k) = asupmax(i, k) 165 166 da1(idcum(i), k) = da(i, k) !AC! 167 mp1(idcum(i), k) = mp(i, k) !RomP 168 d1a1(idcum(i), k) = d1a(i, k) !RomP 169 dam1(idcum(i), k) = dam(i, k) !RomP 170 clw1(idcum(i), k) = clw(i, k) !RomP 171 evap1(idcum(i), k) = evap(i, k) !RomP 172 ep1(idcum(i), k) = ep(i, k) !RomP 173 eplamM1(idcum(i), k) = eplamM(i, k) !RomP+jyg 174 wdtrainA1(idcum(i), k) = wdtrainA(i, k) !RomP 175 wdtrainM1(idcum(i), k) = wdtrainM(i, k) !RomP 176 qtc1(idcum(i), k) = qtc(i, k) 177 sigt1(idcum(i), k) = sigt(i, k) 178 176 179 END DO 177 180 END DO 178 END DO 179 ! AC! 180 181 182 ! do 2220 k2=1,nd 183 ! do 2210 k1=1,nd 184 ! do 2200 i=1,ncum 185 ! ment1(idcum(i),k1,k2) = ment(i,k1,k2) 186 ! sigij1(idcum(i),k1,k2) = sigij(i,k1,k2) 187 ! 2200 enddo 188 ! 2210 enddo 189 ! 2220 enddo 181 182 ! AC! do 2100 j=1,ntra 183 ! AC!c oct3 do 2110 k=1,nl 184 ! AC! do 2110 k=1,nd ! oct3 185 ! AC! do 2120 i=1,ncum 186 ! AC! ftra1(idcum(i),k,j)=ftra(i,k,j) 187 ! AC! 2120 continue 188 ! AC! 2110 continue 189 ! AC! 2100 continue 190 191 ! AC! 192 !jyg< 193 ! Essais pour gagner du temps en diminuant l'adressage indirect 194 !! DO j = 1, nd 195 !! DO k = 1, nd 196 !! DO i = 1, ncum 197 !! phi1(idcum(i), k, j) = phi(i, k, j) !AC! 198 !! phi21(idcum(i), k, j) = phi2(i, k, j) !RomP 199 !! sigij1(idcum(i), k, j) = sigij(i, k, j) !RomP 200 !! elij1(idcum(i), k, j) = elij(i, k, j) !RomP 201 !! epmlmMm(idcum(i), k, j) = epmlmMm(i, k, j) !RomP+jyg 202 !! END DO 203 !! END DO 204 !! END DO 205 DO i = 1, ncum 206 jdcum=idcum(i) 207 phi1 (jdcum, 1:nl+1, 1:nl+1) = phi (i, 1:nl+1, 1:nl+1) !AC! 208 phi21 (jdcum, 1:nl+1, 1:nl+1) = phi2 (i, 1:nl+1, 1:nl+1) !RomP 209 sigij1 (jdcum, 1:nl+1, 1:nl+1) = sigij (i, 1:nl+1, 1:nl+1) !RomP 210 elij1 (jdcum, 1:nl+1, 1:nl+1) = elij (i, 1:nl+1, 1:nl+1) !RomP 211 epmlmMm1(jdcum, 1:nl+1, 1:nl+1) = epmlmMm(i, 1:nl+1, 1:nl+1) !RomP+jyg 212 END DO 213 !>jyg 214 ! AC! 215 216 217 ! do 2220 k2=1,nd 218 ! do 2210 k1=1,nd 219 ! do 2200 i=1,ncum 220 ! ment1(idcum(i),k1,k2) = ment(i,k1,k2) 221 ! sigij1(idcum(i),k1,k2) = sigij(i,k1,k2) 222 ! 2200 enddo 223 ! 2210 enddo 224 ! 2220 enddo 225 ! 226 !jyg< 227 ELSE !(compress) 228 ! 229 sig1(:,nd) = sig(:,nd) 230 ptop21(:) = ptop2(:) 231 sigd1(:) = sigd(:) 232 precip1(:) = precip(:) 233 cbmf1(:) = cbmf(:) 234 plcl1(:) = plcl(:) 235 plfc1(:) = plfc(:) 236 wbeff1(:) = wbeff(:) 237 iflag1(:) = iflag(:) 238 kbas1(:) = kbas(:) 239 ktop1(:) = ktop(:) 240 wd1(:) = wd(:) 241 cape1(:) = cape(:) 242 cin1(:) = cin(:) 243 plim11(:) = plim1(:) 244 plim21(:) = plim2(:) 245 supmax01(:) = supmax0(:) 246 asupmaxmin1(:) = asupmaxmin(:) 247 ! 248 sig1(:, 1:nl+1) = sig(:, 1:nl+1) 249 w01(:, 1:nl+1) = w0(:, 1:nl+1) 250 ft1(:, 1:nl+1) = ft(:, 1:nl+1) 251 fq1(:, 1:nl+1) = fq(:, 1:nl+1) 252 fu1(:, 1:nl+1) = fu(:, 1:nl+1) 253 fv1(:, 1:nl+1) = fv(:, 1:nl+1) 254 ma1(:, 1:nl+1) = ma(:, 1:nl+1) 255 mip1(:, 1:nl+1) = mip(:, 1:nl+1) 256 vprecip1(:, 1:nl+1) = vprecip(:, 1:nl+1) 257 upwd1(:, 1:nl+1) = upwd(:, 1:nl+1) 258 dnwd1(:, 1:nl+1) = dnwd(:, 1:nl+1) 259 dnwd01(:, 1:nl+1) = dnwd0(:, 1:nl+1) 260 qcondc1(:, 1:nl+1) = qcondc(:, 1:nl+1) 261 tvp1(:, 1:nl+1) = tvp(:, 1:nl+1) 262 ftd1(:, 1:nl+1) = ftd(:, 1:nl+1) 263 fqd1(:, 1:nl+1) = fqd(:, 1:nl+1) 264 asupmax1(:, 1:nl+1) = asupmax(:, 1:nl+1) 265 266 da1(:, 1:nl+1) = da(:, 1:nl+1) !AC! 267 mp1(:, 1:nl+1) = mp(:, 1:nl+1) !RomP 268 d1a1(:, 1:nl+1) = d1a(:, 1:nl+1) !RomP 269 dam1(:, 1:nl+1) = dam(:, 1:nl+1) !RomP 270 clw1(:, 1:nl+1) = clw(:, 1:nl+1) !RomP 271 evap1(:, 1:nl+1) = evap(:, 1:nl+1) !RomP 272 ep1(:, 1:nl+1) = ep(:, 1:nl+1) !RomP 273 eplamM1(:, 1:nl+1) = eplamM(:, 1:nl+1) !RomP+jyg 274 wdtrainA1(:, 1:nl+1) = wdtrainA(:, 1:nl+1) !RomP 275 wdtrainM1(:, 1:nl+1) = wdtrainM(:, 1:nl+1) !RomP 276 qtc1(:, 1:nl+1) = qtc(:, 1:nl+1) 277 sigt1(:, 1:nl+1) = sigt(:, 1:nl+1) 278 ! 279 phi1 (:, 1:nl+1, 1:nl+1) = phi (:, 1:nl+1, 1:nl+1) !AC! 280 phi21 (:, 1:nl+1, 1:nl+1) = phi2 (:, 1:nl+1, 1:nl+1) !RomP 281 sigij1 (:, 1:nl+1, 1:nl+1) = sigij (:, 1:nl+1, 1:nl+1) !RomP 282 elij1 (:, 1:nl+1, 1:nl+1) = elij (:, 1:nl+1, 1:nl+1) !RomP 283 epmlmMm1(:, 1:nl+1, 1:nl+1) = epmlmMm(:, 1:nl+1, 1:nl+1) !RomP+jyg 284 ENDIF !(compress) 285 !>jyg 190 286 191 287 RETURN -
LMDZ5/branches/testing/libf/phylmd/cv3p1_closure.F90
r2258 r2298 29 29 30 30 ! input: 31 INTEGER ncum, nd, nloc 32 INTEGER icb(nloc), inb(nloc) 33 REAL pbase(nloc), plcl(nloc) 34 REAL p(nloc, nd), ph(nloc, nd+1) 35 REAL tv(nloc, nd), tvp(nloc, nd), buoy(nloc, nd) 36 REAL supmax(nloc, nd) 37 LOGICAL ok_inhib ! enable convection inhibition by dryness 38 REAL ale(nloc), alp(nloc) 39 REAL omega(nloc,nd) 31 INTEGER, INTENT (IN) :: ncum, nd, nloc 32 INTEGER, DIMENSION (nloc), INTENT (IN) :: icb, inb 33 REAL, DIMENSION (nloc), INTENT (IN) :: pbase, plcl 34 REAL, DIMENSION (nloc, nd), INTENT (IN) :: p 35 REAL, DIMENSION (nloc, nd+1), INTENT (IN) :: ph 36 REAL, DIMENSION (nloc, nd), INTENT (IN) :: tv, tvp, buoy 37 REAL, DIMENSION (nloc, nd), INTENT (IN) :: supmax 38 LOGICAL, INTENT (IN) :: ok_inhib ! enable convection inhibition by dryness 39 REAL, DIMENSION (nloc), INTENT (IN) :: ale, alp 40 REAL, DIMENSION (nloc, nd), INTENT (IN) :: omega 40 41 41 42 ! input/output: 42 REAL sig(nloc, nd), w0(nloc, nd), ptop2(nloc) 43 REAL, DIMENSION (nloc, nd), INTENT (INOUT) :: sig, w0 44 REAL, DIMENSION (nloc), INTENT (INOUT) :: ptop2 43 45 44 46 ! output: 45 REAL cape(nloc), cin(nloc) 46 REAL m(nloc, nd) 47 REAL plim1(nloc), plim2(nloc) 48 REAL asupmax(nloc, nd), supmax0(nloc) 49 REAL asupmaxmin(nloc) 50 REAL cbmf(nloc), plfc(nloc) 51 REAL wbeff(nloc) 52 INTEGER iflag(nloc) 47 REAL, DIMENSION (nloc), INTENT (OUT) :: cape, cin 48 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: m 49 REAL, DIMENSION (nloc), INTENT (OUT) :: plim1, plim2 50 REAL, DIMENSION (nloc, nd), INTENT (OUT) :: asupmax 51 REAL, DIMENSION (nloc), INTENT (OUT) :: supmax0 52 REAL, DIMENSION (nloc), INTENT (OUT) :: asupmaxmin 53 REAL, DIMENSION (nloc), INTENT (OUT) :: cbmf, plfc 54 REAL, DIMENSION (nloc), INTENT (OUT) :: wbeff 55 INTEGER, DIMENSION (nloc), INTENT (OUT) :: iflag 53 56 54 57 ! local variables: … … 91 94 92 95 93 94 96 DO il = 1, ncum 95 97 alp2(il) = max(alp(il), 1.E-5) … … 498 500 IF (prt_level>=20) PRINT *, 'cv3p1_param apres cbmflim' 499 501 500 ! c 1.5 Compute cloud base mass flux given by Alp closure (Cbmf1), maximum 501 ! c allowed mass flux (Cbmfmax) and final target mass flux (Cbmf) 502 ! c Cbmf is set to zero if Cbmflim (the mass flux of elementary cloud) 503 ! is 504 ! -- exceedingly small. 502 ! 1.5 Compute cloud base mass flux given by Alp closure (Cbmf1), maximum 503 ! allowed mass flux (Cbmfmax) and final target mass flux (Cbmf) 504 ! Cbmf is set to zero if Cbmflim (the mass flux of elementary cloud) 505 ! is exceedingly small. 505 506 506 507 DO il = 1, ncum -
LMDZ5/branches/testing/libf/phylmd/cv3param.h
r1999 r2298 19 19 real betad 20 20 21 COMMON /cv3param/ noff, minorig, nl, nlp, nlm & 22 , sigdz, spfac & 23 ,flag_epKEorig & 21 COMMON /cv3param/ sigdz, spfac & 24 22 ,pbcrit, ptcrit & 25 23 ,elcrit, tlcrit & … … 27 25 ,dtovsh, dpbase, dttrig & 28 26 ,dtcrit, tau, beta, alpha, alpha1 & 29 ,flag_wb,wbmax & 30 ,delta, betad 27 ,wbmax & 28 ,delta, betad & 29 ,flag_epKEorig & 30 ,flag_wb & 31 ,noff, minorig, nl, nlp, nlm 31 32 !$OMP THREADPRIVATE(/cv3param/) 32 33 -
LMDZ5/branches/testing/libf/phylmd/cva_driver.F90
r2220 r2298 2 2 ! $Id$ 3 3 4 SUBROUTINE cva_driver(len, nd, ndp1, ntra, nloc, &4 SUBROUTINE cva_driver(len, nd, ndp1, ntra, nloc, k_upper, & 5 5 iflag_con, iflag_mix, iflag_ice_thermo, iflag_clos, ok_conserv_q, & 6 delt, t1, q1, qs1, t1_wake, q1_wake, qs1_wake, s1_wake, & 6 !! delt, t1, q1, qs1, t1_wake, q1_wake, qs1_wake, s1_wake, & ! jyg 7 delt, comp_threshold, & ! jyg 8 t1, q1, qs1, t1_wake, q1_wake, qs1_wake, s1_wake, & ! jyg 7 9 u1, v1, tra1, & 8 10 p1, ph1, & … … 19 21 ftd1, fqd1, & 20 22 Plim11, Plim21, asupmax1, supmax01, asupmaxmin1, & 21 lalim_conv , &23 lalim_conv1, & 22 24 !! da1,phi1,mp1,phi21,d1a1,dam1,sigij1,clw1, & ! RomP 23 25 !! elij1,evap1,ep1,epmlmMm1,eplaMm1, & ! RomP … … 52 54 ! ndp1 Integer Input nd + 1 53 55 ! ntra Integer Input number of tracors 56 ! nloc Integer Input dimension of arrays for compressed fields 57 ! k_upper Integer Input upmost level for vertical loops 54 58 ! iflag_con Integer Input version of convect (3/4) 55 59 ! iflag_mix Integer Input version of mixing (0/1/2) … … 60 64 ! ok_conserv_q Logical Input when true corrections for water conservation are swtiched on 61 65 ! delt Real Input time step 66 ! comp_threshold Real Input threshold on the fraction of convective points below which 67 ! fields are compressed 62 68 ! t1 Real Input temperature (sat draught envt) 63 69 ! q1 Real Input specific hum (sat draught envt) … … 156 162 include 'iniprint.h' 157 163 158 159 164 ! Input 160 INTEGER len 161 INTEGER nd 162 INTEGER ndp1 163 INTEGER ntra 164 INTEGER iflag_con 165 INTEGER iflag_mix 166 INTEGER iflag_ice_thermo 167 INTEGER iflag_clos 168 LOGICAL ok_conserv_q 169 REAL tau_cld_cv 170 REAL coefw_cld_cv 171 REAL delt 172 REAL t1(len, nd) 173 REAL q1(len, nd) 174 REAL qs1(len, nd) 175 REAL t1_wake(len, nd) 176 REAL q1_wake(len, nd) 177 REAL qs1_wake(len, nd) 178 REAL s1_wake(len) 179 REAL u1(len, nd) 180 REAL v1(len, nd) 181 REAL tra1(len, nd, ntra) 182 REAL p1(len, nd) 183 REAL ph1(len, ndp1) 184 REAL Ale1(len) 185 REAL Alp1(len) 186 REAL omega1(len,nd) 187 REAL sig1feed1 ! pressure at lower bound of feeding layer 188 REAL sig2feed1 ! pressure at upper bound of feeding layer 189 REAL wght1(nd) ! weight density determining the feeding mixture 165 INTEGER, INTENT (IN) :: len 166 INTEGER, INTENT (IN) :: nd 167 INTEGER, INTENT (IN) :: ndp1 168 INTEGER, INTENT (IN) :: ntra 169 INTEGER, INTENT(IN) :: nloc ! (nloc=klon) pour l'instant 170 INTEGER, INTENT (IN) :: k_upper 171 INTEGER, INTENT (IN) :: iflag_con 172 INTEGER, INTENT (IN) :: iflag_mix 173 INTEGER, INTENT (IN) :: iflag_ice_thermo 174 INTEGER, INTENT (IN) :: iflag_clos 175 LOGICAL, INTENT (IN) :: ok_conserv_q 176 REAL, INTENT (IN) :: tau_cld_cv 177 REAL, INTENT (IN) :: coefw_cld_cv 178 REAL, INTENT (IN) :: delt 179 REAL, INTENT (IN) :: comp_threshold 180 REAL, DIMENSION (len, nd), INTENT (IN) :: t1 181 REAL, DIMENSION (len, nd), INTENT (IN) :: q1 182 REAL, DIMENSION (len, nd), INTENT (IN) :: qs1 183 REAL, DIMENSION (len, nd), INTENT (IN) :: t1_wake 184 REAL, DIMENSION (len, nd), INTENT (IN) :: q1_wake 185 REAL, DIMENSION (len, nd), INTENT (IN) :: qs1_wake 186 REAL, DIMENSION (len), INTENT (IN) :: s1_wake 187 REAL, DIMENSION (len, nd), INTENT (IN) :: u1 188 REAL, DIMENSION (len, nd), INTENT (IN) :: v1 189 REAL, DIMENSION (len, nd, ntra), INTENT (IN) :: tra1 190 REAL, DIMENSION (len, nd), INTENT (IN) :: p1 191 REAL, DIMENSION (len, ndp1), INTENT (IN) :: ph1 192 REAL, DIMENSION (len), INTENT (IN) :: Ale1 193 REAL, DIMENSION (len), INTENT (IN) :: Alp1 194 REAL, DIMENSION (len, nd), INTENT (IN) :: omega1 195 REAL, INTENT (IN) :: sig1feed1 ! pressure at lower bound of feeding layer 196 REAL, INTENT (IN) :: sig2feed1 ! pressure at upper bound of feeding layer 197 REAL, DIMENSION (nd), INTENT (IN) :: wght1 ! weight density determining the feeding mixture 198 INTEGER, DIMENSION (len), INTENT (IN) :: lalim_conv1 199 200 ! Input/Output 201 REAL, DIMENSION (len, nd), INTENT (INOUT) :: sig1 202 REAL, DIMENSION (len, nd), INTENT (INOUT) :: w01 190 203 191 204 ! Output 192 INTEGER iflag1(len) 193 REAL ft1(len, nd) 194 REAL fq1(len, nd) 195 REAL fu1(len, nd) 196 REAL fv1(len, nd) 197 REAL ftra1(len, nd, ntra) 198 REAL precip1(len) 199 INTEGER kbas1(len) 200 INTEGER ktop1(len) 201 REAL cbmf1(len) 202 REAL plcl1(klon) 203 REAL plfc1(klon) 204 REAL wbeff1(klon) 205 REAL sig1(len, klev) !input/output 206 REAL w01(len, klev) !input/output 207 REAL ptop21(len) 208 REAL sigd1(len) 209 REAL ma1(len, nd) 210 REAL mip1(len, nd) 205 INTEGER, DIMENSION (len), INTENT (OUT) :: iflag1 206 REAL, DIMENSION (len, nd), INTENT (OUT) :: ft1 207 REAL, DIMENSION (len, nd), INTENT (OUT) :: fq1 208 REAL, DIMENSION (len, nd), INTENT (OUT) :: fu1 209 REAL, DIMENSION (len, nd), INTENT (OUT) :: fv1 210 REAL, DIMENSION (len, nd, ntra), INTENT (OUT) :: ftra1 211 REAL, DIMENSION (len), INTENT (OUT) :: precip1 212 INTEGER, DIMENSION (len), INTENT (OUT) :: kbas1 213 INTEGER, DIMENSION (len), INTENT (OUT) :: ktop1 214 REAL, DIMENSION (len), INTENT (OUT) :: cbmf1 215 REAL, DIMENSION (len), INTENT (OUT) :: plcl1 216 REAL, DIMENSION (len), INTENT (OUT) :: plfc1 217 REAL, DIMENSION (len), INTENT (OUT) :: wbeff1 218 REAL, DIMENSION (len), INTENT (OUT) :: ptop21 219 REAL, DIMENSION (len), INTENT (OUT) :: sigd1 220 REAL, DIMENSION (len, nd), INTENT (OUT) :: ma1 221 REAL, DIMENSION (len, nd), INTENT (OUT) :: mip1 211 222 ! real Vprecip1(len,nd) 212 REAL vprecip1(len, nd+1)213 REAL upwd1(len, nd)214 REAL dnwd1(len, nd)215 REAL dnwd01(len, nd)216 REAL qcondc1(len, nd)! cld217 REAL wd1(len)! gust218 REAL cape1(len)219 REAL cin1(len)220 REAL tvp1(len, nd)223 REAL, DIMENSION (len, ndp1), INTENT (OUT) :: vprecip1 224 REAL, DIMENSION (len, nd), INTENT (OUT) :: upwd1 225 REAL, DIMENSION (len, nd), INTENT (OUT) :: dnwd1 226 REAL, DIMENSION (len, nd), INTENT (OUT) :: dnwd01 227 REAL, DIMENSION (len, nd), INTENT (OUT) :: qcondc1 ! cld 228 REAL, DIMENSION (len), INTENT (OUT) :: wd1 ! gust 229 REAL, DIMENSION (len), INTENT (OUT) :: cape1 230 REAL, DIMENSION (len), INTENT (OUT) :: cin1 231 REAL, DIMENSION (len, nd), INTENT (OUT) :: tvp1 221 232 222 233 !AC! … … 224 235 !! real da(len,nd),phi(len,nd,nd) 225 236 !AC! 226 REAL ftd1(len, nd) 227 REAL fqd1(len, nd) 228 REAL Plim11(len) 229 REAL Plim21(len) 230 REAL asupmax1(len, nd) 231 REAL supmax01(len) 232 REAL asupmaxmin1(len) 233 INTEGER lalim_conv(len) 234 REAL qtc1(len, nd) ! cld 235 REAL sigt1(len, nd) ! cld 237 REAL, DIMENSION (len, nd), INTENT (OUT) :: ftd1 238 REAL, DIMENSION (len, nd), INTENT (OUT) :: fqd1 239 REAL, DIMENSION (len), INTENT (OUT) :: Plim11 240 REAL, DIMENSION (len), INTENT (OUT) :: Plim21 241 REAL, DIMENSION (len, nd), INTENT (OUT) :: asupmax1 242 REAL, DIMENSION (len), INTENT (OUT) :: supmax01 243 REAL, DIMENSION (len), INTENT (OUT) :: asupmaxmin1 244 REAL, DIMENSION (len, nd), INTENT (OUT) :: qtc1 ! cld 245 REAL, DIMENSION (len, nd), INTENT (OUT) :: sigt1 ! cld 236 246 237 247 ! RomP >>> 238 REAL wdtrainA1(len, nd), wdtrainM1(len, nd) 239 REAL da1(len, nd), phi1(len, nd, nd), mp1(len, nd) 240 REAL epmlmMm1(len, nd, nd), eplaMm1(len, nd) 241 REAL evap1(len, nd), ep1(len, nd) 242 REAL sigij1(len, nd, nd), elij1(len, nd, nd) 248 REAL, DIMENSION (len, nd), INTENT (OUT) :: wdtrainA1, wdtrainM1 249 REAL, DIMENSION (len, nd), INTENT (OUT) :: da1, mp1 250 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: phi1 251 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: epmlmMm1 252 REAL, DIMENSION (len, nd), INTENT (OUT) :: eplaMm1 253 REAL, DIMENSION (len, nd), INTENT (OUT) :: evap1, ep1 254 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: sigij1, elij1 243 255 !JYG,RL 244 REAL wghti1(len, nd)! final weight of the feeding layers256 REAL, DIMENSION (len, nd), INTENT (OUT) :: wghti1 ! final weight of the feeding layers 245 257 !JYG,RL 246 REAL phi21(len, nd, nd)247 REAL d1a1(len, nd), dam1(len, nd)258 REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: phi21 259 REAL, DIMENSION (len, nd), INTENT (OUT) :: d1a1, dam1 248 260 ! RomP <<< 249 261 … … 388 400 !$OMP THREADPRIVATE(debut) 389 401 402 REAL coef_convective(len) ! = 1 for convective points, = 0 otherwise 390 403 REAL tnk1(klon) 391 404 REAL thnk1(klon) … … 426 439 ! (local) compressed fields: 427 440 428 INTEGER nloc429 ! parameter (nloc=klon) ! pour l'instant430 441 431 442 INTEGER idcum(nloc) 443 !jyg< 444 LOGICAL compress ! True if compression occurs 445 !>jyg 432 446 INTEGER iflag(nloc), nk(nloc), icb(nloc) 433 447 INTEGER nent(nloc, klev) … … 480 494 REAL fu(nloc, klev), fv(nloc, klev) 481 495 REAL upwd(nloc, klev), dnwd(nloc, klev), dnwd0(nloc, klev) 482 REAL ma(nloc, klev), mip(nloc, klev), tls(nloc, klev) 483 REAL tps(nloc, klev), qprime(nloc), tprime(nloc) 496 REAL ma(nloc, klev), mip(nloc, klev) 497 !! REAL tls(nloc, klev), tps(nloc, klev) ! unused . jyg 498 REAL qprime(nloc), tprime(nloc) 484 499 REAL precip(nloc) 485 500 ! real Vprecip(nloc,klev) … … 547 562 548 563 IF (iflag_con==3) THEN 549 CALL cv3_param(nd, delt)564 CALL cv3_param(nd, k_upper, delt) 550 565 551 566 END IF … … 682 697 ! p2feed1(i)=ph1(i,3) 683 698 !testCR: on prend la couche alim des thermiques 684 ! p2feed1(i)=ph1(i,lalim_conv (i)+1)699 ! p2feed1(i)=ph1(i,lalim_conv1(i)+1) 685 700 ! print*,'lentr=',lentr(i),ph1(i,lentr(i)+1),ph1(i,2) 686 701 END DO … … 762 777 ! ===================================================================== 763 778 779 ! Determine the number "ncum" of convective gridpoints, the list "idcum" of convective 780 ! gridpoints and the weights "coef_convective" (= 1. for convective gridpoints and = 0. 781 ! elsewhere). 764 782 ncum = 0 783 coef_convective(:) = 0. 765 784 DO i = 1, len 766 785 IF (iflag1(i)==0) THEN 786 coef_convective(i) = 1. 767 787 ncum = ncum + 1 768 788 idcum(ncum) = i … … 782 802 ! print*,'ncum tv1 ',ncum,tv1 783 803 ! print*,'tvp1 ',tvp1 784 CALL cv3a_compress(len, nloc, ncum, nd, ntra, & 804 !jyg< 805 ! If the fraction of convective points is larger than comp_threshold, then compression 806 ! is assumed useless. 807 ! 808 compress = ncum .lt. len*comp_threshold 809 ! 810 IF (.not. compress) THEN 811 DO i = 1,len 812 idcum(i) = i 813 ENDDO 814 ENDIF 815 ! 816 !>jyg 817 CALL cv3a_compress(len, nloc, ncum, nd, ntra, compress, & 785 818 iflag1, nk1, icb1, icbs1, & 786 819 plcl1, tnk1, qnk1, gznk1, hnk1, unk1, vnk1, & … … 837 870 inb, tp, tvp, clw, hp, ep, sigp, buoy, & 838 871 frac) 839 840 872 END IF 841 873 … … 897 929 Plim1, plim2, asupmax, supmax0, & 898 930 asupmaxmin, cbmf, plfc, wbeff) 899 900 931 if (prt_level >= 10) & 901 932 PRINT *, 'cv3p1_closure-> plfc,wbeff ', plfc(1), wbeff(1) … … 993 1024 iflag, precip, vprecip, ft, fq, fu, fv, ftra, & 994 1025 cbmf, upwd, dnwd, dnwd0, ma, mip, & 995 tls, tps, qcondc, wd, & 1026 !! tls, tps, & ! useless . jyg 1027 qcondc, wd, & 996 1028 ftd, fqd, qnk, qtc, sigt, tau_cld_cv, coefw_cld_cv) 997 1029 END IF … … 1035 1067 1036 1068 IF (iflag_con==3) THEN 1037 CALL cv3a_uncompress(nloc, len, ncum, nd, ntra, idcum, &1069 CALL cv3a_uncompress(nloc, len, ncum, nd, ntra, idcum, compress, & 1038 1070 iflag, icb, inb, & 1039 1071 precip, cbmf, plcl, plfc, wbeff, sig, w0, ptop2, & … … 1078 1110 END IF ! ncum>0 1079 1111 1112 ! 1113 ! In order take into account the possibility of changing the compression, 1114 ! reset m, sig and w0 to zero for non-convective points. 1115 DO k = 1,nd-1 1116 sig1(:, k) = sig1(:, k)*coef_convective(:) 1117 w01(:, k) = w01(:, k)*coef_convective(:) 1118 ENDDO 1119 1080 1120 IF (debut) THEN 1081 PRINT *, ' cv_ compress -> '1121 PRINT *, ' cv_uncompress -> ' 1082 1122 debut = .FALSE. 1083 1123 END IF !(debut) THEN -
LMDZ5/branches/testing/libf/phylmd/cvltr_scav.F90
r2160 r2298 122 122 real :: conservMA 123 123 124 ! ====================================================== 125 ! calcul de l'impaction 126 ! ====================================================== 127 128 ! impaction sur la surface de la colonne de la descente insaturee 129 ! On prend la moyenne des precip entre le niveau i+1 et i 130 ! I=3/4* (P(1+1)+P(i))/2 / (sigd*r*rho_l) 131 ! 1000kg/m3= densite de l'eau 132 ! 0.75e-3 = 3/4 /1000 133 ! Par la suite, I est tout le temps multiplie par sig_d pour avoir l'impaction sur la surface de la maille 134 ! on le neglige ici pour simplifier le code 135 136 DO j=1,klev-1 137 DO i=1,klon 138 imp(i,j) = coefcoli_3d(i,j)*0.75e-3/rdrop *& 139 0.5*(pmflxr(i,j+1)+pmflxs(i,j+1)+pmflxr(i,j)+pmflxs(i,j)) 140 ENDDO 141 ENDDO 124 !jyg< 125 !! ! ====================================================== 126 !! ! calcul de l'impaction 127 !! ! ====================================================== 128 !! 129 !! ! impaction sur la surface de la colonne de la descente insaturee 130 !! ! On prend la moyenne des precip entre le niveau i+1 et i 131 !! ! I=3/4* (P(1+1)+P(i))/2 / (sigd*r*rho_l) 132 !! ! 1000kg/m3= densite de l'eau 133 !! ! 0.75e-3 = 3/4 /1000 134 !! ! Par la suite, I est tout le temps multiplie par sig_d pour avoir l'impaction sur la surface de la maille 135 !!!! ! on le neglige ici pour simplifier le code 136 !! 137 !! DO j=1,klev-1 138 !! DO i=1,klon 139 !! imp(i,j) = coefcoli_3d(i,j)*0.75e-3/rdrop *& 140 !! 0.5*(pmflxr(i,j+1)+pmflxs(i,j+1)+pmflxr(i,j)+pmflxs(i,j)) 141 !! ENDDO 142 !! ENDDO 143 !>jyg 142 144 ! 143 145 ! initialisation pour flux de traceurs, td et autre … … 237 239 END DO 238 240 241 !jyg< 242 ! ====================================================== 243 ! calcul de l'impaction 244 ! ====================================================== 245 246 ! impaction sur la surface de la colonne de la descente insaturee 247 ! On prend la moyenne des precip entre le niveau i+1 et i 248 ! I=3/4* (P(1+1)+P(i))/2 / (sigd*r*rho_l) 249 ! 1000kg/m3= densite de l'eau 250 ! 0.75e-3 = 3/4 /1000 251 ! Par la suite, I est tout le temps multiplie par sig_d pour avoir l'impaction sur la surface de la maille 252 ! on le neglige ici pour simplifier le code 253 254 DO j=1,klev-1 255 DO i=1,klon 256 imp(i,j) = coefcoli_3d(i,j)*0.75e-3/rdrop *& 257 0.5*(pmflxr(i,j+1)+pmflxs(i,j+1)+pmflxr(i,j)+pmflxs(i,j)) 258 ENDDO 259 ENDDO 260 !>jyg 239 261 ! ========================================= 240 262 ! calcul des tendances liees au downdraft -
LMDZ5/branches/testing/libf/phylmd/declare_STDlev.h
r1910 r2298 57 57 REAL zx_tmp_fiNC(klon,nlevSTD) 58 58 59 59 ! REAL missing_val 60 60 REAL, SAVE :: freq_moyNMC(nout) 61 61 !$OMP THREADPRIVATE(freq_moyNMC) -
LMDZ5/branches/testing/libf/phylmd/etat0_netcdf.F90
r2258 r2298 5 5 ! 6 6 SUBROUTINE etat0_netcdf(ib, masque, phis, letat0) 7 #ifndef CPP_1D 7 8 ! 8 9 !------------------------------------------------------------------------------- … … 53 54 #include "dimsoil.h" 54 55 #include "temps.h" 55 REAL, DIMENSION(klon) :: tsol , qsol56 REAL, DIMENSION(klon) :: tsol 56 57 REAL, DIMENSION(klon) :: sn, rugmer, run_off_lic_0 57 58 REAL, DIMENSION(iip1,jjp1) :: orog, rugo, psol … … 60 61 REAL, DIMENSION(iip1,jjm ,llm) :: vvent 61 62 REAL, DIMENSION(:,:,:,:), ALLOCATABLE :: q3d 62 REAL, DIMENSION(klon,nbsrf) :: qsolsrf, snsrf, evap 63 REAL, DIMENSION(klon,nbsrf) :: frugs, agesno 63 REAL, DIMENSION(klon,nbsrf) :: qsolsrf, snsrf 64 64 REAL, DIMENSION(klon,nsoilmx,nbsrf) :: tsoil 65 65 … … 479 479 DO i=1,nbsrf; ftsol(:,i) = tsol; END DO 480 480 DO i=1,nbsrf; snsrf(:,i) = sn; END DO 481 falb1(:,is_ter) = 0.08; falb1(:,is_lic) = 0.6482 falb1(:,is_oce) = 0.5; falb1(:,is_sic) = 0.6483 falb2 = falb1484 481 !albedo SB >>> 485 482 falb_dir(:,is_ter,:)=0.08; falb_dir(:,is_lic,:)=0.6 486 483 falb_dir(:,is_oce,:)=0.5; falb_dir(:,is_sic,:)=0.6 487 484 !albedo SB <<< 488 evap(:,:) = 0.485 fevap(:,:) = 0. 489 486 DO i=1,nbsrf; qsolsrf(:,i)=150.; END DO 490 487 DO i=1,nbsrf; DO j=1,nsoilmx; tsoil(:,j,i) = tsol; END DO; END DO … … 494 491 q_ancien = 0. 495 492 agesno = 0. 496 frugs(:,is_oce) = rugmer(:) 497 frugs(:,is_ter) = MAX(1.0e-05,zstd(:)*zsig(:)/2.0) 498 frugs(:,is_lic) = MAX(1.0e-05,zstd(:)*zsig(:)/2.0) 499 frugs(:,is_sic) = 0.001 493 494 z0m(:,is_oce) = rugmer(:) 495 z0m(:,is_ter) = MAX(1.0e-05,zstd(:)*zsig(:)/2.0) 496 z0m(:,is_lic) = MAX(1.0e-05,zstd(:)*zsig(:)/2.0) 497 z0m(:,is_sic) = 0.001 498 z0h(:,:)=z0m(:,:) 499 500 500 fder = 0.0 501 501 clwcon = 0.0 … … 525 525 526 526 CALL fonte_neige_init(run_off_lic_0) 527 CALL pbl_surface_init( qsol, fder, snsrf, qsolsrf, evap, frugs, agesno, tsoil )527 CALL pbl_surface_init( fder, snsrf, qsolsrf, tsoil ) 528 528 CALL phyredem( "startphy.nc" ) 529 529 … … 535 535 !#endif of #ifdef CPP_EARTH 536 536 RETURN 537 537 #endif 538 !#endif of ifndef CPP_1D 538 539 END SUBROUTINE etat0_netcdf 539 540 ! -
LMDZ5/branches/testing/libf/phylmd/ini_histrac.h
r1910 r2298 30 30 !---------------- 31 31 DO it = 1,nbtr 32 iiq = niadv(it+2) 32 !! iiq = niadv(it+2) ! jyg 33 iiq = niadv(it+nqo) ! jyg 33 34 34 35 ! CONCENTRATIONS -
LMDZ5/branches/testing/libf/phylmd/init_phys_lmdz.F90
r1910 r2298 3 3 ! 4 4 SUBROUTINE Init_Phys_lmdz(iim,jjp1,llm,nb_proc,distrib) 5 USE mod_phys_lmdz_para 6 USE mod_grid_phy_lmdz 5 USE mod_phys_lmdz_para, ONLY: Init_phys_lmdz_para, klon_omp 6 USE mod_grid_phy_lmdz, ONLY: Init_grid_phy_lmdz, nbp_lev 7 7 USE dimphy, ONLY : Init_dimphy 8 8 USE infotrac, ONLY : type_trac -
LMDZ5/branches/testing/libf/phylmd/limit_netcdf.F90
r2187 r2298 4 4 ! 5 5 SUBROUTINE limit_netcdf(interbar, extrap, oldice, masque) 6 #ifndef CPP_1D 6 7 ! 7 8 !------------------------------------------------------------------------------- … … 662 663 ! of #ifdef CPP_EARTH 663 664 665 #endif 666 ! of #ifndef CPP_1D 664 667 END SUBROUTINE limit_netcdf -
LMDZ5/branches/testing/libf/phylmd/lsc_scav.F90
r1910 r2298 1 1 !$Id $ 2 2 3 SUBROUTINE lsc_scav(pdtime,it,iflag_lscav,oliq,flxr,flxs,rneb,beta_fisrt, & 3 SUBROUTINE lsc_scav(pdtime,it,iflag_lscav, & 4 !jyg< 5 aerosol, & 6 !>jyg 7 oliq,flxr,flxs,rneb,beta_fisrt, & 4 8 beta_v1,pplay,paprs,t,tr_seri,d_tr_insc, & 5 9 d_tr_bcscav,d_tr_evap,qPrls) … … 37 41 REAL,DIMENSION(klon,klev),INTENT(IN) :: t ! temperature 38 42 ! tracers 43 LOGICAL,DIMENSION(nbtr), INTENT(IN) :: aerosol 39 44 REAL,DIMENSION(klon,klev,nbtr),INTENT(IN) :: tr_seri ! q de traceur 40 45 REAL,DIMENSION(klon,klev),INTENT(IN) :: beta_fisrt ! taux de conversion de l'eau cond … … 172 177 ENDDO 173 178 174 IF (it.gt.1) THEN ! aerosol 179 !jyg< 180 !! IF (it.gt.1) THEN ! aerosol 181 !! Temporary correction: all non-aerosol tracers are dealt with in the same way. 182 !! Should be updated once it has been decided how gases should be dealt with. 183 IF (aerosol(it)) THEN 184 !>jyg 175 185 frac_ev=frac_aer 176 186 ELSE ! gas … … 178 188 ENDIF 179 189 180 IF(it.gt.1) then ! aerosol 190 !jyg< 191 !! IF (it.gt.1) THEN ! aerosol 192 IF (aerosol(it)) THEN 193 !>jyg 181 194 DO k=1, klev 182 195 DO i=1, klon … … 214 227 215 228 ! below-cloud impaction 216 IF(it.eq.1) then 229 !jyg< 230 !! IF (it.eq.1) THEN 231 IF (.NOT.aerosol(it)) THEN 232 !>jyg 217 233 d_tr_bcscav(i,k,it)=0. 218 234 ELSE -
LMDZ5/branches/testing/libf/phylmd/moy_undefSTD.F90
r1999 r2298 5 5 USE netcdf 6 6 USE dimphy 7 #ifdef CPP_IOIPSL 7 8 USE phys_state_var_mod 9 #endif 10 8 11 USE phys_cal_mod, ONLY: mth_len 9 12 IMPLICIT NONE 10 13 include "clesphys.h" 14 #ifdef CPP_IOIPSL 15 REAL :: missing_val 16 #endif 11 17 12 18 ! ==================================================================== … … 51 57 REAL un_jour 52 58 PARAMETER (un_jour=86400.) 53 59 ! REAL missing_val 54 60 55 missing_val = nf90_fill_real 61 ! missing_val = nf90_fill_real 62 #ifndef CPP_XIOS 63 missing_val=missing_val_nf90 64 #endif 56 65 57 66 DO n = 1, nout -
LMDZ5/branches/testing/libf/phylmd/nuage.h
r2220 r2298 7 7 REAL tau_cld_cv,coefw_cld_cv 8 8 9 REAL tmax_fonte_cv 10 9 11 INTEGER iflag_t_glace,iflag_cld_cv 10 12 … … 12 14 & t_glace_min,exposant_glace,rei_min,rei_max, & 13 15 & tau_cld_cv,coefw_cld_cv, & 14 & iflag_t_glace,iflag_cld_cv 16 & iflag_t_glace,iflag_cld_cv,tmax_fonte_cv 15 17 !$OMP THREADPRIVATE(/nuagecom/) -
LMDZ5/branches/testing/libf/phylmd/ocean_cpl_mod.F90
r1910 r2298 46 46 windsp, fder_old, & 47 47 itime, dtime, knon, knindex, & 48 p1lay, cdragh, cdrag m, precip_rain, precip_snow, temp_air, spechum, &48 p1lay, cdragh, cdragq, cdragm, precip_rain, precip_snow, temp_air, spechum, & 49 49 AcoefH, AcoefQ, BcoefH, BcoefQ, & 50 50 AcoefU, AcoefV, BcoefU, BcoefV, & 51 ps, u1, v1, &51 ps, u1, v1, gustiness, & 52 52 radsol, snow, agesno, & 53 53 qsurf, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 65 65 66 66 INCLUDE "YOMCST.h" 67 INCLUDE "clesphys.h" 67 68 ! 68 69 ! Input arguments … … 77 78 REAL, DIMENSION(klon), INTENT(IN) :: fder_old 78 79 REAL, DIMENSION(klon), INTENT(IN) :: p1lay 79 REAL, DIMENSION(klon), INTENT(IN) :: cdragh, cdrag m80 REAL, DIMENSION(klon), INTENT(IN) :: cdragh, cdragq, cdragm 80 81 REAL, DIMENSION(klon), INTENT(IN) :: precip_rain, precip_snow 81 82 REAL, DIMENSION(klon), INTENT(IN) :: temp_air, spechum … … 83 84 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 84 85 REAL, DIMENSION(klon), INTENT(IN) :: ps 85 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 86 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 86 87 87 88 ! In/Output arguments … … 136 137 137 138 CALL calcul_fluxs(knon, is_oce, dtime, & 138 tsurf_cpl, p1lay, cal, beta, cdragh, ps, &139 tsurf_cpl, p1lay, cal, beta, cdragh, cdragq, ps, & 139 140 precip_rain, precip_snow, snow, qsurf, & 140 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &141 AcoefH, AcoefQ, BcoefH, BcoefQ, &141 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, gustiness, & 142 f_qsat_oce,AcoefH, AcoefQ, BcoefH, BcoefQ, & 142 143 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 143 144 144 145 ! - Flux calculation at first modele level for U and V 145 146 CALL calcul_flux_wind(knon, dtime, & 146 u0_cpl, v0_cpl, u1, v1, cdragm, &147 u0_cpl, v0_cpl, u1, v1, gustiness, cdragm, & 147 148 AcoefU, AcoefV, BcoefU, BcoefV, & 148 149 p1lay, temp_air, & … … 185 186 AcoefH, AcoefQ, BcoefH, BcoefQ, & 186 187 AcoefU, AcoefV, BcoefU, BcoefV, & 187 ps, u1, v1, pctsrf, &188 ps, u1, v1, gustiness, pctsrf, & 188 189 radsol, snow, qsurf, & 189 190 alb1_new, alb2_new, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 200 201 201 202 INCLUDE "YOMCST.h" 203 INCLUDE "clesphys.h" 202 204 203 205 ! Input arguments … … 219 221 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 220 222 REAL, DIMENSION(klon), INTENT(IN) :: ps 221 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 223 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 222 224 REAL, DIMENSION(klon,nbsrf), INTENT(IN) :: pctsrf 223 225 … … 279 281 280 282 CALL calcul_fluxs(knon, is_sic, dtime, & 281 tsurf_cpl, p1lay, cal, beta, cdragh, ps, &283 tsurf_cpl, p1lay, cal, beta, cdragh, cdragh, ps, & 282 284 precip_rain, precip_snow, snow, qsurf, & 283 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &284 AcoefH, AcoefQ, BcoefH, BcoefQ, &285 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, gustiness, & 286 f_qsat_oce,AcoefH, AcoefQ, BcoefH, BcoefQ, & 285 287 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 286 288 … … 288 290 ! - Flux calculation at first modele level for U and V 289 291 CALL calcul_flux_wind(knon, dtime, & 290 u0, v0, u1, v1, cdragm, &292 u0, v0, u1, v1, gustiness, cdragm, & 291 293 AcoefU, AcoefV, BcoefU, BcoefV, & 292 294 p1lay, temp_air, & -
LMDZ5/branches/testing/libf/phylmd/ocean_forced_mod.F90
r1999 r2298 13 13 SUBROUTINE ocean_forced_noice( & 14 14 itime, dtime, jour, knon, knindex, & 15 p1lay, cdragh, cdrag m, precip_rain, precip_snow, &15 p1lay, cdragh, cdragq, cdragm, precip_rain, precip_snow, & 16 16 temp_air, spechum, & 17 17 AcoefH, AcoefQ, BcoefH, BcoefQ, & 18 18 AcoefU, AcoefV, BcoefU, BcoefV, & 19 ps, u1, v1, &19 ps, u1, v1, gustiness, & 20 20 radsol, snow, agesno, & 21 21 qsurf, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 33 33 USE indice_sol_mod 34 34 INCLUDE "YOMCST.h" 35 INCLUDE "clesphys.h" 36 35 37 36 38 ! Input arguments … … 40 42 REAL, INTENT(IN) :: dtime 41 43 REAL, DIMENSION(klon), INTENT(IN) :: p1lay 42 REAL, DIMENSION(klon), INTENT(IN) :: cdragh, cdrag m44 REAL, DIMENSION(klon), INTENT(IN) :: cdragh, cdragq, cdragm 43 45 REAL, DIMENSION(klon), INTENT(IN) :: precip_rain, precip_snow 44 46 REAL, DIMENSION(klon), INTENT(IN) :: temp_air, spechum … … 46 48 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 47 49 REAL, DIMENSION(klon), INTENT(IN) :: ps 48 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 50 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 49 51 50 52 ! In/Output arguments … … 109 111 ! Calcul de tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l and qsurf 110 112 CALL calcul_fluxs(knon, is_oce, dtime, & 111 tsurf_lim, p1lay, cal, beta, cdragh, ps, &113 tsurf_lim, p1lay, cal, beta, cdragh, cdragq, ps, & 112 114 precip_rain, precip_snow, snow, qsurf, & 113 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &114 AcoefH, AcoefQ, BcoefH, BcoefQ, &115 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, gustiness, & 116 f_qsat_oce,AcoefH, AcoefQ, BcoefH, BcoefQ, & 115 117 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 116 118 117 119 ! - Flux calculation at first modele level for U and V 118 120 CALL calcul_flux_wind(knon, dtime, & 119 u0, v0, u1, v1, cdragm, &121 u0, v0, u1, v1, gustiness, cdragm, & 120 122 AcoefU, AcoefV, BcoefU, BcoefV, & 121 123 p1lay, temp_air, & … … 131 133 AcoefH, AcoefQ, BcoefH, BcoefQ, & 132 134 AcoefU, AcoefV, BcoefU, BcoefV, & 133 ps, u1, v1, &135 ps, u1, v1, gustiness, & 134 136 radsol, snow, qsol, agesno, tsoil, & 135 137 qsurf, alb1_new, alb2_new, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 165 167 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 166 168 REAL, DIMENSION(klon), INTENT(IN) :: ps 167 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 169 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 168 170 169 171 ! In/Output arguments … … 231 233 v1_lay(:) = v1(:) - v0(:) 232 234 CALL calcul_fluxs(knon, is_sic, dtime, & 233 tsurf_tmp, p1lay, cal, beta, cdragh, ps, &235 tsurf_tmp, p1lay, cal, beta, cdragh, cdragh, ps, & 234 236 precip_rain, precip_snow, snow, qsurf, & 235 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &236 AcoefH, AcoefQ, BcoefH, BcoefQ, &237 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, gustiness, & 238 f_qsat_oce,AcoefH, AcoefQ, BcoefH, BcoefQ, & 237 239 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 238 240 239 241 ! - Flux calculation at first modele level for U and V 240 242 CALL calcul_flux_wind(knon, dtime, & 241 u0, v0, u1, v1, cdragm, &243 u0, v0, u1, v1, gustiness, cdragm, & 242 244 AcoefU, AcoefV, BcoefU, BcoefV, & 243 245 p1lay, temp_air, & -
LMDZ5/branches/testing/libf/phylmd/ocean_slab_mod.F90
r2220 r2298 216 216 SUBROUTINE ocean_slab_noice( & 217 217 itime, dtime, jour, knon, knindex, & 218 p1lay, cdragh, cdrag m, precip_rain, precip_snow, temp_air, spechum, &218 p1lay, cdragh, cdragq, cdragm, precip_rain, precip_snow, temp_air, spechum, & 219 219 AcoefH, AcoefQ, BcoefH, BcoefQ, & 220 220 AcoefU, AcoefV, BcoefU, BcoefV, & 221 ps, u1, v1, tsurf_in, &221 ps, u1, v1, gustiness, tsurf_in, & 222 222 radsol, snow, & 223 223 qsurf, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 227 227 228 228 INCLUDE "iniprint.h" 229 INCLUDE "clesphys.h" 229 230 230 231 ! Input arguments … … 236 237 REAL, INTENT(IN) :: dtime 237 238 REAL, DIMENSION(klon), INTENT(IN) :: p1lay 238 REAL, DIMENSION(klon), INTENT(IN) :: cdragh, cdrag m239 REAL, DIMENSION(klon), INTENT(IN) :: cdragh, cdragq, cdragm 239 240 REAL, DIMENSION(klon), INTENT(IN) :: precip_rain, precip_snow 240 241 REAL, DIMENSION(klon), INTENT(IN) :: temp_air, spechum … … 242 243 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 243 244 REAL, DIMENSION(klon), INTENT(IN) :: ps 244 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 245 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 245 246 REAL, DIMENSION(klon), INTENT(IN) :: tsurf_in 246 247 REAL, DIMENSION(klon), INTENT(INOUT) :: radsol … … 287 288 288 289 CALL calcul_fluxs(knon, is_oce, dtime, & 289 tsurf_in, p1lay, cal, beta, cdragh, ps, &290 tsurf_in, p1lay, cal, beta, cdragh, cdragq, ps, & 290 291 precip_rain, precip_snow, snow, qsurf, & 291 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &292 AcoefH, AcoefQ, BcoefH, BcoefQ, &292 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, gustiness, & 293 f_qsat_oce,AcoefH, AcoefQ, BcoefH, BcoefQ, & 293 294 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 294 295 295 296 ! - Flux calculation at first modele level for U and V 296 297 CALL calcul_flux_wind(knon, dtime, & 297 u0, v0, u1, v1, cdragm, &298 u0, v0, u1, v1, gustiness, cdragm, & 298 299 AcoefU, AcoefV, BcoefU, BcoefV, & 299 300 p1lay, temp_air, & … … 398 399 AcoefH, AcoefQ, BcoefH, BcoefQ, & 399 400 AcoefU, AcoefV, BcoefU, BcoefV, & 400 ps, u1, v1, &401 ps, u1, v1, gustiness, & 401 402 radsol, snow, qsurf, qsol, agesno, & 402 403 alb1_new, alb2_new, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 406 407 407 408 INCLUDE "YOMCST.h" 409 INCLUDE "clesphys.h" 408 410 409 411 ! Input arguments … … 420 422 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 421 423 REAL, DIMENSION(klon), INTENT(IN) :: ps 422 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 424 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 423 425 REAL, DIMENSION(klon), INTENT(IN) :: swnet 424 426 … … 498 500 ! calcul_fluxs (sens, lat etc) 499 501 CALL calcul_fluxs(knon, is_sic, dtime, & 500 tsurf_in, p1lay, cal, beta, cdragh, ps, &502 tsurf_in, p1lay, cal, beta, cdragh, cdragh, ps, & 501 503 precip_rain, precip_snow, snow, qsurf, & 502 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &503 AcoefH, AcoefQ, BcoefH, BcoefQ, &504 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, gustiness, & 505 f_qsat_oce,AcoefH, AcoefQ, BcoefH, BcoefQ, & 504 506 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 505 507 DO i=1,knon … … 509 511 ! calcul_flux_wind 510 512 CALL calcul_flux_wind(knon, dtime, & 511 u0, v0, u1, v1, cdragm, &513 u0, v0, u1, v1, gustiness, cdragm, & 512 514 AcoefU, AcoefV, BcoefU, BcoefV, & 513 515 p1lay, temp_air, & -
LMDZ5/branches/testing/libf/phylmd/pbl_surface_mod.F90
r2258 r2298 29 29 30 30 ! Declaration of variables saved in restart file 31 REAL, ALLOCATABLE, DIMENSION(:), PRIVATE, SAVE :: qsol ! water height in the soil (mm)32 !$OMP THREADPRIVATE(qsol)33 31 REAL, ALLOCATABLE, DIMENSION(:), PRIVATE, SAVE :: fder ! flux drift 34 32 !$OMP THREADPRIVATE(fder) … … 37 35 REAL, ALLOCATABLE, DIMENSION(:,:), PRIVATE, SAVE :: qsurf ! humidity at surface 38 36 !$OMP THREADPRIVATE(qsurf) 39 REAL, ALLOCATABLE, DIMENSION(:,:), PRIVATE, SAVE :: evap ! evaporation at surface40 !$OMP THREADPRIVATE(evap)41 REAL, ALLOCATABLE, DIMENSION(:,:), PRIVATE, SAVE :: rugos ! rugosity at surface (m)42 !$OMP THREADPRIVATE(rugos)43 REAL, ALLOCATABLE, DIMENSION(:,:), PRIVATE, SAVE :: agesno ! age of snow at surface44 !$OMP THREADPRIVATE(agesno)45 ! Correction pour le cas AMMA (PRIVATE)46 37 REAL, ALLOCATABLE, DIMENSION(:,:,:), SAVE :: ftsoil ! soil temperature 47 38 !$OMP THREADPRIVATE(ftsoil) … … 51 42 !**************************************************************************************** 52 43 ! 53 SUBROUTINE pbl_surface_init(qsol_rst, fder_rst, snow_rst, qsurf_rst,& 54 evap_rst, rugos_rst, agesno_rst, ftsoil_rst) 44 SUBROUTINE pbl_surface_init(fder_rst, snow_rst, qsurf_rst, ftsoil_rst) 55 45 56 46 ! This routine should be called after the restart file has been read. … … 65 55 ! Input variables 66 56 !**************************************************************************************** 67 REAL, DIMENSION(klon), INTENT(IN) :: qsol_rst68 57 REAL, DIMENSION(klon), INTENT(IN) :: fder_rst 69 58 REAL, DIMENSION(klon, nbsrf), INTENT(IN) :: snow_rst 70 59 REAL, DIMENSION(klon, nbsrf), INTENT(IN) :: qsurf_rst 71 REAL, DIMENSION(klon, nbsrf), INTENT(IN) :: evap_rst72 REAL, DIMENSION(klon, nbsrf), INTENT(IN) :: rugos_rst73 REAL, DIMENSION(klon, nbsrf), INTENT(IN) :: agesno_rst74 60 REAL, DIMENSION(klon, nsoilmx, nbsrf), INTENT(IN) :: ftsoil_rst 75 61 … … 86 72 ! 87 73 !**************************************************************************************** 88 ALLOCATE(qsol(klon), stat=ierr)89 IF (ierr /= 0) CALL abort_gcm('pbl_surface_init', 'pb in allocation',1)90 91 74 ALLOCATE(fder(klon), stat=ierr) 92 75 IF (ierr /= 0) CALL abort_gcm('pbl_surface_init', 'pb in allocation',1) … … 98 81 IF (ierr /= 0) CALL abort_gcm('pbl_surface_init', 'pb in allocation',1) 99 82 100 ALLOCATE(evap(klon,nbsrf), stat=ierr)101 IF (ierr /= 0) CALL abort_gcm('pbl_surface_init', 'pb in allocation',1)102 103 ALLOCATE(rugos(klon,nbsrf), stat=ierr)104 IF (ierr /= 0) CALL abort_gcm('pbl_surface_init', 'pb in allocation',1)105 106 ALLOCATE(agesno(klon,nbsrf), stat=ierr)107 IF (ierr /= 0) CALL abort_gcm('pbl_surface_init', 'pb in allocation',1)108 109 83 ALLOCATE(ftsoil(klon,nsoilmx,nbsrf), stat=ierr) 110 84 IF (ierr /= 0) CALL abort_gcm('pbl_surface_init', 'pb in allocation',1) 111 85 112 86 113 qsol(:) = qsol_rst(:)114 87 fder(:) = fder_rst(:) 115 88 snow(:,:) = snow_rst(:,:) 116 89 qsurf(:,:) = qsurf_rst(:,:) 117 evap(:,:) = evap_rst(:,:)118 rugos(:,:) = rugos_rst(:,:)119 agesno(:,:) = agesno_rst(:,:)120 90 ftsoil(:,:,:) = ftsoil_rst(:,:,:) 121 91 … … 174 144 zsig, lwdown_m, pphi, cldt, & 175 145 rain_f, snow_f, solsw_m, sollw_m, & 146 gustiness, & 176 147 t, q, u, v, & 177 148 !!! nrlmd+jyg le 02/05/2011 et le 20/02/2012 … … 181 152 !!! 182 153 pplay, paprs, pctsrf, & 183 !albedo SB >>>184 ! ts, alb1, alb2,ustar, u10m, v10m,wstar, &185 154 ts,SFRWL, alb_dir, alb_dif,ustar, u10m, v10m,wstar, & 186 !albedo SB <<<187 155 cdragh, cdragm, zu1, zv1, & 188 !albedo SB >>>189 ! alb1_m, alb2_m, zxsens, zxevap, &190 156 alb_dir_m, alb_dif_m, zxsens, zxevap, & 191 !albedo SB <<<192 157 alb3_lic, runoff, snowhgt, qsnow, to_ice, sissnow, & 193 158 zxtsol, zxfluxlat, zt2m, qsat2m, & … … 204 169 !!! 205 170 zcoefh, zcoefm, slab_wfbils, & 206 qsol _d, zq2m, s_pblh, s_plcl, &171 qsol, zq2m, s_pblh, s_plcl, & 207 172 !!! 208 173 !!! jyg le 08/02/2012 … … 211 176 s_capCL, s_oliqCL, s_cteiCL, s_pblT, & 212 177 s_therm, s_trmb1, s_trmb2, s_trmb3, & 213 z xrugs,zustar,zu10m, zv10m, fder_print, &178 zustar,zu10m, zv10m, fder_print, & 214 179 zxqsurf, rh2m, zxfluxu, zxfluxv, & 215 rugos_d, agesno_d, sollw, solsw, &216 d_ts, evap _d, fluxlat, t2m, &180 z0m, z0h, agesno, sollw, solsw, & 181 d_ts, evap, fluxlat, t2m, & 217 182 wfbils, wfbilo, flux_t, flux_u, flux_v,& 218 183 dflux_t, dflux_q, zxsnow, & … … 263 228 ! pplay----input-R- pression au milieu de couche (Pa) 264 229 ! rlat-----input-R- latitude en degree 265 ! rugos----input-R- longeur de rugosite (en m)230 ! z0m, z0h ----input-R- longeur de rugosite (en m) 266 231 ! Martin 267 232 ! zsig-----input-R- slope … … 334 299 REAL, DIMENSION(klon), INTENT(IN) :: zsig ! slope 335 300 REAL, DIMENSION(klon), INTENT(IN) :: lwdown_m ! downward longwave radiation at mean s 301 REAL, DIMENSION(klon), INTENT(IN) :: gustiness ! gustiness 302 336 303 REAL, DIMENSION(klon), INTENT(IN) :: cldt ! total cloud fraction 337 304 REAL, DIMENSION(klon,klev), INTENT(IN) :: pphi ! geopotential (m2/s2) … … 356 323 !wake and off-wake regions 357 324 !albedo SB >>> 358 ! REAL, DIMENSION(klon, nbsrf), INTENT(INOUT) :: alb1 ! albedo in visible SW interval359 ! REAL, DIMENSION(klon, nbsrf), INTENT(INOUT) :: alb2 ! albedo in near infra-red SW interval360 325 REAL, DIMENSIOn(6),intent(in) :: SFRWL 361 326 REAL, DIMENSION(klon, nsw, nbsrf), INTENT(INOUT) :: alb_dir,alb_dif … … 382 347 REAL, DIMENSION(klon), INTENT(OUT) :: zv1 ! v wind speed in first layer 383 348 !albedo SB >>> 384 ! REAL, DIMENSION(klon), INTENT(OUT) :: alb1_m ! mean albedo385 ! in visible SW interval386 ! REAL, DIMENSION(klon), INTENT(OUT) :: alb2_m ! mean albedo387 ! in near IR SW interval388 349 REAL, DIMENSION(klon, nsw), INTENT(OUT) :: alb_dir_m,alb_dif_m 389 350 !albedo SB <<< … … 434 395 !!! 435 396 REAL, DIMENSION(klon), INTENT(OUT) :: slab_wfbils! heat balance at surface only for slab at ocean points 436 REAL, DIMENSION(klon), INTENT(OUT) :: qsol _d! water height in the soil (mm)397 REAL, DIMENSION(klon), INTENT(OUT) :: qsol ! water height in the soil (mm) 437 398 REAL, DIMENSION(klon), INTENT(OUT) :: zq2m ! water vapour at 2m, mean for each grid point 438 399 REAL, DIMENSION(klon), INTENT(OUT) :: s_pblh ! height of the planetary boundary layer(HPBL) … … 454 415 REAL, DIMENSION(klon), INTENT(OUT) :: s_trmb2 ! inhibition, mean for each grid point 455 416 REAL, DIMENSION(klon), INTENT(OUT) :: s_trmb3 ! point Omega, mean for each grid point 456 REAL, DIMENSION(klon), INTENT(OUT) :: zxrugs ! rugosity at surface (m), mean for each grid point457 417 REAL, DIMENSION(klon), INTENT(OUT) :: zustar ! u* 458 418 REAL, DIMENSION(klon), INTENT(OUT) :: zu10m ! u speed at 10m, mean for each grid point … … 463 423 REAL, DIMENSION(klon, klev), INTENT(OUT) :: zxfluxu ! u wind tension, mean for each grid point 464 424 REAL, DIMENSION(klon, klev), INTENT(OUT) :: zxfluxv ! v wind tension, mean for each grid point 465 REAL, DIMENSION(klon, nbsrf ), INTENT(OUT) :: rugos_d! rugosity length (m)466 REAL, DIMENSION(klon, nbsrf), INTENT( OUT) :: agesno_d! age of snow at surface425 REAL, DIMENSION(klon, nbsrf+1), INTENT(INOUT) :: z0m,z0h ! rugosity length (m) 426 REAL, DIMENSION(klon, nbsrf), INTENT(INOUT) :: agesno ! age of snow at surface 467 427 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: solsw ! net shortwave radiation at surface 468 428 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: sollw ! net longwave radiation at surface 469 429 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: d_ts ! change in temperature at surface 470 REAL, DIMENSION(klon, nbsrf), INTENT( OUT) :: evap_d! evaporation at surface430 REAL, DIMENSION(klon, nbsrf), INTENT(INOUT) :: evap ! evaporation at surface 471 431 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: fluxlat ! latent flux 472 432 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: t2m ! temperature at 2 meter height … … 519 479 REAL :: f1 ! fraction de longeurs visibles parmi tout SW intervalle 520 480 REAL, DIMENSION(klon) :: r_co2_ppm ! taux CO2 atmosphere 521 REAL, DIMENSION(klon) :: yts, y rugos, ypct, yz0_new481 REAL, DIMENSION(klon) :: yts, yz0m, yz0h, ypct 522 482 !albedo SB >>> 523 ! REAL, DIMENSION(klon) :: yalb, yalb1, yalb2524 483 REAL, DIMENSION(klon) :: yalb,yalb_vis 525 484 !albedo SB <<< … … 559 518 REAL, DIMENSION(klon) :: AcoefU, AcoefV, BcoefU, BcoefV 560 519 REAL, DIMENSION(klon) :: ypsref 561 REAL, DIMENSION(klon) :: yevap, ytsurf_new, yalb 1_new, yalb2_new, yalb3_new520 REAL, DIMENSION(klon) :: yevap, ytsurf_new, yalb3_new 562 521 !albedo SB >>> 563 522 REAL, DIMENSION(klon,nsw) :: yalb_dir_new, yalb_dif_new … … 795 754 REAL, DIMENSION(klon, nbsrf) :: alb ! mean albedo for whole SW interval 796 755 REAL, DIMENSION(klon) :: ylwdown ! jg : temporary (ysollwdown) 756 REAL, DIMENSION(klon) :: ygustiness ! jg : temporary (ysollwdown) 797 757 798 758 REAL :: zx_qs1, zcor1, zdelta1 … … 823 783 824 784 IF (first_call) THEN 785 print*,'PBL SURFACE AVEC GUSTINESS' 825 786 first_call=.FALSE. 826 787 … … 877 838 zu1(:)=0. ; zv1(:)=0. 878 839 !albedo SB >>> 879 ! alb1_m(:)=0. ; alb2_m(:)=0. ; alb3_lic(:)=0.880 840 alb_dir_m=0. ; alb_dif_m=0. ; alb3_lic(:)=0. 881 841 !albedo SB <<< … … 890 850 kh(:)=0. ; kh_x(:)=0. ; kh_w(:)=0. 891 851 slab_wfbils(:)=0. 892 qsol_d(:)=0.893 852 s_pblh(:)=0. ; s_pblh_x(:)=0. ; s_pblh_w(:)=0. 894 853 s_plcl(:)=0. ; s_plcl_x(:)=0. ; s_plcl_w(:)=0. … … 896 855 s_therm(:)=0. 897 856 s_trmb1(:)=0. ; s_trmb2(:)=0. ; s_trmb3(:)=0. 898 z xrugs(:)=0. ; zustar(:)=0.857 zustar(:)=0. 899 858 zu10m(:)=0. ; zv10m(:)=0. 900 859 fder_print(:)=0. 901 860 zxqsurf(:)=0. 902 861 zxfluxu(:,:)=0. ; zxfluxv(:,:)=0. 903 rugos_d(:,:)=0. ; agesno_d(:,:)=0.904 862 solsw(:,:)=0. ; sollw(:,:)=0. 905 863 d_ts(:,:)=0. 906 evap _d(:,:)=0.864 evap(:,:)=0. 907 865 fluxlat(:,:)=0. 908 866 wfbils(:,:)=0. ; wfbilo(:,:)=0. … … 943 901 !! cdragh = 0.0 ; cdragm = 0.0 ; dflux_t = 0.0 ; dflux_q = 0.0 944 902 ypct = 0.0 ; yts = 0.0 ; ysnow = 0.0 945 !! zv1 = 0.0 ; yqsurf = 0.0 ; yalb1 = 0.0 ; yalb2 = 0.0903 !! zv1 = 0.0 ; yqsurf = 0.0 946 904 !albedo SB >>> 947 ! yqsurf = 0.0 ; yalb1 = 0.0 ; yalb2 = 0.0948 905 yqsurf = 0.0 ; yalb = 0.0 ; yalb_vis = 0.0 949 906 !albedo SB <<< 950 907 yrain_f = 0.0 ; ysnow_f = 0.0 ; yfder = 0.0 ; ysolsw = 0.0 951 ysollw = 0.0 ; y rugos = 0.0; yu1 = 0.0908 ysollw = 0.0 ; yz0m = 0.0 ; yz0h = 0.0 ; yu1 = 0.0 952 909 yv1 = 0.0 ; ypaprs = 0.0 ; ypplay = 0.0 953 910 ydelp = 0.0 ; yu = 0.0 ; yv = 0.0 ; yt = 0.0 … … 1077 1034 !**************************************************************************************** 1078 1035 1079 zxrugs(:) = 0.01080 1036 DO nsrf = 1, nbsrf 1081 1037 DO i = 1, klon 1082 rugos(i,nsrf) = MAX(rugos(i,nsrf),0.000015)1083 z xrugs(i) = zxrugs(i) + rugos(i,nsrf)*pctsrf(i,nsrf)1038 z0m(i,nsrf) = MAX(z0m(i,nsrf),z0min) 1039 z0h(i,nsrf) = MAX(z0h(i,nsrf),z0min) 1084 1040 ENDDO 1085 1041 ENDDO … … 1087 1043 ! Mean calculations of albedo 1088 1044 ! 1089 ! Albedo at sub-surface1090 ! * alb1 : albedo in visible SW interval1091 ! * alb2 : albedo in near infrared SW interval1092 1045 ! * alb : mean albedo for whole SW interval 1093 1046 ! 1094 1047 ! Mean albedo for grid point 1095 ! * alb1_m : albedo in visible SW interval1096 ! * alb2_m : albedo in near infrared SW interval1097 1048 ! * alb_m : mean albedo at whole SW interval 1098 1099 !albedo SB >>>1100 ! alb1_m(:) = 0.01101 ! alb2_m(:) = 0.01102 ! DO nsrf = 1, nbsrf1103 ! DO i = 1, klon1104 ! alb1_m(i) = alb1_m(i) + alb1(i,nsrf) * pctsrf(i,nsrf)1105 ! alb2_m(i) = alb2_m(i) + alb2(i,nsrf) * pctsrf(i,nsrf)1106 ! ENDDO1107 ! ENDDO1108 1049 1109 1050 alb_dir_m(:,:) = 0.0 … … 1123 1064 ! f1 = 1 ! put f1=1 to recreate old calculations 1124 1065 1125 ! DO nsrf = 1, nbsrf1126 ! DO i = 1, klon1127 ! alb(i,nsrf) = f1*alb1(i,nsrf) + (1-f1)*alb2(i,nsrf)1128 ! ENDDO1129 ! ENDDO1130 !1131 ! DO i = 1, klon1132 ! alb_m(i) = f1*alb1_m(i) + (1-f1)*alb2_m(i)1133 ! END DO1134 1135 1136 1066 !f1 is already included with SFRWL values in each surf files 1137 1067 alb=0.0 … … 1177 1107 ENDDO 1178 1108 ENDDO 1179 1180 1109 1181 1110 !**************************************************************************************** … … 1231 1160 yalb(j) = alb(i,nsrf) 1232 1161 !albedo SB >>> 1233 ! yalb1(j) = alb1(i,nsrf)1234 ! yalb2(j) = alb2(i,nsrf)1235 1162 yalb_vis(j) = alb_dir(i,1,nsrf) 1236 1163 if(nsw==6)then … … 1244 1171 yfder(j) = fder(i) 1245 1172 ylwdown(j) = lwdown_m(i) 1173 ygustiness(j) = gustiness(i) 1246 1174 ysolsw(j) = solsw(i,nsrf) 1247 1175 ysollw(j) = sollw(i,nsrf) 1248 yrugos(j) = rugos(i,nsrf) 1176 yz0m(j) = z0m(i,nsrf) 1177 yz0h(j) = z0h(i,nsrf) 1249 1178 yrugoro(j) = rugoro(i) 1250 1179 yu1(j) = u(i,1) … … 1377 1306 CALL cdrag(knon, nsrf, & 1378 1307 speed, yt(:,1), yq(:,1), zgeo1, ypaprs(:,1),& 1379 yts, yqsurf, y rugos, &1308 yts, yqsurf, yz0m, yz0h, & 1380 1309 ycdragm, ycdragh, zri1, pref ) 1381 1310 … … 1408 1337 CALL cdrag(knon, nsrf, & 1409 1338 speed_x, yt_x(:,1), yq_x(:,1), zgeo1_x, ypaprs(:,1),& 1410 yts_x, yqsurf, y rugos, &1339 yts_x, yqsurf, yz0m, yz0h, & 1411 1340 ycdragm_x, ycdragh_x, zri1_x, pref_x ) 1412 1341 … … 1422 1351 IF (prt_level >=10) print *,'clcdrag -> ycdragh_x ', ycdragh_x 1423 1352 ! 1424 CALL clcdrag( knon, nsrf, ypaprs, ypplay, & 1425 yu_w(:,1), yv_w(:,1), yt_w(:,1), yq_w(:,1), & 1426 yts_w, yqsurf, yrugos, & 1427 ycdragm_w, ycdragh_w ) 1353 ! Faire disparaitre les lignes commentees fin 2015 (le temps des tests) 1354 ! CALL clcdrag( knon, nsrf, ypaprs, ypplay, & 1355 ! yu_w(:,1), yv_w(:,1), yt_w(:,1), yq_w(:,1), & 1356 ! yts_w, yqsurf, yz0m, & 1357 ! ycdragm_w, ycdragh_w ) 1358 ! Fuxing WANG, 04/03/2015, replace the clcdrag by the merged version: cdrag 1359 DO i = 1, knon 1360 zgeo1_w(i) = RD * yt_w(i,1) / (0.5*(ypaprs(i,1)+ypplay(i,1))) & 1361 * (ypaprs(i,1)-ypplay(i,1)) 1362 speed_w(i) = SQRT(yu_w(i,1)**2+yv_w(i,1)**2) 1363 END DO 1364 CALL cdrag(knon, nsrf, & 1365 speed_w, yt_w(:,1), yq_w(:,1), zgeo1_w, ypaprs(:,1),& 1366 yts_w, yqsurf, yz0m, yz0h, & 1367 ycdragm_w, ycdragh_w, zri1_w, pref_w ) 1368 1428 1369 ! --- special Dice. JYG+MPL 25112013 1429 1370 IF (ok_prescr_ust) then … … 1456 1397 print *,' args coef_diff_turb: yt ', yt 1457 1398 print *,' args coef_diff_turb: yts ', yts 1458 print *,' args coef_diff_turb: y rugos ', yrugos1399 print *,' args coef_diff_turb: yz0m ', yz0m 1459 1400 print *,' args coef_diff_turb: yqsurf ', yqsurf 1460 1401 print *,' args coef_diff_turb: ycdragm ', ycdragm … … 1463 1404 ENDIF 1464 1405 CALL coef_diff_turb(dtime, nsrf, knon, ni, & 1465 ypaprs, ypplay, yu, yv, yq, yt, yts, y rugos, yqsurf, ycdragm, &1406 ypaprs, ypplay, yu, yv, yq, yt, yts, yqsurf, ycdragm, & 1466 1407 ycoefm, ycoefh, ytke) 1467 1408 IF (iflag_pbl>=20.AND.iflag_pbl<30) THEN … … 1484 1425 print *,' args coef_diff_turb: yt_x ', yt_x 1485 1426 print *,' args coef_diff_turb: yts_x ', yts_x 1486 print *,' args coef_diff_turb: yrugos ', yrugos1487 1427 print *,' args coef_diff_turb: yqsurf ', yqsurf 1488 1428 print *,' args coef_diff_turb: ycdragm_x ', ycdragm_x … … 1491 1431 ENDIF 1492 1432 CALL coef_diff_turb(dtime, nsrf, knon, ni, & 1493 ypaprs, ypplay, yu_x, yv_x, yq_x, yt_x, yts_x, y rugos, yqsurf, ycdragm_x, &1433 ypaprs, ypplay, yu_x, yv_x, yq_x, yt_x, yts_x, yqsurf, ycdragm_x, & 1494 1434 ycoefm_x, ycoefh_x, ytke_x) 1495 1435 IF (iflag_pbl>=20.AND.iflag_pbl<30) THEN … … 1511 1451 print *,' args coef_diff_turb: yt_w ', yt_w 1512 1452 print *,' args coef_diff_turb: yts_w ', yts_w 1513 print *,' args coef_diff_turb: yrugos ', yrugos1514 1453 print *,' args coef_diff_turb: yqsurf ', yqsurf 1515 1454 print *,' args coef_diff_turb: ycdragm_w ', ycdragm_w … … 1518 1457 ENDIF 1519 1458 CALL coef_diff_turb(dtime, nsrf, knon, ni, & 1520 ypaprs, ypplay, yu_w, yv_w, yq_w, yt_w, yts_w, y rugos, yqsurf, ycdragm_w, &1459 ypaprs, ypplay, yu_w, yv_w, yq_w, yt_w, yts_w, yqsurf, ycdragm_w, & 1521 1460 ycoefm_w, ycoefh_w, ytke_w) 1522 1461 IF (iflag_pbl>=20.AND.iflag_pbl<30) THEN … … 1779 1718 CALL stdlevvar(klon, knon, is_ter, zxli, & 1780 1719 yu(:,1), yv(:,1), yt(:,1), yq(:,1), zgeo1, & 1781 yts, yqsurf, y rugos, ypaprs(:,1), ypplay(:,1), &1720 yts, yqsurf, yz0m, yz0h, ypaprs(:,1), ypplay(:,1), & 1782 1721 yt2m, yq2m, yt10m, yq10m, yu10m, yustar) 1783 1722 … … 1801 1740 AcoefH, AcoefQ, BcoefH, BcoefQ, & 1802 1741 AcoefU, AcoefV, BcoefU, BcoefV, & 1803 ypsref, yu1, yv1, y rugoro, pctsrf, &1742 ypsref, yu1, yv1, ygustiness, yrugoro, pctsrf, & 1804 1743 ylwdown, yq2m, yt2m, & 1805 1744 ysnow, yqsol, yagesno, ytsoil, & 1806 !albedo SB >>> 1807 ! yz0_new, yalb1_new, yalb2_new, yevap, yfluxsens, yfluxlat, & 1808 yz0_new, SFRWL, yalb_dir_new, yalb_dif_new, yevap, yfluxsens,yfluxlat,& 1809 !albedo SB <<< 1745 yz0m, yz0h, SFRWL, yalb_dir_new, yalb_dif_new, yevap, yfluxsens,yfluxlat,& 1810 1746 yqsurf, ytsurf_new, y_dflux_t, y_dflux_q, & 1811 1747 y_flux_u1, y_flux_v1 ) … … 1818 1754 ! ytsoil(:,:)=300. 1819 1755 ! yz0_new(:)=0.001 1820 ! yalb1_new(:)=0.221821 ! yalb2_new(:)=0.221822 1756 ! yevap(:)=flat/RLVTT 1823 1757 ! yfluxlat(:)=-flat … … 1841 1775 AcoefH, AcoefQ, BcoefH, BcoefQ, & 1842 1776 AcoefU, AcoefV, BcoefU, BcoefV, & 1843 ypsref, yu1, yv1, y rugoro, pctsrf, &1777 ypsref, yu1, yv1, ygustiness, yrugoro, pctsrf, & 1844 1778 ysnow, yqsurf, yqsol, yagesno, & 1845 !albedo SB >>> 1846 ! ytsoil, yz0_new, yalb1_new, yalb2_new, yevap, yfluxsens, yfluxlat, & 1847 ytsoil, yz0_new, SFRWL, yalb_dir_new, yalb_dif_new, yevap,yfluxsens,yfluxlat, & 1848 !albedo SB <<< 1779 ytsoil, yz0m, yz0h, SFRWL, yalb_dir_new, yalb_dif_new, yevap,yfluxsens,yfluxlat, & 1849 1780 ytsurf_new, y_dflux_t, y_dflux_q, & 1850 1781 yzsig, ycldt, & … … 1852 1783 yalb3_new, yrunoff, & 1853 1784 y_flux_u1, y_flux_v1) 1854 !CALL surf_landice(itap, dtime, knon, ni, &1855 ! ysolsw, ysollw, yts, ypplay(:,1), &1856 ! ycdragh, ycdragm, yrain_f, ysnow_f, yt(:,1), yq(:,1),&1857 ! AcoefH, AcoefQ, BcoefH, BcoefQ, &1858 ! AcoefU, AcoefV, BcoefU, BcoefV, &1859 ! ypsref, yu1, yv1, yrugoro, pctsrf, &1860 ! ysnow, yqsurf, yqsol, yagesno, &1861 ! ytsoil, yz0_new, yalb1_new, yalb2_new, yevap, yfluxsens, yfluxlat, &1862 ! ytsurf_new, y_dflux_t, y_dflux_q, &1863 ! y_flux_u1, y_flux_v1)1864 1785 1865 1786 !jyg< … … 1878 1799 1879 1800 CASE(is_oce) 1880 !albedo SB >>>1881 ! CALL surf_ocean(rlon, rlat, ysolsw, ysollw, yalb1, &1882 1801 CALL surf_ocean(rlon, rlat, ysolsw, ysollw, yalb_vis, & 1883 !albedo SB <<< 1884 yrugos, ywindsp, rmu0, yfder, yts, & 1802 ywindsp, rmu0, yfder, yts, & 1885 1803 itap, dtime, jour, knon, ni, & 1886 ypplay(:,1), ycdragh, ycdragm, yrain_f, ysnow_f, yt(:,1), yq(:,1),&1804 ypplay(:,1), zgeo1/RG, ycdragh, ycdragm, yrain_f, ysnow_f, yt(:,1), yq(:,1),& 1887 1805 AcoefH, AcoefQ, BcoefH, BcoefQ, & 1888 1806 AcoefU, AcoefV, BcoefU, BcoefV, & 1889 ypsref, yu1, yv1, y rugoro, pctsrf, &1807 ypsref, yu1, yv1, ygustiness, yrugoro, pctsrf, & 1890 1808 ysnow, yqsurf, yagesno, & 1891 !albedo SB >>> 1892 ! yz0_new, yalb1_new, yalb2_new, yevap, yfluxsens, yfluxlat, & 1893 yz0_new, SFRWL,yalb_dir_new, yalb_dif_new, yevap, yfluxsens,yfluxlat,& 1894 !albedo SB <<< 1809 yz0m, yz0h, SFRWL,yalb_dir_new, yalb_dif_new, yevap, yfluxsens,yfluxlat,& 1895 1810 ytsurf_new, y_dflux_t, y_dflux_q, slab_wfbils, & 1896 1811 y_flux_u1, y_flux_v1) … … 1914 1829 CALL surf_seaice( & 1915 1830 !albedo SB >>> 1916 ! rlon, rlat, ysolsw, ysollw, yalb1, yfder, &1917 1831 rlon, rlat, ysolsw, ysollw, yalb_vis, yfder, & 1918 1832 !albedo SB <<< … … 1922 1836 AcoefH, AcoefQ, BcoefH, BcoefQ, & 1923 1837 AcoefU, AcoefV, BcoefU, BcoefV, & 1924 ypsref, yu1, yv1, y rugoro, pctsrf, &1838 ypsref, yu1, yv1, ygustiness, pctsrf, & 1925 1839 ysnow, yqsurf, yqsol, yagesno, ytsoil, & 1926 1840 !albedo SB >>> 1927 ! yz0_new, yalb1_new, yalb2_new, yevap, yfluxsens, yfluxlat, & 1928 yz0_new, SFRWL, yalb_dir_new, yalb_dif_new, yevap, yfluxsens,yfluxlat,& 1841 yz0m, yz0h, SFRWL, yalb_dir_new, yalb_dif_new, yevap, yfluxsens,yfluxlat,& 1929 1842 !albedo SB <<< 1930 1843 ytsurf_new, y_dflux_t, y_dflux_q, & … … 2298 2211 d_ts(i,nsrf) = y_d_ts(j) 2299 2212 !albedo SB >>> 2300 ! alb1(i,nsrf) = yalb1_new(j)2301 ! alb2(i,nsrf) = yalb2_new(j)2302 2213 do k=1,nsw 2303 2214 alb_dir(i,k,nsrf) = yalb_dir_new(j,k) … … 2307 2218 snow(i,nsrf) = ysnow(j) 2308 2219 qsurf(i,nsrf) = yqsurf(j) 2309 rugos(i,nsrf) = yz0_new(j) 2220 z0m(i,nsrf) = yz0m(j) 2221 z0h(i,nsrf) = yz0h(j) 2310 2222 fluxlat(i,nsrf) = yfluxlat(j) 2311 2223 agesno(i,nsrf) = yagesno(j) … … 2519 2431 DO j=1, knon 2520 2432 i = ni(j) 2521 rugo1(j) = y rugos(j)2433 rugo1(j) = yz0m(j) 2522 2434 IF(nsrf.EQ.is_oce) THEN 2523 rugo1(j) = rugos(i,nsrf)2435 rugo1(j) = z0m(i,nsrf) 2524 2436 ENDIF 2525 2437 psfce(j)=ypaprs(j,1) … … 2536 2448 CALL stdlevvar(klon, knon, nsrf, zxli, & 2537 2449 uzon, vmer, tair1, qair1, zgeo1, & 2538 tairsol, qairsol, rugo1, psfce, patm, &2450 tairsol, qairsol, rugo1, rugo1, psfce, patm, & 2539 2451 yt2m, yq2m, yt10m, yq10m, yu10m, yustar) 2540 2452 ELSE !(iflag_split .eq.0) 2541 2453 CALL stdlevvar(klon, knon, nsrf, zxli, & 2542 2454 uzon_x, vmer_x, tair1_x, qair1_x, zgeo1_x, & 2543 tairsol_x, qairsol, rugo1, psfce, patm, &2455 tairsol_x, qairsol, rugo1, rugo1, psfce, patm, & 2544 2456 yt2m_x, yq2m_x, yt10m_x, yq10m_x, yu10m_x, yustar_x) 2545 2457 CALL stdlevvar(klon, knon, nsrf, zxli, & 2546 2458 uzon_w, vmer_w, tair1_w, qair1_w, zgeo1_w, & 2547 tairsol_w, qairsol, rugo1, psfce, patm, &2459 tairsol_w, qairsol, rugo1, rugo1, psfce, patm, & 2548 2460 yt2m_w, yq2m_w, yt10m_w, yq10m_w, yu10m_w, yustar_w) 2549 2461 !!! … … 2771 2683 !**************************************************************************************** 2772 2684 2685 z0m(:,nbsrf+1) = 0.0 2686 z0h(:,nbsrf+1) = 0.0 2687 DO nsrf = 1, nbsrf 2688 DO i = 1, klon 2689 z0m(i,nbsrf+1) = z0m(i,nbsrf+1) + z0m(i,nsrf)*pctsrf(i,nsrf) 2690 z0h(i,nbsrf+1) = z0h(i,nbsrf+1) + z0h(i,nsrf)*pctsrf(i,nsrf) 2691 ENDDO 2692 ENDDO 2693 2773 2694 ! print*,'OK pbl 7' 2774 2695 zxfluxt(:,:) = 0.0 ; zxfluxq(:,:) = 0.0 … … 2987 2908 zv1(:) = v(:,1) 2988 2909 2989 ! Some of the module declared variables are returned for printing in physiq.F2990 qsol_d(:) = qsol(:)2991 evap_d(:,:) = evap(:,:)2992 rugos_d(:,:) = rugos(:,:)2993 agesno_d(:,:) = agesno(:,:)2994 2995 2910 2996 2911 END SUBROUTINE pbl_surface … … 2998 2913 !**************************************************************************************** 2999 2914 ! 3000 SUBROUTINE pbl_surface_final(qsol_rst, fder_rst, snow_rst, qsurf_rst, & 3001 evap_rst, rugos_rst, agesno_rst, ftsoil_rst) 2915 SUBROUTINE pbl_surface_final(fder_rst, snow_rst, qsurf_rst, ftsoil_rst) 3002 2916 3003 2917 USE indice_sol_mod … … 3007 2921 ! Ouput variables 3008 2922 !**************************************************************************************** 3009 REAL, DIMENSION(klon), INTENT(OUT) :: qsol_rst3010 2923 REAL, DIMENSION(klon), INTENT(OUT) :: fder_rst 3011 2924 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: snow_rst 3012 2925 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: qsurf_rst 3013 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: evap_rst3014 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: rugos_rst3015 REAL, DIMENSION(klon, nbsrf), INTENT(OUT) :: agesno_rst3016 2926 REAL, DIMENSION(klon, nsoilmx, nbsrf), INTENT(OUT) :: ftsoil_rst 3017 2927 … … 3021 2931 ! 3022 2932 !**************************************************************************************** 3023 qsol_rst(:) = qsol(:)3024 2933 fder_rst(:) = fder(:) 3025 2934 snow_rst(:,:) = snow(:,:) 3026 2935 qsurf_rst(:,:) = qsurf(:,:) 3027 evap_rst(:,:) = evap(:,:)3028 rugos_rst(:,:) = rugos(:,:)3029 agesno_rst(:,:) = agesno(:,:)3030 2936 ftsoil_rst(:,:,:) = ftsoil(:,:,:) 3031 2937 … … 3035 2941 !**************************************************************************************** 3036 2942 ! DEALLOCATE(qsol, fder, snow, qsurf, evap, rugos, agesno, ftsoil) 3037 IF (ALLOCATED(qsol)) DEALLOCATE(qsol)3038 2943 IF (ALLOCATED(fder)) DEALLOCATE(fder) 3039 2944 IF (ALLOCATED(snow)) DEALLOCATE(snow) 3040 2945 IF (ALLOCATED(qsurf)) DEALLOCATE(qsurf) 3041 IF (ALLOCATED(evap)) DEALLOCATE(evap)3042 IF (ALLOCATED(rugos)) DEALLOCATE(rugos)3043 IF (ALLOCATED(agesno)) DEALLOCATE(agesno)3044 2946 IF (ALLOCATED(ftsoil)) DEALLOCATE(ftsoil) 3045 2947 … … 3050 2952 3051 2953 !albedo SB >>> 3052 ! SUBROUTINE pbl_surface_newfrac(itime, pctsrf_new, pctsrf_old, tsurf, alb1, alb2, ustar, u10m, v10m, tke) 3053 SUBROUTINE pbl_surface_newfrac(itime, pctsrf_new, pctsrf_old, tsurf,alb_dir,alb_dif, ustar, u10m, v10m, tke) 2954 SUBROUTINE pbl_surface_newfrac(itime, pctsrf_new, pctsrf_old, & 2955 evap, z0m, z0h, agesno, & 2956 tsurf,alb_dir,alb_dif, ustar, u10m, v10m, tke) 3054 2957 !albedo SB <<< 3055 2958 ! Give default values where new fraction has appread … … 3070 2973 REAL, DIMENSION(klon,nbsrf), INTENT(INOUT) :: tsurf 3071 2974 !albedo SB >>> 3072 ! REAL, DIMENSION(klon,nbsrf), INTENT(INOUT) :: alb1, alb23073 2975 REAL, DIMENSION(klon,nsw,nbsrf), INTENT(INOUT) :: alb_dir, alb_dif 3074 2976 INTEGER :: k 3075 2977 !albedo SB <<< 3076 2978 REAL, DIMENSION(klon,nbsrf), INTENT(INOUT) :: ustar,u10m, v10m 2979 REAL, DIMENSION(klon,nbsrf), INTENT(INOUT) :: evap, agesno 2980 REAL, DIMENSION(klon,nbsrf+1), INTENT(INOUT) :: z0m,z0h 3077 2981 REAL, DIMENSION(klon,klev+1,nbsrf+1), INTENT(INOUT) :: tke 3078 2982 … … 3116 3020 qsurf(i,nsrf) = qsurf(i,nsrf_comp1) 3117 3021 evap(i,nsrf) = evap(i,nsrf_comp1) 3118 rugos(i,nsrf) = rugos(i,nsrf_comp1) 3022 z0m(i,nsrf) = z0m(i,nsrf_comp1) 3023 z0h(i,nsrf) = z0h(i,nsrf_comp1) 3119 3024 tsurf(i,nsrf) = tsurf(i,nsrf_comp1) 3120 3025 !albedo SB >>> 3121 ! alb1(i,nsrf) = alb1(i,nsrf_comp1)3122 ! alb2(i,nsrf) = alb2(i,nsrf_comp1)3123 3026 DO k=1,nsw 3124 3027 alb_dir(i,k,nsrf)=alb_dir(i,k,nsrf_comp1) … … 3137 3040 qsurf(i,nsrf) = qsurf(i,nsrf_comp2)*pctsrf_old(i,nsrf_comp2) + qsurf(i,nsrf_comp3)*pctsrf_old(i,nsrf_comp3) 3138 3041 evap(i,nsrf) = evap(i,nsrf_comp2) *pctsrf_old(i,nsrf_comp2) + evap(i,nsrf_comp3) *pctsrf_old(i,nsrf_comp3) 3139 rugos(i,nsrf) = rugos(i,nsrf_comp2)*pctsrf_old(i,nsrf_comp2) + rugos(i,nsrf_comp3)*pctsrf_old(i,nsrf_comp3) 3042 z0m(i,nsrf) = z0m(i,nsrf_comp2)*pctsrf_old(i,nsrf_comp2) + z0m(i,nsrf_comp3)*pctsrf_old(i,nsrf_comp3) 3043 z0h(i,nsrf) = z0h(i,nsrf_comp2)*pctsrf_old(i,nsrf_comp2) + z0h(i,nsrf_comp3)*pctsrf_old(i,nsrf_comp3) 3140 3044 tsurf(i,nsrf) = tsurf(i,nsrf_comp2)*pctsrf_old(i,nsrf_comp2) + tsurf(i,nsrf_comp3)*pctsrf_old(i,nsrf_comp3) 3141 3045 !albedo SB >>> 3142 ! alb1(i,nsrf) = alb1(i,nsrf_comp2) *pctsrf_old(i,nsrf_comp2) + alb1(i,nsrf_comp3) *pctsrf_old(i,nsrf_comp3)3143 ! alb2(i,nsrf) = alb2(i,nsrf_comp2) *pctsrf_old(i,nsrf_comp2) + alb2(i,nsrf_comp3) *pctsrf_old(i,nsrf_comp3)3144 3046 DO k=1,nsw 3145 3047 alb_dir(i,k,nsrf)=alb_dir(i,k,nsrf_comp2)*pctsrf_old(i,nsrf_comp2)+& -
LMDZ5/branches/testing/libf/phylmd/phyaqua_mod.F90
r2220 r2298 48 48 REAL :: run_off_lic_0(nlon) 49 49 REAL :: qsolsrf(nlon, nbsrf), snsrf(nlon, nbsrf) 50 REAL :: frugs(nlon, nbsrf)51 REAL :: agesno(nlon, nbsrf)52 50 REAL :: tsoil(nlon, nsoilmx, nbsrf) 53 51 REAL :: tslab(nlon), seaice(nlon) 54 REAL evap(nlon, nbsrf),fder(nlon)52 REAL fder(nlon) 55 53 56 54 … … 67 65 REAL tsurf 68 66 REAL time, timestep, day, day0 69 REAL qsol_f , qsol(nlon)67 REAL qsol_f 70 68 REAL rugsrel(nlon) 71 69 ! real zmea(nlon),zstd(nlon),zsig(nlon) … … 328 326 seaice(:) = 0. 329 327 run_off_lic_0 = 0. 330 evap = 0.328 fevap = 0. 331 329 332 330 … … 336 334 qsolsrf(:, :) = qsol(1) ! humidite du sol des sous surface 337 335 snsrf(:, :) = 0. ! couverture de neige des sous surface 338 frugs(:, :) = rugos ! couverture de neige des sous surface339 340 341 CALL pbl_surface_init(qsol, fder, snsrf, qsolsrf, evap, frugs, agesno, & 342 336 z0m(:, :) = rugos ! couverture de neige des sous surface 337 z0h=z0m 338 339 340 CALL pbl_surface_init(fder, snsrf, qsolsrf, tsoil) 343 341 344 342 PRINT *, 'iniaqua: before phyredem' -
LMDZ5/branches/testing/libf/phylmd/phyetat0.F90
r2258 r2298 10 10 USE surface_data, ONLY : type_ocean, version_ocean 11 11 USE phys_state_var_mod, ONLY : ancien_ok, clwcon, detr_therm, dtime, & 12 du_gwd_rando, dv_gwd_rando, entr_therm, f0, falb1, falb2, fm_therm, & 12 qsol, fevap, z0m, z0h, agesno, & 13 du_gwd_rando, dv_gwd_rando, entr_therm, f0, fm_therm, & 13 14 falb_dir, falb_dif, & 14 15 ftsol, pbl_tke, pctsrf, q_ancien, radpas, radsol, rain_fall, ratqs, & … … 20 21 zstd, zthe, zval, ale_bl, ale_bl_trig, alp_bl 21 22 USE iostart, ONLY : close_startphy, get_field, get_var, open_startphy 22 USE infotrac, only: nbtr, type_trac, tname, niadv23 USE infotrac, only: nbtr, nqo, type_trac, tname, niadv 23 24 USE traclmdz_mod, ONLY : traclmdz_from_restart 24 25 USE carbon_cycle_mod, ONLY : carbon_cycle_tr, carbon_cycle_cpl, co2_send … … 46 47 REAL tsoil(klon, nsoilmx, nbsrf) 47 48 REAL qsurf(klon, nbsrf) 48 REAL qsol(klon)49 49 REAL snow(klon, nbsrf) 50 REAL evap(klon, nbsrf)51 50 real fder(klon) 52 REAL frugs(klon, nbsrf)53 REAL agesno(klon, nbsrf)54 51 REAL run_off_lic_0(klon) 55 52 REAL fractint(klon) … … 74 71 CHARACTER*7 str7 75 72 CHARACTER*2 str2 76 LOGICAL :: found 73 LOGICAL :: found,phyetat0_get,phyetat0_srf 77 74 78 75 ! FH1D … … 205 202 END DO 206 203 207 ! Lecture des temperatures du sol: 208 209 CALL get_field("TS", ftsol(:, 1), found) 210 IF (.NOT. found) THEN 211 PRINT*, 'phyetat0: Le champ <TS> est absent' 212 PRINT*, ' Mais je vais essayer de lire TS**' 213 DO nsrf = 1, nbsrf 214 IF (nsrf.GT.99) THEN 215 PRINT*, "Trop de sous-mailles" 204 !=================================================================== 205 ! Lecture des temperatures du sol: 206 !=================================================================== 207 208 found=phyetat0_get(1,ftsol(:,1),"TS","Surface temperature",283.) 209 IF (found) THEN 210 DO nsrf=2,nbsrf 211 ftsol(:,nsrf)=ftsol(:,1) 212 ENDDO 213 ELSE 214 found=phyetat0_srf(1,ftsol,"TS","Surface temperature",283.) 215 ENDIF 216 217 !=================================================================== 218 ! Lecture des albedo difus et direct 219 !=================================================================== 220 221 DO nsrf = 1, nbsrf 222 DO isw=1, nsw 223 IF (isw.GT.99) THEN 224 PRINT*, "Trop de bandes SW" 216 225 call abort_gcm("phyetat0", "", 1) 217 226 ENDIF 218 WRITE(str2, '(i2.2)') nsrf 219 CALL get_field("TS"//str2, ftsol(:, nsrf)) 220 221 xmin = 1.0E+20 222 xmax = -1.0E+20 223 DO i = 1, klon 224 xmin = MIN(ftsol(i, nsrf), xmin) 225 xmax = MAX(ftsol(i, nsrf), xmax) 226 ENDDO 227 PRINT*, 'Temperature du sol TS**:', nsrf, xmin, xmax 227 WRITE(str2, '(i2.2)') isw 228 found=phyetat0_srf(1,falb_dir(:, isw,:),"A_dir_SW"//str2//"srf","Direct Albedo",0.2) 229 found=phyetat0_srf(1,falb_dif(:, isw,:),"A_dif_SW"//str2//"srf","Direct Albedo",0.2) 228 230 ENDDO 229 ELSE 230 PRINT*, 'phyetat0: Le champ <TS> est present' 231 PRINT*, ' J ignore donc les autres temperatures TS**' 232 xmin = 1.0E+20 233 xmax = -1.0E+20 234 DO i = 1, klon 235 xmin = MIN(ftsol(i, 1), xmin) 236 xmax = MAX(ftsol(i, 1), xmax) 237 ENDDO 238 PRINT*, 'Temperature du sol <TS>', xmin, xmax 239 DO nsrf = 2, nbsrf 240 DO i = 1, klon 241 ftsol(i, nsrf) = ftsol(i, 1) 242 ENDDO 243 ENDDO 244 ENDIF 245 246 !=================================================================== 247 ! Lecture des albedo difus et direct 248 249 DO nsrf = 1, nbsrf 250 DO isw=1, nsw 251 IF (isw.GT.99 .AND. nsrf.GT.99) THEN 252 PRINT*, "Trop de bandes SW ou sous-mailles" 231 ENDDO 232 233 !=================================================================== 234 ! Lecture des temperatures du sol profond: 235 !=================================================================== 236 237 DO isoil=1, nsoilmx 238 IF (isoil.GT.99) THEN 239 PRINT*, "Trop de couches " 253 240 call abort_gcm("phyetat0", "", 1) 254 241 ENDIF 255 WRITE(str7, '(i2.2, "srf", i2.2)') isw, nsrf 256 257 CALL get_field('A_dir_SW'//str7, falb_dir(:, isw, nsrf), found) 258 IF (.NOT. found) THEN 259 PRINT*, "phyetat0: Le champ <A_dir_SW"//str7//"> est absent" 260 PRINT*, " Il prend donc la valeur de surface" 261 DO i=1, klon 262 falb_dir(i, isw, nsrf)=0.2 263 ENDDO 264 ENDIF 265 CALL get_field('A_dif_SW'//str7, falb_dif(:, isw, nsrf), found) 266 IF (.NOT. found) THEN 267 PRINT*, "phyetat0: Le champ <A_dif_SW"//str7//"> est absent" 268 PRINT*, " Il prend donc la valeur de surface" 269 DO i=1, klon 270 falb_dif(i, isw, nsrf)=0.2 271 ENDDO 272 ENDIF 273 ENDDO 274 ENDDO 275 276 !=================================================================== 277 ! Lecture des temperatures du sol profond: 278 279 DO nsrf = 1, nbsrf 280 DO isoil=1, nsoilmx 281 IF (isoil.GT.99 .AND. nsrf.GT.99) THEN 282 PRINT*, "Trop de couches ou sous-mailles" 283 call abort_gcm("phyetat0", "", 1) 284 ENDIF 285 WRITE(str7, '(i2.2, "srf", i2.2)') isoil, nsrf 286 287 CALL get_field('Tsoil'//str7, tsoil(:, isoil, nsrf), found) 242 WRITE(str2,'(i2.2)') isoil 243 found=phyetat0_srf(1,tsoil(:, isoil,:),"Tsoil"//str2//"srf","Temp soil",0.) 288 244 IF (.NOT. found) THEN 289 245 PRINT*, "phyetat0: Le champ <Tsoil"//str7//"> est absent" 290 246 PRINT*, " Il prend donc la valeur de surface" 291 DO i=1, klon 292 tsoil(i, isoil, nsrf)=ftsol(i, nsrf) 293 ENDDO 247 tsoil(:, isoil, :)=ftsol(:, :) 294 248 ENDIF 295 ENDDO 296 ENDDO 297 298 !=================================================================== 299 ! Lecture de l'humidite de l'air juste au dessus du sol: 300 301 CALL get_field("QS", qsurf(:, 1), found) 249 ENDDO 250 251 !======================================================================= 252 ! Lecture precipitation/evaporation 253 !======================================================================= 254 255 found=phyetat0_srf(1,qsurf,"QS","Near surface hmidity",0.) 256 found=phyetat0_get(1,qsol,"QSOL","Surface hmidity / bucket",0.) 257 found=phyetat0_srf(1,snow,"SNOW","Surface snow",0.) 258 found=phyetat0_srf(1,fevap,"EVAP","evaporation",0.) 259 found=phyetat0_get(1,snow_fall,"snow_f","snow fall",0.) 260 found=phyetat0_get(1,rain_fall,"rain_f","rain fall",0.) 261 262 !======================================================================= 263 ! Radiation 264 !======================================================================= 265 266 found=phyetat0_get(1,solsw,"solsw","net SW radiation surf",0.) 267 found=phyetat0_get(1,sollw,"sollw","net LW radiation surf",0.) 268 found=phyetat0_get(1,sollwdown,"sollwdown","down LW radiation surf",0.) 302 269 IF (.NOT. found) THEN 303 PRINT*, 'phyetat0: Le champ <QS> est absent' 304 PRINT*, ' Mais je vais essayer de lire QS**' 305 DO nsrf = 1, nbsrf 306 IF (nsrf.GT.99) THEN 307 PRINT*, "Trop de sous-mailles" 308 call abort_gcm("phyetat0", "", 1) 309 ENDIF 310 WRITE(str2, '(i2.2)') nsrf 311 CALL get_field("QS"//str2, qsurf(:, nsrf)) 312 xmin = 1.0E+20 313 xmax = -1.0E+20 314 DO i = 1, klon 315 xmin = MIN(qsurf(i, nsrf), xmin) 316 xmax = MAX(qsurf(i, nsrf), xmax) 317 ENDDO 318 PRINT*, 'Humidite pres du sol QS**:', nsrf, xmin, xmax 319 ENDDO 320 ELSE 321 PRINT*, 'phyetat0: Le champ <QS> est present' 322 PRINT*, ' J ignore donc les autres humidites QS**' 323 xmin = 1.0E+20 324 xmax = -1.0E+20 325 DO i = 1, klon 326 xmin = MIN(qsurf(i, 1), xmin) 327 xmax = MAX(qsurf(i, 1), xmax) 328 ENDDO 329 PRINT*, 'Humidite pres du sol <QS>', xmin, xmax 330 DO nsrf = 2, nbsrf 331 DO i = 1, klon 332 qsurf(i, nsrf) = qsurf(i, 1) 333 ENDDO 334 ENDDO 335 ENDIF 336 337 ! Eau dans le sol (pour le modele de sol "bucket") 338 339 CALL get_field("QSOL", qsol, found) 340 IF (.NOT. found) THEN 341 PRINT*, 'phyetat0: Le champ <QSOL> est absent' 342 PRINT*, ' Valeur par defaut nulle' 343 qsol(:)=0. 344 ENDIF 345 346 xmin = 1.0E+20 347 xmax = -1.0E+20 348 DO i = 1, klon 349 xmin = MIN(qsol(i), xmin) 350 xmax = MAX(qsol(i), xmax) 351 ENDDO 352 PRINT*, 'Eau dans le sol (mm) <QSOL>', xmin, xmax 353 354 ! Lecture de neige au sol: 355 356 CALL get_field("SNOW", snow(:, 1), found) 357 IF (.NOT. found) THEN 358 PRINT*, 'phyetat0: Le champ <SNOW> est absent' 359 PRINT*, ' Mais je vais essayer de lire SNOW**' 360 DO nsrf = 1, nbsrf 361 IF (nsrf.GT.99) THEN 362 PRINT*, "Trop de sous-mailles" 363 call abort_gcm("phyetat0", "", 1) 364 ENDIF 365 WRITE(str2, '(i2.2)') nsrf 366 CALL get_field( "SNOW"//str2, snow(:, nsrf)) 367 xmin = 1.0E+20 368 xmax = -1.0E+20 369 DO i = 1, klon 370 xmin = MIN(snow(i, nsrf), xmin) 371 xmax = MAX(snow(i, nsrf), xmax) 372 ENDDO 373 PRINT*, 'Neige du sol SNOW**:', nsrf, xmin, xmax 374 ENDDO 375 ELSE 376 PRINT*, 'phyetat0: Le champ <SNOW> est present' 377 PRINT*, ' J ignore donc les autres neiges SNOW**' 378 xmin = 1.0E+20 379 xmax = -1.0E+20 380 DO i = 1, klon 381 xmin = MIN(snow(i, 1), xmin) 382 xmax = MAX(snow(i, 1), xmax) 383 ENDDO 384 PRINT*, 'Neige du sol <SNOW>', xmin, xmax 385 DO nsrf = 2, nbsrf 386 DO i = 1, klon 387 snow(i, nsrf) = snow(i, 1) 388 ENDDO 389 ENDDO 390 ENDIF 391 392 ! Lecture de albedo de l'interval visible au sol: 393 394 CALL get_field("ALBE", falb1(:, 1), found) 395 IF (.NOT. found) THEN 396 PRINT*, 'phyetat0: Le champ <ALBE> est absent' 397 PRINT*, ' Mais je vais essayer de lire ALBE**' 398 DO nsrf = 1, nbsrf 399 IF (nsrf.GT.99) THEN 400 PRINT*, "Trop de sous-mailles" 401 call abort_gcm("phyetat0", "", 1) 402 ENDIF 403 WRITE(str2, '(i2.2)') nsrf 404 CALL get_field("ALBE"//str2, falb1(:, nsrf)) 405 xmin = 1.0E+20 406 xmax = -1.0E+20 407 DO i = 1, klon 408 xmin = MIN(falb1(i, nsrf), xmin) 409 xmax = MAX(falb1(i, nsrf), xmax) 410 ENDDO 411 PRINT*, 'Albedo du sol ALBE**:', nsrf, xmin, xmax 412 ENDDO 413 ELSE 414 PRINT*, 'phyetat0: Le champ <ALBE> est present' 415 PRINT*, ' J ignore donc les autres ALBE**' 416 xmin = 1.0E+20 417 xmax = -1.0E+20 418 DO i = 1, klon 419 xmin = MIN(falb1(i, 1), xmin) 420 xmax = MAX(falb1(i, 1), xmax) 421 ENDDO 422 PRINT*, 'Neige du sol <ALBE>', xmin, xmax 423 DO nsrf = 2, nbsrf 424 DO i = 1, klon 425 falb1(i, nsrf) = falb1(i, 1) 426 ENDDO 427 ENDDO 428 ENDIF 429 430 ! Lecture de albedo au sol dans l'interval proche infra-rouge: 431 432 CALL get_field("ALBLW", falb2(:, 1), found) 433 IF (.NOT. found) THEN 434 PRINT*, 'phyetat0: Le champ <ALBLW> est absent' 435 PRINT*, ' Mais je vais prendre ALBE**' 436 DO nsrf = 1, nbsrf 437 DO i = 1, klon 438 falb2(i, nsrf) = falb1(i, nsrf) 439 ENDDO 440 ENDDO 441 ELSE 442 PRINT*, 'phyetat0: Le champ <ALBLW> est present' 443 PRINT*, ' J ignore donc les autres ALBLW**' 444 xmin = 1.0E+20 445 xmax = -1.0E+20 446 DO i = 1, klon 447 xmin = MIN(falb2(i, 1), xmin) 448 xmax = MAX(falb2(i, 1), xmax) 449 ENDDO 450 PRINT*, 'Neige du sol <ALBLW>', xmin, xmax 451 DO nsrf = 2, nbsrf 452 DO i = 1, klon 453 falb2(i, nsrf) = falb2(i, 1) 454 ENDDO 455 ENDDO 456 ENDIF 457 458 ! Lecture de evaporation: 459 460 CALL get_field("EVAP", evap(:, 1), found) 461 IF (.NOT. found) THEN 462 PRINT*, 'phyetat0: Le champ <EVAP> est absent' 463 PRINT*, ' Mais je vais essayer de lire EVAP**' 464 DO nsrf = 1, nbsrf 465 IF (nsrf.GT.99) THEN 466 PRINT*, "Trop de sous-mailles" 467 call abort_gcm("phyetat0", "", 1) 468 ENDIF 469 WRITE(str2, '(i2.2)') nsrf 470 CALL get_field("EVAP"//str2, evap(:, nsrf)) 471 xmin = 1.0E+20 472 xmax = -1.0E+20 473 DO i = 1, klon 474 xmin = MIN(evap(i, nsrf), xmin) 475 xmax = MAX(evap(i, nsrf), xmax) 476 ENDDO 477 PRINT*, 'evap du sol EVAP**:', nsrf, xmin, xmax 478 ENDDO 479 ELSE 480 PRINT*, 'phyetat0: Le champ <EVAP> est present' 481 PRINT*, ' J ignore donc les autres EVAP**' 482 xmin = 1.0E+20 483 xmax = -1.0E+20 484 DO i = 1, klon 485 xmin = MIN(evap(i, 1), xmin) 486 xmax = MAX(evap(i, 1), xmax) 487 ENDDO 488 PRINT*, 'Evap du sol <EVAP>', xmin, xmax 489 DO nsrf = 2, nbsrf 490 DO i = 1, klon 491 evap(i, nsrf) = evap(i, 1) 492 ENDDO 493 ENDDO 494 ENDIF 495 496 ! Lecture precipitation liquide: 497 498 CALL get_field("rain_f", rain_fall) 499 xmin = 1.0E+20 500 xmax = -1.0E+20 501 DO i = 1, klon 502 xmin = MIN(rain_fall(i), xmin) 503 xmax = MAX(rain_fall(i), xmax) 504 ENDDO 505 PRINT*, 'Precipitation liquide rain_f:', xmin, xmax 506 507 ! Lecture precipitation solide: 508 509 CALL get_field("snow_f", snow_fall) 510 xmin = 1.0E+20 511 xmax = -1.0E+20 512 DO i = 1, klon 513 xmin = MIN(snow_fall(i), xmin) 514 xmax = MAX(snow_fall(i), xmax) 515 ENDDO 516 PRINT*, 'Precipitation solide snow_f:', xmin, xmax 517 518 ! Lecture rayonnement solaire au sol: 519 520 CALL get_field("solsw", solsw, found) 521 IF (.NOT. found) THEN 522 PRINT*, 'phyetat0: Le champ <solsw> est absent' 523 PRINT*, 'mis a zero' 524 solsw(:) = 0. 525 ENDIF 526 xmin = 1.0E+20 527 xmax = -1.0E+20 528 DO i = 1, klon 529 xmin = MIN(solsw(i), xmin) 530 xmax = MAX(solsw(i), xmax) 531 ENDDO 532 PRINT*, 'Rayonnement solaire au sol solsw:', xmin, xmax 533 534 ! Lecture rayonnement IF au sol: 535 536 CALL get_field("sollw", sollw, found) 537 IF (.NOT. found) THEN 538 PRINT*, 'phyetat0: Le champ <sollw> est absent' 539 PRINT*, 'mis a zero' 540 sollw = 0. 541 ENDIF 542 xmin = 1.0E+20 543 xmax = -1.0E+20 544 DO i = 1, klon 545 xmin = MIN(sollw(i), xmin) 546 xmax = MAX(sollw(i), xmax) 547 ENDDO 548 PRINT*, 'Rayonnement IF au sol sollw:', xmin, xmax 549 550 CALL get_field("sollwdown", sollwdown, found) 551 IF (.NOT. found) THEN 552 PRINT*, 'phyetat0: Le champ <sollwdown> est absent' 553 PRINT*, 'mis a zero' 554 sollwdown = 0. 555 zts=0. 270 sollwdown = 0. ; zts=0. 556 271 do nsrf=1,nbsrf 557 272 zts(:)=zts(:)+ftsol(:,nsrf)*pctsrf(:,nsrf) … … 559 274 sollwdown(:)=sollw(:)+RSIGMA*zts(:)**4 560 275 ENDIF 561 ! print*,'TS SOLL',zts(klon/2),sollw(klon/2),sollwdown(klon/2) 562 xmin = 1.0E+20 563 xmax = -1.0E+20 564 DO i = 1, klon 565 xmin = MIN(sollwdown(i), xmin) 566 xmax = MAX(sollwdown(i), xmax) 567 ENDDO 568 PRINT*, 'Rayonnement IF au sol sollwdown:', xmin, xmax 569 570 571 ! Lecture derive des flux: 572 573 CALL get_field("fder", fder, found) 574 IF (.NOT. found) THEN 575 PRINT*, 'phyetat0: Le champ <fder> est absent' 576 PRINT*, 'mis a zero' 577 fder = 0. 276 277 found=phyetat0_get(1,radsol,"RADS","Solar radiation",0.) 278 found=phyetat0_get(1,fder,"fder","Flux derivative",0.) 279 280 281 ! Lecture de la longueur de rugosite 282 found=phyetat0_srf(1,z0m,"RUG","Z0m ancien",0.001) 283 IF (found) THEN 284 z0h(:,1:nbsrf)=z0m(:,1:nbsrf) 285 ELSE 286 found=phyetat0_srf(1,z0m,"Z0m","Roughness length, momentum ",0.001) 287 found=phyetat0_srf(1,z0h,"Z0h","Roughness length, enthalpy ",0.001) 578 288 ENDIF 579 xmin = 1.0E+20 580 xmax = -1.0E+20 581 DO i = 1, klon 582 xmin = MIN(fder(i), xmin) 583 xmax = MAX(fder(i), xmax) 584 ENDDO 585 PRINT*, 'Derive des flux fder:', xmin, xmax 586 587 ! Lecture du rayonnement net au sol: 588 589 CALL get_field("RADS", radsol) 590 xmin = 1.0E+20 591 xmax = -1.0E+20 592 DO i = 1, klon 593 xmin = MIN(radsol(i), xmin) 594 xmax = MAX(radsol(i), xmax) 595 ENDDO 596 PRINT*, 'Rayonnement net au sol radsol:', xmin, xmax 597 598 ! Lecture de la longueur de rugosite 599 600 CALL get_field("RUG", frugs(:, 1), found) 601 IF (.NOT. found) THEN 602 PRINT*, 'phyetat0: Le champ <RUG> est absent' 603 PRINT*, ' Mais je vais essayer de lire RUG**' 604 DO nsrf = 1, nbsrf 605 IF (nsrf.GT.99) THEN 606 PRINT*, "Trop de sous-mailles" 607 call abort_gcm("phyetat0", "", 1) 608 ENDIF 609 WRITE(str2, '(i2.2)') nsrf 610 CALL get_field("RUG"//str2, frugs(:, nsrf)) 611 xmin = 1.0E+20 612 xmax = -1.0E+20 613 DO i = 1, klon 614 xmin = MIN(frugs(i, nsrf), xmin) 615 xmax = MAX(frugs(i, nsrf), xmax) 616 ENDDO 617 PRINT*, 'rugosite du sol RUG**:', nsrf, xmin, xmax 618 ENDDO 619 ELSE 620 PRINT*, 'phyetat0: Le champ <RUG> est present' 621 PRINT*, ' J ignore donc les autres RUG**' 622 xmin = 1.0E+20 623 xmax = -1.0E+20 624 DO i = 1, klon 625 xmin = MIN(frugs(i, 1), xmin) 626 xmax = MAX(frugs(i, 1), xmax) 627 ENDDO 628 PRINT*, 'rugosite <RUG>', xmin, xmax 629 DO nsrf = 2, nbsrf 630 DO i = 1, klon 631 frugs(i, nsrf) = frugs(i, 1) 632 ENDDO 633 ENDDO 289 290 ! Lecture de l'age de la neige: 291 found=phyetat0_srf(1,agesno,"AGESNO","SNOW AGE",0.001) 292 293 ancien_ok=.true. 294 ancien_ok=ancien_ok.AND.phyetat0_get(klev,t_ancien,"TANCIEN","TANCIEN",0.) 295 ancien_ok=ancien_ok.AND.phyetat0_get(klev,q_ancien,"QANCIEN","QANCIEN",0.) 296 ancien_ok=ancien_ok.AND.phyetat0_get(klev,u_ancien,"UANCIEN","UANCIEN",0.) 297 ancien_ok=ancien_ok.AND.phyetat0_get(klev,v_ancien,"VANCIEN","VANCIEN",0.) 298 299 found=phyetat0_get(klev,clwcon,"CLWCON","CLWCON",0.) 300 found=phyetat0_get(klev,rnebcon,"RNEBCON","RNEBCON",0.) 301 found=phyetat0_get(klev,ratqs,"RATQS","RATQS",0.) 302 303 found=phyetat0_get(1,run_off_lic_0,"RUNOFFLIC0","RUNOFFLIC0",0.) 304 305 !================================== 306 ! TKE 307 !================================== 308 ! 309 IF (iflag_pbl>1) then 310 found=phyetat0_srf(klev+1,pbl_tke,"TKE","Turb. Kinetic. Energ. ",1.e-8) 634 311 ENDIF 635 312 636 ! Lecture de l'age de la neige: 637 638 CALL get_field("AGESNO", agesno(:, 1), found) 639 IF (.NOT. found) THEN 640 PRINT*, 'phyetat0: Le champ <AGESNO> est absent' 641 PRINT*, ' Mais je vais essayer de lire AGESNO**' 642 DO nsrf = 1, nbsrf 643 IF (nsrf.GT.99) THEN 644 PRINT*, "Trop de sous-mailles" 645 call abort_gcm("phyetat0", "", 1) 646 ENDIF 647 WRITE(str2, '(i2.2)') nsrf 648 CALL get_field("AGESNO"//str2, agesno(:, nsrf), found) 649 IF (.NOT. found) THEN 650 PRINT*, "phyetat0: Le champ <AGESNO"//str2//"> est absent" 651 agesno = 50.0 652 ENDIF 653 xmin = 1.0E+20 654 xmax = -1.0E+20 655 DO i = 1, klon 656 xmin = MIN(agesno(i, nsrf), xmin) 657 xmax = MAX(agesno(i, nsrf), xmax) 658 ENDDO 659 PRINT*, 'Age de la neige AGESNO**:', nsrf, xmin, xmax 660 ENDDO 661 ELSE 662 PRINT*, 'phyetat0: Le champ <AGESNO> est present' 663 PRINT*, ' J ignore donc les autres AGESNO**' 664 xmin = 1.0E+20 665 xmax = -1.0E+20 666 DO i = 1, klon 667 xmin = MIN(agesno(i, 1), xmin) 668 xmax = MAX(agesno(i, 1), xmax) 669 ENDDO 670 PRINT*, 'Age de la neige <AGESNO>', xmin, xmax 671 DO nsrf = 2, nbsrf 672 DO i = 1, klon 673 agesno(i, nsrf) = agesno(i, 1) 674 ENDDO 675 ENDDO 676 ENDIF 677 678 CALL get_field("ZMEA", zmea) 679 xmin = 1.0E+20 680 xmax = -1.0E+20 681 DO i = 1, klon 682 xmin = MIN(zmea(i), xmin) 683 xmax = MAX(zmea(i), xmax) 684 ENDDO 685 PRINT*, 'OROGRAPHIE SOUS-MAILLE zmea:', xmin, xmax 686 687 CALL get_field("ZSTD", zstd) 688 xmin = 1.0E+20 689 xmax = -1.0E+20 690 DO i = 1, klon 691 xmin = MIN(zstd(i), xmin) 692 xmax = MAX(zstd(i), xmax) 693 ENDDO 694 PRINT*, 'OROGRAPHIE SOUS-MAILLE zstd:', xmin, xmax 695 696 CALL get_field("ZSIG", zsig) 697 xmin = 1.0E+20 698 xmax = -1.0E+20 699 DO i = 1, klon 700 xmin = MIN(zsig(i), xmin) 701 xmax = MAX(zsig(i), xmax) 702 ENDDO 703 PRINT*, 'OROGRAPHIE SOUS-MAILLE zsig:', xmin, xmax 704 705 CALL get_field("ZGAM", zgam) 706 xmin = 1.0E+20 707 xmax = -1.0E+20 708 DO i = 1, klon 709 xmin = MIN(zgam(i), xmin) 710 xmax = MAX(zgam(i), xmax) 711 ENDDO 712 PRINT*, 'OROGRAPHIE SOUS-MAILLE zgam:', xmin, xmax 713 714 CALL get_field("ZTHE", zthe) 715 xmin = 1.0E+20 716 xmax = -1.0E+20 717 DO i = 1, klon 718 xmin = MIN(zthe(i), xmin) 719 xmax = MAX(zthe(i), xmax) 720 ENDDO 721 PRINT*, 'OROGRAPHIE SOUS-MAILLE zthe:', xmin, xmax 722 723 CALL get_field("ZPIC", zpic) 724 xmin = 1.0E+20 725 xmax = -1.0E+20 726 DO i = 1, klon 727 xmin = MIN(zpic(i), xmin) 728 xmax = MAX(zpic(i), xmax) 729 ENDDO 730 PRINT*, 'OROGRAPHIE SOUS-MAILLE zpic:', xmin, xmax 731 732 CALL get_field("ZVAL", zval) 733 xmin = 1.0E+20 734 xmax = -1.0E+20 735 DO i = 1, klon 736 xmin = MIN(zval(i), xmin) 737 xmax = MAX(zval(i), xmax) 738 ENDDO 739 PRINT*, 'OROGRAPHIE SOUS-MAILLE zval:', xmin, xmax 740 741 CALL get_field("RUGSREL", rugoro) 742 xmin = 1.0E+20 743 xmax = -1.0E+20 744 DO i = 1, klon 745 xmin = MIN(rugoro(i), xmin) 746 xmax = MAX(rugoro(i), xmax) 747 ENDDO 748 PRINT*, 'Rugosite relief (ecart-type) rugsrel:', xmin, xmax 749 750 ancien_ok = .TRUE. 751 752 CALL get_field("TANCIEN", t_ancien, found) 753 IF (.NOT. found) THEN 754 PRINT*, "phyetat0: Le champ <TANCIEN> est absent" 755 PRINT*, "Depart legerement fausse. Mais je continue" 756 ancien_ok = .FALSE. 757 ENDIF 758 759 CALL get_field("QANCIEN", q_ancien, found) 760 IF (.NOT. found) THEN 761 PRINT*, "phyetat0: Le champ <QANCIEN> est absent" 762 PRINT*, "Depart legerement fausse. Mais je continue" 763 ancien_ok = .FALSE. 764 ENDIF 765 766 CALL get_field("UANCIEN", u_ancien, found) 767 IF (.NOT. found) THEN 768 PRINT*, "phyetat0: Le champ <UANCIEN> est absent" 769 PRINT*, "Depart legerement fausse. Mais je continue" 770 ancien_ok = .FALSE. 771 ENDIF 772 773 CALL get_field("VANCIEN", v_ancien, found) 774 IF (.NOT. found) THEN 775 PRINT*, "phyetat0: Le champ <VANCIEN> est absent" 776 PRINT*, "Depart legerement fausse. Mais je continue" 777 ancien_ok = .FALSE. 778 ENDIF 779 780 clwcon=0. 781 CALL get_field("CLWCON", clwcon, found) 782 IF (.NOT. found) THEN 783 PRINT*, "phyetat0: Le champ CLWCON est absent" 784 PRINT*, "Depart legerement fausse. Mais je continue" 785 ENDIF 786 xmin = 1.0E+20 787 xmax = -1.0E+20 788 xmin = MINval(clwcon) 789 xmax = MAXval(clwcon) 790 PRINT*, 'Eau liquide convective (ecart-type) clwcon:', xmin, xmax 791 792 rnebcon = 0. 793 CALL get_field("RNEBCON", rnebcon, found) 794 IF (.NOT. found) THEN 795 PRINT*, "phyetat0: Le champ RNEBCON est absent" 796 PRINT*, "Depart legerement fausse. Mais je continue" 797 ENDIF 798 xmin = 1.0E+20 799 xmax = -1.0E+20 800 xmin = MINval(rnebcon) 801 xmax = MAXval(rnebcon) 802 PRINT*, 'Nebulosite convective (ecart-type) rnebcon:', xmin, xmax 803 804 ! Lecture ratqs 805 806 ratqs=0. 807 CALL get_field("RATQS", ratqs, found) 808 IF (.NOT. found) THEN 809 PRINT*, "phyetat0: Le champ <RATQS> est absent" 810 PRINT*, "Depart legerement fausse. Mais je continue" 811 ENDIF 812 xmin = 1.0E+20 813 xmax = -1.0E+20 814 xmin = MINval(ratqs) 815 xmax = MAXval(ratqs) 816 PRINT*, '(ecart-type) ratqs:', xmin, xmax 817 818 ! Lecture run_off_lic_0 819 820 CALL get_field("RUNOFFLIC0", run_off_lic_0, found) 821 IF (.NOT. found) THEN 822 PRINT*, "phyetat0: Le champ <RUNOFFLIC0> est absent" 823 PRINT*, "Depart legerement fausse. Mais je continue" 824 run_off_lic_0 = 0. 825 ENDIF 826 xmin = 1.0E+20 827 xmax = -1.0E+20 828 xmin = MINval(run_off_lic_0) 829 xmax = MAXval(run_off_lic_0) 830 PRINT*, '(ecart-type) run_off_lic_0:', xmin, xmax 831 832 ! Lecture de l'energie cinetique turbulente 833 834 IF (iflag_pbl>1) then 835 DO nsrf = 1, nbsrf 836 IF (nsrf.GT.99) THEN 837 PRINT*, "Trop de sous-mailles" 838 call abort_gcm("phyetat0", "", 1) 839 ENDIF 840 WRITE(str2, '(i2.2)') nsrf 841 CALL get_field("TKE"//str2, pbl_tke(:, 1:klev+1, nsrf), found) 842 IF (.NOT. found) THEN 843 PRINT*, "phyetat0: <TKE"//str2//"> est absent" 844 pbl_tke(:, :, nsrf)=1.e-8 845 ENDIF 846 xmin = 1.0E+20 847 xmax = -1.0E+20 848 DO k = 1, klev+1 849 DO i = 1, klon 850 xmin = MIN(pbl_tke(i, k, nsrf), xmin) 851 xmax = MAX(pbl_tke(i, k, nsrf), xmax) 852 ENDDO 853 ENDDO 854 PRINT*, 'Turbulent kinetic energyl TKE**:', nsrf, xmin, xmax 855 ENDDO 856 ENDIF 857 858 ! Lecture de l'ecart de TKE (w) - (x) 859 ! 860 IF (iflag_pbl>1 .AND. iflag_wake>=1 & 861 .AND. iflag_pbl_split >=1 ) then 862 DO nsrf = 1, nbsrf 863 IF (nsrf.GT.99) THEN 864 PRINT*, "Trop de sous-mailles" 865 call abort_gcm("phyetat0", "", 1) 866 ENDIF 867 WRITE(str2,'(i2.2)') nsrf 868 CALL get_field("DELTATKE"//str2, & 869 wake_delta_pbl_tke(:,1:klev+1,nsrf),found) 870 IF (.NOT. found) THEN 871 PRINT*, "phyetat0: <DELTATKE"//str2//"> est absent" 872 wake_delta_pbl_tke(:,:,nsrf)=0. 873 ENDIF 874 xmin = 1.0E+20 875 xmax = -1.0E+20 876 DO k = 1, klev+1 877 DO i = 1, klon 878 xmin = MIN(wake_delta_pbl_tke(i,k,nsrf),xmin) 879 xmax = MAX(wake_delta_pbl_tke(i,k,nsrf),xmax) 880 ENDDO 881 ENDDO 882 PRINT*,'TKE difference (w)-(x) DELTATKE**:', nsrf, xmin, xmax 883 ENDDO 884 885 ! delta_tsurf 886 887 DO nsrf = 1, nbsrf 888 IF (nsrf.GT.99) THEN 889 PRINT*, "Trop de sous-mailles" 890 call abort_gcm("phyetat0", "", 1) 891 ENDIF 892 WRITE(str2,'(i2.2)') nsrf 893 CALL get_field("DELTA_TSURF"//str2, delta_tsurf(:,nsrf), found) 894 IF (.NOT. found) THEN 895 PRINT*, "phyetat0: Le champ <DELTA_TSURF"//str2//"> est absent" 896 PRINT*, "Depart legerement fausse. Mais je continue" 897 delta_tsurf(:,nsrf)=0. 898 ELSE 899 xmin = 1.0E+20 900 xmax = -1.0E+20 901 DO i = 1, klon 902 xmin = MIN(delta_tsurf(i, nsrf), xmin) 903 xmax = MAX(delta_tsurf(i, nsrf), xmax) 904 ENDDO 905 PRINT*, 'delta_tsurf:', xmin, xmax 906 ENDIF 907 ENDDO ! nsrf = 1, nbsrf 313 IF (iflag_pbl>1 .AND. iflag_wake>=1 .AND. iflag_pbl_split >=1 ) then 314 found=phyetat0_srf(klev+1,wake_delta_pbl_tke,"DELTATKE","Del TKE wk/env",0.) 315 found=phyetat0_srf(1,delta_tsurf,"DELTA_TSURF","Delta Ts wk/env ",0.) 908 316 ENDIF !(iflag_pbl>1 .AND. iflag_wake>=1 .AND. iflag_pbl_split >=1 ) 909 317 910 ! zmax0 911 CALL get_field("ZMAX0", zmax0, found) 912 IF (.NOT. found) THEN 913 PRINT*, "phyetat0: Le champ <ZMAX0> est absent" 914 PRINT*, "Depart legerement fausse. Mais je continue" 915 zmax0=40. 916 ENDIF 917 xmin = 1.0E+20 918 xmax = -1.0E+20 919 xmin = MINval(zmax0) 920 xmax = MAXval(zmax0) 921 PRINT*, '(ecart-type) zmax0:', xmin, xmax 922 923 ! f0(ig)=1.e-5 924 ! f0 925 CALL get_field("F0", f0, found) 926 IF (.NOT. found) THEN 927 PRINT*, "phyetat0: Le champ <f0> est absent" 928 PRINT*, "Depart legerement fausse. Mais je continue" 929 f0=1.e-5 930 ENDIF 931 xmin = 1.0E+20 932 xmax = -1.0E+20 933 xmin = MINval(f0) 934 xmax = MAXval(f0) 935 PRINT*, '(ecart-type) f0:', xmin, xmax 936 937 ! sig1 or ema_work1 938 939 CALL get_field("sig1", sig1, found) 940 IF (.NOT. found) CALL get_field("EMA_WORK1", sig1, found) 941 IF (.NOT. found) THEN 942 PRINT*, "phyetat0: Le champ sig1 est absent" 943 PRINT*, "Depart legerement fausse. Mais je continue" 944 sig1=0. 945 ELSE 946 xmin = 1.0E+20 947 xmax = -1.0E+20 948 DO k = 1, klev 949 DO i = 1, klon 950 xmin = MIN(sig1(i, k), xmin) 951 xmax = MAX(sig1(i, k), xmax) 952 ENDDO 953 ENDDO 954 PRINT*, 'sig1:', xmin, xmax 955 ENDIF 956 957 ! w01 or ema_work2 958 959 CALL get_field("w01", w01, found) 960 IF (.NOT. found) CALL get_field("EMA_WORK2", w01, found) 961 IF (.NOT. found) THEN 962 PRINT*, "phyetat0: Le champ w01 est absent" 963 PRINT*, "Depart legerement fausse. Mais je continue" 964 w01=0. 965 ELSE 966 xmin = 1.0E+20 967 xmax = -1.0E+20 968 DO k = 1, klev 969 DO i = 1, klon 970 xmin = MIN(w01(i, k), xmin) 971 xmax = MAX(w01(i, k), xmax) 972 ENDDO 973 ENDDO 974 PRINT*, 'w01:', xmin, xmax 975 ENDIF 976 977 ! wake_deltat 978 979 CALL get_field("WAKE_DELTAT", wake_deltat, found) 980 IF (.NOT. found) THEN 981 PRINT*, "phyetat0: Le champ <WAKE_DELTAT> est absent" 982 PRINT*, "Depart legerement fausse. Mais je continue" 983 wake_deltat=0. 984 ELSE 985 xmin = 1.0E+20 986 xmax = -1.0E+20 987 DO k = 1, klev 988 DO i = 1, klon 989 xmin = MIN(wake_deltat(i, k), xmin) 990 xmax = MAX(wake_deltat(i, k), xmax) 991 ENDDO 992 ENDDO 993 PRINT*, 'wake_deltat:', xmin, xmax 994 ENDIF 995 996 ! wake_deltaq 997 998 CALL get_field("WAKE_DELTAQ", wake_deltaq, found) 999 IF (.NOT. found) THEN 1000 PRINT*, "phyetat0: Le champ <WAKE_DELTAQ> est absent" 1001 PRINT*, "Depart legerement fausse. Mais je continue" 1002 wake_deltaq=0. 1003 ELSE 1004 xmin = 1.0E+20 1005 xmax = -1.0E+20 1006 DO k = 1, klev 1007 DO i = 1, klon 1008 xmin = MIN(wake_deltaq(i, k), xmin) 1009 xmax = MAX(wake_deltaq(i, k), xmax) 1010 ENDDO 1011 ENDDO 1012 PRINT*, 'wake_deltaq:', xmin, xmax 1013 ENDIF 1014 1015 ! wake_s 1016 1017 CALL get_field("WAKE_S", wake_s, found) 1018 IF (.NOT. found) THEN 1019 PRINT*, "phyetat0: Le champ <WAKE_S> est absent" 1020 PRINT*, "Depart legerement fausse. Mais je continue" 1021 wake_s=0. 1022 ENDIF 1023 xmin = 1.0E+20 1024 xmax = -1.0E+20 1025 xmin = MINval(wake_s) 1026 xmax = MAXval(wake_s) 1027 PRINT*, '(ecart-type) wake_s:', xmin, xmax 1028 1029 ! wake_cstar 1030 1031 CALL get_field("WAKE_CSTAR", wake_cstar, found) 1032 IF (.NOT. found) THEN 1033 PRINT*, "phyetat0: Le champ <WAKE_CSTAR> est absent" 1034 PRINT*, "Depart legerement fausse. Mais je continue" 1035 wake_cstar=0. 1036 ENDIF 1037 xmin = 1.0E+20 1038 xmax = -1.0E+20 1039 xmin = MINval(wake_cstar) 1040 xmax = MAXval(wake_cstar) 1041 PRINT*, '(ecart-type) wake_cstar:', xmin, xmax 1042 1043 ! wake_pe 1044 1045 CALL get_field("WAKE_PE", wake_pe, found) 1046 IF (.NOT. found) THEN 1047 PRINT*, "phyetat0: Le champ <WAKE_PE> est absent" 1048 PRINT*, "Depart legerement fausse. Mais je continue" 1049 wake_pe=0. 1050 ENDIF 1051 xmin = 1.0E+20 1052 xmax = -1.0E+20 1053 xmin = MINval(wake_pe) 1054 xmax = MAXval(wake_pe) 1055 PRINT*, '(ecart-type) wake_pe:', xmin, xmax 1056 1057 ! wake_fip 1058 1059 CALL get_field("WAKE_FIP", wake_fip, found) 1060 IF (.NOT. found) THEN 1061 PRINT*, "phyetat0: Le champ <WAKE_FIP> est absent" 1062 PRINT*, "Depart legerement fausse. Mais je continue" 1063 wake_fip=0. 1064 ENDIF 1065 xmin = 1.0E+20 1066 xmax = -1.0E+20 1067 xmin = MINval(wake_fip) 1068 xmax = MAXval(wake_fip) 1069 PRINT*, '(ecart-type) wake_fip:', xmin, xmax 1070 1071 ! thermiques 1072 1073 CALL get_field("FM_THERM", fm_therm, found) 1074 IF (.NOT. found) THEN 1075 PRINT*, "phyetat0: Le champ <fm_therm> est absent" 1076 PRINT*, "Depart legerement fausse. Mais je continue" 1077 fm_therm=0. 1078 ENDIF 1079 xmin = 1.0E+20 1080 xmax = -1.0E+20 1081 xmin = MINval(fm_therm) 1082 xmax = MAXval(fm_therm) 1083 PRINT*, '(ecart-type) fm_therm:', xmin, xmax 1084 1085 CALL get_field("ENTR_THERM", entr_therm, found) 1086 IF (.NOT. found) THEN 1087 PRINT*, "phyetat0: Le champ <entr_therm> est absent" 1088 PRINT*, "Depart legerement fausse. Mais je continue" 1089 entr_therm=0. 1090 ENDIF 1091 xmin = 1.0E+20 1092 xmax = -1.0E+20 1093 xmin = MINval(entr_therm) 1094 xmax = MAXval(entr_therm) 1095 PRINT*, '(ecart-type) entr_therm:', xmin, xmax 1096 1097 CALL get_field("DETR_THERM", detr_therm, found) 1098 IF (.NOT. found) THEN 1099 PRINT*, "phyetat0: Le champ <detr_therm> est absent" 1100 PRINT*, "Depart legerement fausse. Mais je continue" 1101 detr_therm=0. 1102 ENDIF 1103 xmin = 1.0E+20 1104 xmax = -1.0E+20 1105 xmin = MINval(detr_therm) 1106 xmax = MAXval(detr_therm) 1107 PRINT*, '(ecart-type) detr_therm:', xmin, xmax 1108 1109 CALL get_field("ALE_BL", ale_bl, found) 1110 IF (.NOT. found) THEN 1111 PRINT*, "phyetat0: Le champ <ale_bl> est absent" 1112 PRINT*, "Depart legerement fausse. Mais je continue" 1113 ale_bl=0. 1114 ENDIF 1115 xmin = 1.0E+20 1116 xmax = -1.0E+20 1117 xmin = MINval(ale_bl) 1118 xmax = MAXval(ale_bl) 1119 PRINT*, '(ecart-type) ale_bl:', xmin, xmax 1120 1121 CALL get_field("ALE_BL_TRIG", ale_bl_trig, found) 1122 IF (.NOT. found) THEN 1123 PRINT*, "phyetat0: Le champ <ale_bl_trig> est absent" 1124 PRINT*, "Depart legerement fausse. Mais je continue" 1125 ale_bl_trig=0. 1126 ENDIF 1127 xmin = 1.0E+20 1128 xmax = -1.0E+20 1129 xmin = MINval(ale_bl_trig) 1130 xmax = MAXval(ale_bl_trig) 1131 PRINT*, '(ecart-type) ale_bl_trig:', xmin, xmax 1132 1133 CALL get_field("ALP_BL", alp_bl, found) 1134 IF (.NOT. found) THEN 1135 PRINT*, "phyetat0: Le champ <alp_bl> est absent" 1136 PRINT*, "Depart legerement fausse. Mais je continue" 1137 alp_bl=0. 1138 ENDIF 1139 xmin = 1.0E+20 1140 xmax = -1.0E+20 1141 xmin = MINval(alp_bl) 1142 xmax = MAXval(alp_bl) 1143 PRINT*, '(ecart-type) alp_bl:', xmin, xmax 1144 318 !================================== 319 ! thermiques, poches, convection 320 !================================== 321 322 ! Emanuel 323 found=phyetat0_get(klev,sig1,"sig1","sig1",0.) 324 found=phyetat0_get(klev,w01,"w01","w01",0.) 325 326 ! Wake 327 found=phyetat0_get(klev,wake_deltat,"WAKE_DELTAT","Delta T wake/env",0.) 328 found=phyetat0_get(klev,wake_deltaq,"WAKE_DELTAQ","Delta hum. wake/env",0.) 329 found=phyetat0_get(1,wake_s,"WAKE_S","WAKE_S",0.) 330 found=phyetat0_get(1,wake_cstar,"WAKE_CSTAR","WAKE_CSTAR",0.) 331 found=phyetat0_get(1,wake_pe,"WAKE_PE","WAKE_PE",0.) 332 found=phyetat0_get(1,wake_fip,"WAKE_FIP","WAKE_FIP",0.) 333 334 ! Thermiques 335 found=phyetat0_get(1,zmax0,"ZMAX0","ZMAX0",40.) 336 found=phyetat0_get(1,f0,"F0","F0",1.e-5) 337 found=phyetat0_get(klev+1,fm_therm,"FM_THERM","Thermals mass flux",0.) 338 found=phyetat0_get(klev,entr_therm,"ENTR_THERM","Thermals Entrain.",0.) 339 found=phyetat0_get(klev,detr_therm,"DETR_THERM","Thermals Detrain.",0.) 340 341 ! ALE/ALP 342 found=phyetat0_get(1,ale_bl,"ALE_BL","ALE BL",0.) 343 found=phyetat0_get(1,ale_bl_trig,"ALE_BL_TRIG","ALE BL_TRIG",0.) 344 found=phyetat0_get(1,alp_bl,"ALP_BL","ALP BL",0.) 345 346 !=========================================== 1145 347 ! Read and send field trs to traclmdz 348 !=========================================== 1146 349 1147 350 IF (type_trac == 'lmdz') THEN 1148 DO it=1, nbtr 1149 iiq=niadv(it+2) 1150 CALL get_field("trs_"//tname(iiq), trs(:, it), found) 1151 IF (.NOT. found) THEN 1152 PRINT*, & 1153 "phyetat0: Le champ <trs_"//tname(iiq)//"> est absent" 1154 PRINT*, "Depart legerement fausse. Mais je continue" 1155 trs(:, it) = 0. 1156 ENDIF 1157 xmin = 1.0E+20 1158 xmax = -1.0E+20 1159 xmin = MINval(trs(:, it)) 1160 xmax = MAXval(trs(:, it)) 1161 PRINT*, "(ecart-type) trs_"//tname(iiq)//" :", xmin, xmax 1162 351 DO it=1, nbtr 352 !! iiq=niadv(it+2) ! jyg 353 iiq=niadv(it+nqo) ! jyg 354 found=phyetat0_get(1,trs(:,it),"trs_"//tname(iiq), & 355 "Surf trac"//tname(iiq),0.) 1163 356 END DO 1164 357 CALL traclmdz_from_restart(trs) … … 1166 359 IF (carbon_cycle_cpl) THEN 1167 360 ALLOCATE(co2_send(klon), stat=ierr) 1168 IF (ierr /= 0) CALL abort_gcm & 1169 ('phyetat0', 'pb allocation co2_send', 1) 1170 CALL get_field("co2_send", co2_send, found) 1171 IF (.NOT. found) THEN 1172 PRINT*, "phyetat0: Le champ <co2_send> est absent" 1173 PRINT*, "Initialisation uniforme a co2_ppm=", co2_ppm 1174 co2_send(:) = co2_ppm 1175 END IF 361 IF (ierr /= 0) CALL abort_gcm('phyetat0', 'pb allocation co2_send', 1) 362 found=phyetat0_get(1,co2_send,"co2_send","co2 send",0.) 1176 363 END IF 1177 364 END IF 1178 365 366 !=========================================== 367 ! ondes de gravite / relief 368 !=========================================== 369 370 ! ondes de gravite non orographiques 1179 371 if (ok_gwd_rando) then 1180 call get_field("du_gwd_rando", du_gwd_rando, found) 1181 if (.not. found) then 1182 print *, "du_gwd_rando not found, setting it to 0." 1183 du_gwd_rando = 0. 1184 end if 1185 1186 call get_field("dv_gwd_rando", dv_gwd_rando, found) 1187 if (.not. found) then 1188 print *, "dv_gwd_rando not found, setting it to 0." 1189 dv_gwd_rando = 0. 1190 end if 372 found=phyetat0_get(klev,du_gwd_rando,"du_gwd_rando","du_gwd_rando",0.) 373 found=phyetat0_get(klev,dv_gwd_rando,"dv_gwd_rando","dv_gwd_rando",0.) 1191 374 end if 1192 375 1193 ! Initialize Slab variables 376 ! prise en compte du relief sous-maille 377 found=phyetat0_get(1,zmea,"ZMEA","sub grid orography",0.) 378 found=phyetat0_get(1,zstd,"ZSTD","sub grid orography",0.) 379 found=phyetat0_get(1,zsig,"ZSIG","sub grid orography",0.) 380 found=phyetat0_get(1,zgam,"ZGAM","sub grid orography",0.) 381 found=phyetat0_get(1,zthe,"ZTHE","sub grid orography",0.) 382 found=phyetat0_get(1,zpic,"ZPIC","sub grid orography",0.) 383 found=phyetat0_get(1,zval,"ZVAL","sub grid orography",0.) 384 found=phyetat0_get(1,zmea,"ZMEA","sub grid orography",0.) 385 found=phyetat0_get(1,rugoro,"RUGSREL","sub grid orography",0.) 386 387 !=========================================== 388 ! Initialize ocean 389 !=========================================== 390 1194 391 IF ( type_ocean == 'slab' ) THEN 1195 print*, "calling slab_init"1196 392 CALL ocean_slab_init(dtime, pctsrf) 1197 ! tslab 1198 CALL get_field("tslab", tslab, found) 393 found=phyetat0_get(nslay,tslab,"tslab","tslab",0.) 1199 394 IF (.NOT. found) THEN 1200 395 PRINT*, "phyetat0: Le champ <tslab> est absent" … … 1204 399 END DO 1205 400 END IF 401 1206 402 ! Sea ice variables 403 found=phyetat0_get(1,tice,"slab_tice","slab_tice",0.) 1207 404 IF (version_ocean == 'sicINT') THEN 1208 CALL get_field("slab_tice", tice, found)1209 405 IF (.NOT. found) THEN 1210 406 PRINT*, "phyetat0: Le champ <tice> est absent" … … 1212 408 tice(:)=ftsol(:,is_sic) 1213 409 END IF 1214 CALL get_field("seaice", seaice, found)1215 410 IF (.NOT. found) THEN 1216 411 PRINT*, "phyetat0: Le champ <seaice> est absent" … … 1229 424 ! Initialize module pbl_surface_mod 1230 425 1231 CALL pbl_surface_init(qsol, fder, snow, qsurf, & 1232 evap, frugs, agesno, tsoil) 426 CALL pbl_surface_init(fder, snow, qsurf, tsoil) 1233 427 1234 428 ! Initialize module ocean_cpl_mod for the case of coupled ocean … … 1243 437 1244 438 END SUBROUTINE phyetat0 439 440 !=================================================================== 441 FUNCTION phyetat0_get(nlev,field,name,descr,default) 442 !=================================================================== 443 ! Lecture d'un champ avec contrôle 444 ! Function logique dont le resultat indique si la lecture 445 ! s'est bien passée 446 ! On donne une valeur par defaut dans le cas contraire 447 !=================================================================== 448 449 USE iostart, ONLY : get_field 450 USE dimphy, only: klon 451 452 IMPLICIT NONE 453 INCLUDE "iniprint.h" 454 455 LOGICAL phyetat0_get 456 457 ! arguments 458 INTEGER,INTENT(IN) :: nlev 459 CHARACTER*(*),INTENT(IN) :: name,descr 460 REAL,INTENT(IN) :: default 461 REAL,DIMENSION(klon,nlev),INTENT(INOUT) :: field 462 463 ! Local variables 464 LOGICAL found 465 466 CALL get_field(name, field, found) 467 IF (.NOT. found) THEN 468 WRITE(lunout,*) "phyetat0: Le champ <",name,"> est absent" 469 WRITE(lunout,*) "Depart legerement fausse. Mais je continue" 470 field(:,:)=default 471 ENDIF 472 WRITE(lunout,*) name, descr, MINval(field),MAXval(field) 473 phyetat0_get=found 474 475 RETURN 476 END FUNCTION phyetat0_get 477 478 !================================================================ 479 FUNCTION phyetat0_srf(nlev,field,name,descr,default) 480 !=================================================================== 481 ! Lecture d'un champ par sous-surface avec contrôle 482 ! Function logique dont le resultat indique si la lecture 483 ! s'est bien passée 484 ! On donne une valeur par defaut dans le cas contraire 485 !=================================================================== 486 487 USE iostart, ONLY : get_field 488 USE dimphy, only: klon 489 USE indice_sol_mod, only: nbsrf 490 491 IMPLICIT NONE 492 INCLUDE "iniprint.h" 493 494 LOGICAL phyetat0_srf 495 ! arguments 496 INTEGER,INTENT(IN) :: nlev 497 CHARACTER*(*),INTENT(IN) :: name,descr 498 REAL,INTENT(IN) :: default 499 REAL,DIMENSION(klon,nlev,nbsrf),INTENT(INOUT) :: field 500 501 ! Local variables 502 LOGICAL found,phyetat0_get 503 INTEGER nsrf 504 CHARACTER*2 str2 505 506 IF (nbsrf.GT.99) THEN 507 WRITE(lunout,*) "Trop de sous-mailles" 508 call abort_gcm("phyetat0", "", 1) 509 ENDIF 510 511 DO nsrf = 1, nbsrf 512 WRITE(str2, '(i2.2)') nsrf 513 found= phyetat0_get(nlev,field(:,:, nsrf), & 514 name//str2,descr//" srf:"//str2,default) 515 ENDDO 516 517 phyetat0_srf=found 518 519 RETURN 520 END FUNCTION phyetat0_srf 521 -
LMDZ5/branches/testing/libf/phylmd/phyredem.F90
r2258 r2298 36 36 REAL tsoil(klon, nsoilmx, nbsrf) 37 37 REAL qsurf(klon, nbsrf) 38 REAL qsol(klon)39 38 REAL snow(klon, nbsrf) 40 REAL evap(klon, nbsrf)41 39 real fder(klon) 42 REAL frugs(klon, nbsrf)43 REAL agesno(klon, nbsrf)44 40 REAL run_off_lic_0(klon) 45 41 REAL trs(klon, nbtr) … … 60 56 ! Get variables which will be written to restart file from module 61 57 ! pbl_surface_mod 62 CALL pbl_surface_final(qsol, fder, snow, qsurf, & 63 evap, frugs, agesno, tsoil) 58 CALL pbl_surface_final(fder, snow, qsurf, tsoil) 64 59 65 60 ! Get a variable calculated in module fonte_neige_mod … … 190 185 IF (nsrf.LE.99) THEN 191 186 WRITE(str2, '(i2.2)') nsrf 192 CALL put_field("ALBE"//str2, "albedo de surface No."//str2, &193 falb1(:, nsrf))194 ELSE195 PRINT*, "Trop de sous-mailles"196 call abort_gcm("phyredem", "", 1)197 ENDIF198 ENDDO199 200 DO nsrf = 1, nbsrf201 IF (nsrf.LE.99) THEN202 WRITE(str2, '(i2.2)') nsrf203 CALL put_field("ALBLW"//str2, "albedo LW de surface No."//str2, &204 falb2(:, nsrf))205 ELSE206 PRINT*, "Trop de sous-mailles"207 call abort_gcm("phyredem", "", 1)208 ENDIF209 ENDDO210 211 DO nsrf = 1, nbsrf212 IF (nsrf.LE.99) THEN213 WRITE(str2, '(i2.2)') nsrf214 187 CALL put_field("EVAP"//str2, "Evaporation de surface No."//str2 & 215 , evap(:, nsrf))188 , fevap(:, nsrf)) 216 189 ELSE 217 190 PRINT*, "Trop de sous-mailles" … … 248 221 IF (nsrf.LE.99) THEN 249 222 WRITE(str2, '(i2.2)') nsrf 250 CALL put_field("RUG"//str2, "rugosite de surface No."//str2, & 251 frugs(:, nsrf)) 223 CALL put_field("Z0m"//str2, "rugosite de surface No."//str2, & 224 z0m(:, nsrf)) 225 CALL put_field("Z0h"//str2, "rugosite de surface No."//str2, & 226 z0h(:, nsrf)) 252 227 ELSE 253 228 PRINT*, "Trop de sous-mailles" … … 291 266 292 267 CALL put_field("VANCIEN", "", v_ancien) 293 294 CALL put_field("RUGMER", "Longueur de rugosite sur mer", &295 frugs(:, is_oce))296 268 297 269 CALL put_field("CLWCON", "Eau liquide convective", clwcon) … … 313 285 CALL put_field("TKE"//str2, "Energ. Cineti. Turb."//str2, & 314 286 pbl_tke(:, 1:klev+1, nsrf)) 287 CALL put_field("DELTATKE"//str2, "Del TKE wk/env."//str2, & 288 wake_delta_pbl_tke(:, 1:klev+1, nsrf)) 315 289 ELSE 316 290 PRINT*, "Trop de sous-mailles" … … 363 337 CALL traclmdz_to_restart(trs) 364 338 DO it=1, nbtr 365 iiq=niadv(it+2) 339 !! iiq=niadv(it+2) ! jyg 340 iiq=niadv(it+nqo) ! jyg 366 341 CALL put_field("trs_"//tname(iiq), "", trs(:, it)) 367 342 END DO -
LMDZ5/branches/testing/libf/phylmd/phys_local_var_mod.F90
r2220 r2298 239 239 REAL,ALLOCATABLE,SAVE,DIMENSION(:) :: cdragm, cdragh 240 240 !$OMP THREADPRIVATE(cdragm, cdragh) 241 REAL,ALLOCATABLE,SAVE,DIMENSION(:) :: cldh, cldl, cldm, cldq, cldt, qsat2m , qsol242 !$OMP THREADPRIVATE(cldh, cldl, cldm, cldq, cldt, qsat2m , qsol)241 REAL,ALLOCATABLE,SAVE,DIMENSION(:) :: cldh, cldl, cldm, cldq, cldt, qsat2m 242 !$OMP THREADPRIVATE(cldh, cldl, cldm, cldq, cldt, qsat2m ) 243 243 REAL,ALLOCATABLE,SAVE,DIMENSION(:) :: cldhjn, cldljn, cldmjn,cldtjn 244 244 !$OMP THREADPRIVATE(cldhjn, cldljn, cldmjn, cldtjn) … … 265 265 REAL,ALLOCATABLE,SAVE,DIMENSION(:) :: zxfqcalving 266 266 !$OMP THREADPRIVATE(zxfqcalving) 267 REAL,ALLOCATABLE,SAVE,DIMENSION(:) :: zxfluxlat, zx rugs, zxtsol, snow_lsc, zxfqfonte268 !$OMP THREADPRIVATE(zxfluxlat, zx rugs, zxtsol, snow_lsc, zxfqfonte)267 REAL,ALLOCATABLE,SAVE,DIMENSION(:) :: zxfluxlat, zxtsol, snow_lsc, zxfqfonte 268 !$OMP THREADPRIVATE(zxfluxlat, zxtsol, snow_lsc, zxfqfonte) 269 269 REAL,ALLOCATABLE,SAVE,DIMENSION(:) :: zxqsurf, rain_lsc 270 270 !$OMP THREADPRIVATE(zxqsurf, rain_lsc) … … 328 328 REAL,ALLOCATABLE,SAVE,DIMENSION(:,:) :: fsolsw, wfbils, wfbilo 329 329 !$OMP THREADPRIVATE(fsolsw, wfbils, wfbilo) 330 REAL,ALLOCATABLE,SAVE,DIMENSION(:,:) :: t2m, f evap, fluxlat, fsollw,evap_pot331 !$OMP THREADPRIVATE(t2m, f evap, fluxlat, fsollw,evap_pot)330 REAL,ALLOCATABLE,SAVE,DIMENSION(:,:) :: t2m, fluxlat, fsollw,evap_pot 331 !$OMP THREADPRIVATE(t2m, fluxlat, fsollw,evap_pot) 332 332 REAL,ALLOCATABLE,SAVE,DIMENSION(:,:) :: dnwd, dnwd0, upwd, omega 333 333 !$OMP THREADPRIVATE(dnwd, dnwd0, upwd, omega) … … 343 343 REAL,ALLOCATABLE,SAVE,DIMENSION(:,:) :: wake_omg, zx_rh 344 344 !$OMP THREADPRIVATE(wake_omg, zx_rh) 345 REAL,ALLOCATABLE,SAVE,DIMENSION(:,:) :: frugs, agesno346 !$OMP THREADPRIVATE(frugs, agesno)347 345 REAL,ALLOCATABLE,SAVE,DIMENSION(:,:) :: pmflxr, pmflxs, prfl, psfl, fraca 348 346 !$OMP THREADPRIVATE(pmflxr, pmflxs, prfl, psfl, fraca) … … 501 499 ALLOCATE(ale_wake(klon), alp_wake(klon), bils(klon)) 502 500 ALLOCATE(cdragm(klon), cdragh(klon), cldh(klon), cldl(klon)) 503 ALLOCATE(cldm(klon), cldq(klon), cldt(klon), qsat2m(klon) , qsol(klon))501 ALLOCATE(cldm(klon), cldq(klon), cldt(klon), qsat2m(klon)) 504 502 ALLOCATE(cldhjn(klon), cldljn(klon), cldmjn(klon), cldtjn(klon)) 505 503 ALLOCATE(JrNt(klon)) … … 516 514 ALLOCATE(slab_wfbils(klon), tpot(klon), tpote(klon), ue(klon)) 517 515 ALLOCATE(uq(klon), ve(klon), vq(klon), zxffonte(klon)) 518 ALLOCATE(zxfqcalving(klon), zxfluxlat(klon) , zxrugs(klon))516 ALLOCATE(zxfqcalving(klon), zxfluxlat(klon)) 519 517 ALLOCATE(zxtsol(klon), snow_lsc(klon), zxfqfonte(klon), zxqsurf(klon)) 520 518 ALLOCATE(rain_lsc(klon)) … … 557 555 ALLOCATE(pmfd(klon, klev), pmfu(klon, klev)) 558 556 559 ALLOCATE(t2m(klon, nbsrf), f evap(klon, nbsrf), fluxlat(klon, nbsrf))560 ALLOCATE(f rugs(klon, nbsrf), agesno(klon, nbsrf), fsollw(klon, nbsrf))557 ALLOCATE(t2m(klon, nbsrf), fluxlat(klon, nbsrf)) 558 ALLOCATE(fsollw(klon, nbsrf)) 561 559 ALLOCATE(fsolsw(klon, nbsrf), wfbils(klon, nbsrf), wfbilo(klon, nbsrf)) 562 560 ALLOCATE(evap_pot(klon, nbsrf)) … … 701 699 DEALLOCATE(ale_wake, alp_wake, bils) 702 700 DEALLOCATE(cdragm, cdragh, cldh, cldl) 703 DEALLOCATE(cldm, cldq, cldt, qsat2m , qsol)701 DEALLOCATE(cldm, cldq, cldt, qsat2m) 704 702 DEALLOCATE(cldljn, cldmjn, cldhjn, cldtjn, JrNt) 705 703 DEALLOCATE(dthmin, evap, fder, plcl, plfc) … … 714 712 DEALLOCATE(slab_wfbils, tpot, tpote, ue) 715 713 DEALLOCATE(uq, ve, vq, zxffonte) 716 DEALLOCATE(zxfqcalving, zxfluxlat , zxrugs)714 DEALLOCATE(zxfqcalving, zxfluxlat) 717 715 DEALLOCATE(zxtsol, snow_lsc, zxfqfonte, zxqsurf) 718 716 DEALLOCATE(rain_lsc) … … 755 753 DEALLOCATE(pmfd, pmfu) 756 754 757 DEALLOCATE(t2m, f evap, fluxlat)758 DEALLOCATE(f rugs, agesno, fsollw, evap_pot)755 DEALLOCATE(t2m, fluxlat) 756 DEALLOCATE(fsollw, evap_pot) 759 757 DEALLOCATE(fsolsw, wfbils, wfbilo) 760 758 -
LMDZ5/branches/testing/libf/phylmd/phys_output_ctrlout_mod.F90
r2220 r2298 74 74 ctrl_out((/ 10, 6, 10, 10, 10, 10, 11, 11, 11 /), & 75 75 't2m_sic', "Temp 2m "//clnsurf(4), "K", (/ ('', i=1, 9) /)) /) 76 77 TYPE(ctrl_out), SAVE :: o_gusts = ctrl_out((/ 1, 1, 1, 10, 10, 10, 11, 11, 11 /), & 78 'gusts', 'surface gustiness', 'm2/s2', (/ ('', i=1, 9) /)) 76 79 77 80 TYPE(ctrl_out), SAVE :: o_wind10m = ctrl_out((/ 1, 1, 1, 10, 10, 10, 11, 11, 11 /), & … … 541 544 TYPE(ctrl_out), SAVE :: o_proba_notrig = ctrl_out((/ 1, 1, 1, 6, 10, 10, 11, 11, 11 /), & 542 545 'proba_notrig', & 543 'Probabilit é de non-déclenchement', ' ', (/ ('', i=1, 9) /))546 'Probabilite de non-declenchement', ' ', (/ ('', i=1, 9) /)) 544 547 TYPE(ctrl_out), SAVE :: o_random_notrig = ctrl_out((/ 1, 1, 1, 6, 10, 10, 11, 11, 11 /), & 545 548 'random_notrig', & 546 'Tirage al éatoire de non-déclenchement', ' ', (/ ('', i=1, 9) /))549 'Tirage aleatoire de non-declenchement', ' ', (/ ('', i=1, 9) /)) 547 550 TYPE(ctrl_out), SAVE :: o_ale_bl_stat = ctrl_out((/ 1, 1, 1, 6, 10, 10, 11, 11, 11 /), & 548 551 'ale_bl_stat', & … … 601 604 602 605 TYPE(ctrl_out), SAVE, DIMENSION(7) :: o_wSTDlevs = (/ & 603 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'w850', "Vertical wind 1hPa", "Pa/s", &606 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'w850', "Vertical wind 850hPa", "Pa/s", & 604 607 (/ 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)' /)), & 605 608 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'w700', "Vertical wind 700hPa", "Pa/s", & … … 617 620 618 621 TYPE(ctrl_out), SAVE, DIMENSION(7) :: o_tSTDlevs = (/ & 619 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'t850', "Temperature 1hPa", "K", &622 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'t850', "Temperature 850hPa", "K", & 620 623 (/ 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)' /)), & 621 624 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'t700', "Temperature 700hPa", "K", & … … 633 636 634 637 TYPE(ctrl_out), SAVE, DIMENSION(7) :: o_qSTDlevs = (/ & 635 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'q850', "Specific humidity 1hPa", &638 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'q850', "Specific humidity 850hPa", & 636 639 "kg/kg", (/ 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)' /)), & 637 640 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'q700', "Specific humidity 700hPa", & … … 649 652 650 653 TYPE(ctrl_out), SAVE, DIMENSION(7) :: o_zSTDlevs = (/ & 651 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'z850', "Geopotential height 1hPa", &654 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'z850', "Geopotential height 850hPa", & 652 655 "m", (/ 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)' /)), & 653 656 ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'z700', "Geopotential height 700hPa", & … … 776 779 TYPE(ctrl_out), SAVE :: o_dtsvdfi = ctrl_out((/ 10, 10, 10, 10, 10, 10, 11, 11, 11 /), & 777 780 'dtsvdfi', 'Boundary-layer dTs(g)', 'K/s', (/ ('', i=1, 9) /)) 778 TYPE(ctrl_out), SAVE :: o_rugs = ctrl_out((/ 10, 10, 10, 10, 10, 10, 11, 11, 11 /), & 779 'rugs', 'rugosity', '-', (/ ('', i=1, 9) /)) 781 TYPE(ctrl_out), SAVE :: o_z0m = ctrl_out((/ 10, 10, 10, 10, 10, 10, 11, 11, 11 /), & 782 'z0m', 'roughness length, momentum', '-', (/ ('', i=1, 9) /)) 783 TYPE(ctrl_out), SAVE :: o_z0h = ctrl_out((/ 10, 10, 10, 10, 10, 10, 11, 11, 11 /), & 784 'z0h', 'roughness length, enthalpy', '-', (/ ('', i=1, 9) /)) 780 785 TYPE(ctrl_out), SAVE :: o_topswad = ctrl_out((/ 2, 10, 10, 10, 10, 10, 11, 11, 11 /), & 781 786 'topswad', 'ADE at TOA', 'W/m2', (/ ('', i=1, 9) /)) … … 1021 1026 ctrl_out((/ 3, 10, 10, 10, 10, 10, 11, 11, 11 /),'snow_sic',"Snow", "kg/m2", (/ ('', i=1, 9) /)) /) 1022 1027 1023 TYPE(ctrl_out), SAVE, DIMENSION(4) :: o_rugs_srf = (/ & 1024 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'rugs_ter', "Surface roughness "//clnsurf(1),"m", (/ ('', i=1, 9) /)), & 1025 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'rugs_lic', "Surface roughness "//clnsurf(2),"m", (/ ('', i=1, 9) /)), & 1026 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'rugs_oce', "Surface roughness "//clnsurf(3),"m", (/ ('', i=1, 9) /)), & 1027 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'rugs_sic', "Surface roughness "//clnsurf(4),"m", (/ ('', i=1, 9) /)) /) 1028 TYPE(ctrl_out), SAVE, DIMENSION(4) :: o_z0m_srf = (/ & 1029 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'z0m_ter', "Surface roughness "//clnsurf(1),"m", (/ ('', i=1, 9) /)), & 1030 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'z0m_lic', "Surface roughness "//clnsurf(2),"m", (/ ('', i=1, 9) /)), & 1031 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'z0m_oce', "Surface roughness "//clnsurf(3),"m", (/ ('', i=1, 9) /)), & 1032 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'z0m_sic', "Surface roughness "//clnsurf(4),"m", (/ ('', i=1, 9) /)) /) 1033 1034 TYPE(ctrl_out), SAVE, DIMENSION(4) :: o_z0h_srf = (/ & 1035 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'z0h_ter', "Surface roughness "//clnsurf(1),"m", (/ ('', i=1, 9) /)), & 1036 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'z0h_lic', "Surface roughness "//clnsurf(2),"m", (/ ('', i=1, 9) /)), & 1037 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'z0h_oce', "Surface roughness "//clnsurf(3),"m", (/ ('', i=1, 9) /)), & 1038 ctrl_out((/ 3, 6, 10, 10, 10, 10, 11, 11, 11 /),'z0h_sic', "Surface roughness "//clnsurf(4),"m", (/ ('', i=1, 9) /)) /) 1028 1039 1029 1040 TYPE(ctrl_out), SAVE :: o_alb1 = ctrl_out((/ 3, 10, 10, 10, 10, 10, 11, 11, 11 /), & -
LMDZ5/branches/testing/libf/phylmd/phys_output_write_mod.F90
r2220 r2298 32 32 o_t2m_min_mon, o_t2m_max_mon, & 33 33 o_q2m, o_ustar, o_u10m, o_v10m, & 34 o_wind10m, o_wind10max, o_ sicf, &34 o_wind10m, o_wind10max, o_gusts, o_sicf, & 35 35 o_psol, o_mass, o_qsurf, o_qsol, & 36 36 o_precip, o_ndayrain, o_plul, o_pluc, & … … 88 88 o_SWdownOR, o_LWdownOR, o_snowl, & 89 89 o_solldown, o_dtsvdfo, o_dtsvdft, & 90 o_dtsvdfg, o_dtsvdfi, o_ rugs, o_od550aer, &90 o_dtsvdfg, o_dtsvdfi, o_z0m, o_z0h, o_od550aer, & 91 91 o_od865aer, o_absvisaer, o_od550lt1aer, & 92 92 o_sconcso4, o_sconcno3, o_sconcoa, o_sconcbc, & … … 113 113 o_zfull, o_zhalf, o_rneb, o_rnebjn, o_rnebcon, & 114 114 o_rnebls, o_rhum, o_ozone, o_ozone_light, & 115 o_dtphy, o_dqphy, o_albe_srf, o_ rugs_srf, &115 o_dtphy, o_dqphy, o_albe_srf, o_z0m_srf, o_z0h_srf, & 116 116 o_ages_srf, o_snow_srf, o_alb1, o_alb2, o_tke, & 117 117 o_tke_max, o_kz, o_kz_max, o_clwcon, & … … 154 154 155 155 USE phys_state_var_mod, only: pctsrf, paire_ter, rain_fall, snow_fall, & 156 qsol, z0m, z0h, fevap, agesno, & 156 157 nday_rain, rain_con, snow_con, & 157 158 topsw, toplw, toplw0, swup, swdn, & … … 159 160 SWdn200, SWdn200clr, LWup200, LWup200clr, & 160 161 LWdn200, LWdn200clr, solsw, solsw0, sollw, & 161 radsol, sollw0, sollwdown, sollw, &162 radsol, sollw0, sollwdown, sollw, gustiness, & 162 163 sollwdownclr, lwdn0, ftsol, ustar, u10m, & 163 164 v10m, pbl_tke, wake_delta_pbl_TKE, & … … 173 174 vqsumSTD, vTsumSTD, O3daysumSTD, wqsumSTD, & 174 175 vphisumSTD, wTsumSTD, u2sumSTD, v2sumSTD, & 175 T2sumSTD, nlevSTD, du_gwd_rando, dv_gwd_rando 176 T2sumSTD, nlevSTD, du_gwd_rando, dv_gwd_rando, & 177 ulevSTD, vlevSTD, wlevSTD, philevSTD, qlevSTD, tlevSTD, & 178 rhlevSTD, O3STD, O3daySTD, uvSTD, vqSTD, vTSTD, wqSTD, & 179 vphiSTD, wTSTD, u2STD, v2STD, T2STD, missing_val_nf90 176 180 177 181 USE phys_local_var_mod, only: zxfluxlat, slp, zxtsol, zt2m, & 178 t2m_min_mon, t2m_max_mon, &179 zu10m, zv10m, zq2m, zustar, zxqsurf, qsol,&180 rain_lsc, snow_lsc, evap,bils, sens, fder, &182 t2m_min_mon, t2m_max_mon, evap, & 183 zu10m, zv10m, zq2m, zustar, zxqsurf, & 184 rain_lsc, snow_lsc, bils, sens, fder, & 181 185 zxffonte, zxfqcalving, zxfqfonte, fluxu, & 182 186 fluxv, zxsnow, qsnow, snowhgt, to_ice, & 183 187 sissnow, runoff, albsol3_lic, evap_pot, & 184 t2m, f evap, fluxt, fluxlat, fsollw, fsolsw, &188 t2m, fluxt, fluxlat, fsollw, fsolsw, & 185 189 wfbils, wfbilo, cdragm, cdragh, cldl, cldm, & 186 190 cldh, cldt, JrNt, cldljn, cldmjn, cldhjn, & … … 197 201 weak_inversion, dthmin, cldtau, cldemi, & 198 202 pmflxr, pmflxs, prfl, psfl, re, fl, rh2m, & 199 qsat2m, tpote, tpot, d_ts, zxrugs,od550aer, &203 qsat2m, tpote, tpot, d_ts, od550aer, & 200 204 od865aer, absvisaer, od550lt1aer, sconcso4, sconcno3, & 201 205 sconcoa, sconcbc, sconcss, sconcdust, concso4, concno3, & … … 211 215 lcc, lcc3d, lcc3dcon, lcc3dstra, reffclwtop, & 212 216 ec550aer, flwc, fiwc, t_seri, theta, q_seri, & 213 ql_seri, zphi, u_seri, v_seri, omega, cldfra, & 214 rneb, rnebjn, zx_rh, frugs, agesno, d_t_dyn, d_q_dyn, & 217 !jyg< 218 !! ql_seri, zphi, u_seri, v_seri, omega, cldfra, & 219 ql_seri, tr_seri, & 220 zphi, u_seri, v_seri, omega, cldfra, & 221 !>jyg 222 rneb, rnebjn, zx_rh, d_t_dyn, d_q_dyn, & 215 223 d_u_dyn, d_v_dyn, d_t_con, d_t_ajsb, d_t_ajs, & 216 224 d_u_ajs, d_v_ajs, & … … 243 251 ! ug Pour les sorties XIOS 244 252 USE xios, ONLY: xios_update_calendar 245 USE wxios, only: wxios_closedef 253 USE wxios, only: wxios_closedef, missing_val 246 254 #endif 247 255 USE phys_cal_mod, only : mth_len … … 289 297 INTEGER, DIMENSION(iim*jjmp1*klev) :: ndex3d 290 298 REAL, PARAMETER :: dobson_u = 2.1415e-05 ! Dobson unit, in kg m-2 291 REAL, PARAMETER :: missing_val=nf90_fill_real 299 ! REAL, PARAMETER :: missing_val=nf90_fill_real 300 #ifndef CPP_XIOS 301 REAL :: missing_val 302 #endif 292 303 REAL, PARAMETER :: un_jour=86400. 293 304 … … 354 365 ENDIF 355 366 CALL histwrite_phy(o_wind10max, zx_tmp_fi2d) 367 368 CALL histwrite_phy(o_gusts, gustiness) 356 369 357 370 IF (vars_defined) THEN … … 566 579 ENDIF 567 580 !jyg< 568 IF (iflag_pbl > 1 ) THEN581 IF (iflag_pbl > 1 .AND. iflag_wake>=1 .AND. iflag_pbl_split >=1) THEN 569 582 CALL histwrite_phy(o_dltpbltke_srf(nsrf), wake_delta_pbl_TKE(:,1:klev,nsrf)) 570 583 ENDIF … … 655 668 ! ENDIF 656 669 670 #ifdef CPP_IOIPSL 671 #ifndef CPP_XIOS 672 IF (.NOT.ok_all_xml) THEN 657 673 ! ATTENTION, LES ANCIENS HISTWRITE ONT ETES CONSERVES EN ATTENDANT MIEUX: 658 674 ! Champs interpolles sur des niveaux de pression 675 missing_val=missing_val_nf90 659 676 DO iff=1, nfiles 660 677 ll=0 … … 678 695 ENDDO 679 696 ENDDO 680 697 ENDIF 698 #endif 699 #endif 700 #ifdef CPP_XIOS 701 IF(ok_all_xml) THEN 702 !XIOS CALL xios_get_field_attr("u850",default_value=missing_val) 703 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 704 ll=0 705 DO k=1, nlevSTD 706 bb2=clevSTD(k) 707 IF(bb2.EQ."850".OR.bb2.EQ."700".OR. & 708 bb2.EQ."500".OR.bb2.EQ."200".OR. & 709 bb2.EQ."100".OR. & 710 bb2.EQ."50".OR.bb2.EQ."10") THEN 711 ll=ll+1 712 CALL histwrite_phy(o_uSTDlevs(ll),ulevSTD(:,k)) 713 CALL histwrite_phy(o_vSTDlevs(ll),vlevSTD(:,k)) 714 CALL histwrite_phy(o_wSTDlevs(ll),wlevSTD(:,k)) 715 CALL histwrite_phy(o_zSTDlevs(ll),philevSTD(:,k)) 716 CALL histwrite_phy(o_qSTDlevs(ll),qlevSTD(:,k)) 717 CALL histwrite_phy(o_tSTDlevs(ll),tlevSTD(:,k)) 718 ENDIF !(bb2.EQ."850".OR.bb2.EQ."700".OR. 719 ENDDO 720 ENDIF 721 #endif 681 722 IF (vars_defined) THEN 682 723 DO i=1, klon … … 720 761 CALL histwrite_phy(o_dqwak, zx_tmp_fi3d) 721 762 ENDIF ! iflag_wake>=1 722 CALL histwrite_phy(o_Vprecip, Vprecip)723 763 CALL histwrite_phy(o_ftd, ftd) 724 764 CALL histwrite_phy(o_fqd, fqd) 725 ELSEIF (iflag_con.EQ.30) THEN 765 ENDIF !(iflag_con.EQ.3) 766 IF (iflag_con.EQ.3.OR.iflag_con.EQ.30) THEN 726 767 ! sortie RomP convection descente insaturee iflag_con=30 768 ! etendue a iflag_con=3 (jyg) 727 769 CALL histwrite_phy(o_Vprecip, Vprecip) 728 770 CALL histwrite_phy(o_wdtrainA, wdtrainA) … … 808 850 CALL histwrite_phy(o_dtsvdfg, d_ts(:,is_lic)) 809 851 CALL histwrite_phy(o_dtsvdfi, d_ts(:,is_sic)) 810 CALL histwrite_phy(o_rugs, zxrugs) 852 CALL histwrite_phy(o_z0m, z0m(:,nbsrf+1)) 853 CALL histwrite_phy(o_z0h, z0h(:,nbsrf+1)) 811 854 ! OD550 per species 812 855 !--OLIVIER … … 973 1016 IF (vars_defined) zx_tmp_fi2d(1 : klon) = falb1( 1 : klon, nsrf) 974 1017 CALL histwrite_phy(o_albe_srf(nsrf), zx_tmp_fi2d) 975 IF (vars_defined) zx_tmp_fi2d(1 : klon) = frugs( 1 : klon, nsrf) 976 CALL histwrite_phy(o_rugs_srf(nsrf), zx_tmp_fi2d) 1018 IF (vars_defined) zx_tmp_fi2d(1 : klon) = z0m( 1 : klon, nsrf) 1019 CALL histwrite_phy(o_z0m_srf(nsrf), zx_tmp_fi2d) 1020 IF (vars_defined) zx_tmp_fi2d(1 : klon) = z0h( 1 : klon, nsrf) 1021 CALL histwrite_phy(o_z0h_srf(nsrf), zx_tmp_fi2d) 977 1022 IF (vars_defined) zx_tmp_fi2d(1 : klon) = agesno( 1 : klon, nsrf) 978 1023 CALL histwrite_phy(o_ages_srf(nsrf), zx_tmp_fi2d) … … 1267 1312 ENDIF 1268 1313 !!!!!!!!!!!! Sorties niveaux de pression NMC !!!!!!!!!!!!!!!!!!!! 1314 #ifdef CPP_IOIPSL 1315 #ifndef CPP_XIOS 1316 IF (.NOT.ok_all_xml) THEN 1317 ! ATTENTION, LES ANCIENS HISTWRITE ONT ETES CONSERVES EN ATTENDANT MIEUX: 1318 ! Champs interpolles sur des niveaux de pression 1319 missing_val=missing_val_nf90 1269 1320 DO iff=7, nfiles 1270 1321 … … 1330 1381 CALL histwrite_phy(o_TxT,T2sumSTD(:,:,iff-6),iff) 1331 1382 ENDDO !nfiles 1383 ENDIF 1384 #endif 1385 #endif 1386 #ifdef CPP_XIOS 1387 IF(ok_all_xml) THEN 1388 ! DO iff=7, nfiles 1389 1390 ! CALL histwrite_phy(o_tnondef,tnondef(:,:,3)) 1391 CALL histwrite_phy(o_ta,tlevSTD(:,:)) 1392 CALL histwrite_phy(o_zg,philevSTD(:,:)) 1393 CALL histwrite_phy(o_hus,qlevSTD(:,:)) 1394 CALL histwrite_phy(o_hur,rhlevSTD(:,:)) 1395 CALL histwrite_phy(o_ua,ulevSTD(:,:)) 1396 CALL histwrite_phy(o_va,vlevSTD(:,:)) 1397 CALL histwrite_phy(o_wap,wlevSTD(:,:)) 1398 ! IF(vars_defined) THEN 1399 ! DO k=1, nlevSTD 1400 ! DO i=1, klon 1401 ! IF(tnondef(i,k,3).NE.missing_val) THEN 1402 ! IF(freq_outNMC(iff-6).LT.0) THEN 1403 ! freq_moyNMC(iff-6)=(mth_len*un_jour)/freq_calNMC(iff-6) 1404 ! ELSE 1405 ! freq_moyNMC(iff-6)=freq_outNMC(iff-6)/freq_calNMC(iff-6) 1406 ! ENDIF 1407 ! zx_tmp_fi3d_STD(i,k) = (100.*tnondef(i,k,3))/freq_moyNMC(iff-6) 1408 ! ELSE 1409 ! zx_tmp_fi3d_STD(i,k) = missing_val 1410 ! ENDIF 1411 ! ENDDO 1412 ! ENDDO 1413 ! ENDIF 1414 ! CALL histwrite_phy(o_psbg,zx_tmp_fi3d_STD) 1415 IF(vars_defined) THEN 1416 DO k=1, nlevSTD 1417 DO i=1, klon 1418 IF(O3STD(i,k).NE.missing_val) THEN 1419 zx_tmp_fi3d_STD(i,k) = O3STD(i,k) * 1.e+9 1420 ELSE 1421 zx_tmp_fi3d_STD(i,k) = missing_val 1422 ENDIF 1423 ENDDO 1424 ENDDO !k=1, nlevSTD 1425 ENDIF 1426 CALL histwrite_phy(o_tro3,zx_tmp_fi3d_STD) 1427 if (read_climoz == 2) THEN 1428 IF(vars_defined) THEN 1429 DO k=1, nlevSTD 1430 DO i=1, klon 1431 IF(O3daySTD(i,k).NE.missing_val) THEN 1432 zx_tmp_fi3d_STD(i,k) = O3daySTD(i,k) * 1.e+9 1433 ELSE 1434 zx_tmp_fi3d_STD(i,k) = missing_val 1435 ENDIF 1436 ENDDO 1437 ENDDO !k=1, nlevSTD 1438 ENDIF 1439 CALL histwrite_phy(o_tro3_daylight,zx_tmp_fi3d_STD) 1440 endif 1441 CALL histwrite_phy(o_uxv,uvSTD(:,:)) 1442 CALL histwrite_phy(o_vxq,vqSTD(:,:)) 1443 CALL histwrite_phy(o_vxT,vTSTD(:,:)) 1444 CALL histwrite_phy(o_wxq,wqSTD(:,:)) 1445 CALL histwrite_phy(o_vxphi,vphiSTD(:,:)) 1446 CALL histwrite_phy(o_wxT,wTSTD(:,:)) 1447 CALL histwrite_phy(o_uxu,u2STD(:,:)) 1448 CALL histwrite_phy(o_vxv,v2STD(:,:)) 1449 CALL histwrite_phy(o_TxT,T2STD(:,:)) 1450 ! ENDDO !nfiles 1451 ENDIF 1452 #endif 1332 1453 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 1333 1454 IF (nqtot.GE.nqo+1) THEN … … 1335 1456 IF (type_trac == 'lmdz' .OR. type_trac == 'repr') THEN 1336 1457 1337 CALL histwrite_phy(o_trac(iq-nqo), qx(:,:,iq)) 1458 !jyg< 1459 !! CALL histwrite_phy(o_trac(iq-nqo), qx(:,:,iq)) 1460 CALL histwrite_phy(o_trac(iq-nqo), tr_seri(:,:,iq-nqo)) 1461 !>jyg 1338 1462 CALL histwrite_phy(o_dtr_vdf(iq-nqo),d_tr_cl(:,:,iq-nqo)) 1339 1463 CALL histwrite_phy(o_dtr_the(iq-nqo),d_tr_th(:,:,iq-nqo)) … … 1352 1476 IF(vars_defined) THEN 1353 1477 DO k=1,klev 1354 zx_tmp_fi2d(:)=zx_tmp_fi2d(:)+zmasse(:,k)*qx(:,k,iq) 1478 !jyg< 1479 !! zx_tmp_fi2d(:)=zx_tmp_fi2d(:)+zmasse(:,k)*qx(:,k,iq) 1480 zx_tmp_fi2d(:)=zx_tmp_fi2d(:)+zmasse(:,k)*tr_seri(:,k,iq-nqo) 1481 !>jyg 1355 1482 ENDDO 1356 1483 ENDIF -
LMDZ5/branches/testing/libf/phylmd/phys_state_var_mod.F90
r2258 r2298 10 10 ! Declaration des variables 11 11 USE dimphy 12 USE netcdf, only: nf90_fill_real 12 13 INTEGER, PARAMETER :: nlevSTD=17 13 14 INTEGER, PARAMETER :: nlevSTD8=8 … … 16 17 INTEGER, PARAMETER :: napisccp=1 17 18 INTEGER, SAVE :: radpas 19 REAL, PARAMETER :: missing_val_nf90=nf90_fill_real 18 20 !$OMP THREADPRIVATE(radpas) 19 21 REAL, SAVE :: dtime, solaire_etat0 … … 24 26 REAL, ALLOCATABLE, SAVE :: ftsol(:,:) 25 27 !$OMP THREADPRIVATE(ftsol) 28 REAL,ALLOCATABLE,SAVE :: qsol(:),fevap(:,:),z0m(:,:),z0h(:,:),agesno(:,:) 29 !$OMP THREADPRIVATE(qsol,fevap,z0m,z0h,agesno) 26 30 ! character(len=6), SAVE :: ocean 27 31 !!!!!!$OMP THREADPRIVATE(ocean) … … 304 308 REAL,ALLOCATABLE,SAVE :: sollwdown(:) 305 309 !$OMP THREADPRIVATE(sollwdown) 310 REAL,ALLOCATABLE,SAVE :: gustiness(:) 311 !$OMP THREADPRIVATE(gustiness) 306 312 REAL,ALLOCATABLE,SAVE :: sollwdownclr(:) 307 313 !$OMP THREADPRIVATE(sollwdownclr) … … 416 422 ALLOCATE(pctsrf(klon,nbsrf)) 417 423 ALLOCATE(ftsol(klon,nbsrf)) 424 ALLOCATE(qsol(klon),fevap(klon,nbsrf)) 425 ALLOCATE(z0m(klon,nbsrf+1),z0h(klon,nbsrf+1),agesno(klon,nbsrf)) 418 426 ALLOCATE(falb1(klon,nbsrf)) 419 427 ALLOCATE(falb2(klon,nbsrf)) … … 544 552 ALLOCATE(albplap(klon)) 545 553 ALLOCATE(solswp(klon), sollwp(klon)) 554 ALLOCATE(gustiness(klon)) 546 555 ALLOCATE(sollwdownp(klon)) 547 556 ALLOCATE(topsw0p(klon),toplw0p(klon)) … … 586 595 587 596 deallocate(rlat, rlon, pctsrf, ftsol, falb1, falb2) 597 deallocate(qsol,fevap,z0m,z0h,agesno) 588 598 deallocate(rain_fall, snow_fall, solsw, sollw, radsol) 589 599 deallocate(zmea, zstd, zsig, zgam) … … 664 674 deallocate(topsw, toplw) 665 675 deallocate(sollwdown, sollwdownclr) 676 deallocate(gustiness) 666 677 deallocate(toplwdown, toplwdownclr) 667 678 deallocate(topsw0,toplw0,solsw0,sollw0) -
LMDZ5/branches/testing/libf/phylmd/physiq.F90
r2258 r2298 47 47 use phyaqua_mod, only: zenang_an 48 48 USE control_mod 49 #ifdef CPP_XIOS 50 USE wxios, ONLY: missing_val, missing_val_omp 51 USE xios, ONLY: xios_get_field_attr 52 #endif 49 53 #ifdef REPROBUS 50 54 USE CHEM_REP, ONLY : Init_chem_rep_xjour … … 240 244 real da(klon,klev),phi(klon,klev,klev),mp(klon,klev) 241 245 real wght_cvfd(klon,klev) 246 #ifndef CPP_XIOS 247 REAL, SAVE :: missing_val 248 #endif 242 249 ! Variables pour le lessivage convectif 243 250 ! RomP >>> … … 316 323 SAVE top 317 324 !$OMP THREADPRIVATE(bas, top) 318 325 !------------------------------------------------------------------ 326 ! Upmost level reached by deep convection and related variable (jyg) 327 ! 328 INTEGER izero 329 INTEGER k_upper_cv 330 !------------------------------------------------------------------ 319 331 ! 320 332 !================================================================================================= … … 528 540 ! !par la masse/airetot (moyglo_pondaima) et la vraie masse (moyglo_pondmass) 529 541 ! 530 ! Variables locales 542 ! 543 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 544 ! Local variables 545 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 531 546 ! 532 547 REAL rhcl(klon,klev) ! humiditi relative ciel clair … … 570 585 REAL zx_t, zx_qs, zdelta, zcor, zlvdcp, zlsdcp 571 586 real zqsat(klon,klev) 587 ! 572 588 INTEGER i, k, iq, ig, j, nsrf, ll, l, iiq 589 ! 573 590 REAL t_coup 574 591 PARAMETER (t_coup=234.0) … … 885 902 igout=klon/2+1/klon 886 903 write(lunout,*) 'DEBUT DE PHYSIQ !!!!!!!!!!!!!!!!!!!!' 904 write(lunout,*) 'igout, rlat, rlon ',igout, rlatd(igout)*180./3.141593, rlond(igout)*180./3.141593 887 905 write(lunout,*) & 888 906 'nlon,klev,nqtot,debut,lafin, jD_cur, jH_cur,pdtphys' … … 904 922 905 923 if (first) then 906 924 907 925 !CR:nvelles variables convection/poches froides 908 926 … … 957 975 pde_u(:,:) = 0. 958 976 aam=0. 977 978 alp_bl_conv(:)=0. 959 979 960 980 torsfc=0. … … 1332 1352 END IF 1333 1353 ! 1334 !1335 1354 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 1336 1355 ! Nouvelle initialisation pour le rayonnement RRTM … … 1413 1432 ! 1414 1433 CALL change_srf_frac(itap, dtime, days_elapsed+1, & 1415 !albedo SB >>> 1416 ! pctsrf, falb1, falb2, ftsol, ustar, u10m, v10m, pbl_tke) 1417 pctsrf, falb_dir, falb_dif, ftsol, ustar, u10m, v10m, pbl_tke) 1418 !albedo SB <<< 1434 pctsrf, fevap, z0m, z0h, agesno, & 1435 falb_dir, falb_dif, ftsol, ustar, u10m, v10m, pbl_tke) 1419 1436 1420 1437 ! Update time and other variables in Reprobus … … 1547 1564 ENDDO 1548 1565 !!! RomP >>> td dyn traceur 1549 IF (nqtot.GE.3) THEN 1550 DO iq = 3, nqtot 1566 !! IF (nqtot.GE.3) THEN ! jyg 1567 !! DO iq = 3, nqtot ! jyg 1568 IF (nqtot.GE.nqo+1) THEN ! jyg 1569 DO iq = nqo+1, nqtot ! jyg 1551 1570 DO k = 1, klev 1552 1571 DO i = 1, klon 1553 d_tr_dyn(i,k,iq-2)= & 1554 (tr_seri(i,k,iq-2)-tr_ancien(i,k,iq-2))/dtime 1572 !! d_tr_dyn(i,k,iq-2)= & ! jyg 1573 !! (tr_seri(i,k,iq-2)-tr_ancien(i,k,iq-2))/dtime ! jyg 1574 d_tr_dyn(i,k,iq-nqo)= & ! jyg 1575 (tr_seri(i,k,iq-nqo)-tr_ancien(i,k,iq-nqo))/dtime ! jyg 1555 1576 ! iiq=niadv(iq) 1556 ! print*,i,k," d_tr_dyn",d_tr_dyn(i,k,iq- 2),"tra:",iq,tname(iiq)1577 ! print*,i,k," d_tr_dyn",d_tr_dyn(i,k,iq-nqo),"tra:",iq,tname(iiq) 1557 1578 ENDDO 1558 1579 ENDDO … … 1570 1591 ENDDO 1571 1592 !!! RomP >>> td dyn traceur 1572 IF (nqtot.GE.3) THEN 1573 DO iq = 3, nqtot 1593 !! IF (nqtot.GE.3) THEN ! jyg 1594 !! DO iq = 3, nqtot ! jyg 1595 IF (nqtot.GE.nqo+1) THEN ! jyg 1596 DO iq = nqo+1, nqtot ! jyg 1574 1597 DO k = 1, klev 1575 1598 DO i = 1, klon 1576 d_tr_dyn(i,k,iq-2)= 0.0 1599 !! d_tr_dyn(i,k,iq-2)= 0.0 ! jyg 1600 d_tr_dyn(i,k,iq-nqo)= 0.0 ! jyg 1577 1601 ENDDO 1578 1602 ENDDO … … 1809 1833 ! s_capCL, s_oliqCL, s_cteiCL,s_pblT, 1810 1834 ! s_therm, s_trmb1, s_trmb2, s_trmb3, 1811 ! z xrugs, zu10m, zv10m, fder,1835 ! zu10m, zv10m, fder, 1812 1836 ! zxqsurf, rh2m, zxfluxu, zxfluxv, 1813 1837 ! frugs, agesno, fsollw, fsolsw, … … 1841 1865 !>jyg+nrlmd 1842 1866 ! 1867 !-------gustiness calculation-------! 1868 IF (iflag_gusts==0) THEN 1869 gustiness(1:klon)=0 1870 ELSE IF (iflag_gusts==1) THEN 1871 do i = 1, klon 1872 gustiness(i)=f_gust_bl*ale_bl(i)+f_gust_wk*ale_wake(i) 1873 enddo 1874 ! ELSE IF (iflag_gusts==2) THEN 1875 ! do i = 1, klon 1876 ! gustiness(i)=f_gust_bl*ale_bl(i)+sigma_wk(i)*f_gust_wk*ale_wake(i) !! need to make sigma_wk accessible here 1877 ! enddo 1878 ! ELSE IF (iflag_gusts==3) THEN 1879 ! do i = 1, klon 1880 ! gustiness(i)=f_gust_bl*alp_bl(i)+f_gust_wk*alp_wake(i) 1881 ! enddo 1882 ENDIF 1883 1884 1885 1843 1886 CALL pbl_surface( & 1844 1887 dtime, date0, itap, days_elapsed+1, & … … 1847 1890 zsig, sollwdown, pphi, cldt, & 1848 1891 rain_fall, snow_fall, solsw, sollw, & 1892 gustiness, & 1849 1893 t_seri, q_seri, u_seri, v_seri, & 1850 1894 !nrlmd+jyg< … … 1852 1896 !>nrlmd+jyg 1853 1897 pplay, paprs, pctsrf, & 1854 !albedo SB >>>1855 ! ftsol,falb1,falb2,ustar,u10m,v10m,wstar, &1856 1898 ftsol,SFRWL,falb_dir,falb_dif,ustar,u10m,v10m,wstar, & 1857 1899 !albedo SB <<< … … 1882 1924 s_capCL, s_oliqCL, s_cteiCL,s_pblT, & 1883 1925 s_therm, s_trmb1, s_trmb2, s_trmb3, & 1884 z xrugs, zustar, zu10m, zv10m, fder, &1926 zustar, zu10m, zv10m, fder, & 1885 1927 zxqsurf, rh2m, zxfluxu, zxfluxv, & 1886 frugs, agesno, fsollw, fsolsw, &1928 z0m, z0h, agesno, fsollw, fsolsw, & 1887 1929 d_ts, fevap, fluxlat, t2m, & 1888 1930 wfbils, wfbilo, fluxt, fluxu, fluxv, & … … 2151 2193 ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 2152 2194 ! Estimation d'une vitesse verticale effective pour ALP 2195 if (1==0) THEN 2153 2196 www(1:klon)=0. 2154 2197 do k=2,klev-1 … … 2166 2209 if (www(i)>0. .and. ale_bl(i)>0. ) www(i)=www(i)/ale_bl(i) 2167 2210 enddo 2211 ENDIF 2168 2212 2169 2213 … … 2178 2222 ALP(i) = alp_wake(i) + Alp_bl(i) + alp_offset ! modif sb 2179 2223 else 2224 abort_message ='Ne pas passer la car www non calcule' 2225 CALL abort_gcm (modname,abort_message,1) 2180 2226 2181 2227 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! … … 2222 2268 ! 2223 2269 IF (ok_cvl) THEN ! new driver for convectL 2224 2270 ! 2271 !jyg< 2272 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 2273 ! Calculate the upmost level of deep convection loops: k_upper_cv 2274 ! (near 22 km) 2275 izero = klon/2+1/klon 2276 k_upper_cv = klev 2277 DO k = klev,1,-1 2278 IF (pphi(izero,k) > 22.e4) k_upper_cv = k 2279 ENDDO 2280 IF (prt_level .ge. 5) THEN 2281 Print *, 'upmost level of deep convection loops: k_upper_cv = ',k_upper_cv 2282 ENDIF 2283 ! 2284 !>jyg 2225 2285 IF (type_trac == 'repr') THEN 2226 2286 nbtr_tmp=ntra … … 2231 2291 !c CALL concvl (iflag_con,iflag_clos, 2232 2292 CALL concvl (iflag_clos, & 2233 dtime, paprs,pplay,t_undi,q_undi, &2293 dtime, paprs, pplay, k_upper_cv, t_undi,q_undi, & 2234 2294 t_wake,q_wake,wake_s, & 2235 2295 u_seri,v_seri,tr_seri,nbtr_tmp, & … … 3382 3442 !albedo SB <<< 3383 3443 3384 !albedo SB >>>3385 ! DO i = 1, klon3386 ! albsol1(i) = falb1(i,is_oce) * pctsrf(i,is_oce) &3387 ! + falb1(i,is_lic) * pctsrf(i,is_lic) &3388 ! + falb1(i,is_ter) * pctsrf(i,is_ter) &3389 ! + falb1(i,is_sic) * pctsrf(i,is_sic)3390 ! albsol2(i) = falb2(i,is_oce) * pctsrf(i,is_oce) &3391 ! + falb2(i,is_lic) * pctsrf(i,is_lic) &3392 ! + falb2(i,is_ter) * pctsrf(i,is_ter) &3393 ! + falb2(i,is_sic) * pctsrf(i,is_sic)3394 ! ENDDO3395 !albedo SB <<<3396 3444 3397 3445 if (mydebug) then … … 3935 3983 !IM Interpolation sur les niveaux de pression du NMC 3936 3984 ! ------------------------------------------------- 3985 #ifdef CPP_XIOS 3986 !$OMP MASTER 3987 !On recupere la valeur de la missing value donnee dans le xml 3988 CALL xios_get_field_attr("t850",default_value=missing_val_omp) 3989 ! PRINT *,"ARNAUD value missing ",missing_val_omp 3990 !$OMP END MASTER 3991 !$OMP BARRIER 3992 missing_val=missing_val_omp 3993 #endif 3994 #ifndef CPP_XIOS 3995 missing_val=missing_val_nf90 3996 #endif 3937 3997 ! 3938 3998 include "calcul_STDlev.h" … … 4313 4373 ENDDO 4314 4374 RETURN 4315 END SUBROUTINE gr_fi_ecrit 4375 END SUBROUTINE gr_fi_ecrit 4376 -
LMDZ5/branches/testing/libf/phylmd/phytrac_mod.F90
r2220 r2298 769 769 ! Liu (2001) proposed to use 1.5e-3 kg/kg 770 770 771 CALL lsc_scav(pdtphys,it,iflag_lscav,ql_incl,prfl,psfl,rneb,beta_fisrt, & 771 !jyg< 772 !! CALL lsc_scav(pdtphys,it,iflag_lscav,ql_incl,prfl,psfl,rneb,beta_fisrt, & 773 CALL lsc_scav(pdtphys,it,iflag_lscav,aerosol,ql_incl,prfl,psfl,rneb,beta_fisrt, & 774 !>jyg 772 775 beta_v1,pplay,paprs,t_seri,tr_seri,d_tr_insc, & 773 776 d_tr_bcscav,d_tr_evapls,qPrls) -
LMDZ5/branches/testing/libf/phylmd/plevel.F90
r1999 r2298 9 9 USE netcdf 10 10 USE dimphy 11 #ifdef CPP_IOIPSL 12 USE phys_state_var_mod, ONLY: missing_val_nf90 13 #endif 14 #ifdef CPP_XIOS 15 USE wxios, ONLY: missing_val 16 #endif 11 17 IMPLICIT NONE 12 18 … … 56 62 INTEGER i, k 57 63 58 REAL missing_val 64 ! REAL missing_val 65 #ifndef CPP_XIOS 66 REAL :: missing_val 67 #endif 59 68 60 missing_val = nf90_fill_real 69 ! missing_val = nf90_fill_real 70 71 #ifndef CPP_XIOS 72 missing_val=missing_val_nf90 73 #endif 61 74 62 75 IF (first) THEN -
LMDZ5/branches/testing/libf/phylmd/plevel_new.F90
r1999 r2298 10 10 USE netcdf 11 11 USE dimphy 12 #ifdef CPP_IOIPSL 13 USE phys_state_var_mod, ONLY: missing_val_nf90 14 #endif 15 #ifdef CPP_XIOS 16 USE wxios, ONLY: missing_val 17 #endif 18 12 19 IMPLICIT NONE 13 20 … … 58 65 INTEGER i, k 59 66 60 REAL missing_val 67 ! REAL missing_val 68 #ifndef CPP_XIOS 69 REAL :: missing_val 70 #endif 61 71 62 missing_val = nf90_fill_real 72 ! missing_val = nf90_fill_real 73 74 #ifndef CPP_XIOS 75 missing_val=missing_val_nf90 76 #endif 63 77 64 78 IF (first) THEN -
LMDZ5/branches/testing/libf/phylmd/screenc.F90
r2258 r2298 4 4 SUBROUTINE screenc(klon, knon, nsrf, zxli, & 5 5 speed, temp, q_zref, zref, & 6 ts, qsurf, rugos, psol, &6 ts, qsurf, z0m, z0h, psol, & 7 7 ustar, testar, qstar, okri, ri1, & 8 8 pref, delu, delte, delq) … … 30 30 ! ts------input-R- temperature de l'air a la surface 31 31 ! qsurf---input-R- humidite relative a la surface 32 ! rugos---input-R- rugosite32 ! z0m, z0h---input-R- rugosite 33 33 ! psol----input-R- pression au sol 34 34 ! ustar---input-R- facteur d'echelle pour le vent … … 48 48 REAL, dimension(klon), intent(in) :: speed, temp, q_zref 49 49 REAL, intent(in) :: zref 50 REAL, dimension(klon), intent(in) :: ts, qsurf, rugos, psol50 REAL, dimension(klon), intent(in) :: ts, qsurf, z0m, z0h, psol 51 51 REAL, dimension(klon), intent(in) :: ustar, testar, qstar, ri1 52 52 ! … … 75 75 CALL cdrag (knon, nsrf, & 76 76 speed, temp, q_zref, gref, & 77 psol, ts, qsurf, rugos, &77 psol, ts, qsurf, z0m, z0h, & 78 78 cdram, cdrah, zri1, pref) 79 79 DO i = 1, knon -
LMDZ5/branches/testing/libf/phylmd/stdlevvar.F90
r2258 r2298 4 4 SUBROUTINE stdlevvar(klon, knon, nsrf, zxli, & 5 5 u1, v1, t1, q1, z1, & 6 ts1, qsurf, rugos, psol, pat1, &6 ts1, qsurf, z0m, z0h, psol, pat1, & 7 7 t_2m, q_2m, t_10m, q_10m, u_10m, ustar) 8 8 IMPLICIT NONE … … 32 32 ! ts1-----input-R- temperature de l'air a la surface 33 33 ! qsurf---input-R- humidite relative a la surface 34 ! rugos---input-R- rugosite34 ! z0m, z0h---input-R- rugosite 35 35 ! psol----input-R- pression au sol 36 36 ! pat1----input-R- pression au 1er niveau du modele … … 47 47 LOGICAL, intent(in) :: zxli 48 48 REAL, dimension(klon), intent(in) :: u1, v1, t1, q1, z1, ts1 49 REAL, dimension(klon), intent(in) :: qsurf, rugos49 REAL, dimension(klon), intent(in) :: qsurf, z0m, z0h 50 50 REAL, dimension(klon), intent(in) :: psol, pat1 51 51 ! … … 103 103 ! & cdram, cdrah, cdran, zri1, pref) 104 104 ! Fuxing WANG, 04/03/2015, replace the coefcdrag by the merged version: cdrag 105 105 106 CALL cdrag(knon, nsrf, & 106 107 & speed, t1, q1, z1, & 107 & psol, ts1, qsurf, rugos, &108 & psol, ts1, qsurf, z0m, z0h, & 108 109 & cdram, cdrah, zri1, pref) 109 110 … … 139 140 zref = 2.0 140 141 CALL screenp(klon, knon, nsrf, speed, tpot, q1, & 141 & ts1, qsurf, rugos, lmon, &142 & ts1, qsurf, z0m, lmon, & 142 143 & ustar, testar, qstar, zref, & 143 144 & delu, delte, delq) … … 160 161 CALL screenc(klon, knon, nsrf, zxli, & 161 162 & u_zref, temp, q_zref, zref, & 162 & ts1, qsurf, rugos, psol, &163 & ts1, qsurf, z0m, z0h, psol, & 163 164 & ustar, testar, qstar, okri, ri1, & 164 165 & pref, delu, delte, delq) … … 241 242 zref = 10.0 242 243 CALL screenp(klon, knon, nsrf, speed, tpot, q1, & 243 & ts1, qsurf, rugos, lmon, &244 & ts1, qsurf, z0m, lmon, & 244 245 & ustar, testar, qstar, zref, & 245 246 & delu, delte, delq) … … 262 263 CALL screenc(klon, knon, nsrf, zxli, & 263 264 & u_zref, temp, q_zref, zref, & 264 & ts1, qsurf, rugos, psol, &265 & ts1, qsurf, z0m, z0h, psol, & 265 266 & ustar, testar, qstar, okri, ri1, & 266 267 & pref, delu, delte, delq) -
LMDZ5/branches/testing/libf/phylmd/surf_land_bucket_mod.F90
r1910 r2298 13 13 tsurf, p1lay, tq_cdrag, precip_rain, precip_snow, temp_air, & 14 14 spechum, petAcoef, peqAcoef, petBcoef, peqBcoef, pref, & 15 u1, v1, rugoro, swnet, lwnet, &15 u1, v1, gustiness, rugoro, swnet, lwnet, & 16 16 snow, qsol, agesno, tsoil, & 17 17 qsurf, z0_new, alb1_new, alb2_new, evap, & … … 49 49 REAL, DIMENSION(klon), INTENT(IN) :: petBcoef, peqBcoef 50 50 REAL, DIMENSION(klon), INTENT(IN) :: pref 51 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 51 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 52 52 REAL, DIMENSION(klon), INTENT(IN) :: rugoro 53 53 REAL, DIMENSION(klon), INTENT(IN) :: swnet, lwnet … … 99 99 CALL calbeta(dtime, is_ter, knon, snow, qsol, beta, capsol, dif_grnd) 100 100 if (type_veget=='betaclim') then 101 CALL calbeta_clim(knon,jour,rlatd(knindex( :)),beta)101 CALL calbeta_clim(knon,jour,rlatd(knindex(1:knon)),beta) 102 102 endif 103 103 … … 123 123 124 124 CALL calcul_fluxs(knon, is_ter, dtime, & 125 tsurf, p1lay, cal, beta, tq_cdrag, pref, &125 tsurf, p1lay, cal, beta, tq_cdrag, tq_cdrag, pref, & 126 126 precip_rain, precip_snow, snow, qsurf, & 127 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &128 petAcoef, peqAcoef, petBcoef, peqBcoef, &127 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, gustiness, & 128 1.,petAcoef, peqAcoef, petBcoef, peqBcoef, & 129 129 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 130 130 -
LMDZ5/branches/testing/libf/phylmd/surf_land_mod.F90
r2258 r2298 14 14 AcoefH, AcoefQ, BcoefH, BcoefQ, & 15 15 AcoefU, AcoefV, BcoefU, BcoefV, & 16 pref, u1, v1, rugoro, pctsrf, &16 pref, u1, v1, gustiness, rugoro, pctsrf, & 17 17 lwdown_m, q2m, t2m, & 18 18 snow, qsol, agesno, tsoil, & 19 !albedo SB >>> 20 ! z0_new, alb1_new, alb2_new, evap, fluxsens, fluxlat, & 21 z0_new, SFRWL, alb_dir_new, alb_dif_new, evap, fluxsens, fluxlat, & 22 !albedo SB <<< 19 z0m, z0h, SFRWL, alb_dir_new, alb_dif_new, evap, fluxsens, fluxlat, & 23 20 qsurf, tsurf_new, dflux_s, dflux_l, & 24 21 flux_u1, flux_v1 ) … … 61 58 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 62 59 REAL, DIMENSION(klon), INTENT(IN) :: pref ! pressure reference 63 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 60 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 64 61 REAL, DIMENSION(klon), INTENT(IN) :: rugoro 65 62 REAL, DIMENSION(klon,nbsrf), INTENT(IN) :: pctsrf … … 76 73 ! Output variables 77 74 !**************************************************************************************** 78 REAL, DIMENSION(klon), INTENT(OUT) :: z0 _new75 REAL, DIMENSION(klon), INTENT(OUT) :: z0m, z0h 79 76 !albedo SB >>> 80 77 ! REAL, DIMENSION(klon), INTENT(OUT) :: alb1_new ! albdeo for shortwave interval 1(visible) … … 137 134 knindex, rlon, rlat, pctsrf, & 138 135 debut, lafin, & 139 zlev, u1, v1, temp_air, spechum, epot_air, ccanopy, &136 zlev, u1, v1, gustiness, temp_air, spechum, epot_air, ccanopy, & 140 137 cdragh, AcoefH, AcoefQ, BcoefH, BcoefQ, & 141 138 precip_rain, precip_snow, lwdown_m, swnet, swdown, & … … 143 140 evap, fluxsens, fluxlat, & 144 141 tsol_rad, tsurf_new, alb1_new, alb2_new, & 145 emis_new, z0_new, qsurf) 142 emis_new, z0m, qsurf) 143 z0h(1:knon)=z0m(1:knon) ! En attendant mieux 146 144 147 145 ! … … 149 147 ! 150 148 DO i=1,knon 151 z0 _new(i) = MAX(1.5e-05,SQRT(z0_new(i)**2 + rugoro(i)**2))149 z0m(i) = MAX(1.5e-05,SQRT(z0m(i)**2 + rugoro(i)**2)) 152 150 ENDDO 153 151 … … 160 158 tsurf, p1lay, cdragh, precip_rain, precip_snow, temp_air, & 161 159 spechum, AcoefH, AcoefQ, BcoefH, BcoefQ, pref, & 162 u1, v1, rugoro, swnet, lwnet, &160 u1, v1, gustiness, rugoro, swnet, lwnet, & 163 161 snow, qsol, agesno, tsoil, & 164 qsurf, z0 _new, alb1_new, alb2_new, evap, &162 qsurf, z0m, alb1_new, alb2_new, evap, & 165 163 fluxsens, fluxlat, tsurf_new, dflux_s, dflux_l) 164 z0h(1:knon)=z0m(1:knon) ! En attendant mieux 166 165 167 166 ENDIF ! ok_veget … … 175 174 v0(:)=0.0 176 175 CALL calcul_flux_wind(knon, dtime, & 177 u0, v0, u1, v1, cdragm, &176 u0, v0, u1, v1, gustiness, cdragm, & 178 177 AcoefU, AcoefV, BcoefU, BcoefV, & 179 178 p1lay, temp_air, & -
LMDZ5/branches/testing/libf/phylmd/surf_land_orchidee_mod.F90
r2160 r2298 33 33 knindex, rlon, rlat, pctsrf, & 34 34 debut, lafin, & 35 plev, u1_lay, v1_lay, temp_air, spechum, epot_air, ccanopy, &35 plev, u1_lay, v1_lay, gustiness, temp_air, spechum, epot_air, ccanopy, & 36 36 tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, & 37 37 precip_rain, precip_snow, lwdown, swnet, swdown, & … … 115 115 REAL, DIMENSION(klon), INTENT(IN) :: rlon, rlat 116 116 REAL, DIMENSION(klon), INTENT(IN) :: plev 117 REAL, DIMENSION(klon), INTENT(IN) :: u1_lay, v1_lay 117 REAL, DIMENSION(klon), INTENT(IN) :: u1_lay, v1_lay, gustiness 118 118 REAL, DIMENSION(klon), INTENT(IN) :: temp_air, spechum 119 119 REAL, DIMENSION(klon), INTENT(IN) :: epot_air, ccanopy -
LMDZ5/branches/testing/libf/phylmd/surf_landice_mod.F90
r2258 r2298 15 15 AcoefH, AcoefQ, BcoefH, BcoefQ, & 16 16 AcoefU, AcoefV, BcoefU, BcoefV, & 17 ps, u1, v1, rugoro, pctsrf, &17 ps, u1, v1, gustiness, rugoro, pctsrf, & 18 18 snow, qsurf, qsol, agesno, & 19 !albedo SB >>> 20 ! tsoil, z0_new, alb1, alb2, evap, fluxsens, fluxlat, & 21 tsoil, z0_new, SFRWL, alb_dir, alb_dif, evap, fluxsens, fluxlat, & 22 !albedo SB <<< 19 tsoil, z0m, z0h, SFRWL, alb_dir, alb_dif, evap, fluxsens, fluxlat, & 23 20 tsurf_new, dflux_s, dflux_l, & 24 21 slope, cloudf, & … … 59 56 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 60 57 REAL, DIMENSION(klon), INTENT(IN) :: ps 61 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 58 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 62 59 REAL, DIMENSION(klon), INTENT(IN) :: rugoro 63 60 REAL, DIMENSION(klon,nbsrf), INTENT(IN) :: pctsrf … … 82 79 !**************************************************************************************** 83 80 REAL, DIMENSION(klon), INTENT(OUT) :: qsurf 84 REAL, DIMENSION(klon), INTENT(OUT) :: z0 _new81 REAL, DIMENSION(klon), INTENT(OUT) :: z0m, z0h 85 82 !albedo SB >>> 86 83 ! REAL, DIMENSION(klon), INTENT(OUT) :: alb1 ! new albedo in visible SW interval … … 182 179 tsoil0(i,:)=tsoil(i,:) 183 180 END DO 184 185 186 181 ! Martin 182 PRINT*, 'on appelle surf_sisvat' 183 ! Martin 187 184 CALL surf_sisvat(knon, rlon, rlat, knindex, itime, dtime, debut, lafin, & 188 185 rmu0, swdown, lwdown, pexner, ps, p1lay, & … … 194 191 run_off_lic, evap, fluxsens, fluxlat, dflux_s, dflux_l, & 195 192 tsurf_new, alb1, alb2, alb3, & 196 emis_new, z0_new, qsurf) 193 emis_new, z0m, qsurf) 194 z0h(1:knon)=z0m(1:knon) ! en attendant mieux 197 195 198 196 ! Suppose zero surface speed … … 205 203 206 204 CALL calcul_flux_wind(knon, dtime, & 207 u0, v0, u1, v1, cdragm, &205 u0, v0, u1, v1, gustiness, cdragm, & 208 206 AcoefU, AcoefV, BcoefU, BcoefV, & 209 207 p1lay, temp_air, & … … 243 241 244 242 CALL calcul_fluxs(knon, is_lic, dtime, & 245 tsurf, p1lay, cal, beta, cdragh, ps, &243 tsurf, p1lay, cal, beta, cdragh, cdragh, ps, & 246 244 precip_rain, precip_snow, snow, qsurf, & 247 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &248 AcoefH, AcoefQ, BcoefH, BcoefQ, &245 radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, gustiness, & 246 1.,AcoefH, AcoefQ, BcoefH, BcoefQ, & 249 247 tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 250 248 251 249 CALL calcul_flux_wind(knon, dtime, & 252 u0, v0, u1, v1, cdragm, &250 u0, v0, u1, v1, gustiness, cdragm, & 253 251 AcoefU, AcoefV, BcoefU, BcoefV, & 254 252 p1lay, temp_air, & … … 290 288 ! 291 289 !**************************************************************************************** 292 z0_new(:) = MAX(1.E-3,rugoro(:)) 290 z0m=1.e-3 291 z0h = z0m 292 z0m = SQRT(z0m**2+rugoro**2) 293 293 294 END IF ! ok_snow 294 295 -
LMDZ5/branches/testing/libf/phylmd/surf_ocean_mod.F90
r2258 r2298 6 6 CONTAINS 7 7 ! 8 !****************************************************************************** **********8 !****************************************************************************** 9 9 ! 10 10 SUBROUTINE surf_ocean(rlon, rlat, swnet, lwnet, alb1, & 11 rugos,windsp, rmu0, fder, tsurf_in, &11 windsp, rmu0, fder, tsurf_in, & 12 12 itime, dtime, jour, knon, knindex, & 13 p1lay, cdragh, cdragm, precip_rain, precip_snow, temp_air, spechum, &13 p1lay, z1lay, cdragh, cdragm, precip_rain, precip_snow, temp_air, spechum, & 14 14 AcoefH, AcoefQ, BcoefH, BcoefQ, & 15 15 AcoefU, AcoefV, BcoefU, BcoefV, & 16 ps, u1, v1, rugoro, pctsrf, &16 ps, u1, v1, gustiness, rugoro, pctsrf, & 17 17 snow, qsurf, agesno, & 18 !albedo SB >>> 19 ! z0_new, alb1_new, alb2_new, evap, fluxsens, fluxlat, & 20 z0_new, SFRWL, alb_dir_new, alb_dif_new, evap, fluxsens, fluxlat, & 21 !albedo SB <<< 18 z0m, z0h, SFRWL, alb_dir_new, alb_dif_new, evap, fluxsens, fluxlat, & 22 19 tsurf_new, dflux_s, dflux_l, lmt_bils, & 23 20 flux_u1, flux_v1) … … 41 38 42 39 ! Input variables 43 !****************************************************************************** **********40 !****************************************************************************** 44 41 INTEGER, INTENT(IN) :: itime, jour, knon 45 42 INTEGER, DIMENSION(klon), INTENT(IN) :: knindex … … 49 46 REAL, DIMENSION(klon), INTENT(IN) :: lwnet ! net longwave radiation at surface 50 47 REAL, DIMENSION(klon), INTENT(IN) :: alb1 ! albedo in visible SW interval 51 REAL, DIMENSION(klon), INTENT(IN) :: rugos52 48 REAL, DIMENSION(klon), INTENT(IN) :: windsp 53 49 REAL, DIMENSION(klon), INTENT(IN) :: rmu0 54 50 REAL, DIMENSION(klon), INTENT(IN) :: fder 55 51 REAL, DIMENSION(klon), INTENT(IN) :: tsurf_in 56 REAL, DIMENSION(klon), INTENT(IN) :: p1lay 52 REAL, DIMENSION(klon), INTENT(IN) :: p1lay,z1lay ! pression (Pa) et altitude (m) du premier niveau 57 53 REAL, DIMENSION(klon), INTENT(IN) :: cdragh 58 54 REAL, DIMENSION(klon), INTENT(IN) :: cdragm … … 62 58 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 63 59 REAL, DIMENSION(klon), INTENT(IN) :: ps 64 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 60 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 65 61 REAL, DIMENSION(klon), INTENT(IN) :: rugoro 66 62 REAL, DIMENSION(klon,nbsrf), INTENT(IN) :: pctsrf 67 63 68 64 ! In/Output variables 69 !****************************************************************************** **********65 !****************************************************************************** 70 66 REAL, DIMENSION(klon), INTENT(INOUT) :: snow 71 67 REAL, DIMENSION(klon), INTENT(INOUT) :: qsurf … … 73 69 74 70 ! Output variables 75 !****************************************************************************** **********76 REAL, DIMENSION(klon), INTENT(OUT) :: z0 _new71 !****************************************************************************** 72 REAL, DIMENSION(klon), INTENT(OUT) :: z0m, z0h 77 73 !albedo SB >>> 78 74 ! REAL, DIMENSION(klon), INTENT(OUT) :: alb1_new ! new albedo in visible SW interval … … 88 84 89 85 ! Local variables 90 !****************************************************************************** **********86 !****************************************************************************** 91 87 INTEGER :: i, k 92 88 REAL :: tmp … … 94 90 REAL, DIMENSION(klon) :: alb_eau 95 91 REAL, DIMENSION(klon) :: radsol 92 REAL, DIMENSION(klon) :: cdragq ! Cdrag pour l'evaporation 96 93 97 94 ! End definition 98 !****************************************************************************** **********99 100 101 !****************************************************************************** **********95 !****************************************************************************** 96 97 98 !****************************************************************************** 102 99 ! Calculate total net radiance at surface 103 100 ! 104 !****************************************************************************** **********101 !****************************************************************************** 105 102 radsol(:) = 0.0 106 103 radsol(1:knon) = swnet(1:knon) + lwnet(1:knon) 107 104 108 !**************************************************************************************** 105 !****************************************************************************** 106 ! Cdragq computed from cdrag 107 ! The difference comes only from a factor (f_z0qh_oce) on z0, so that 108 ! it can be computed inside surf_ocean 109 ! More complicated appraches may require the propagation through 110 ! pbl_surface of an independant cdragq variable. 111 !****************************************************************************** 112 113 IF ( f_z0qh_oce .ne. 1.) THEN 114 ! Si on suit les formulations par exemple de Tessel, on 115 ! a z0h=0.4*nu/u*, z0q=0.62*nu/u*, d'ou f_z0qh_oce=0.62/0.4=1.55 116 cdragq(:)=cdragh(:)* & 117 log(z1lay(:)/z0h(:))/log(z1lay(:)/(f_z0qh_oce*z0h(:))) 118 ELSE 119 cdragq(:)=cdragh(:) 120 ENDIF 121 122 !****************************************************************************** 109 123 ! Switch according to type of ocean (couple, slab or forced) 110 !****************************************************************************** **********124 !****************************************************************************** 111 125 SELECT CASE(type_ocean) 112 126 CASE('couple') … … 115 129 windsp, fder, & 116 130 itime, dtime, knon, knindex, & 117 p1lay, cdragh, cdrag m, precip_rain, precip_snow,temp_air,spechum,&131 p1lay, cdragh, cdragq, cdragm, precip_rain, precip_snow,temp_air,spechum,& 118 132 AcoefH, AcoefQ, BcoefH, BcoefQ, & 119 133 AcoefU, AcoefV, BcoefU, BcoefV, & 120 ps, u1, v1, &134 ps, u1, v1, gustiness, & 121 135 radsol, snow, agesno, & 122 136 qsurf, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 126 140 CALL ocean_slab_noice( & 127 141 itime, dtime, jour, knon, knindex, & 128 p1lay, cdragh, cdrag m, precip_rain, precip_snow, temp_air, spechum,&142 p1lay, cdragh, cdragq, cdragm, precip_rain, precip_snow, temp_air, spechum,& 129 143 AcoefH, AcoefQ, BcoefH, BcoefQ, & 130 144 AcoefU, AcoefV, BcoefU, BcoefV, & 131 ps, u1, v1, tsurf_in, &145 ps, u1, v1, gustiness, tsurf_in, & 132 146 radsol, snow, & 133 147 qsurf, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 137 151 CALL ocean_forced_noice( & 138 152 itime, dtime, jour, knon, knindex, & 139 p1lay, cdragh, cdrag m, precip_rain, precip_snow, &153 p1lay, cdragh, cdragq, cdragm, precip_rain, precip_snow, & 140 154 temp_air, spechum, & 141 155 AcoefH, AcoefQ, BcoefH, BcoefQ, & 142 156 AcoefU, AcoefV, BcoefU, BcoefV, & 143 ps, u1, v1, &157 ps, u1, v1, gustiness, & 144 158 radsol, snow, agesno, & 145 159 qsurf, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 147 161 END SELECT 148 162 149 !****************************************************************************** **********163 !****************************************************************************** 150 164 ! fcodron: compute lmt_bils forced case (same as wfbils_oce / 1.-contfracatm) 151 !****************************************************************************** **********165 !****************************************************************************** 152 166 IF (type_ocean.NE.'slab') THEN 153 167 lmt_bils(:)=0. … … 158 172 END IF 159 173 160 !****************************************************************************** **********174 !****************************************************************************** 161 175 ! Calculate albedo 162 ! 163 !**************************************************************************************** 176 !****************************************************************************** 164 177 !albedo SB >>> 165 166 167 178 if(iflag_albedo==1)then 168 179 call ocean_albedo(knon,rmu0,knindex,windsp,SFRWL,alb_dir_new,alb_dif_new) … … 184 195 !albedo SB <<< 185 196 186 !****************************************************************************** **********197 !****************************************************************************** 187 198 ! Calculate the rugosity 188 ! 189 !**************************************************************************************** 199 !****************************************************************************** 200 IF (iflag_z0_oce==0) THEN 190 201 DO i = 1, knon 191 tmp = MAX(cepdu2, u1(i)**2+v1(i)**2)192 z0 _new(i) = 0.018*cdragm(i) * (u1(i)**2+v1(i)**2)/RG &202 tmp = MAX(cepdu2,gustiness(i)+u1(i)**2+v1(i)**2) 203 z0m(i) = 0.018*cdragm(i) * (gustiness(i)+u1(i)**2+v1(i)**2)/RG & 193 204 + 0.11*14e-6 / SQRT(cdragm(i) * tmp) 194 z0 _new(i) = MAX(1.5e-05,z0_new(i))205 z0m(i) = MAX(1.5e-05,z0m(i)) 195 206 ENDDO 196 ! 197 !**************************************************************************************** 198 ! 207 z0h(1:knon)=z0m(1:knon) ! En attendant mieux 208 209 ELSE IF (iflag_z0_oce==1) THEN 210 DO i = 1, knon 211 tmp = MAX(cepdu2,gustiness(i)+u1(i)**2+v1(i)**2) 212 z0m(i) = 0.018*cdragm(i) * (gustiness(i)+u1(i)**2+v1(i)**2)/RG & 213 + 0.11*14e-6 / SQRT(cdragm(i) * tmp) 214 z0m(i) = MAX(1.5e-05,z0m(i)) 215 z0h(i)=0.4*14e-6 / SQRT(cdragm(i) * tmp) 216 ENDDO 217 ELSE 218 STOP'version non prevue' 219 ENDIF 220 ! 221 !****************************************************************************** 199 222 END SUBROUTINE surf_ocean 200 ! 201 !**************************************************************************************** 223 !****************************************************************************** 202 224 ! 203 225 END MODULE surf_ocean_mod -
LMDZ5/branches/testing/libf/phylmd/surf_seaice_mod.F90
r2258 r2298 17 17 AcoefH, AcoefQ, BcoefH, BcoefQ, & 18 18 AcoefU, AcoefV, BcoefU, BcoefV, & 19 ps, u1, v1, rugoro, pctsrf, &19 ps, u1, v1, gustiness, pctsrf, & 20 20 snow, qsurf, qsol, agesno, tsoil, & 21 !albedo SB >>> 22 ! z0_new, alb1_new, alb2_new, evap, fluxsens, fluxlat, & 23 z0_new, SFRWL, alb_dir_new, alb_dif_new, evap, fluxsens, fluxlat, & 24 !albedo SB <<< 21 z0m, z0h, SFRWL, alb_dir_new, alb_dif_new, evap, fluxsens, fluxlat, & 25 22 tsurf_new, dflux_s, dflux_l, & 26 23 flux_u1, flux_v1) … … 60 57 REAL, DIMENSION(klon), INTENT(IN) :: AcoefU, AcoefV, BcoefU, BcoefV 61 58 REAL, DIMENSION(klon), INTENT(IN) :: ps 62 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1 63 REAL, DIMENSION(klon), INTENT(IN) :: rugoro 59 REAL, DIMENSION(klon), INTENT(IN) :: u1, v1, gustiness 64 60 REAL, DIMENSION(klon,nbsrf), INTENT(IN) :: pctsrf 65 61 … … 72 68 ! Output arguments 73 69 !**************************************************************************************** 74 REAL, DIMENSION(klon), INTENT(OUT) :: z0 _new70 REAL, DIMENSION(klon), INTENT(OUT) :: z0m, z0h 75 71 !albedo SB >>> 76 72 ! REAL, DIMENSION(klon), INTENT(OUT) :: alb1_new ! new albedo in visible SW interval … … 117 113 AcoefH, AcoefQ, BcoefH, BcoefQ, & 118 114 AcoefU, AcoefV, BcoefU, BcoefV, & 119 ps, u1, v1, pctsrf, &115 ps, u1, v1, gustiness, pctsrf, & 120 116 radsol, snow, qsurf, & 121 117 alb1_new, alb2_new, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 128 124 AcoefH, AcoefQ, BcoefH, BcoefQ, & 129 125 AcoefU, AcoefV, BcoefU, BcoefV, & 130 ps, u1, v1, &126 ps, u1, v1, gustiness, & 131 127 radsol, snow, qsurf, qsol, agesno, & 132 128 alb1_new, alb2_new, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 139 135 AcoefH, AcoefQ, BcoefH, BcoefQ, & 140 136 AcoefU, AcoefV, BcoefU, BcoefV, & 141 ps, u1, v1, &137 ps, u1, v1, gustiness, & 142 138 radsol, snow, qsol, agesno, tsoil, & 143 139 qsurf, alb1_new, alb2_new, evap, fluxsens, fluxlat, flux_u1, flux_v1, & … … 150 146 ! 151 147 !**************************************************************************************** 152 z0_new = 0.002153 z0_new = SQRT(z0_new**2+rugoro**2)154 148 149 z0m=z0m_seaice 150 z0h = z0h_seaice 155 151 156 152 !albedo SB >>> -
LMDZ5/branches/testing/libf/phylmd/thermcell_plume.F90
r2220 r2298 6 6 & lalim,f0,detr_star,entr_star,f_star,csc,ztva, & 7 7 & ztla,zqla,zqta,zha,zw2,w_est,ztva_est,zqsatth,lmix,lmix_bis,linter & 8 9 ! & ,lev_out,lunout1,igout,zbuoy,zbuoyjam)8 & ,lev_out,lunout1,igout) 9 ! & ,lev_out,lunout1,igout,zbuoy,zbuoyjam) 10 10 !-------------------------------------------------------------------------- 11 11 !thermcell_plume: calcule les valeurs de qt, thetal et w dans l ascendance … … 87 87 real ztv_est1,ztv_est2 88 88 real zcor,zdelta,zcvm5,qlbef 89 real zbetalpha 89 real zbetalpha, coefzlmel 90 90 real eps 91 91 REAL REPS,RLvCp,DDT0 … … 396 396 else ! if (iflag_thermals_ed.lt.8) then 397 397 lt=l+1 398 zlt=zlev(ig,lt) 398 399 zdz2=zlev(ig,lt)-zlev(ig,l) 399 400 … … 405 406 zdz3=zlev(ig,lt+1)-zlt 406 407 zltdwn=zlev(ig,lt)-zdz3/2 407 408 zbuoyjam(ig,l)=1.*RG*(((lmel+zdz3-zdz2)/zdz3)*(ztva_est(ig,l)- & 409 & ztv(ig,lt))/ztv(ig,lt)+((zdz2-lmel)/zdz3)*(ztva_est(ig,l)- & 408 zlmelup=zlmel+(zdz/2) 409 coefzlmel=Min(1.,(zlmelup-zltdwn)/zdz) 410 zbuoyjam(ig,l)=1.*RG*(coefzlmel*(ztva_est(ig,l)- & 411 & ztv(ig,lt))/ztv(ig,lt)+(1.-coefzlmel)*(ztva_est(ig,l)- & 410 412 & ztv(ig,lt-1))/ztv(ig,lt-1))+0.*zbuoy(ig,l) 411 413 endif ! if (iflag_thermals_ed.lt.8) then … … 422 424 zdw2=afact*zbuoy(ig,l)/fact_epsilon 423 425 zdw2bis=afact*zbuoy(ig,l-1)/fact_epsilon 426 ! zdw2bis=0.5*(zdw2+zdw2bis) 424 427 lm=Max(1,l-2) 425 428 ! zdw2=(afact/fact_epsilon)*((zdz/zdzbis)*zbuoy(ig,l) & … … 442 445 ! & (exp(-zw2factbis)*(w_est(ig,l-1)-zdw2bis)+zdw2)) 443 446 444 w_est(ig,l+1)=Max(0.0001,exp(-zw2fact)*(w_est(ig,l)-zdw2 bis)+zdw2)447 w_est(ig,l+1)=Max(0.0001,exp(-zw2fact)*(w_est(ig,l)-zdw2)+zdw2) 445 448 446 449 ! Nouvelle version Arnaud … … 556 559 & mix0 * 0.1 / (zalpha+0.001) & 557 560 & + zbetalpha*MAX(entr_min, & 558 & afact*zbuoyjam(ig,l)/zw2m - fact_epsilon 561 & afact*zbuoyjam(ig,l)/zw2m - fact_epsilon)) 559 562 560 563 … … 645 648 ! & (zw2(ig,l)-zdw2)+zdw2)+(zdzbis-zdz)/zdzbis* & 646 649 ! & (exp(-zw2factbis)*(zw2(ig,l-1)-zdw2bis)+zdw2)) 650 if (iflag_thermals_ed==8) then 651 zw2(ig,l+1)=Max(0.0001,exp(-zw2fact)*(zw2(ig,l)-zdw2)+zdw2) 652 else 647 653 zw2(ig,l+1)=Max(0.0001,exp(-zw2fact)*(zw2(ig,l)-zdw2bis)+zdw2) 654 endif 648 655 ! zw2(ig,l+1)=Max(0.0001,(zdz/(zdz+zdzbis))*(exp(-zw2fact)* & 649 ! & (zw2(ig,l)-zdw2 bis)+zdw2)+(zdzbis/(zdz+zdzbis))* &656 ! & (zw2(ig,l)-zdw2)+zdw2bis)+(zdzbis/(zdz+zdzbis))* & 650 657 ! & (exp(-zw2factbis)*(zw2(ig,l-1)-zdw2bis)+zdw2bis)) 651 658 -
LMDZ5/branches/testing/libf/phylmd/traclmdz_mod.F90
r2187 r2298 174 174 id_pcsat=0; id_pcocsat=0; id_pcq=0; id_pcs0=0; id_pcos0=0; id_pcq0=0 175 175 DO it=1,nbtr 176 iiq=niadv(it+2) 177 IF ( tname(iiq) == "RN" ) THEN 176 !! iiq=niadv(it+2) ! jyg 177 iiq=niadv(it+nqo) ! jyg 178 IF ( tname(iiq) == "RN" ) THEN 178 179 id_rn=it ! radon 179 180 ELSE IF ( tname(iiq) == "PB") THEN … … 293 294 ! ---------------------------------------------- 294 295 DO it=1,nbtr 295 iiq=niadv(it+2) 296 !! iiq=niadv(it+2) ! jyg 297 iiq=niadv(it+nqo) ! jyg 296 298 ! Test if tracer is zero everywhere. 297 299 ! Done by master process MPI and master thread OpenMP -
LMDZ5/branches/testing/libf/phylmd/undefSTD.F90
r1999 r2298 5 5 USE netcdf 6 6 USE dimphy 7 USE phys_state_var_mod ! Variables sauvegardees de la physique 7 #ifdef CPP_IOIPSL 8 USE phys_state_var_mod 9 #endif 10 8 11 IMPLICIT NONE 9 12 include "clesphys.h" 13 #ifdef CPP_IOIPSL 14 REAL :: missing_val 15 #endif 10 16 11 17 ! ==================================================================== … … 51 57 ! REAL tnondef(klon,klevSTD,nout) 52 58 53 59 ! REAL missing_val 54 60 55 missing_val = nf90_fill_real 61 ! missing_val = nf90_fill_real 62 #ifndef CPP_XIOS 63 missing_val=missing_val_nf90 64 #endif 56 65 57 66 DO n = 1, nout -
LMDZ5/branches/testing/libf/phylmd/write_histrac.h
r1910 r2298 17 17 !---------------- 18 18 DO it=1,nbtr 19 iiq=niadv(it+2) 19 !! iiq=niadv(it+2) ! jyg 20 iiq=niadv(it+nqo) ! jyg 20 21 21 22 ! CONCENTRATIONS
Note: See TracChangeset
for help on using the changeset viewer.