[2343] | 1 | ! |
---|
| 2 | ! $Id: phystokenc_mod.f90 5268 2024-10-23 17:02:39Z jyg $ |
---|
| 3 | ! |
---|
| 4 | MODULE phystokenc_mod |
---|
| 5 | |
---|
[5148] | 6 | IMPLICIT NONE |
---|
[2343] | 7 | |
---|
[5148] | 8 | LOGICAL,SAVE :: offline |
---|
| 9 | !$OMP THREADPRIVATE(offline) |
---|
| 10 | INTEGER,SAVE :: istphy |
---|
| 11 | !$OMP THREADPRIVATE(istphy) |
---|
| 12 | |
---|
| 13 | |
---|
| 14 | CONTAINS |
---|
| 15 | |
---|
| 16 | SUBROUTINE init_phystokenc(offline_dyn,istphy_dyn) |
---|
| 17 | IMPLICIT NONE |
---|
| 18 | LOGICAL,INTENT(IN) :: offline_dyn |
---|
| 19 | INTEGER,INTENT(IN) :: istphy_dyn |
---|
| 20 | |
---|
| 21 | offline=offline_dyn |
---|
| 22 | istphy=istphy_dyn |
---|
| 23 | |
---|
| 24 | END SUBROUTINE init_phystokenc |
---|
| 25 | |
---|
| 26 | SUBROUTINE phystokenc (nlon,nlev,pdtphys,rlon,rlat, & |
---|
| 27 | pt,pmfu, pmfd, pen_u, pde_u, pen_d, pde_d, & |
---|
| 28 | pfm_therm,pentr_therm, & |
---|
| 29 | cdragh, pcoefh,yu1,yv1,ftsol,pctsrf, & |
---|
| 30 | frac_impa,frac_nucl, & |
---|
| 31 | pphis,paire,dtime,itap, & |
---|
| 32 | psh, pda, pphi, pmp, pupwd, pdnwd) |
---|
| 33 | |
---|
| 34 | USE ioipsl |
---|
| 35 | USE dimphy |
---|
| 36 | USE infotrac_phy, ONLY : nqtot |
---|
| 37 | USE iophy |
---|
| 38 | USE indice_sol_mod |
---|
| 39 | USE print_control_mod, ONLY: lunout |
---|
| 40 | USE mod_grid_phy_lmdz, ONLY: nbp_lon, nbp_lat |
---|
| 41 | |
---|
[1447] | 42 | IMPLICIT NONE |
---|
[5148] | 43 | |
---|
| 44 | !====================================================================== |
---|
| 45 | ! Auteur(s) FH |
---|
| 46 | ! Objet: Ecriture des variables pour transport offline |
---|
| 47 | ! |
---|
| 48 | ! Note (A Cozic - July 2024): when coupled with inca, offline fields are no |
---|
| 49 | ! longer calculated in this routine but directly in the physics code. |
---|
| 50 | !====================================================================== |
---|
[1403] | 51 | |
---|
[5148] | 52 | ! Arguments: |
---|
| 53 | ! |
---|
| 54 | REAL,DIMENSION(klon,klev), INTENT(IN) :: psh ! humidite specifique |
---|
| 55 | REAL,DIMENSION(klon,klev), INTENT(IN) :: pda |
---|
| 56 | REAL,DIMENSION(klon,klev,klev), INTENT(IN):: pphi |
---|
| 57 | REAL,DIMENSION(klon,klev), INTENT(IN) :: pmp |
---|
| 58 | REAL,DIMENSION(klon,klev), INTENT(IN) :: pupwd ! saturated updraft mass flux |
---|
| 59 | REAL,DIMENSION(klon,klev), INTENT(IN) :: pdnwd ! saturated downdraft mass flux |
---|
| 60 | |
---|
| 61 | ! EN ENTREE: |
---|
| 62 | ! ========== |
---|
| 63 | ! |
---|
| 64 | ! divers: |
---|
| 65 | ! ------- |
---|
| 66 | ! |
---|
| 67 | INTEGER nlon ! nombre de points horizontaux |
---|
| 68 | INTEGER nlev ! nombre de couches verticales |
---|
| 69 | REAL pdtphys ! pas d'integration pour la physique (seconde) |
---|
| 70 | INTEGER itap |
---|
| 71 | INTEGER, SAVE :: physid |
---|
| 72 | !$OMP THREADPRIVATE(physid) |
---|
| 73 | |
---|
| 74 | ! convection: |
---|
| 75 | ! ----------- |
---|
| 76 | ! |
---|
| 77 | REAL pmfu(klon,klev) ! flux de masse dans le panache montant |
---|
| 78 | REAL pmfd(klon,klev) ! flux de masse dans le panache descendant |
---|
| 79 | REAL pen_u(klon,klev) ! flux entraine dans le panache montant |
---|
| 80 | REAL pde_u(klon,klev) ! flux detraine dans le panache montant |
---|
| 81 | REAL pen_d(klon,klev) ! flux entraine dans le panache descendant |
---|
| 82 | REAL pde_d(klon,klev) ! flux detraine dans le panache descendant |
---|
| 83 | REAL pt(klon,klev) |
---|
| 84 | REAL,ALLOCATABLE,SAVE :: t(:,:) |
---|
| 85 | !$OMP THREADPRIVATE(t) |
---|
| 86 | ! |
---|
| 87 | REAL rlon(klon), rlat(klon), dtime |
---|
| 88 | REAL zx_tmp_3d(nbp_lon,nbp_lat,klev),zx_tmp_2d(nbp_lon,nbp_lat) |
---|
| 89 | |
---|
| 90 | ! Couche limite: |
---|
| 91 | ! -------------- |
---|
| 92 | ! |
---|
| 93 | REAL cdragh(klon) ! cdrag |
---|
| 94 | REAL pcoefh(klon,klev) ! coeff melange CL |
---|
| 95 | REAL pcoefh_buf(klon,klev) ! coeff melange CL + cdrag |
---|
| 96 | REAL yv1(klon) |
---|
| 97 | REAL yu1(klon),pphis(klon),paire(klon) |
---|
| 98 | |
---|
| 99 | ! Les Thermiques : (Abderr 25 11 02) |
---|
| 100 | ! --------------- |
---|
| 101 | REAL, INTENT(IN) :: pfm_therm(klon,klev+1) |
---|
| 102 | REAL pentr_therm(klon,klev) |
---|
[1447] | 103 | |
---|
[5148] | 104 | REAL,ALLOCATABLE,SAVE :: entr_therm(:,:) |
---|
| 105 | REAL,ALLOCATABLE,SAVE :: fm_therm(:,:) |
---|
| 106 | !$OMP THREADPRIVATE(entr_therm) |
---|
| 107 | !$OMP THREADPRIVATE(fm_therm) |
---|
| 108 | ! |
---|
| 109 | ! Lessivage: |
---|
| 110 | ! ---------- |
---|
| 111 | ! |
---|
| 112 | REAL frac_impa(klon,klev) |
---|
| 113 | REAL frac_nucl(klon,klev) |
---|
| 114 | ! |
---|
| 115 | ! Arguments necessaires pour les sources et puits de traceur |
---|
| 116 | ! |
---|
| 117 | REAL ftsol(klon,nbsrf) ! Temperature du sol (surf)(Kelvin) |
---|
| 118 | REAL pctsrf(klon,nbsrf) ! Pourcentage de sol f(nature du sol) |
---|
| 119 | !====================================================================== |
---|
| 120 | ! |
---|
| 121 | INTEGER i, k, kk |
---|
| 122 | REAL,ALLOCATABLE,SAVE :: mfu(:,:) ! flux de masse dans le panache montant |
---|
| 123 | REAL,ALLOCATABLE,SAVE :: mfd(:,:) ! flux de masse dans le panache descendant |
---|
| 124 | REAL,ALLOCATABLE,SAVE :: en_u(:,:) ! flux entraine dans le panache montant |
---|
| 125 | REAL,ALLOCATABLE,SAVE :: de_u(:,:) ! flux detraine dans le panache montant |
---|
| 126 | REAL,ALLOCATABLE,SAVE :: en_d(:,:) ! flux entraine dans le panache descendant |
---|
| 127 | REAL,ALLOCATABLE,SAVE :: de_d(:,:) ! flux detraine dans le panache descendant |
---|
| 128 | REAL,ALLOCATABLE,SAVE :: coefh(:,:) ! flux detraine dans le panache descendant |
---|
| 129 | |
---|
| 130 | REAL,ALLOCATABLE,SAVE :: pyu1(:) |
---|
| 131 | REAL,ALLOCATABLE,SAVE :: pyv1(:) |
---|
| 132 | REAL,ALLOCATABLE,SAVE :: pftsol(:,:) |
---|
| 133 | REAL,ALLOCATABLE,SAVE :: ppsrf(:,:) |
---|
| 134 | !$OMP THREADPRIVATE(mfu,mfd,en_u,de_u,en_d,de_d,coefh) |
---|
| 135 | !$OMP THREADPRIVATE(pyu1,pyv1,pftsol,ppsrf) |
---|
[524] | 136 | |
---|
[541] | 137 | |
---|
[5148] | 138 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: sh |
---|
| 139 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: da |
---|
| 140 | REAL,DIMENSION(:,:,:), ALLOCATABLE,SAVE :: phi |
---|
| 141 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: mp |
---|
| 142 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: upwd |
---|
| 143 | REAL,DIMENSION(:,:), ALLOCATABLE,SAVE :: dnwd |
---|
| 144 | |
---|
| 145 | REAL, SAVE :: dtcum |
---|
| 146 | INTEGER, SAVE:: iadvtr=0 |
---|
| 147 | !$OMP THREADPRIVATE(dtcum,iadvtr) |
---|
| 148 | REAL zmin,zmax |
---|
| 149 | LOGICAL ok_sync |
---|
| 150 | CHARACTER(len=12) :: nvar |
---|
| 151 | logical, parameter :: lstokenc=.FALSE. |
---|
| 152 | ! |
---|
| 153 | !====================================================================== |
---|
| 154 | |
---|
| 155 | iadvtr=iadvtr+1 |
---|
| 156 | |
---|
| 157 | ! Dans le meme vecteur on recombine le drag et les coeff d'echange |
---|
| 158 | pcoefh_buf(:,1) = cdragh(:) |
---|
| 159 | pcoefh_buf(:,2:klev) = pcoefh(:,2:klev) |
---|
| 160 | |
---|
| 161 | ok_sync = .TRUE. |
---|
| 162 | |
---|
| 163 | ! Initialization done only once |
---|
| 164 | !====================================================================== |
---|
| 165 | IF (iadvtr==1) THEN |
---|
| 166 | ALLOCATE( t(klon,klev)) |
---|
| 167 | ALLOCATE( mfu(klon,klev)) |
---|
| 168 | ALLOCATE( mfd(klon,klev)) |
---|
| 169 | ALLOCATE( en_u(klon,klev)) |
---|
| 170 | ALLOCATE( de_u(klon,klev)) |
---|
| 171 | ALLOCATE( en_d(klon,klev)) |
---|
| 172 | ALLOCATE( de_d(klon,klev)) |
---|
| 173 | ALLOCATE( coefh(klon,klev)) |
---|
| 174 | ALLOCATE( entr_therm(klon,klev)) |
---|
| 175 | ALLOCATE( fm_therm(klon,klev)) |
---|
| 176 | ALLOCATE( pyu1(klon)) |
---|
| 177 | ALLOCATE( pyv1(klon)) |
---|
| 178 | ALLOCATE( pftsol(klon,nbsrf)) |
---|
| 179 | ALLOCATE( ppsrf(klon,nbsrf)) |
---|
| 180 | |
---|
| 181 | ALLOCATE(sh(klon,klev)) |
---|
| 182 | ALLOCATE(da(klon,klev)) |
---|
| 183 | ALLOCATE(phi(klon,klev,klev)) |
---|
| 184 | ALLOCATE(mp(klon,klev)) |
---|
| 185 | ALLOCATE(upwd(klon,klev)) |
---|
| 186 | ALLOCATE(dnwd(klon,klev)) |
---|
| 187 | |
---|
| 188 | CALL initphysto('phystoke', dtime, dtime*istphy,dtime*istphy,physid) |
---|
| 189 | |
---|
| 190 | ! Write field phis and aire only once |
---|
| 191 | CALL histwrite_phy(physid,lstokenc,"phis",itap,pphis) |
---|
| 192 | CALL histwrite_phy(physid,lstokenc,"aire",itap,paire) |
---|
| 193 | CALL histwrite_phy(physid,lstokenc,"longitudes",itap,rlon) |
---|
| 194 | CALL histwrite_phy(physid,lstokenc,"latitudes",itap,rlat) |
---|
| 195 | |
---|
| 196 | END IF |
---|
| 197 | |
---|
| 198 | |
---|
| 199 | ! Set to zero cumulating fields |
---|
| 200 | !====================================================================== |
---|
| 201 | IF (MOD(iadvtr,istphy)==1.OR.istphy==1) THEN |
---|
| 202 | WRITE(lunout,*)'reinitialisation des champs cumules a iadvtr=',iadvtr |
---|
| 203 | mfu(:,:)=0. |
---|
| 204 | mfd(:,:)=0. |
---|
| 205 | en_u(:,:)=0. |
---|
| 206 | de_u(:,:)=0. |
---|
| 207 | en_d(:,:)=0. |
---|
| 208 | de_d(:,:)=0. |
---|
| 209 | coefh(:,:)=0. |
---|
| 210 | t(:,:)=0. |
---|
| 211 | fm_therm(:,:)=0. |
---|
| 212 | entr_therm(:,:)=0. |
---|
| 213 | pyv1(:)=0. |
---|
| 214 | pyu1(:)=0. |
---|
| 215 | pftsol(:,:)=0. |
---|
| 216 | ppsrf(:,:)=0. |
---|
| 217 | sh(:,:)=0. |
---|
| 218 | da(:,:)=0. |
---|
| 219 | phi(:,:,:)=0. |
---|
| 220 | mp(:,:)=0. |
---|
| 221 | upwd(:,:)=0. |
---|
| 222 | dnwd(:,:)=0. |
---|
| 223 | dtcum=0. |
---|
| 224 | ENDIF |
---|
| 225 | |
---|
| 226 | |
---|
| 227 | ! Cumulate fields at each time step |
---|
| 228 | !====================================================================== |
---|
| 229 | DO k=1,klev |
---|
| 230 | DO i=1,klon |
---|
| 231 | mfu(i,k)=mfu(i,k)+pmfu(i,k)*pdtphys |
---|
| 232 | mfd(i,k)=mfd(i,k)+pmfd(i,k)*pdtphys |
---|
| 233 | en_u(i,k)=en_u(i,k)+pen_u(i,k)*pdtphys |
---|
| 234 | de_u(i,k)=de_u(i,k)+pde_u(i,k)*pdtphys |
---|
| 235 | en_d(i,k)=en_d(i,k)+pen_d(i,k)*pdtphys |
---|
| 236 | de_d(i,k)=de_d(i,k)+pde_d(i,k)*pdtphys |
---|
| 237 | coefh(i,k)=coefh(i,k)+pcoefh_buf(i,k)*pdtphys |
---|
| 238 | t(i,k)=t(i,k)+pt(i,k)*pdtphys |
---|
| 239 | fm_therm(i,k)=fm_therm(i,k)+pfm_therm(i,k)*pdtphys |
---|
| 240 | entr_therm(i,k)=entr_therm(i,k)+pentr_therm(i,k)*pdtphys |
---|
| 241 | sh(i,k) = sh(i,k) + psh(i,k)*pdtphys |
---|
| 242 | da(i,k) = da(i,k) + pda(i,k)*pdtphys |
---|
| 243 | mp(i,k) = mp(i,k) + pmp(i,k)*pdtphys |
---|
| 244 | upwd(i,k) = upwd(i,k) + pupwd(i,k)*pdtphys |
---|
| 245 | dnwd(i,k) = dnwd(i,k) + pdnwd(i,k)*pdtphys |
---|
| 246 | ENDDO |
---|
| 247 | ENDDO |
---|
| 248 | |
---|
| 249 | DO kk=1,klev |
---|
| 250 | DO k=1,klev |
---|
| 251 | DO i=1,klon |
---|
| 252 | phi(i,k,kk) = phi(i,k,kk) + pphi(i,k,kk)*pdtphys |
---|
| 253 | END DO |
---|
| 254 | END DO |
---|
| 255 | END DO |
---|
| 256 | |
---|
| 257 | DO i=1,klon |
---|
| 258 | pyv1(i)=pyv1(i)+yv1(i)*pdtphys |
---|
| 259 | pyu1(i)=pyu1(i)+yu1(i)*pdtphys |
---|
| 260 | END DO |
---|
| 261 | DO k=1,nbsrf |
---|
| 262 | DO i=1,klon |
---|
| 263 | pftsol(i,k)=pftsol(i,k)+ftsol(i,k)*pdtphys |
---|
| 264 | ppsrf(i,k)=ppsrf(i,k)+pctsrf(i,k)*pdtphys |
---|
| 265 | ENDDO |
---|
| 266 | ENDDO |
---|
| 267 | |
---|
| 268 | ! Add time step to cumulated time |
---|
| 269 | dtcum=dtcum+pdtphys |
---|
| 270 | |
---|
| 271 | |
---|
| 272 | ! Write fields to file, if it is time to do so |
---|
| 273 | !====================================================================== |
---|
| 274 | IF(MOD(iadvtr,istphy)==0) THEN |
---|
| 275 | |
---|
| 276 | ! normalize with time period |
---|
| 277 | DO k=1,klev |
---|
| 278 | DO i=1,klon |
---|
| 279 | mfu(i,k)=mfu(i,k)/dtcum |
---|
| 280 | mfd(i,k)=mfd(i,k)/dtcum |
---|
| 281 | en_u(i,k)=en_u(i,k)/dtcum |
---|
| 282 | de_u(i,k)=de_u(i,k)/dtcum |
---|
| 283 | en_d(i,k)=en_d(i,k)/dtcum |
---|
| 284 | de_d(i,k)=de_d(i,k)/dtcum |
---|
| 285 | coefh(i,k)=coefh(i,k)/dtcum |
---|
| 286 | t(i,k)=t(i,k)/dtcum |
---|
| 287 | fm_therm(i,k)=fm_therm(i,k)/dtcum |
---|
| 288 | entr_therm(i,k)=entr_therm(i,k)/dtcum |
---|
| 289 | sh(i,k)=sh(i,k)/dtcum |
---|
| 290 | da(i,k)=da(i,k)/dtcum |
---|
| 291 | mp(i,k)=mp(i,k)/dtcum |
---|
| 292 | upwd(i,k)=upwd(i,k)/dtcum |
---|
| 293 | dnwd(i,k)=dnwd(i,k)/dtcum |
---|
| 294 | ENDDO |
---|
| 295 | ENDDO |
---|
| 296 | DO kk=1,klev |
---|
| 297 | DO k=1,klev |
---|
| 298 | DO i=1,klon |
---|
| 299 | phi(i,k,kk) = phi(i,k,kk)/dtcum |
---|
| 300 | END DO |
---|
| 301 | END DO |
---|
| 302 | END DO |
---|
| 303 | DO i=1,klon |
---|
| 304 | pyv1(i)=pyv1(i)/dtcum |
---|
| 305 | pyu1(i)=pyu1(i)/dtcum |
---|
| 306 | END DO |
---|
| 307 | DO k=1,nbsrf |
---|
| 308 | DO i=1,klon |
---|
| 309 | pftsol(i,k)=pftsol(i,k)/dtcum |
---|
| 310 | ppsrf(i,k)=ppsrf(i,k)/dtcum |
---|
| 311 | ENDDO |
---|
| 312 | ENDDO |
---|
| 313 | |
---|
| 314 | ! write fields |
---|
| 315 | CALL histwrite_phy(physid,lstokenc,"t",itap,t) |
---|
| 316 | CALL histwrite_phy(physid,lstokenc,"mfu",itap,mfu) |
---|
| 317 | CALL histwrite_phy(physid,lstokenc,"mfd",itap,mfd) |
---|
| 318 | CALL histwrite_phy(physid,lstokenc,"en_u",itap,en_u) |
---|
| 319 | CALL histwrite_phy(physid,lstokenc,"de_u",itap,de_u) |
---|
| 320 | CALL histwrite_phy(physid,lstokenc,"en_d",itap,en_d) |
---|
| 321 | CALL histwrite_phy(physid,lstokenc,"de_d",itap,de_d) |
---|
| 322 | CALL histwrite_phy(physid,lstokenc,"coefh",itap,coefh) |
---|
| 323 | CALL histwrite_phy(physid,lstokenc,"fm_th",itap,fm_therm) |
---|
| 324 | CALL histwrite_phy(physid,lstokenc,"en_th",itap,entr_therm) |
---|
| 325 | CALL histwrite_phy(physid,lstokenc,"frac_impa",itap,frac_impa) |
---|
| 326 | CALL histwrite_phy(physid,lstokenc,"frac_nucl",itap,frac_nucl) |
---|
| 327 | CALL histwrite_phy(physid,lstokenc,"pyu1",itap,pyu1) |
---|
| 328 | CALL histwrite_phy(physid,lstokenc,"pyv1",itap,pyv1) |
---|
| 329 | CALL histwrite_phy(physid,lstokenc,"ftsol1",itap,pftsol(:,1)) |
---|
| 330 | CALL histwrite_phy(physid,lstokenc,"ftsol2",itap,pftsol(:,2)) |
---|
| 331 | CALL histwrite_phy(physid,lstokenc,"ftsol3",itap,pftsol(:,3)) |
---|
| 332 | CALL histwrite_phy(physid,lstokenc,"ftsol4",itap,pftsol(:,4)) |
---|
| 333 | CALL histwrite_phy(physid,lstokenc,"psrf1",itap,ppsrf(:,1)) |
---|
| 334 | CALL histwrite_phy(physid,lstokenc,"psrf2",itap,ppsrf(:,2)) |
---|
| 335 | CALL histwrite_phy(physid,lstokenc,"psrf3",itap,ppsrf(:,3)) |
---|
| 336 | CALL histwrite_phy(physid,lstokenc,"psrf4",itap,ppsrf(:,4)) |
---|
| 337 | CALL histwrite_phy(physid,lstokenc,"sh",itap,sh) |
---|
| 338 | CALL histwrite_phy(physid,lstokenc,"da",itap,da) |
---|
| 339 | CALL histwrite_phy(physid,lstokenc,"mp",itap,mp) |
---|
| 340 | CALL histwrite_phy(physid,lstokenc,"upwd",itap,upwd) |
---|
| 341 | CALL histwrite_phy(physid,lstokenc,"dnwd",itap,dnwd) |
---|
| 342 | |
---|
| 343 | |
---|
| 344 | ! phi |
---|
| 345 | DO k=1,klev |
---|
| 346 | IF (k<10) THEN |
---|
| 347 | WRITE(nvar,'(i1)') k |
---|
| 348 | ELSE IF (k<100) THEN |
---|
| 349 | WRITE(nvar,'(i2)') k |
---|
| 350 | ELSE |
---|
| 351 | WRITE(nvar,'(i3)') k |
---|
| 352 | END IF |
---|
| 353 | nvar='phi_lev'//trim(nvar) |
---|
| 354 | |
---|
| 355 | CALL histwrite_phy(physid,lstokenc,nvar,itap,phi(:,:,k)) |
---|
| 356 | END DO |
---|
| 357 | |
---|
| 358 | ! Syncronize file |
---|
| 359 | !$OMP MASTER |
---|
| 360 | IF (ok_sync) CALL histsync(physid) |
---|
| 361 | !$OMP END MASTER |
---|
| 362 | |
---|
| 363 | |
---|
| 364 | ! Calculate min and max values for some fields (coefficients de lessivage) |
---|
| 365 | zmin=1e33 |
---|
| 366 | zmax=-1e33 |
---|
| 367 | DO k=1,klev |
---|
| 368 | DO i=1,klon |
---|
| 369 | zmax=MAX(zmax,frac_nucl(i,k)) |
---|
| 370 | zmin=MIN(zmin,frac_nucl(i,k)) |
---|
| 371 | ENDDO |
---|
| 372 | ENDDO |
---|
| 373 | WRITE(lunout,*)'------ coefs de lessivage (min et max) --------' |
---|
| 374 | WRITE(lunout,*)'facteur de nucleation ',zmin,zmax |
---|
| 375 | zmin=1e33 |
---|
| 376 | zmax=-1e33 |
---|
| 377 | DO k=1,klev |
---|
| 378 | DO i=1,klon |
---|
| 379 | zmax=MAX(zmax,frac_impa(i,k)) |
---|
| 380 | zmin=MIN(zmin,frac_impa(i,k)) |
---|
| 381 | ENDDO |
---|
| 382 | ENDDO |
---|
| 383 | WRITE(lunout,*)'facteur d impaction ',zmin,zmax |
---|
| 384 | |
---|
| 385 | ENDIF ! IF(MOD(iadvtr,istphy)==0) |
---|
| 386 | |
---|
| 387 | END SUBROUTINE phystokenc |
---|
| 388 | |
---|
| 389 | END MODULE phystokenc_mod |
---|