Changeset 98
- Timestamp:
- Jul 5, 2000, 4:58:04 PM (25 years ago)
- Location:
- LMDZ.3.3/branches/rel-LF/libf/phylmd
- Files:
-
- 16 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ.3.3/branches/rel-LF/libf/phylmd/YOMCST.h
r2 r98 1 CA1.0 Fundamental constants1 ! A1.0 Fundamental constants 2 2 REAL RPI,RCLUM,RHPLA,RKBOL,RNAVO 3 CA1.1 Astronomical constants3 ! A1.1 Astronomical constants 4 4 REAL RDAY,REA,REPSM,RSIYEA,RSIDAY,ROMEGA 5 cA1.1.bis Constantes concernant l'orbite de la Terre:5 ! A1.1.bis Constantes concernant l'orbite de la Terre: 6 6 REAL R_ecc, R_peri, R_incl 7 CA1.2 Geoide7 ! A1.2 Geoide 8 8 REAL RA,RG,R1SA 9 CA1.3 Radiation9 ! A1.3 Radiation 10 10 REAL RSIGMA,RI0 11 CA1.4 Thermodynamic gas phase11 ! A1.4 Thermodynamic gas phase 12 12 REAL R,RMD,RMV,RD,RV,RCPD,RCPV,RCVD,RCVV 13 13 REAL RKAPPA,RETV 14 CA1.5,6 Thermodynamic liquid,solid phases14 ! A1.5,6 Thermodynamic liquid,solid phases 15 15 REAL RCW,RCS 16 CA1.7 Thermodynamic transition of phase16 ! A1.7 Thermodynamic transition of phase 17 17 REAL RLVTT,RLSTT,RLMLT,RTT,RATM 18 CA1.8 Curve of saturation18 ! A1.8 Curve of saturation 19 19 REAL RESTT,RALPW,RBETW,RGAMW,RALPS,RBETS,RGAMS 20 20 REAL RALPD,RBETD,RGAMD 21 C 21 ! 22 22 COMMON/YOMCST/RPI ,RCLUM ,RHPLA ,RKBOL ,RNAVO 23 23 S ,RDAY ,REA ,REPSM ,RSIYEA,RSIDAY,ROMEGA … … 31 31 S ,RESTT ,RALPW ,RBETW ,RGAMW ,RALPS ,RBETS ,RGAMS 32 32 S ,RALPD ,RBETD ,RGAMD 33 C------------------------------------------------------------------33 ! ------------------------------------------------------------------ -
LMDZ.3.3/branches/rel-LF/libf/phylmd/clim.h
r2 r98 42 42 PARAMETER ( CLIM_Void = 0 ) 43 43 PARAMETER ( CLIM_MaxMod = 8 ) 44 PARAMETER ( CLIM_MaxPort = 16)44 PARAMETER ( CLIM_MaxPort = 40 ) 45 45 PARAMETER ( CLIM_MaxSegments = 160 ) 46 46 PARAMETER ( CLIM_MaxLink = CLIM_MaxMod * CLIM_MaxPort ) -
LMDZ.3.3/branches/rel-LF/libf/phylmd/clmain.F
r86 r98 1 1 SUBROUTINE clmain(dtime,pctsrf,t,q,u,v, 2 . soil_model,ts,soilcap,soilflux, 3 . paprs,pplay,radsol,snow,qsol, 4 . xlat, rugos, 2 . ok_veget,ts, 3 . paprs,pplay,radsol,snow,qsol,evap,albe, 4 . rain_f, snow_f, solsw, sollw, 5 . rlon, rlat, rugos, 6 . debut, lafin, 5 7 . d_t,d_q,d_u,d_v,d_ts, 6 8 . flux_t,flux_q,flux_u,flux_v,cdragh,cdragm, … … 41 43 c beta-----input-R- coefficient de l'evaporation reelle (0 a 1) 42 44 c dif_grnd-input-R- coeff. de diffusion (chaleur) vers le sol profond 43 c xlat-----input-R- latitude en degree45 c rlat-----input-R- latitude en degree 44 46 c rugos----input-R- longeur de rugosite (en m) 45 47 c … … 75 77 REAL u(klon,klev), v(klon,klev) 76 78 REAL paprs(klon,klev+1), pplay(klon,klev), radsol(klon) 77 REAL xlat(klon)79 REAL rlon(klon), rlat(klon) 78 80 REAL d_t(klon, klev), d_q(klon, klev) 79 81 REAL d_u(klon, klev), d_v(klon, klev) 80 REAL flux_t(klon,klev ), flux_q(klon,klev)82 REAL flux_t(klon,klev, nbsrf), flux_q(klon,klev, nbsrf) 81 83 REAL dflux_t(klon), dflux_q(klon) 82 REAL flux_u(klon,klev ), flux_v(klon,klev)84 REAL flux_u(klon,klev, nbsrf), flux_v(klon,klev, nbsrf) 83 85 REAL rugmer(klon) 84 86 REAL cdragh(klon), cdragm(klon) 87 LOGICAL debut, lafin, ok_veget 85 88 cAA INTEGER itr 86 89 cAA REAL tr(klon,klev,nbtr) … … 93 96 REAL snow(klon,nbsrf) 94 97 REAL qsol(klon,nbsrf) 98 REAL evap(klon,nbsrf) 99 REAL albe(klon,nbsrf) 100 real rain_f(klon), snow_f(klon) 101 REAL sollw(klon), solsw(klon) 95 102 REAL rugos(klon,nbsrf) 96 103 cAA … … 103 110 c====================================================================== 104 111 REAL yts(klon), yrugos(klon), ypct(klon) 105 REAL ycal(klon), ybeta(klon), ydif(klon) 112 REAL ycal(klon), ybeta(klon), ydif(klon), yalb(klon),yevap(klon) 106 113 REAL yu1(klon), yv1(klon) 114 real ysnow(klon), yqsol(klon) 115 real yrain_f(klon), ysnow_f(klon) 116 real ysollw(klon), ysolsw(klon), ysolswnet(klon) 107 117 REAL yrugm(klon), yrads(klon) 108 118 REAL y_d_ts(klon) … … 144 154 c====================================================================== 145 155 146 write(*,*)'CLMAIN.NEW'147 148 156 DO k = 1, klev ! epaisseur de couche 149 157 DO i = 1, klon … … 174 182 d_ts(i,nsrf) = 0.0 175 183 ENDDO 176 ENDDO 184 END DO 185 C§§§ PB 186 flux_t = 0. 187 flux_q = 0. 188 flux_u = 0. 189 flux_v = 0. 177 190 DO k = 1, klev 178 191 DO i = 1, klon 179 192 d_t(i,k) = 0.0 180 193 d_q(i,k) = 0.0 181 flux_t(i,k) = 0.0182 flux_q(i,k) = 0.0194 c$$$ flux_t(i,k) = 0.0 195 c$$$ flux_q(i,k) = 0.0 183 196 d_u(i,k) = 0.0 184 197 d_v(i,k) = 0.0 185 flux_u(i,k) = 0.0186 flux_v(i,k) = 0.0198 c$$$ flux_u(i,k) = 0.0 199 c$$$ flux_v(i,k) = 0.0 187 200 zcoefh(i,k) = 0.0 188 201 ENDDO … … 203 216 c 204 217 c prescrire les proprietes du sol: 205 CALL calbeta(dtime,nsrf,snow,qsol, beta,capsol,dif_grnd) 206 IF (.NOT.soil_model) THEN 207 DO i = 1, klon 208 cal(i) = RCPD * capsol(i) 209 totalflu(i) = radsol(i) 210 ENDDO 211 ELSE 212 DO i = 1, klon 213 totalflu(i) = soilflux(i,nsrf) + radsol(i) 214 IF (nsrf.EQ.is_oce) THEN 215 cal(i) = 0.0 216 ELSE 217 cal(i) = RCPD / soilcap(i,nsrf) 218 ENDIF 219 ENDDO 220 ENDIF 221 c 218 c CALL calbeta(dtime,nsrf,snow,qsol, beta,capsol,dif_grnd) 219 c IF (.NOT.soil_model) THEN 220 c DO i = 1, klon 221 c cal(i) = RCPD * capsol(i) 222 c totalflu(i) = radsol(i) 223 c ENDDO 224 c ELSE 225 c DO i = 1, klon 226 c totalflu(i) = soilflux(i,nsrf) + radsol(i) 227 c IF (nsrf.EQ.is_oce) THEN 228 c cal(i) = 0.0 229 c ELSE 230 c cal(i) = RCPD / soilcap(i,nsrf) 231 c ENDIF 232 c ENDDO 233 c ENDIF 234 c 235 totalflu = radsol 236 222 237 c chercher les indices: 223 238 DO j = 1, klon … … 237 252 ypct(j) = pctsrf(i,nsrf) 238 253 yts(j) = ts(i,nsrf) 254 ysnow(j) = snow(i,nsrf) 255 yevap(j) = evap(i,nsrf) 256 yqsol(j) = qsol(i,nsrf) 257 yalb(j) = albe(i,nsrf) 258 yrain_f(j) = rain_f(i) 259 ysnow_f(j) = snow_f(i) 260 ysolsw(j) = solsw(i) 261 ysollw(j) = sollw(i) 239 262 yrugos(j) = rugos(i,nsrf) 240 263 yu1(j) = u1lay(i) 241 264 yv1(j) = v1lay(i) 242 265 yrads(j) = totalflu(i) 243 ycal(j) = cal(i)244 ybeta(j) = beta(i)245 ydif(j) = dif_grnd(i)266 c ycal(j) = cal(i) 267 c ybeta(j) = beta(i) 268 c ydif(j) = dif_grnd(i) 246 269 ypaprs(j,klev+1) = paprs(i,klev+1) 247 270 ENDDO … … 259 282 ENDDO 260 283 c 261 cAA IF (itr.GE.1) THEN262 cAA DO it = 1, itr263 cAA DO k = 1, klev264 cAA DO j = 1, knon265 cAA i = ni(j)266 cAA ytr(j,k,it) = tr(i,k,it)267 cAA ENDDO268 cAA ENDDO269 cAA DO j = 1, knon270 cAA i = ni(j)271 cAA yflxsrf(j,it) = flux_surf(i,it)272 cAA ENDDO273 cAA ENDDO274 cAA ENDIF275 284 c 276 285 c calculer Cdrag et les coefficients d'echange … … 287 296 ENDDO 288 297 c 289 c parametrisation non-locale:290 IF (ok_nonloc) THEN291 DO i = 1, knon292 y_cd_h(i) = ycoefh(i,1)293 y_cd_m(i) = ycoefm(i,1)294 ENDDO295 CALL nonlocal(knon, ypaprs, ypplay,296 . yts,ybeta,yu,yv,yt,yq,297 . y_cd_h, y_cd_m, ycoefm0, ycoefh0, ygamt, ygamq)298 DO k = 1, klev299 DO i = 1, knon300 ycoefm(i,k) = MAX(ycoefm(i,k),ycoefm0(i,k))301 ycoefh(i,k) = MAX(ycoefh(i,k),ycoefh0(i,k))302 ENDDO303 ENDDO304 ELSE305 IF (.NOT.contreg) THEN306 DO k = 2, klev307 DO i = 1, knon308 ygamq(i,k) = 0.0309 ygamt(i,k) = 0.0310 ENDDO311 ENDDO312 ELSE313 DO k = 3, klev314 DO i = 1, knon315 ygamq(i,k) = 0.0316 ygamt(i,k) = -1.0E-03317 ENDDO318 ENDDO319 DO i = 1, knon320 ygamq(i,2) = 0.0321 ygamt(i,2) = -2.5E-03322 ENDDO323 ENDIF324 ENDIF325 298 c 326 299 c calculer la diffusion de "q" et de "h" 327 CALL clqh(knon, dtime, nsrf,yu1, yv1, 300 CALL clqh(knon, dtime, nsrf, ni, pctsrf, rlon, rlat, 301 e yu1, yv1, 328 302 e ycoefh,yt,yq,yts,ypaprs,ypplay,ydelp,yrads, 329 e ycal,ybeta,ydif,ygamt,ygamq, 303 e yevap,yalb, ysnow, yqsol, yrain_f, ysnow_f, 304 e ysollw, ysolsw, 330 305 s y_d_t, y_d_q, y_d_ts, 331 306 s y_flux_t, y_flux_q, y_dflux_t, y_dflux_q) … … 363 338 c 364 339 DO k = 1, klev 340 DO j = 1, knon 341 i = ni(j) 342 ycoefh(j,k) = ycoefh(j,k) * ypct(j) 343 ycoefm(j,k) = ycoefm(j,k) * ypct(j) 344 y_d_t(j,k) = y_d_t(j,k) * ypct(j) 345 y_d_q(j,k) = y_d_q(j,k) * ypct(j) 346 C§§§ PB 347 flux_t(i,k,nsrf) = y_flux_t(j,k) 348 flux_q(i,k,nsrf) = y_flux_q(j,k) 349 flux_u(i,k,nsrf) = y_flux_u(j,k) 350 flux_v(i,k,nsrf) = y_flux_v(j,k) 351 c$$$ PB y_flux_t(j,k) = y_flux_t(j,k) * ypct(j) 352 c$$$ PB y_flux_q(j,k) = y_flux_q(j,k) * ypct(j) 353 y_d_u(j,k) = y_d_u(j,k) * ypct(j) 354 y_d_v(j,k) = y_d_v(j,k) * ypct(j) 355 c$$$ PB y_flux_u(j,k) = y_flux_u(j,k) * ypct(j) 356 c$$$ PB y_flux_v(j,k) = y_flux_v(j,k) * ypct(j) 357 ENDDO 358 ENDDO 359 360 evap(:,nsrf) = - flux_q(:,1,nsrf) 361 c 365 362 DO j = 1, knon 366 ycoefh(j,k) = ycoefh(j,k) * ypct(j) 367 ycoefm(j,k) = ycoefm(j,k) * ypct(j) 368 y_d_t(j,k) = y_d_t(j,k) * ypct(j) 369 y_d_q(j,k) = y_d_q(j,k) * ypct(j) 370 y_flux_t(j,k) = y_flux_t(j,k) * ypct(j) 371 y_flux_q(j,k) = y_flux_q(j,k) * ypct(j) 372 y_d_u(j,k) = y_d_u(j,k) * ypct(j) 373 y_d_v(j,k) = y_d_v(j,k) * ypct(j) 374 y_flux_u(j,k) = y_flux_u(j,k) * ypct(j) 375 y_flux_v(j,k) = y_flux_v(j,k) * ypct(j) 376 ENDDO 377 ENDDO 378 c 379 DO j = 1, knon 380 i = ni(j) 363 i = ni(j) 381 364 d_ts(i,nsrf) = y_d_ts(j) 365 albe(i,nsrf) = yalb(j) 366 snow(i,nsrf) = ysnow(j) 367 qsol(i,nsrf) = yqsol(j) 382 368 rugmer(i) = yrugm(j) 383 369 cdragh(i) = cdragh(i) + ycoefh(j,1) … … 400 386 d_t(i,k) = d_t(i,k) + y_d_t(j,k) 401 387 d_q(i,k) = d_q(i,k) + y_d_q(j,k) 402 403 flux_q(i,k) = flux_q(i,k) + y_flux_q(j,k)388 c$$$ PB flux_t(i,k) = flux_t(i,k) + y_flux_t(j,k) 389 c$$$ flux_q(i,k) = flux_q(i,k) + y_flux_q(j,k) 404 390 d_u(i,k) = d_u(i,k) + y_d_u(j,k) 405 391 d_v(i,k) = d_v(i,k) + y_d_v(j,k) 406 407 flux_v(i,k) = flux_v(i,k) + y_flux_v(j,k)392 c$$$ PB flux_u(i,k) = flux_u(i,k) + y_flux_u(j,k) 393 c$$$ flux_v(i,k) = flux_v(i,k) + y_flux_v(j,k) 408 394 zcoefh(i,k) = zcoefh(i,k) + ycoefh(j,k) 409 395 ENDDO … … 430 416 99999 CONTINUE 431 417 c 418 432 419 RETURN 433 420 END 434 SUBROUTINE clqh(knon,dtime,nisurf,u1lay,v1lay,coef, 421 SUBROUTINE clqh(knon,dtime,nisurf,knindex,pctsrf, rlon, rlat, 422 e u1lay,v1lay,coef, 435 423 e t,q,ts,paprs,pplay, 436 e delp,radsol,cal,beta,dif_grnd, gamt,gamq, 424 e delp,radsol,evap,albedo,snow,qsol, 425 e precip_rain, precip_snow, 426 e lwdown, swdown, 437 427 s d_t, d_q, d_ts, flux_t, flux_q,dflux_s,dflux_l) 438 428 … … 446 436 #include "dimensions.h" 447 437 #include "dimphy.h" 438 #include "YOMCST.h" 439 #include "YOETHF.h" 440 #include "FCTTRE.h" 441 #include "indicesol.h" 448 442 c Arguments: 449 443 INTEGER knon … … 462 456 REAL q(klon,klev) ! humidite specifique (kg/kg) 463 457 REAL ts(klon) ! temperature du sol (K) 458 REAL evap(klon) ! evaporation au sol 464 459 REAL paprs(klon,klev+1) ! pression a inter-couche (Pa) 465 460 REAL pplay(klon,klev) ! pression au milieu de couche (Pa) 466 461 REAL delp(klon,klev) ! epaisseur de couche en pression (Pa) 467 462 REAL radsol(klon) ! ray. net au sol (Solaire+IR) W/m2 463 REAL albedo(klon) ! albedo de la surface 464 REAL snow(klon) ! hauteur de neige 465 REAL qsol(klon) ! humidite de la surface 466 real precip_rain(klon), precip_snow(klon) 467 integer knindex(klon) 468 real pctsrf(klon,nbsrf) 469 real rlon(klon), rlat(klon) 468 470 c 469 471 REAL d_t(klon,klev) ! incrementation de "t" … … 521 523 c====================================================================== 522 524 REAL zcor, zdelta, zcvm5 523 #include "YOMCST.h" 524 #include "YOETHF.h" 525 #include "FCTTRE.h" 526 #include "indicesol.h" 525 logical contreg 526 parameter (contreg=.true.) 527 527 c====================================================================== 528 528 c Rajout pour l'interface … … 530 530 integer jour 531 531 integer nisurf 532 integer knindex(klon)533 532 logical debut, lafin, ok_veget 534 real rlon(klon), rlat(klon) 535 real zlev(klon), zlflu(klon) 533 real zlev1(klon) 536 534 real temp_air(klon), spechum(klon) 537 535 real hum_air(klon), ccanopy(klon) 538 536 real tq_cdrag(klon), petAcoef(klon), peqAcoef(klon) 539 537 real petBcoef(klon), peqBcoef(klon) 540 real precip_rain(klon), precip_snow(klon)541 538 real lwdown(klon), swnet(klon), swdown(klon), ps(klon) 542 539 real p1lay(klon) … … 545 542 546 543 ! Parametres de sortie 547 real evap(klon),fluxsens(klon), fluxlat(klon)544 real fluxsens(klon), fluxlat(klon) 548 545 real tsol_rad(klon), tsurf_new(klon), alb_new(klon) 549 546 real emis_new(klon), z0_new(klon) 550 real dflux_l(klon), dflux_s(klon)551 547 real pctsrf_new(klon,nbsrf) 552 548 c 549 550 if (.not. contreg) then 551 do k = 2, klev 552 do i = 1, knon 553 gamq(i,k) = 0.0 554 gamt(i,k) = 0.0 555 enddo 556 enddo 557 else 558 do k = 3, klev 559 do i = 1, knon 560 gamq(i,k)= 0.0 561 gamt(i,k)= -1.0e-03 562 enddo 563 enddo 564 do i = 1, knon 565 gamq(i,2) = 0.0 566 gamt(i,2) = -2.5e-03 567 enddo 568 endif 553 569 554 570 DO i = 1, knon … … 650 666 spechum=q(:,1) 651 667 p1lay = pplay(:,1) 668 zlev1 = delp(:,1) 669 swnet = swdown * (1 - albedo) 670 c En attendant mieux 671 hum_air = 0. 672 ccanopy = 0. 673 tq_cdrag = 0. 652 674 653 675 CALL interfsurf(itime, dtime, jour, 654 . klon, nisurf, knon, knindex, rlon, rlat,676 . klon, iim, jjm, nisurf, knon, knindex, pctsrf, rlon, rlat, 655 677 . debut, lafin, ok_veget, 656 . zlev , zlflu,u1lay, v1lay, temp_air, spechum, hum_air, ccanopy,678 . zlev1, u1lay, v1lay, temp_air, spechum, hum_air, ccanopy, 657 679 . tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, 658 680 . precip_rain, precip_snow, lwdown, swnet, swdown, 659 . ts, p1lay, cal, beta, coef1lay, psref, radsol, dif_grnd, 681 . albedo, snow, qsol, 682 . ts, p1lay, coef1lay, psref, radsol, 660 683 . ocean, 661 684 . evap, fluxsens, fluxlat, dflux_l, dflux_s, 662 . tsol_rad, tsurf_new, alb_new, emis_new, z0_new, pctsrf_new) 685 . tsol_rad, tsurf_new, alb_new, emis_new, z0_new, pctsrf_new, 686 . zmasq) 663 687 664 688 flux_t(:,1) = fluxsens 665 flux_q(:,1) = fluxlat689 flux_q(:,1) = - evap 666 690 d_ts = tsurf_new - ts 691 albedo = alb_new 667 692 668 693 c==== une fois on a zx_h_ts, on peut faire l'iteration ======== … … 1228 1253 RETURN 1229 1254 END 1230 SUBROUTINE calbeta(dtime,indice, snow,qsol,1255 SUBROUTINE calbeta(dtime,indice,knon,snow,qsol, 1231 1256 . vbeta,vcal,vdif) 1232 1257 IMPLICIT none … … 1238 1263 c Calculer quelques parametres pour appliquer la couche limite 1239 1264 c ------------------------------------------------------------ 1240 #include "dimensions.h"1241 #include "dimphy.h"1265 !#include "dimensions.h" 1266 !#include "dimphy.h" 1242 1267 #include "YOMCST.h" 1243 1268 #include "indicesol.h" … … 1256 1281 c 1257 1282 REAL dtime 1258 REAL snow(k lon,nbsrf), qsol(klon,nbsrf)1259 INTEGER indice 1260 C 1261 REAL vbeta(k lon)1262 REAL vcal(k lon)1263 REAL vdif(k lon)1283 REAL snow(knon,nbsrf), qsol(knon,nbsrf) 1284 INTEGER indice, knon 1285 C 1286 REAL vbeta(knon) 1287 REAL vcal(knon) 1288 REAL vdif(knon) 1264 1289 C 1265 1290 IF (indice.EQ.is_oce) THEN 1266 DO i = 1, k lon1291 DO i = 1, knon 1267 1292 vcal(i) = 0.0 1268 1293 vbeta(i) = 1.0 … … 1272 1297 c 1273 1298 IF (indice.EQ.is_sic) THEN 1274 DO i = 1, k lon1299 DO i = 1, knon 1275 1300 vcal(i) = calice 1276 1301 IF (snow(i,is_sic) .GT. 0.0) vcal(i) = calsno … … 1282 1307 c 1283 1308 IF (indice.EQ.is_ter) THEN 1284 DO i = 1, k lon1309 DO i = 1, knon 1285 1310 vcal(i) = calsol 1286 1311 IF (snow(i,is_ter) .GT. 0.0) vcal(i) = calsno … … 1291 1316 c 1292 1317 IF (indice.EQ.is_lic) THEN 1293 DO i = 1, k lon1318 DO i = 1, knon 1294 1319 vcal(i) = calice 1295 1320 IF (snow(i,is_lic) .GT. 0.0) vcal(i) = calsno -
LMDZ.3.3/branches/rel-LF/libf/phylmd/condsurf.F
r79 r98 31 31 32 32 LOGICAL newlmt 33 PARAMETER (newlmt=. FALSE.)33 PARAMETER (newlmt=.TRUE.) 34 34 35 35 INTEGER nannemax … … 114 114 IF (newlmt) THEN 115 115 c 116 c Fraction "ocean":117 ierr = NF_INQ_VARID (nid, "FOCE", nvarid)118 IF (ierr .NE. NF_NOERR) THEN119 PRINT*, "condsurf: Le champ <FOCE> est absent"120 CALL abort121 ENDIF122 #ifdef NC_DOUBLE123 ierr = NF_GET_VARA_DOUBLE(nid,nvarid,debut,epais,pctsrf(1,is_oce))124 #else125 ierr = NF_GET_VARA_REAL(nid,nvarid,debut,epais,pctsrf(1,is_oce))126 #endif127 IF (ierr .NE. NF_NOERR) THEN128 PRINT*, "condsurf: Lecture echouee pour <FOCE>"129 CALL abort130 ENDIF116 c$$$c Fraction "ocean": 117 c$$$ ierr = NF_INQ_VARID (nid, "FOCE", nvarid) 118 c$$$ IF (ierr .NE. NF_NOERR) THEN 119 c$$$ PRINT*, "condsurf: Le champ <FOCE> est absent" 120 c$$$ CALL abort 121 c$$$ ENDIF 122 c$$$#ifdef NC_DOUBLE 123 c$$$ ierr = NF_GET_VARA_DOUBLE(nid,nvarid,debut,epais,pctsrf(1,is_oce)) 124 c$$$#else 125 c$$$ ierr = NF_GET_VARA_REAL(nid,nvarid,debut,epais,pctsrf(1,is_oce)) 126 c$$$#endif 127 c$$$ IF (ierr .NE. NF_NOERR) THEN 128 c$$$ PRINT*, "condsurf: Lecture echouee pour <FOCE>" 129 c$$$ CALL abort 130 c$$$ ENDIF 131 131 c 132 132 c Fraction "glace de mer": 133 c 134 c 133 135 ierr = NF_INQ_VARID (nid, "FSIC", nvarid) 134 136 IF (ierr .NE. NF_NOERR) THEN … … 145 147 CALL abort 146 148 ENDIF 147 c 148 c Fraction "terre": 149 ierr = NF_INQ_VARID (nid, "FTER", nvarid) 150 IF (ierr .NE. NF_NOERR) THEN 151 PRINT*, "condsurf: Le champ <FTER> est absent" 152 CALL abort 153 ENDIF 154 #ifdef NC_DOUBLE 155 ierr = NF_GET_VARA_DOUBLE(nid,nvarid,debut,epais,pctsrf(1,is_ter)) 156 #else 157 ierr = NF_GET_VARA_REAL(nid,nvarid,debut,epais,pctsrf(1,is_ter)) 158 #endif 159 IF (ierr .NE. NF_NOERR) THEN 160 PRINT*, "condsurf: Lecture echouee pour <FTER>" 161 CALL abort 162 ENDIF 163 c 164 c Fraction "glacier terre": 165 ierr = NF_INQ_VARID (nid, "FLIC", nvarid) 166 IF (ierr .NE. NF_NOERR) THEN 167 PRINT*, "condsurf: Le champ <FLIC> est absent" 168 CALL abort 169 ENDIF 170 #ifdef NC_DOUBLE 171 ierr = NF_GET_VARA_DOUBLE(nid,nvarid,debut,epais,pctsrf(1,is_lic)) 172 #else 173 ierr = NF_GET_VARA_REAL(nid,nvarid,debut,epais,pctsrf(1,is_lic)) 174 #endif 175 IF (ierr .NE. 0) THEN 176 PRINT*, "condsurf: Lecture echouee pour <FLIC>" 177 CALL abort 178 ENDIF 149 C 150 C positionnement % ocean libre et verification qu'il y a compatibilite des soussurfaces 151 pctsrf(1 : klon, is_oce) = (1. - zmasq(1 : klon)) 152 $ - pctsrf(1 : klon, is_sic) 153 DO i = 1, klon 154 IF ( pctsrf(i, is_sic) .GT. (1. - zmasq(i)) ) THEN 155 WRITE(*,*) 'condsurf : sea-ice et masque pb en ', i, 156 $ pctsrf(i, is_sic), (1. - zmasq(i)) 157 pctsrf(i, is_sic) = (1. - zmasq(i)) 158 pctsrf(i, is_oce) = 0. 159 ENDIF 160 IF ( abs( pctsrf(i, is_ter) + pctsrf(i, is_lic) + 161 $ pctsrf(i, is_oce) + pctsrf(i, is_sic) - 1.) .GT. EPSFRA) 162 $ THEN 163 WRITE(*,*) 'physiq : pb sous surface au point ', i, 164 $ pctsrf(i, 1 : nbsrf) 165 ENDIF 166 END DO 167 c 168 c$$$c Fraction "terre": 169 c$$$ ierr = NF_INQ_VARID (nid, "FTER", nvarid) 170 c$$$ IF (ierr .NE. NF_NOERR) THEN 171 c$$$ PRINT*, "condsurf: Le champ <FTER> est absent" 172 c$$$ CALL abort 173 c$$$ ENDIF 174 c$$$#ifdef NC_DOUBLE 175 c$$$ ierr = NF_GET_VARA_DOUBLE(nid,nvarid,debut,epais,pctsrf(1,is_ter)) 176 c$$$#else 177 c$$$ ierr = NF_GET_VARA_REAL(nid,nvarid,debut,epais,pctsrf(1,is_ter)) 178 c$$$#endif 179 c$$$ IF (ierr .NE. NF_NOERR) THEN 180 c$$$ PRINT*, "condsurf: Lecture echouee pour <FTER>" 181 c$$$ CALL abort 182 c$$$ ENDIF 183 c$$$c 184 c$$$c Fraction "glacier terre": 185 c$$$ ierr = NF_INQ_VARID (nid, "FLIC", nvarid) 186 c$$$ IF (ierr .NE. NF_NOERR) THEN 187 c$$$ PRINT*, "condsurf: Le champ <FLIC> est absent" 188 c$$$ CALL abort 189 c$$$ ENDIF 190 c$$$#ifdef NC_DOUBLE 191 c$$$ ierr = NF_GET_VARA_DOUBLE(nid,nvarid,debut,epais,pctsrf(1,is_lic)) 192 c$$$#else 193 c$$$ ierr = NF_GET_VARA_REAL(nid,nvarid,debut,epais,pctsrf(1,is_lic)) 194 c$$$#endif 195 c$$$ IF (ierr .NE. 0) THEN 196 c$$$ PRINT*, "condsurf: Lecture echouee pour <FLIC>" 197 c$$$ CALL abort 198 c$$$ ENDIF 179 199 c 180 200 ELSE ! test sur newlmt -
LMDZ.3.3/branches/rel-LF/libf/phylmd/dimphy.h
r83 r98 7 7 PARAMETER (nbtr=nqmx-2+1/(nqmx-1)) 8 8 c----------------------------------------------------------------------- 9 REAL zmasq(KLON) 10 COMMON/terreoce/zmasq -
LMDZ.3.3/branches/rel-LF/libf/phylmd/inc_cpl.h
r79 r98 1 1 C 2 C -- inc_cpl.h 2 C -- inc_cpl.h 1998-04 3 3 C ********** 4 4 C@ 5 C@ Contents : variables describing field restart file names5 C@ Contents : variables describing pipe and field names 6 6 C@ -------- 7 7 C@ 8 C@ -- cl_write/cl_read : for fields to write/READ 9 C@ -- cl_f_write/cl_f_read : for fields to write/read 8 C@ -- cl_write : for fields to write 9 C@ 10 C@ -- cl_read : for fields to read 10 11 C@ 11 12 C ------------------------------------------------------------------- 12 13 C 14 INTEGER jpread, jpwrit 15 PARAMETER (jpread=0, jpwrit=1) 13 16 CHARACTER*8 cl_writ(jpmaxfld), cl_read(jpmaxfld) 14 CHARACTER* 8cl_f_writ(jpmaxfld), cl_f_read(jpmaxfld)17 CHARACTER*6 cl_f_writ(jpmaxfld), cl_f_read(jpmaxfld) 15 18 COMMON / comcpl / cl_writ, cl_read, cl_f_writ, cl_f_read 16 19 C ------------------------------------------------------------------- -
LMDZ.3.3/branches/rel-LF/libf/phylmd/inc_sipc.h
r79 r98 18 18 INTEGER mpoolinitr 19 19 INTEGER mpoolinitw 20 INTEGER mpoolwrit(jp flda2o)21 INTEGER mpoolread(jp fldo2a)20 INTEGER mpoolwrit(jpmaxfld) 21 INTEGER mpoolread(jpmaxfld) 22 22 COMMON / compool / mpoolinitr, mpoolinitw, mpoolwrit, mpoolread 23 23 C ------------------------------------------------------------------- -
LMDZ.3.3/branches/rel-LF/libf/phylmd/indicesol.h
r95 r98 13 13 REAL epsfra 14 14 PARAMETER (epsfra=1.0E-05) 15 ! 16 CHARACTER *3 clnsurf(nbsrf) 17 DATA clnsurf/'ter', 'lic', 'oce', 'sic'/ -
LMDZ.3.3/branches/rel-LF/libf/phylmd/interface_surf.F90
r97 r98 45 45 ! 46 46 SUBROUTINE interfsurf_hq(itime, dtime, jour, & 47 & klon, nisurf, knon, knindex, rlon, rlat, &47 & klon, iim, jjm, nisurf, knon, knindex, pctsrf, rlon, rlat, & 48 48 & debut, lafin, ok_veget, & 49 & zlev, zlflu,u1_lay, v1_lay, temp_air, spechum, hum_air, ccanopy, &49 & zlev, u1_lay, v1_lay, temp_air, spechum, hum_air, ccanopy, & 50 50 & tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, & 51 51 & precip_rain, precip_snow, lwdown, swnet, swdown, & 52 & tsurf, p1lay, cal, beta, coef1lay, ps, radsol, dif_grnd, & 52 & albedo, snow, qsol, & 53 & tsurf, p1lay, coef1lay, ps, radsol, & 53 54 & ocean, & 54 55 & evap, fluxsens, fluxlat, dflux_l, dflux_s, & 55 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, pctsrf_new )56 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, pctsrf_new, zmasq) 56 57 57 58 … … 67 68 ! itime numero du pas de temps 68 69 ! klon nombre total de points de grille 70 ! iim, jjm nbres de pts de grille 69 71 ! dtime pas de temps de la physique (en s) 70 72 ! jour jour dans l'annee en cours … … 72 74 ! knon nombre de points de la surface a traiter 73 75 ! knindex index des points de la surface a traiter 76 ! pctsrf tableau des pourcentages de surface de chaque maille 74 77 ! rlon longitudes 75 78 ! rlat latitudes … … 79 82 ! (si false calcul simplifie des fluxs sur les continents) 80 83 ! zlev hauteur de la premiere couche 81 ! zlflu epaisseur de la premier couche 84 ! u1_lay vitesse u 1ere couche 85 ! v1_lay vitesse v 1ere couche 86 ! temp_air temperature de l'air 1ere couche 87 ! spechum humidite specifique 1ere couche 88 ! hum_air humidite de l'air 89 ! ccanopy concentration CO2 canopee 90 ! tq_cdrag cdrag 91 ! petAcoef coeff. A de la resolution de la CL pour t 92 ! peqAcoef coeff. A de la resolution de la CL pour q 93 ! petBcoef coeff. B de la resolution de la CL pour t 94 ! peqBcoef coeff. B de la resolution de la CL pour q 95 ! precip_rain precipitation liquide 96 ! precip_snow precipitation solide 97 ! lwdown flux IR entrant a la surface 98 ! swnet flux solaire net 99 ! swdown flux solaire entrant a la surface 100 ! albedo albedo de la surface 101 ! tsurf temperature de surface 102 ! p1lay pression 1er niveau (milieu de couche) 103 ! coef1lay coefficient d'echange 104 ! ps pression au sol 105 ! radsol rayonnement net aus sol (LW + SW) 106 ! ocean type d'ocean utilise (force, slab, couple) 107 ! 108 ! output: 109 ! evap evaporation totale 110 ! fluxsens flux de chaleur sensible 111 ! fluxlat flux de chaleur latente 112 ! tsol_rad 113 ! tsurf_new temperature au sol 114 ! alb_new albedo 115 ! emis_new emissivite 116 ! z0_new surface roughness 117 ! pctsrf_new nouvelle repartition des surfaces 118 ! zmasq masque terre/ocean 119 120 include 'indicesol.h' 121 122 ! Parametres d'entree 123 integer, intent(IN) :: itime 124 integer, intent(IN) :: iim, jjm 125 integer, intent(IN) :: klon 126 real, intent(IN) :: dtime 127 integer, intent(IN) :: jour 128 integer, intent(IN) :: nisurf 129 integer, intent(IN) :: knon 130 integer, dimension(knon), intent(in) :: knindex 131 real, dimension(klon,nbsrf), intent(IN) :: pctsrf 132 logical, intent(IN) :: debut, lafin, ok_veget 133 real, dimension(klon), intent(IN) :: rlon, rlat 134 real, dimension(knon), intent(IN) :: zlev 135 real, dimension(knon), intent(IN) :: u1_lay, v1_lay 136 real, dimension(knon), intent(IN) :: temp_air, spechum 137 real, dimension(knon), intent(IN) :: hum_air, ccanopy 138 real, dimension(knon), intent(IN) :: tq_cdrag, petAcoef, peqAcoef 139 real, dimension(knon), intent(IN) :: petBcoef, peqBcoef 140 real, dimension(knon), intent(IN) :: precip_rain, precip_snow 141 real, dimension(knon), intent(IN) :: lwdown, swnet, swdown, ps, albedo 142 real, dimension(knon), intent(IN) :: tsurf, p1lay, coef1lay 143 real, dimension(knon), intent(IN) :: radsol 144 real, dimension(klon), intent(IN) :: zmasq 145 character (len = 6) :: ocean 146 real, dimension(knon), intent(INOUT) :: evap, snow, qsol 147 148 ! Parametres de sortie 149 real, dimension(knon), intent(OUT):: fluxsens, fluxlat 150 real, dimension(knon), intent(OUT):: tsol_rad, tsurf_new, alb_new 151 real, dimension(knon), intent(OUT):: emis_new, z0_new 152 real, dimension(knon), intent(OUT):: dflux_l, dflux_s 153 real, dimension(klon,nbsrf), intent(OUT) :: pctsrf_new 154 155 ! Local 156 character (len = 20) :: modname = 'interfsurf_hq' 157 character (len = 80) :: abort_message 158 logical, save :: first_call = .true. 159 integer :: error 160 logical :: check = .true. 161 real, dimension(knon):: cal, beta, dif_grnd, capsol 162 real, parameter :: calice=1.0/(5.1444e+06*0.15), tau_gl=1./86400.*5. 163 real, parameter :: calsno=1./(2.3867e+06*.15) 164 165 #include "YOMCST.inc" 166 167 if (check) write(*,*) 'Entree ', modname 168 ! 169 ! On doit commencer par appeler les schemas de surfaces continentales 170 ! car l'ocean a besoin du ruissellement qui est y calcule 171 ! 172 if (first_call) then 173 if (nisurf /= is_ter .and. klon > 1) then 174 write(*,*)' *** Warning ***' 175 write(*,*)' nisurf = ',nisurf,' /= is_ter = ',is_ter 176 write(*,*)'or on doit commencer par les surfaces continentales' 177 abort_message='voir ci-dessus' 178 call abort_gcm(modname,abort_message,1) 179 endif 180 if (ocean /= 'slab ' .and. ocean /= 'force ' .and. ocean /= 'couple') then 181 write(*,*)' *** Warning ***' 182 write(*,*)'Option couplage pour l''ocean = ', ocean 183 abort_message='option pour l''ocean non valable' 184 call abort_gcm(modname,abort_message,1) 185 endif 186 endif 187 first_call = .false. 188 ! 189 ! Calcul age de la neige 190 ! 191 192 ! Aiguillage vers les differents schemas de surface 193 194 if (nisurf == is_ter) then 195 ! 196 ! Surface "terre" appel a l'interface avec les sols continentaux 197 ! 198 ! allocation du run-off 199 if (.not. allocated(run_off)) then 200 allocate(run_off(knon), stat = error) 201 if (error /= 0) then 202 abort_message='Pb allocation run_off' 203 call abort_gcm(modname,abort_message,1) 204 endif 205 else if (size(run_off) /= knon) then 206 write(*,*)'Bizarre, le nombre de points continentaux' 207 write(*,*)'a change entre deux appels. Je continue ...' 208 deallocate(run_off, stat = error) 209 allocate(run_off(knon), stat = error) 210 if (error /= 0) then 211 abort_message='Pb allocation run_off' 212 call abort_gcm(modname,abort_message,1) 213 endif 214 endif 215 ! 216 if (.not. ok_veget) then 217 ! 218 ! calcul snow et qsol, hydrol adapté 219 ! 220 call calbeta(dtime, nisurf, knon, snow, qsol, beta, capsol, dif_grnd) 221 cal = RCPD * capsol 222 call calcul_fluxs( knon, nisurf, dtime, & 223 & tsurf, p1lay, cal, beta, coef1lay, ps, & 224 & precip_rain, precip_snow, snow, qsol, & 225 & radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, & 226 & petAcoef, peqAcoef, petBcoef, peqBcoef, & 227 & tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 228 229 ! 230 ! calcul albedo: lecture albedo fichier CL puis ajout albedo neige 231 ! 232 else 233 ! 234 ! appel a sechiba 235 ! 236 call interfsol(itime, klon, dtime, nisurf, knon, & 237 & knindex, rlon, rlat, & 238 & debut, lafin, ok_veget, & 239 & zlev, u1_lay, v1_lay, temp_air, spechum, hum_air, ccanopy, & 240 & tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, & 241 & precip_rain, precip_snow, lwdown, swnet, swdown, & 242 & tsurf, p1lay, coef1lay, ps, radsol, & 243 & evap, fluxsens, fluxlat, & 244 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, dflux_l, dflux_s) 245 endif 246 ! 247 else if (nisurf == is_oce) then 248 249 if (check) write(*,*)'ocean, nisurf = ',nisurf 250 251 252 ! 253 ! Surface "ocean" appel a l'interface avec l'ocean 254 ! 255 ! if (ocean == 'couple') then 256 ! call interfoce(nisurf, ocean) 257 ! else if (ocean == 'slab ') then 258 ! call interfoce(nisurf) 259 ! else ! lecture conditions limites 260 ! call interfoce(itime, dtime, jour, & 261 ! & klon, nisurf, knon, knindex, & 262 ! & debut, & 263 ! & tsurf_new, alb_new, z0_new, pctsrf_new) 264 ! endif 265 ! 266 cal = 0. 267 beta = 1. 268 dif_grnd = 0. 269 270 call calcul_fluxs( knon, nisurf, dtime, & 271 & tsurf, p1lay, cal, beta, coef1lay, ps, & 272 & precip_rain, precip_snow, snow, qsol, & 273 & radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, & 274 & petAcoef, peqAcoef, petBcoef, peqBcoef, & 275 & tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 276 277 278 ! 279 ! calcul albedo 280 ! 281 282 ! 283 else if (nisurf == is_sic) then 284 285 if (check) write(*,*)'sea ice, nisurf = ',nisurf 286 287 ! 288 ! Surface "glace de mer" appel a l'interface avec l'ocean 289 ! 290 ! call interfoce(nisurf, ocean) 291 ! 292 293 cal = calice 294 where (snow > 0.0) cal = calsno 295 beta = 1.0 296 dif_grnd = 1.0 / tau_gl 297 298 call calcul_fluxs( knon, nisurf, dtime, & 299 & tsurf, p1lay, cal, beta, coef1lay, ps, & 300 & precip_rain, precip_snow, snow, qsol, & 301 & radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, & 302 & petAcoef, peqAcoef, petBcoef, peqBcoef, & 303 & tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 304 305 306 else if (nisurf == is_lic) then 307 308 if (check) write(*,*)'glacier, nisurf = ',nisurf 309 310 ! 311 ! Surface "glacier continentaux" appel a l'interface avec le sol 312 ! 313 ! call interfsol(nisurf) 314 315 cal = calice 316 where (snow > 0.0) cal = calsno 317 beta = 1.0 318 dif_grnd = 0.0 319 320 call calcul_fluxs( knon, nisurf, dtime, & 321 & tsurf, p1lay, cal, beta, coef1lay, ps, & 322 & precip_rain, precip_snow, snow, qsol, & 323 & radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, & 324 & petAcoef, peqAcoef, petBcoef, peqBcoef, & 325 & tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 326 327 else 328 write(*,*)'Index surface = ',nisurf 329 abort_message = 'Index surface non valable' 330 call abort_gcm(modname,abort_message,1) 331 endif 332 333 END SUBROUTINE interfsurf_hq 334 335 ! 336 !######################################################################### 337 ! 338 SUBROUTINE interfsurf_vent(nisurf, knon & 339 & ) 340 ! 341 ! Cette routine sert d'aiguillage entre l'atmosphere et la surface en general 342 ! (sols continentaux, oceans, glaces) pour les tensions de vents. 343 ! En pratique l'interface se fait entre la couche limite du modele 344 ! atmospherique (clmain.F) et les routines de surface (sechiba, oasis, ...) 345 ! 346 ! 347 ! L.Fairhead 02/2000 348 ! 349 ! input: 350 ! nisurf index de la surface a traiter (1 = sol continental) 351 ! knon nombre de points de la surface a traiter 352 353 ! Parametres d'entree 354 integer, intent(IN) :: nisurf 355 integer, intent(IN) :: knon 356 357 358 return 359 END SUBROUTINE interfsurf_vent 360 ! 361 !######################################################################### 362 ! 363 SUBROUTINE interfsol(itime, klon, dtime, nisurf, knon, & 364 & knindex, rlon, rlat, & 365 & debut, lafin, ok_veget, & 366 & zlev, u1_lay, v1_lay, temp_air, spechum, hum_air, ccanopy, & 367 & tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, & 368 & precip_rain, precip_snow, lwdown, swnet, swdown, & 369 & tsurf, p1lay, coef1lay, ps, radsol, & 370 & evap, fluxsens, fluxlat, & 371 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, dflux_l, dflux_s) 372 373 ! Cette routine sert d'interface entre le modele atmospherique et le 374 ! modele de sol continental. Appel a sechiba 375 ! 376 ! L. Fairhead 02/2000 377 ! 378 ! input: 379 ! itime numero du pas de temps 380 ! klon nombre total de points de grille 381 ! dtime pas de temps de la physique (en s) 382 ! nisurf index de la surface a traiter (1 = sol continental) 383 ! knon nombre de points de la surface a traiter 384 ! knindex index des points de la surface a traiter 385 ! rlon longitudes de la grille entiere 386 ! rlat latitudes de la grille entiere 387 ! debut logical: 1er appel a la physique (lire les restart) 388 ! lafin logical: dernier appel a la physique (ecrire les restart) 389 ! ok_veget logical: appel ou non au schema de surface continental 390 ! (si false calcul simplifie des fluxs sur les continents) 391 ! zlev hauteur de la premiere couche 82 392 ! u1_lay vitesse u 1ere couche 83 393 ! v1_lay vitesse v 1ere couche … … 98 408 ! tsurf temperature de surface 99 409 ! p1lay pression 1er niveau (milieu de couche) 100 ! cal capacite calorifique du sol101 ! beta evap reelle102 410 ! coef1lay coefficient d'echange 103 411 ! ps pression au sol 104 412 ! radsol rayonnement net aus sol (LW + SW) 105 ! dif_grnd coeff. diffusion vers le sol profond 106 ! ocean type d'ocean utilise (force, slab, couple) 413 ! 414 ! 415 ! input/output 416 ! run_off ruissellement total 107 417 ! 108 418 ! output: … … 116 426 ! z0_new surface roughness 117 427 118 include 'indicesol.h'119 120 ! Parametres d'entree121 integer, intent(IN) :: itime122 integer, intent(IN) :: klon123 real, intent(IN) :: dtime124 integer, intent(IN) :: jour125 integer, intent(IN) :: nisurf126 integer, intent(IN) :: knon127 integer, dimension(knon), intent(in) :: knindex128 logical, intent(IN) :: debut, lafin, ok_veget129 real, dimension(klon), intent(IN) :: rlon, rlat130 real, dimension(knon), intent(IN) :: zlev, zlflu131 real, dimension(knon), intent(IN) :: u1_lay, v1_lay132 real, dimension(knon), intent(IN) :: temp_air, spechum133 real, dimension(knon), intent(IN) :: hum_air, ccanopy134 real, dimension(knon), intent(IN) :: tq_cdrag, petAcoef, peqAcoef135 real, dimension(knon), intent(IN) :: petBcoef, peqBcoef136 real, dimension(knon), intent(IN) :: precip_rain, precip_snow137 real, dimension(knon), intent(IN) :: lwdown, swnet, swdown, ps138 real, dimension(knon), intent(IN) :: tsurf, p1lay, cal, beta, coef1lay139 real, dimension(knon), intent(IN) :: radsol, dif_grnd140 character (len = 6) :: ocean141 142 ! Parametres de sortie143 real, dimension(knon), intent(OUT):: evap, fluxsens, fluxlat144 real, dimension(knon), intent(OUT):: tsol_rad, tsurf_new, alb_new145 real, dimension(knon), intent(OUT):: emis_new, z0_new146 real, dimension(knon), intent(OUT):: dflux_l, dflux_s147 real, dimension(klon,nbsrf), intent(OUT) :: pctsrf_new148 149 ! Local150 character (len = 20) :: modname = 'interfsurf_hq'151 character (len = 80) :: abort_message152 logical, save :: first_call = .true.153 integer :: error154 logical :: check = .true.155 156 if (check) write(*,*) 'Entree ', modname157 !158 ! On doit commencer par appeler les schemas de surfaces continentales159 ! car l'ocean a besoin du ruissellement qui est y calcule160 !161 if (first_call) then162 if (nisurf /= is_ter .and. klon > 1) then163 write(*,*)' *** Warning ***'164 write(*,*)' nisurf = ',nisurf,' /= is_ter = ',is_ter165 write(*,*)'or on doit commencer par les surfaces continentales'166 abort_message='voir ci-dessus'167 call abort_gcm(modname,abort_message,1)168 endif169 if (ocean /= 'slab ' .and. ocean /= 'force ' .and. ocean /= 'couple') then170 write(*,*)' *** Warning ***'171 write(*,*)'Option couplage pour l''ocean = ', ocean172 abort_message='option pour l''ocean non valable'173 call abort_gcm(modname,abort_message,1)174 endif175 endif176 first_call = .false.177 178 ! Aiguillage vers les differents schemas de surface179 180 if (nisurf == is_ter) then181 !182 ! Surface "terre" appel a l'interface avec les sols continentaux183 !184 ! allocation du run-off185 if (.not. allocated(run_off)) then186 allocate(run_off(knon), stat = error)187 if (error /= 0) then188 abort_message='Pb allocation run_off'189 call abort_gcm(modname,abort_message,1)190 endif191 else if (size(run_off) /= knon) then192 write(*,*)'Bizarre, le nombre de points continentaux'193 write(*,*)'a change entre deux appels. Je continue ...'194 deallocate(run_off, stat = error)195 allocate(run_off(knon), stat = error)196 if (error /= 0) then197 abort_message='Pb allocation run_off'198 call abort_gcm(modname,abort_message,1)199 endif200 endif201 !202 call interfsol(itime, klon, dtime, nisurf, knon, &203 & knindex, rlon, rlat, &204 & debut, lafin, ok_veget, &205 & zlev, zlflu, u1_lay, v1_lay, temp_air, spechum, hum_air, ccanopy, &206 & tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, &207 & precip_rain, precip_snow, lwdown, swnet, swdown, &208 & tsurf, p1lay, cal, beta, coef1lay, ps, radsol, dif_grnd, &209 & evap, fluxsens, fluxlat, &210 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, dflux_l, dflux_s)211 212 !213 else if (nisurf == is_oce) then214 215 if (check) write(*,*)'ocean, nisurf = ',nisurf216 !217 ! Surface "ocean" appel a l'interface avec l'ocean218 !219 ! if (ocean == 'couple') then220 ! call interfoce(nisurf, ocean)221 ! else if (ocean == 'slab ') then222 ! call interfoce(nisurf)223 ! else ! lecture conditions limites224 ! call interfoce(itime, dtime, jour, &225 ! & klon, nisurf, knon, knindex, &226 ! & debut, &227 ! & tsurf_new, alb_new, z0_new, pctsrf_new)228 ! endif229 !230 call calcul_fluxs( knon, dtime, &231 & tsurf, p1lay, cal, beta, coef1lay, ps, &232 & radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &233 & petAcoef, peqAcoef, petBcoef, peqBcoef, &234 & tsurf_new, fluxlat, fluxsens, dflux_s, dflux_l)235 !236 else if (nisurf == is_sic) then237 238 if (check) write(*,*)'sea ice, nisurf = ',nisurf239 240 !241 ! Surface "glace de mer" appel a l'interface avec l'ocean242 !243 ! call interfoce(nisurf, ocean)244 !245 call calcul_fluxs( knon, dtime, &246 & tsurf, p1lay, cal, beta, coef1lay, ps, &247 & radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &248 & petAcoef, peqAcoef, petBcoef, peqBcoef, &249 & tsurf_new, fluxlat, fluxsens, dflux_s, dflux_l)250 251 else if (nisurf == is_lic) then252 253 if (check) write(*,*)'glacier, nisurf = ',nisurf254 255 !256 ! Surface "glacier continentaux" appel a l'interface avec le sol257 !258 ! call interfsol(nisurf)259 call calcul_fluxs( knon, dtime, &260 & tsurf, p1lay, cal, beta, coef1lay, ps, &261 & radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &262 & petAcoef, peqAcoef, petBcoef, peqBcoef, &263 & tsurf_new, fluxlat, fluxsens, dflux_s, dflux_l)264 265 else266 write(*,*)'Index surface = ',nisurf267 abort_message = 'Index surface non valable'268 call abort_gcm(modname,abort_message,1)269 endif270 271 END SUBROUTINE interfsurf_hq272 273 !274 !#########################################################################275 !276 SUBROUTINE interfsurf_vent(nisurf, knon &277 & )278 !279 ! Cette routine sert d'aiguillage entre l'atmosphere et la surface en general280 ! (sols continentaux, oceans, glaces) pour les tensions de vents.281 ! En pratique l'interface se fait entre la couche limite du modele282 ! atmospherique (clmain.F) et les routines de surface (sechiba, oasis, ...)283 !284 !285 ! L.Fairhead 02/2000286 !287 ! input:288 ! nisurf index de la surface a traiter (1 = sol continental)289 ! knon nombre de points de la surface a traiter290 291 ! Parametres d'entree292 integer, intent(IN) :: nisurf293 integer, intent(IN) :: knon294 295 296 return297 END SUBROUTINE interfsurf_vent298 !299 !#########################################################################300 !301 SUBROUTINE interfsol(itime, klon, dtime, nisurf, knon, &302 & knindex, rlon, rlat, &303 & debut, lafin, ok_veget, &304 & zlev, zlflu, u1_lay, v1_lay, temp_air, spechum, hum_air, ccanopy, &305 & tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, &306 & precip_rain, precip_snow, lwdown, swnet, swdown, &307 & tsurf, p1lay, cal, beta, coef1lay, ps, radsol, dif_grnd, &308 & evap, fluxsens, fluxlat, &309 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, dflux_l, dflux_s)310 311 ! Cette routine sert d'interface entre le modele atmospherique et le312 ! modele de sol continental. Appel a sechiba313 !314 ! L. Fairhead 02/2000315 !316 ! input:317 ! itime numero du pas de temps318 ! klon nombre total de points de grille319 ! dtime pas de temps de la physique (en s)320 ! nisurf index de la surface a traiter (1 = sol continental)321 ! knon nombre de points de la surface a traiter322 ! knindex index des points de la surface a traiter323 ! rlon longitudes de la grille entiere324 ! rlat latitudes de la grille entiere325 ! debut logical: 1er appel a la physique (lire les restart)326 ! lafin logical: dernier appel a la physique (ecrire les restart)327 ! ok_veget logical: appel ou non au schema de surface continental328 ! (si false calcul simplifie des fluxs sur les continents)329 ! zlev hauteur de la premiere couche330 ! zlflu331 ! u1_lay vitesse u 1ere couche332 ! v1_lay vitesse v 1ere couche333 ! temp_air temperature de l'air 1ere couche334 ! spechum humidite specifique 1ere couche335 ! hum_air humidite de l'air336 ! ccanopy concentration CO2 canopee337 ! tq_cdrag cdrag338 ! petAcoef coeff. A de la resolution de la CL pour t339 ! peqAcoef coeff. A de la resolution de la CL pour q340 ! petBcoef coeff. B de la resolution de la CL pour t341 ! peqBcoef coeff. B de la resolution de la CL pour q342 ! precip_rain precipitation liquide343 ! precip_snow precipitation solide344 ! lwdown flux IR entrant a la surface345 ! swnet flux solaire net346 ! swdown flux solaire entrant a la surface347 ! tsurf temperature de surface348 ! p1lay pression 1er niveau (milieu de couche)349 ! cal capacite calorifique du sol350 ! beta evap reelle351 ! coef1lay coefficient d'echange352 ! ps pression au sol353 ! radsol rayonnement net aus sol (LW + SW)354 ! dif_grnd coeff. diffusion vers le sol profond355 !356 !357 ! input/output358 ! run_off ruissellement total359 !360 ! output:361 ! evap evaporation totale362 ! fluxsens flux de chaleur sensible363 ! fluxlat flux de chaleur latente364 ! tsol_rad365 ! tsurf_new temperature au sol366 ! alb_new albedo367 ! emis_new emissivite368 ! z0_new surface roughness369 428 370 429 ! Parametres d'entree … … 377 436 logical, intent(IN) :: debut, lafin, ok_veget 378 437 real, dimension(klon), intent(IN) :: rlon, rlat 379 real, dimension(knon), intent(IN) :: zlev , zlflu438 real, dimension(knon), intent(IN) :: zlev 380 439 real, dimension(knon), intent(IN) :: u1_lay, v1_lay 381 440 real, dimension(knon), intent(IN) :: temp_air, spechum … … 385 444 real, dimension(knon), intent(IN) :: precip_rain, precip_snow 386 445 real, dimension(knon), intent(IN) :: lwdown, swnet, swdown, ps 387 real, dimension(knon), intent(IN) :: tsurf, p1lay, c al, beta, coef1lay388 real, dimension(knon), intent(IN) :: radsol , dif_grnd446 real, dimension(knon), intent(IN) :: tsurf, p1lay, coef1lay 447 real, dimension(knon), intent(IN) :: radsol 389 448 ! Parametres de sortie 390 449 real, dimension(knon), intent(OUT):: evap, fluxsens, fluxlat … … 400 459 character (len = 80) :: abort_message 401 460 logical :: check = .true. 461 real, dimension(knon) :: cal, beta, dif_grnd, capsol 402 462 ! type de couplage dans sechiba 403 463 ! character (len=10) :: coupling = 'implicit' … … 414 474 integer, save :: rest_id_stom, hist_id_stom 415 475 476 real, dimension(knon):: snow, qsol 477 416 478 if (check) write(*,*)'Entree ', modname 417 479 if (check) write(*,*)'ok_veget = ',ok_veget 418 480 419 481 ! initialisation 420 if (.not. ok_veget) then421 call calcul_fluxs( knon, dtime, &422 & tsurf, p1lay, cal, beta, coef1lay, ps, &423 & radsol, dif_grnd, temp_air, spechum, u1_lay, v1_lay, &424 & petAcoef, peqAcoef, petBcoef, peqBcoef, &425 & tsurf_new, fluxlat, fluxsens, dflux_s, dflux_l)426 else427 482 ! if (debut) then 428 483 ! ! … … 476 531 ! & debut, lafin, coupling, control_in, & 477 532 ! & lalo, neighbours, resolution,& 478 ! & zlev, zlflu,u1_lay, v1_lay, spechum, temp_air,hum_air , ccanopy, &533 ! & zlev, u1_lay, v1_lay, spechum, temp_air,hum_air , ccanopy, & 479 534 ! & tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, & 480 535 ! & precip_rain, precip_snow, lwdown, swnet, swdown, ps, & … … 486 541 ! Sauvegarde dans fichiers histoire 487 542 ! 488 endif ! fin ok_veget489 543 490 544 END SUBROUTINE interfsol … … 492 546 !######################################################################### 493 547 ! 494 SUBROUTINE interfoce_cpl(nisurf, ocean) 548 SUBROUTINE interfoce_cpl(itime, dtime, & 549 & klon, iim, jjm, nisurf, pctsrf, knon, knindex, rlon, rlat, & 550 & ocean, nexca, debut, lafin, & 551 & swdown, lwdown, precip_rain, precip_snow, evap, tsurf, & 552 & fder, albsol, taux, tauy, & 553 & tsurf_new, alb_new, alb_ice, pctsrf_new) 554 555 495 556 496 557 ! Cette routine sert d'interface entre le modele atmospherique et un … … 500 561 ! 501 562 ! input: 563 ! itime numero du pas de temps 564 ! iim, jjm nbres de pts de grille 565 ! dtime pas de tempsde la physique 566 ! klon nombre total de points de grille 502 567 ! nisurf index de la surface a traiter (1 = sol continental) 568 ! pctsrf tableau des fractions de surface de chaque maille 569 ! knon nombre de points de la surface a traiter 570 ! knindex index des points de la surface a traiter 571 ! rlon longitudes 572 ! rlat latitudes 573 ! debut logical: 1er appel a la physique 574 ! lafin logical: dernier appel a la physique 503 575 ! ocean type d'ocean 576 ! nexca frequence de couplage 577 ! swdown flux solaire entrant a la surface 578 ! lwdown flux IR entrant a la surface 579 ! precip_rain precipitation liquide 580 ! precip_snow precipitation solide 581 ! evap evaporation 582 ! tsurf temperature de surface 583 ! fder derivee dF/dT 584 ! albsol albedo du sol (coherent avec swdown) 585 ! taux tension de vent en x 586 ! tauy tension de vent en y 587 ! nexca frequence de couplage 588 ! 504 589 ! 505 590 ! output: 506 ! 591 ! tsurf_new temperature au sol 592 ! alb_new albedo 593 ! pctsrf_new nouvelle repartition des surfaces 594 ! alb_ice albedo de la glace 595 ! 596 597 #include 'indicesol.h' 507 598 508 599 ! Parametres d'entree 600 integer, intent(IN) :: itime 601 integer, intent(IN) :: iim, jjm 602 real, intent(IN) :: dtime 603 integer, intent(IN) :: klon 509 604 integer, intent(IN) :: nisurf 605 integer, intent(IN) :: knon 606 real, dimension(klon,nbsrf), intent(IN) :: pctsrf 607 integer, dimension(knon), intent(in) :: knindex 608 logical, intent(IN) :: debut, lafin 609 real, dimension(klon), intent(IN) :: rlon, rlat 510 610 character (len = 6) :: ocean 611 real, dimension(knon), intent(IN) :: lwdown, swdown 612 real, dimension(knon), intent(IN) :: precip_rain, precip_snow 613 real, dimension(knon), intent(IN) :: tsurf, fder, albsol, taux, tauy 614 integer :: nexca 615 616 real, dimension(knon), intent(INOUT) :: evap 511 617 512 618 ! Parametres de sortie 619 real, dimension(knon), intent(OUT):: tsurf_new, alb_new, alb_ice 620 real, dimension(klon,nbsrf), intent(OUT) :: pctsrf_new 513 621 514 622 ! Variables locales 515 516 623 integer :: j, error, sum_error, ig 624 integer :: npas 625 character (len = 20) :: modname = 'interfoce_cpl' 626 character (len = 80) :: abort_message 627 logical :: check = .true. 628 ! variables pour moyenner les variables de couplage 629 real, allocatable, dimension(:),save :: cpl_sols, cpl_nsol, cpl_rain 630 real, allocatable, dimension(:),save :: cpl_snow, cpl_evap, cpl_tsol 631 real, allocatable, dimension(:),save :: cpl_fder, cpl_albe, cpl_taux 632 real, allocatable, dimension(:),save :: cpl_tauy, cpl_ruis 633 ! variables a passer au coupleur 634 real, dimension(iim, jjm+1) :: wri_sols, wri_nsol, wri_rain 635 real, dimension(iim, jjm+1) :: wri_snow, wri_evap, wri_tsol 636 real, dimension(iim, jjm+1) :: wri_fder, wri_albe, wri_taux 637 real, dimension(iim, jjm+1) :: wri_tauy, wri_ruis 638 ! variables relues par le coupleur 639 real, dimension(iim, jjm+1) :: read_sst, read_sic 640 real, dimension(iim, jjm+1) :: read_alb_sst, read_alb_sic 641 ! variable tampon 642 real, dimension(klon) :: tamp 643 real, dimension(knon) :: tamp_sic 644 645 646 ! 517 647 ! Initialisation 648 ! 649 if (debut) then 650 sum_error = 0 651 allocate(cpl_sols(knon), stat = error) 652 sum_error = sum_error + error 653 allocate(cpl_nsol(knon), stat = error) 654 sum_error = sum_error + error 655 allocate(cpl_rain(knon), stat = error) 656 sum_error = sum_error + error 657 allocate(cpl_snow(knon), stat = error) 658 sum_error = sum_error + error 659 allocate(cpl_evap(knon), stat = error) 660 sum_error = sum_error + error 661 allocate(cpl_tsol(knon), stat = error) 662 sum_error = sum_error + error 663 allocate(cpl_fder(knon), stat = error) 664 sum_error = sum_error + error 665 allocate(cpl_albe(knon), stat = error) 666 sum_error = sum_error + error 667 allocate(cpl_taux(knon), stat = error) 668 sum_error = sum_error + error 669 allocate(cpl_tauy(knon), stat = error) 670 sum_error = sum_error + error 671 allocate(cpl_ruis(knon), stat = error) 672 sum_error = sum_error + error 673 if (sum_error /= 0) then 674 abort_message='Pb allocation variables couplees' 675 call abort_gcm(modname,abort_message,1) 676 endif 677 cpl_sols = 0. 678 cpl_nsol = 0. 679 cpl_rain = 0. 680 cpl_snow = 0. 681 cpl_evap = 0. 682 cpl_tsol = 0. 683 cpl_fder = 0. 684 cpl_albe = 0. 685 cpl_taux = 0. 686 cpl_tauy = 0. 687 cpl_ruis = 0. 688 ! 689 ! initialisation couplage 690 ! 691 call inicma(npas, nexca, dtime) 692 ! 693 ! 1ere lecture champs ocean 694 ! 695 call fromcpl(itime,(jjm+1)*iim, & 696 & read_sst, read_sic, read_alb_sst, read_alb_sic) 697 call cpl2gath(read_sst, tsurf_new, klon, knon,iim,jjm, knindex) 698 call cpl2gath(read_sic, tamp_sic , klon, knon,iim,jjm, knindex) 699 call cpl2gath(read_alb_sst, alb_new, klon, knon,iim,jjm, knindex) 700 call cpl2gath(read_alb_sic, alb_ice, klon, knon,iim,jjm, knindex) 701 ! 702 ! transformer tamp_sic en pctsrf_new 703 ! 704 do ig = 1, klon 705 IF (pctsrf(ig,is_oce) > epsfra .OR. & 706 & pctsrf(ig,is_sic) > epsfra) THEN 707 pctsrf_new(ig,is_oce) = pctsrf(ig,is_oce) & 708 & - (tamp_sic(ig)-pctsrf(ig,is_sic)) 709 pctsrf_new(ig,is_sic) = tamp_sic(ig) 710 endif 711 enddo 712 713 endif ! fin if (debut) 714 518 715 ! fichier restart et fichiers histoires 519 716 520 717 ! calcul des fluxs a passer 521 718 719 cpl_sols = cpl_sols + swdown / FLOAT(nexca) 720 cpl_nsol = cpl_nsol + lwdown / FLOAT(nexca) 721 cpl_rain = cpl_rain + precip_rain / FLOAT(nexca) 722 cpl_snow = cpl_snow + precip_snow / FLOAT(nexca) 723 cpl_evap = cpl_evap + evap / FLOAT(nexca) 724 cpl_tsol = cpl_tsol + tsurf / FLOAT(nexca) 725 cpl_fder = cpl_fder + fder / FLOAT(nexca) 726 cpl_albe = cpl_albe + albsol / FLOAT(nexca) 727 cpl_taux = cpl_taux + taux / FLOAT(nexca) 728 cpl_tauy = cpl_tauy + tauy / FLOAT(nexca) 729 cpl_ruis = cpl_ruis + run_off / FLOAT(nexca)/dtime 730 731 if (mod(itime, nexca) == 0) then 732 ! 733 ! Mise sur la bonne grille des champs a passer au coupleur 734 call gath2cpl(cpl_sols, wri_sols, klon, knon,iim,jjm, knindex) 735 call gath2cpl(cpl_nsol, wri_nsol, klon, knon,iim,jjm, knindex) 736 call gath2cpl(cpl_rain, wri_rain, klon, knon,iim,jjm, knindex) 737 call gath2cpl(cpl_snow, wri_snow, klon, knon,iim,jjm, knindex) 738 call gath2cpl(cpl_evap, wri_evap, klon, knon,iim,jjm, knindex) 739 call gath2cpl(cpl_tsol, wri_tsol, klon, knon,iim,jjm, knindex) 740 call gath2cpl(cpl_fder, wri_fder, klon, knon,iim,jjm, knindex) 741 call gath2cpl(cpl_albe, wri_albe, klon, knon,iim,jjm, knindex) 742 call gath2cpl(cpl_taux, wri_taux, klon, knon,iim,jjm, knindex) 743 call gath2cpl(cpl_tauy, wri_tauy, klon, knon,iim,jjm, knindex) 744 call gath2cpl(cpl_ruis, wri_ruis, klon, knon,iim,jjm, knindex) 745 ! 746 ! Passage des champs au coupleur 747 ! 748 call intocpl(itime, iim, jjm , wri_sols, wri_nsol, wri_rain, wri_snow, & 749 & wri_evap, wri_tsol, wri_fder, wri_albe, wri_taux, wri_tauy, & 750 & wri_ruis ) 751 cpl_sols = 0. 752 cpl_nsol = 0. 753 cpl_rain = 0. 754 cpl_snow = 0. 755 cpl_evap = 0. 756 cpl_tsol = 0. 757 cpl_fder = 0. 758 cpl_albe = 0. 759 cpl_taux = 0. 760 cpl_tauy = 0. 761 cpl_ruis = 0. 762 763 call fromcpl(itime,(jjm+1)*iim, & 764 & read_sst, read_sic, read_alb_sst, read_alb_sic) 765 call cpl2gath(read_sst, tsurf_new, klon, knon,iim,jjm, knindex) 766 call cpl2gath(read_sic, tamp_sic , klon, knon,iim,jjm, knindex) 767 call cpl2gath(read_alb_sst, alb_new, klon, knon,iim,jjm, knindex) 768 call cpl2gath(read_alb_sic, alb_ice, klon, knon,iim,jjm, knindex) 769 ! transformer tamp_sic en pctsrf_new 770 771 do ig = 1, klon 772 IF (pctsrf(ig,is_oce) > epsfra .OR. & 773 & pctsrf(ig,is_sic) > epsfra) THEN 774 pctsrf_new(ig,is_oce) = pctsrf(ig,is_oce) & 775 & - (tamp_sic(ig)-pctsrf(ig,is_sic)) 776 pctsrf_new(ig,is_sic) = tamp_sic(ig) 777 endif 778 enddo 779 endif 780 522 781 END SUBROUTINE interfoce_cpl 523 782 ! 524 783 !######################################################################### 525 784 ! 785 526 786 SUBROUTINE interfoce_slab(nisurf) 527 787 … … 825 1085 ! 826 1086 827 SUBROUTINE calcul_fluxs( knon, dtime, &1087 SUBROUTINE calcul_fluxs( knon, nisurf, dtime, & 828 1088 & tsurf, p1lay, cal, beta, coef1lay, ps, & 1089 & precip_rain, precip_snow, snow, qsol, & 829 1090 & radsol, dif_grnd, t1lay, q1lay, u1lay, v1lay, & 830 1091 & petAcoef, peqAcoef, petBcoef, peqBcoef, & 831 & tsurf_new, fluxlat, fluxsens, dflux_s, dflux_l)1092 & tsurf_new, evap, fluxlat, fluxsens, dflux_s, dflux_l) 832 1093 833 1094 ! Cette routine calcule les fluxs en h et q a l'interface et eventuellement … … 838 1099 ! input: 839 1100 ! knon nombre de points a traiter 1101 ! nisurf surface a traiter 840 1102 ! tsurf temperature de surface 841 1103 ! p1lay pression 1er niveau (milieu de couche) … … 844 1106 ! coef1lay coefficient d'echange 845 1107 ! ps pression au sol 1108 ! precip_rain precipitations liquides 1109 ! precip_snow precipitations solides 1110 ! snow champs hauteur de neige 1111 ! qsol humidite du sol 1112 ! runoff runoff en cas de trop plein 846 1113 ! petAcoef coeff. A de la resolution de la CL pour t 847 1114 ! peqAcoef coeff. A de la resolution de la CL pour q … … 862 1129 #include "YOETHF.inc" 863 1130 #include "FCTTRE.inc" 1131 #include 'indicesol.h' 864 1132 865 1133 ! Parametres d'entree 866 integer, intent(IN) :: knon 1134 integer, intent(IN) :: knon, nisurf 867 1135 real , intent(IN) :: dtime 868 1136 real, dimension(knon), intent(IN) :: petAcoef, peqAcoef … … 870 1138 real, dimension(knon), intent(IN) :: ps, q1lay 871 1139 real, dimension(knon), intent(IN) :: tsurf, p1lay, cal, beta, coef1lay 1140 real, dimension(knon), intent(IN) :: precip_rain, precip_snow 872 1141 real, dimension(knon), intent(IN) :: radsol, dif_grnd 873 1142 real, dimension(knon), intent(IN) :: t1lay, u1lay, v1lay 1143 real, dimension(knon), intent(INOUT) :: snow, qsol 874 1144 875 1145 ! Parametres sorties 876 real, dimension(knon), intent(OUT):: tsurf_new, fluxlat, fluxsens1146 real, dimension(knon), intent(OUT):: tsurf_new, evap, fluxsens, fluxlat 877 1147 real, dimension(knon), intent(OUT):: dflux_s, dflux_l 878 1148 … … 885 1155 real, dimension(knon) :: zx_h_ts, zx_q_0 , d_ts 886 1156 real :: zdelta, zcvm5, zx_qs, zcor, zx_dq_s_dh 1157 real :: bilan_f, fq_fonte 887 1158 real, parameter :: t_grnd = 271.35, t_coup = 273.15 888 1159 logical :: check = .true. 889 1160 character (len = 20) :: modname = 'calcul_fluxs' 1161 logical :: fonte_neige = .false. 1162 real :: max_eau_sol = 150.0 1163 character (len = 80) :: abort_message 890 1164 891 1165 if (check) write(*,*)'Entree ', modname 1166 1167 if (size(run_off) /= knon .AND. nisurf == is_ter) then 1168 write(*,*)'Bizarre, le nombre de points continentaux' 1169 write(*,*)'a change entre deux appels. J''arrete ...' 1170 abort_message='Pb run_off' 1171 call abort_gcm(modname,abort_message,1) 1172 endif 1173 ! 1174 ! Traitement neige et humidite du sol 1175 ! 1176 if (nisurf == is_oce) then 1177 snow = 0. 1178 qsol = max_eau_sol 1179 else 1180 snow = max(0.0, snow + (precip_snow - evap) * dtime) 1181 qsol = qsol + (precip_rain - evap) * dtime 1182 endif 1183 1184 892 1185 ! 893 1186 ! Initialisation … … 961 1254 & zx_nh(i) + zx_sl(i) * zx_nq(i)) & 962 1255 & + dtime * dif_grnd(i)) 1256 1257 ! 1258 ! Y'a-t-il fonte de neige? 1259 ! 1260 fonte_neige = (nisurf /= is_oce) .AND. & 1261 & (snow(i) > 0. .OR. nisurf == is_sic .OR. nisurf == is_lic) & 1262 & .AND. (tsurf_new(i) >= RTT) 1263 if (fonte_neige) tsurf_new(i) = RTT 963 1264 zx_h_ts(i) = tsurf_new(i) * RCPD * zx_pkh(i) 964 1265 d_ts(i) = tsurf_new(i) - tsurf(i) … … 966 1267 !== flux_q est le flux de vapeur d'eau: kg/(m**2 s) positive vers bas 967 1268 !== flux_t est le flux de cpt (energie sensible): j/(m**2 s) 968 fluxlat(i) = zx_mq(i) + zx_nq(i) * tsurf_new(i) 1269 evap(i) = - zx_mq(i) - zx_nq(i) * tsurf_new(i) 1270 fluxlat(i) = - evap(i) * zx_sl(i) 969 1271 fluxsens(i) = zx_mh(i) + zx_nh(i) * tsurf_new(i) 970 1272 ! Derives des flux dF/dTs (W m-2 K-1): 971 1273 dflux_s(i) = zx_nh(i) 972 1274 dflux_l(i) = (zx_sl(i) * zx_nq(i)) 1275 ! 1276 ! en cas de fonte de neige 1277 ! 1278 if (fonte_neige) then 1279 bilan_f = radsol(i) + fluxsens(i) - (zx_sl(i) * evap (i)) - & 1280 & dif_grnd(i) * (tsurf_new(i) - t_grnd) - & 1281 & RCPD * (zx_pkh(i))/cal(i)/dtime * (tsurf_new(i) - tsurf(i)) 1282 bilan_f = max(0., bilan_f) 1283 fq_fonte = bilan_f / zx_sl(i) 1284 snow(i) = max(0., snow(i) - fq_fonte * dtime) 1285 qsol(i) = qsol(i) + (fq_fonte * dtime) 1286 endif 1287 if (nisurf == is_ter) & 1288 & run_off(i) = run_off(i) + max(qsol(i) - max_eau_sol, 0.0) 1289 qsol(i) = min(qsol(i), max_eau_sol) 973 1290 ENDDO 974 1291 … … 978 1295 ! 979 1296 1297 SUBROUTINE sol_dem_write(itime, klon, rlon, rlat, & 1298 & pctsrf_new,tsurf_new,alb_new) 1299 1300 ! Routine d'ecriture de l'etat de redemarrage pour le sol 1301 ! 1302 ! L.Fairhead 1303 ! 1304 ! input: 1305 ! itime numero du pas de temps 1306 ! klon nombre total de points de grille 1307 ! rlon longitudes 1308 ! rlat latitudes 1309 ! tsurf_new temperature au sol 1310 ! alb_new albedo 1311 ! pctsrf_new repartition des surfaces 1312 1313 include 'indicesol.h' 1314 #include 'temps.inc' 1315 include 'netcdf.inc' 1316 1317 ! Parametres d'entree 1318 integer, intent(IN) :: itime 1319 integer, intent(IN) :: klon 1320 real, dimension(klon), intent(IN) :: rlon, rlat 1321 real, dimension(klon,nbsrf), intent(IN) :: tsurf_new, alb_new 1322 real, dimension(klon,nbsrf), intent(IN) :: pctsrf_new 1323 1324 ! Variables locales 1325 integer :: ierr, nid 1326 integer :: idim1, idim2, idim3 1327 integer,parameter :: length = 100 1328 character (len = 20) :: modname = 'sol_dem_write' 1329 character (len = 80) :: abort_message 1330 real, dimension(length) :: tab_cntrl = 0. 1331 integer :: nvarid 1332 1333 ierr = NF_CREATE('restartsol', NF_CLOBBER, nid) 1334 IF (ierr.NE.NF_NOERR) THEN 1335 abort_message=' Pb d''ouverture du fichier restartsol' 1336 CALL abort_gcm(modname,abort_message,ierr) 1337 ENDIF 1338 1339 ierr = NF_PUT_ATT_TEXT (nid, NF_GLOBAL, "title", 23, & 1340 & "Fichier redemmarage sol") 1341 ierr = NF_DEF_DIM (nid, "index", length, idim1) 1342 ierr = NF_DEF_DIM (nid, "points_physiques", klon, idim2) 1343 ierr = NF_DEF_DIM (nid, "nombre_surfaces", nbsrf, idim3) 1344 ierr = NF_ENDDEF(nid) 1345 1346 tab_cntrl(13) = day_end 1347 tab_cntrl(14) = anne_ini 1348 1349 ierr = NF_REDEF (nid) 1350 #ifdef NC_DOUBLE 1351 ierr = NF_DEF_VAR (nid, "controle", NF_DOUBLE, 1, idim1,nvarid) 1352 #else 1353 ierr = NF_DEF_VAR (nid, "controle", NF_FLOAT, 1, idim1,nvarid) 1354 #endif 1355 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 22, & 1356 & "Parametres de controle") 1357 ierr = NF_ENDDEF(nid) 1358 #ifdef NC_DOUBLE 1359 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,tab_cntrl) 1360 #else 1361 ierr = NF_PUT_VAR_REAL (nid,nvarid,tab_cntrl) 1362 #endif 1363 1364 ierr = NF_REDEF (nid) 1365 #ifdef NC_DOUBLE 1366 ierr = NF_DEF_VAR (nid, "longitude", NF_DOUBLE, 1, idim2,nvarid) 1367 #else 1368 ierr = NF_DEF_VAR (nid, "longitude", NF_FLOAT, 1, idim2,nvarid) 1369 #endif 1370 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 32, & 1371 & "Longitudes de la grille physique") 1372 ierr = NF_ENDDEF(nid) 1373 #ifdef NC_DOUBLE 1374 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,rlon) 1375 #else 1376 ierr = NF_PUT_VAR_REAL (nid,nvarid,rlon) 1377 #endif 1378 ! 1379 ierr = NF_REDEF (nid) 1380 #ifdef NC_DOUBLE 1381 ierr = NF_DEF_VAR (nid, "latitude", NF_DOUBLE, 1, idim2,nvarid) 1382 #else 1383 ierr = NF_DEF_VAR (nid, "latitude", NF_FLOAT, 1, idim2,nvarid) 1384 #endif 1385 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 31, & 1386 & "Latitudes de la grille physique") 1387 ierr = NF_ENDDEF(nid) 1388 #ifdef NC_DOUBLE 1389 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,rlat) 1390 #else 1391 ierr = NF_PUT_VAR_REAL (nid,nvarid,rlat) 1392 #endif 1393 ierr = NF_REDEF (nid) 1394 #ifdef NC_DOUBLE 1395 ierr = NF_DEF_VAR (nid, "TS", NF_DOUBLE, 1, idim2,nvarid) 1396 #else 1397 ierr = NF_DEF_VAR (nid, "TS", NF_FLOAT, 1, idim2,nvarid) 1398 #endif 1399 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 22, & 1400 & "Temperature de surface") 1401 ierr = NF_ENDDEF(nid) 1402 1403 1404 1405 1406 END SUBROUTINE sol_dem_write 1407 ! 1408 !######################################################################### 1409 ! 1410 SUBROUTINE gath2cpl(champ_in, champ_out, klon, knon, iim, jjm, knindex) 1411 1412 ! Cette routine ecrit un champ 'gathered' sur la grille 2D pour le passer 1413 ! au coupleur. 1414 ! 1415 ! 1416 ! input: 1417 ! champ_in champ sur la grille gathere 1418 ! knon nombre de points dans le domaine a traiter 1419 ! knindex index des points de la surface a traiter 1420 ! klon taille de la grille 1421 ! iim,jjm dimension de la grille 2D 1422 ! 1423 ! output: 1424 ! champ_out champ sur la grille 2D 1425 ! 1426 ! input 1427 integer :: klon, knon, iim, jjm 1428 real, dimension(knon) :: champ_in 1429 integer, dimension(knon) :: knindex 1430 ! output 1431 real, dimension(iim,jjm+1) :: champ_out 1432 ! local 1433 integer :: i, ig, j 1434 real, dimension(klon) :: tamp 1435 1436 do i = 1, knon 1437 ig = knindex(i) 1438 tamp(ig) = champ_in(i) 1439 enddo 1440 champ_out(:,1) = tamp(1) 1441 do j = 2, jjm 1442 do i = 1, iim 1443 champ_out(i,j) = tamp((j-2)*jjm + i + 1) 1444 enddo 1445 enddo 1446 champ_out(:,jjm+1) = tamp(klon) 1447 1448 END SUBROUTINE gath2cpl 1449 ! 1450 !######################################################################### 1451 ! 1452 SUBROUTINE cpl2gath(champ_in, champ_out, klon, knon, iim, jjm, knindex) 1453 1454 ! Cette routine ecrit un champ 'gathered' sur la grille 2D pour le passer 1455 ! au coupleur. 1456 ! 1457 ! 1458 ! input: 1459 ! champ_in champ sur la grille gathere 1460 ! knon nombre de points dans le domaine a traiter 1461 ! knindex index des points de la surface a traiter 1462 ! klon taille de la grille 1463 ! iim,jjm dimension de la grille 2D 1464 ! 1465 ! output: 1466 ! champ_out champ sur la grille 2D 1467 ! 1468 ! input 1469 integer :: klon, knon, iim, jjm 1470 real, dimension(iim,jjm+1) :: champ_in 1471 integer, dimension(knon) :: knindex 1472 ! output 1473 real, dimension(knon) :: champ_out 1474 ! local 1475 integer :: i, ig, j 1476 real, dimension(klon) :: tamp 1477 1478 tamp(1) = champ_in(1,1) 1479 do j = 2, jjm 1480 do i = 1, iim 1481 tamp((j-2)*jjm + i + 1) = champ_in(i,j) 1482 enddo 1483 enddo 1484 tamp(klon) = champ_in(1,jjm+1) 1485 1486 do i = 1, knon 1487 ig = knindex(i) 1488 champ_out(i) = tamp(ig) 1489 enddo 1490 1491 END SUBROUTINE cpl2gath 1492 ! 1493 !######################################################################### 1494 ! 980 1495 END MODULE interface_surf -
LMDZ.3.3/branches/rel-LF/libf/phylmd/oasis.F
r79 r98 386 386 END 387 387 388 SUBROUTINE fromcpl(kt, imjm, sst, gla)388 SUBROUTINE fromcpl(kt, imjm, sst,sic, alb_sst, alb_sic ) 389 389 IMPLICIT none 390 390 c … … 399 399 INTEGER imjm, kt 400 400 REAL sst(imjm) ! sea-surface-temperature 401 REAL gla(imjm) ! sea-ice 401 REAL alb_sst(imjm) ! open sea albedo 402 REAL sic(imjm) ! sea ice cover 403 REAL alb_sic(imjm) ! sea ice albedo 404 402 405 c 403 406 INTEGER nuout ! listing output unit … … 447 450 $ nuout) 448 451 IF (jf.eq.2) 449 $ CALL locread(cl_read(jf), gla, imjm, nuread, iflag, 452 $ CALL locread(cl_read(jf), sic, imjm, nuread, iflag, 453 $ nuout) 454 IF (jf.eq.3) 455 $ CALL locread(cl_read(jf), alb_sst, imjm, nuread, iflag, 456 $ nuout) 457 IF (jf.eq.4) 458 $ CALL locread(cl_read(jf), alb_sic, imjm, nuread, iflag, 450 459 $ nuout) 451 460 CLOSE (nuread) … … 474 483 c 475 484 CALL SIPC_Read_Model(index, imjm, cmodinf, 476 $ cljobnam_r,infos, gla) 485 $ cljobnam_r,infos, sic) 486 c Index of open sea albedo in total number of fields jpfldo2a: 487 index = 3 488 c 489 CALL SIPC_Read_Model(index, imjm, cmodinf, 490 $ cljobnam_r,infos, alb_sst) 491 c Index of sea-ice albedo in total number of fields jpfldo2a: 492 index = 4 493 c 494 CALL SIPC_Read_Model(index, imjm, cmodinf, 495 $ cljobnam_r,infos, alb_sic) 477 496 c 478 497 c … … 482 501 c exchanges from ocean=CPL to atmosphere 483 502 c 484 DO jf=1,jpfldo2a 485 IF (jf.eq.1) CALL CLIM_Import (cl_read(jf) , kt, sst, info) 486 IF (jf.eq.2) CALL CLIM_Import (cl_read(jf) , kt, gla, info) 487 IF ( info .NE. CLIM_Ok) THEN 503 DO jf=1,jpfldo2a 504 IF (jf.eq.1) CALL CLIM_Import (cl_read(jf) , kt, sst, info) 505 IF (jf.eq.2) CALL CLIM_Import (cl_read(jf) , kt, sic, info) 506 IF (jf.eq.3) CALL CLIM_Import (cl_read(jf) , kt, alb_sst, info) 507 IF (jf.eq.4) CALL CLIM_Import (cl_read(jf) , kt, alb_sic, info) 508 IF ( info .NE. CLIM_Ok) THEN 488 509 WRITE(nuout,*)'Pb in reading ', cl_read(jf), jf 489 510 WRITE(nuout,*)'Couplage kt is = ',kt -
LMDZ.3.3/branches/rel-LF/libf/phylmd/oasis.h
r79 r98 1 LOGICAL ok_oasis 2 PARAMETER (ok_oasis = .FALSE.) 3 c 4 CHARACTER*4 cchan 5 PARAMETER (cchan="PIPE") 6 c PARAMETER (cchan="CLIM") 1 C 2 C -- oasis.h 3 C ****** 4 C@ 5 C@ Contents : choice for the OASIS version: clim or pipe 6 C@ -------- 7 7 8 INTEGER jpmaxfld 9 PARAMETER(jpmaxfld = 20) 8 logical ok_oasis 9 parameter(ok_oasis = .false.) 10 11 CHARACTER*8 cchan 12 PARAMETER ( cchan='PIPE' ) 13 C 14 C --- end of oasis.h -
LMDZ.3.3/branches/rel-LF/libf/phylmd/param_cou.h
r79 r98 2 2 C -- param_cou.h 3 3 C 4 INTEGER jpmaxfld 5 PARAMETER(jpmaxfld = 100) ! Number of maximum fields 6 ! exchange betwwen ocean and atmosphere 4 7 INTEGER jpflda2o 5 PARAMETER(jpflda2o = 1) ! Number of fields exchanged from8 PARAMETER(jpflda2o = 8) ! Number of fields exchanged from 6 9 ! atmosphere to ocean 7 10 C 8 11 INTEGER jpfldo2a 9 PARAMETER(jpfldo2a = 1) ! Number of fields exchanged from12 PARAMETER(jpfldo2a = 2) ! Number of fields exchanged from 10 13 ! ocean to atmosphere 11 14 C -
LMDZ.3.3/branches/rel-LF/libf/phylmd/param_sipc.h
r79 r98 10 10 INTEGER jpbyteint,jpbyterea, jpbytecha 11 11 PARAMETER (jpbyteint = 4) 12 PARAMETER (jpbyterea = 4)12 PARAMETER (jpbyterea = 8) 13 13 PARAMETER (jpbytecha = 1) 14 14 C@ -
LMDZ.3.3/branches/rel-LF/libf/phylmd/phyetat0.F
r79 r98 1 1 SUBROUTINE phyetat0 (fichnom,dtime,co2_ppm,solaire, 2 . rlat,rlon,tsol,tsoil,deltat,qsol,snow, 2 . rlat,rlon, pctsrf, tsol,tsoil,deltat,qsol,snow, 3 . albe, evap, rain_fall, snow_fall, solsw, sollw, 3 4 . radsol,rugmer,agesno,clesphy0, 4 5 . zmea,zstd,zsig,zgam,zthe,zpic,zval,rugsrel,tabcntr0, … … 27 28 REAL qsol(klon,nbsrf) 28 29 REAL snow(klon,nbsrf) 30 REAL albe(klon,nbsrf) 31 REAL evap(klon,nbsrf) 29 32 REAL radsol(klon) 33 REAL rain_fall(klon) 34 REAL snow_fall(klon) 35 REAL sollw(klon) 36 real solsw(klon) 30 37 REAL rugmer(klon) 31 38 REAL agesno(klon) … … 38 45 REAL zval(klon) 39 46 REAL rugsrel(klon) 47 REAL pctsrf(klon, nbsrf) 48 REAL fractint(klon) 40 49 41 50 REAL t_ancien(klon,klev), q_ancien(klon,klev) … … 58 67 c Ouvrir le fichier contenant l'etat initial: 59 68 c 69 print*,'fichnom',fichnom 60 70 ierr = NF_OPEN (fichnom, NF_NOWRITE,nid) 61 71 IF (ierr.NE.NF_NOERR) THEN … … 184 194 CALL abort 185 195 ENDIF 186 c 196 C 197 C 198 C Lecture du masque terre mer 199 C 200 ierr = NF_INQ_VARID (nid, "masque", nvarid) 201 IF (ierr .EQ. NF_NOERR) THEN 202 #ifdef NC_DOUBLE 203 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, zmasq) 204 #else 205 ierr = NF_GET_VAR_REAL(nid, nvarid, zmasq) 206 #endif 207 IF (ierr.NE.NF_NOERR) THEN 208 PRINT*, 'phyetat0: Lecture echouee pour <masque>' 209 CALL abort 210 ENDIF 211 else 212 PRINT*, 'phyetat0: Le champ <masque> est absent' 213 PRINT*, 'fichier startphy non compatible avec phyetat0' 214 C CALL abort 215 ENDIF 216 C Lecture des fractions pour chaque sous-surface 217 C 218 C initialisation des sous-surfaces 219 C 220 pctsrf = 0. 221 C 222 C fraction de terre 223 C 224 ierr = NF_INQ_VARID (nid, "FTER", nvarid) 225 IF (ierr .EQ. NF_NOERR) THEN 226 #ifdef NC_DOUBLE 227 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, pctsrf(1 : klon,is_ter)) 228 #else 229 ierr = NF_GET_VAR_REAL(nid, nvarid, pctsrf(1 : klon,is_ter)) 230 #endif 231 IF (ierr.NE.NF_NOERR) THEN 232 PRINT*, 'phyetat0: Lecture echouee pour <FTER>' 233 CALL abort 234 ENDIF 235 else 236 PRINT*, 'phyetat0: Le champ <FTER> est absent' 237 c$$$ CALL abort 238 ENDIF 239 C 240 C fraction de glace de terre 241 C 242 ierr = NF_INQ_VARID (nid, "FLIC", nvarid) 243 IF (ierr .EQ. NF_NOERR) THEN 244 #ifdef NC_DOUBLE 245 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, pctsrf(1 : klon,is_lic)) 246 #else 247 ierr = NF_GET_VAR_REAL(nid, nvarid, pctsrf(1 : klon,is_lic)) 248 #endif 249 IF (ierr.NE.NF_NOERR) THEN 250 PRINT*, 'phyetat0: Lecture echouee pour <FLIC>' 251 CALL abort 252 ENDIF 253 else 254 PRINT*, 'phyetat0: Le champ <FLIC> est absent' 255 c$$$ CALL abort 256 ENDIF 257 C 258 C fraction d'ocean 259 C 260 ierr = NF_INQ_VARID (nid, "FOCE", nvarid) 261 IF (ierr .EQ. NF_NOERR) THEN 262 #ifdef NC_DOUBLE 263 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, pctsrf(1 : klon,is_oce)) 264 #else 265 ierr = NF_GET_VAR_REAL(nid, nvarid, pctsrf(1 : klon,is_oce)) 266 #endif 267 IF (ierr.NE.NF_NOERR) THEN 268 PRINT*, 'phyetat0: Lecture echouee pour <FOCE>' 269 CALL abort 270 ENDIF 271 else 272 PRINT*, 'phyetat0: Le champ <FOCE> est absent' 273 c$$$ CALL abort 274 ENDIF 275 C 276 C fraction glace de mer 277 C 278 ierr = NF_INQ_VARID (nid, "FSIC", nvarid) 279 IF (ierr .EQ. NF_NOERR) THEN 280 #ifdef NC_DOUBLE 281 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, pctsrf(1 : klon,is_sic)) 282 #else 283 ierr = NF_GET_VAR_REAL(nid, nvarid, pctsrf(1 : klon, is_sic)) 284 #endif 285 IF (ierr.NE.NF_NOERR) THEN 286 PRINT*, 'phyetat0: Lecture echouee pour <FSIC>' 287 CALL abort 288 ENDIF 289 else 290 PRINT*, 'phyetat0: Le champ <FSIC> est absent' 291 c$$$ CALL abort 292 ENDIF 293 C 294 C Verification de l'adequation entre le masque et les sous-surfaces 295 C 296 fractint( 1 : klon) = pctsrf(1 : klon, is_ter) 297 $ + pctsrf(1 : klon, is_lic) 298 DO i = 1 , klon 299 IF ( abs(fractint(i) - zmasq(i) ) .GT. EPSFRA ) THEN 300 WRITE(*,*) 'phyetat0: attention fraction terre pas ', 301 $ 'coherente ', i, zmasq(i), pctsrf(i, is_ter) 302 $ ,pctsrf(i, is_lic) 303 ENDIF 304 END DO 305 fractint (1 : klon) = pctsrf(1 : klon, is_oce) 306 $ + pctsrf(1 : klon, is_sic) 307 DO i = 1 , klon 308 IF ( abs( fractint(i) - (1. - zmasq(i))) .GT. EPSFRA ) THEN 309 WRITE(*,*) 'phyetat0 attention fraction ocean pas ', 310 $ 'coherente ', i, zmasq(i) , pctsrf(i, is_oce) 311 $ ,pctsrf(i, is_sic) 312 ENDIF 313 END DO 314 C 187 315 c Lecture des temperatures du sol: 188 316 c … … 419 547 ENDIF 420 548 c 549 c Lecture de albedo au sol: 550 c 551 ierr = NF_INQ_VARID (nid, "ALBE", nvarid) 552 IF (ierr.NE.NF_NOERR) THEN 553 PRINT*, 'phyetat0: Le champ <ALBE> est absent' 554 PRINT*, ' Mais je vais essayer de lire ALBE**' 555 DO nsrf = 1, nbsrf 556 IF (nsrf.GT.99) THEN 557 PRINT*, "Trop de sous-mailles" 558 CALL abort 559 ENDIF 560 WRITE(str2,'(i2.2)') nsrf 561 ierr = NF_INQ_VARID (nid, "ALBE"//str2, nvarid) 562 IF (ierr.NE.NF_NOERR) THEN 563 PRINT*, "phyetat0: Le champ <ALBE"//str2//"> est absent" 564 CALL abort 565 ENDIF 566 #ifdef NC_DOUBLE 567 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, albe(1,nsrf)) 568 #else 569 ierr = NF_GET_VAR_REAL(nid, nvarid, albe(1,nsrf)) 570 #endif 571 IF (ierr.NE.NF_NOERR) THEN 572 PRINT*, "phyetat0: Lecture echouee pour <ALBE"//str2//">" 573 CALL abort 574 ENDIF 575 xmin = 1.0E+20 576 xmax = -1.0E+20 577 DO i = 1, klon 578 xmin = MIN(snow(i,nsrf),xmin) 579 xmax = MAX(snow(i,nsrf),xmax) 580 ENDDO 581 PRINT*,'Neige du sol ALBE**:', nsrf, xmin, xmax 582 ENDDO 583 ELSE 584 PRINT*, 'phyetat0: Le champ <ALBE> est present' 585 PRINT*, ' J ignore donc les autres ALBE**' 586 #ifdef NC_DOUBLE 587 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, albe(1,1)) 588 #else 589 ierr = NF_GET_VAR_REAL(nid, nvarid, albe(1,1)) 590 #endif 591 IF (ierr.NE.NF_NOERR) THEN 592 PRINT*, "phyetat0: Lecture echouee pour <ALBE>" 593 CALL abort 594 ENDIF 595 xmin = 1.0E+20 596 xmax = -1.0E+20 597 DO i = 1, klon 598 xmin = MIN(albe(i,1),xmin) 599 xmax = MAX(albe(i,1),xmax) 600 ENDDO 601 PRINT*,'Neige du sol <ALBE>', xmin, xmax 602 DO nsrf = 2, nbsrf 603 DO i = 1, klon 604 albe(i,nsrf) = albe(i,1) 605 ENDDO 606 ENDDO 607 ENDIF 608 609 c 610 c Lecture de evaporation: 611 c 612 ierr = NF_INQ_VARID (nid, "EVAP", nvarid) 613 IF (ierr.NE.NF_NOERR) THEN 614 PRINT*, 'phyetat0: Le champ <EVAP> est absent' 615 PRINT*, ' Mais je vais essayer de lire EVAP**' 616 DO nsrf = 1, nbsrf 617 IF (nsrf.GT.99) THEN 618 PRINT*, "Trop de sous-mailles" 619 CALL abort 620 ENDIF 621 WRITE(str2,'(i2.2)') nsrf 622 ierr = NF_INQ_VARID (nid, "EVAP"//str2, nvarid) 623 IF (ierr.NE.NF_NOERR) THEN 624 PRINT*, "phyetat0: Le champ <EVAP"//str2//"> est absent" 625 CALL abort 626 ENDIF 627 #ifdef NC_DOUBLE 628 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, evap(1,nsrf)) 629 #else 630 ierr = NF_GET_VAR_REAL(nid, nvarid, evap(1,nsrf)) 631 #endif 632 IF (ierr.NE.NF_NOERR) THEN 633 PRINT*, "phyetat0: Lecture echouee pour <EVAP"//str2//">" 634 CALL abort 635 ENDIF 636 xmin = 1.0E+20 637 xmax = -1.0E+20 638 DO i = 1, klon 639 xmin = MIN(evap(i,nsrf),xmin) 640 xmax = MAX(evap(i,nsrf),xmax) 641 ENDDO 642 PRINT*,'Neige du sol EVAP**:', nsrf, xmin, xmax 643 ENDDO 644 ELSE 645 PRINT*, 'phyetat0: Le champ <EVAP> est present' 646 PRINT*, ' J ignore donc les autres EVAP**' 647 #ifdef NC_DOUBLE 648 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, evap(1,1)) 649 #else 650 ierr = NF_GET_VAR_REAL(nid, nvarid, evap(1,1)) 651 #endif 652 IF (ierr.NE.NF_NOERR) THEN 653 PRINT*, "phyetat0: Lecture echouee pour <EVAP>" 654 CALL abort 655 ENDIF 656 xmin = 1.0E+20 657 xmax = -1.0E+20 658 DO i = 1, klon 659 xmin = MIN(evap(i,1),xmin) 660 xmax = MAX(evap(i,1),xmax) 661 ENDDO 662 PRINT*,'Neige du sol <EVAP>', xmin, xmax 663 DO nsrf = 2, nbsrf 664 DO i = 1, klon 665 evap(i,nsrf) = evap(i,1) 666 ENDDO 667 ENDDO 668 ENDIF 669 c 670 c Lecture precipitation liquide: 671 c 672 ierr = NF_INQ_VARID (nid, "rain_f", nvarid) 673 IF (ierr.NE.NF_NOERR) THEN 674 PRINT*, 'phyetat0: Le champ <rain_f> est absent' 675 CALL abort 676 ENDIF 677 #ifdef NC_DOUBLE 678 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, rain_fall) 679 #else 680 ierr = NF_GET_VAR_REAL(nid, nvarid, rain_fall) 681 #endif 682 IF (ierr.NE.NF_NOERR) THEN 683 PRINT*, 'phyetat0: Lecture echouee pour <rain_f>' 684 CALL abort 685 ENDIF 686 xmin = 1.0E+20 687 xmax = -1.0E+20 688 DO i = 1, klon 689 xmin = MIN(rain_fall(i),xmin) 690 xmax = MAX(rain_fall(i),xmax) 691 ENDDO 692 PRINT*,'Precipitation liquide rain_f:', xmin, xmax 693 c 694 c Lecture precipitation solide: 695 c 696 ierr = NF_INQ_VARID (nid, "snow_f", nvarid) 697 IF (ierr.NE.NF_NOERR) THEN 698 PRINT*, 'phyetat0: Le champ <snow_f> est absent' 699 CALL abort 700 ENDIF 701 #ifdef NC_DOUBLE 702 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, snow_fall) 703 #else 704 ierr = NF_GET_VAR_REAL(nid, nvarid, snow_fall) 705 #endif 706 IF (ierr.NE.NF_NOERR) THEN 707 PRINT*, 'phyetat0: Lecture echouee pour <snow_f>' 708 CALL abort 709 ENDIF 710 xmin = 1.0E+20 711 xmax = -1.0E+20 712 DO i = 1, klon 713 xmin = MIN(snow_fall(i),xmin) 714 xmax = MAX(snow_fall(i),xmax) 715 ENDDO 716 PRINT*,'Precipitation solide snow_f:', xmin, xmax 717 c 718 c Lecture rayonnement solaire au sol: 719 c 720 ierr = NF_INQ_VARID (nid, "solsw", nvarid) 721 IF (ierr.NE.NF_NOERR) THEN 722 PRINT*, 'phyetat0: Le champ <solsw> est absent' 723 PRINT*, 'mis a zero' 724 solsw = 0. 725 ELSE 726 #ifdef NC_DOUBLE 727 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, solsw) 728 #else 729 ierr = NF_GET_VAR_REAL(nid, nvarid, solsw) 730 #endif 731 IF (ierr.NE.NF_NOERR) THEN 732 PRINT*, 'phyetat0: Lecture echouee pour <solsw>' 733 CALL abort 734 ENDIF 735 ENDIF 736 xmin = 1.0E+20 737 xmax = -1.0E+20 738 DO i = 1, klon 739 xmin = MIN(solsw(i),xmin) 740 xmax = MAX(solsw(i),xmax) 741 ENDDO 742 PRINT*,'Rayonnement solaire au sol solsw:', xmin, xmax 743 c 744 c Lecture rayonnement IF au sol: 745 c 746 ierr = NF_INQ_VARID (nid, "sollw", nvarid) 747 IF (ierr.NE.NF_NOERR) THEN 748 PRINT*, 'phyetat0: Le champ <sollw> est absent' 749 PRINT*, 'mis a zero' 750 sollw = 0. 751 ELSE 752 #ifdef NC_DOUBLE 753 ierr = NF_GET_VAR_DOUBLE(nid, nvarid, sollw) 754 #else 755 ierr = NF_GET_VAR_REAL(nid, nvarid, sollw) 756 #endif 757 IF (ierr.NE.NF_NOERR) THEN 758 PRINT*, 'phyetat0: Lecture echouee pour <sollw>' 759 CALL abort 760 ENDIF 761 ENDIF 762 xmin = 1.0E+20 763 xmax = -1.0E+20 764 DO i = 1, klon 765 xmin = MIN(sollw(i),xmin) 766 xmax = MAX(sollw(i),xmax) 767 ENDDO 768 PRINT*,'Rayonnement IF au sol sollw:', xmin, xmax 769 770 c 421 771 c Lecture du rayonnement net au sol: 422 772 c -
LMDZ.3.3/branches/rel-LF/libf/phylmd/phyredem.F
r79 r98 1 1 SUBROUTINE phyredem (fichnom,dtime,radpas,co2_ppm,solaire, 2 . rlat,rlon,tsol,tsoil,deltat,qsol,snow, 2 . rlat,rlon, pctsrf,tsol,tsoil,deltat,qsol,snow, 3 . albedo, evap, rain_fall, snow_fall, 4 . solsw, sollw, 3 5 . radsol,rugmer,agesno, 4 6 . zmea,zstd,zsig,zgam,zthe,zpic,zval,rugsrel, … … 29 31 REAL qsol(klon,nbsrf) 30 32 REAL snow(klon,nbsrf) 33 REAL albedo(klon,nbsrf) 34 REAL evap(klon,nbsrf) 35 REAL rain_fall(klon) 36 REAL snow_fall(klon) 37 real solsw(klon) 38 real sollw(klon) 31 39 REAL radsol(klon) 32 40 REAL rugmer(klon) … … 40 48 REAL zval(klon) 41 49 REAL rugsrel(klon) 50 REAL pctsrf(klon, nbsrf) 42 51 REAL t_ancien(klon,klev), q_ancien(klon,klev) 43 52 c … … 134 143 #endif 135 144 c 145 C PB ajout du masque terre/mer 146 C 147 ierr = NF_REDEF (nid) 148 #ifdef NC_DOUBLE 149 ierr = NF_DEF_VAR (nid, "masque", NF_DOUBLE, 1, idim2,nvarid) 150 #else 151 ierr = NF_DEF_VAR (nid, "masque", NF_FLOAT, 1, idim2,nvarid) 152 #endif 153 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 16, 154 . "masque terre mer") 155 ierr = NF_ENDDEF(nid) 156 #ifdef NC_DOUBLE 157 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,zmasq) 158 #else 159 ierr = NF_PUT_VAR_REAL (nid,nvarid,zmasq) 160 #endif 161 c BP ajout des fraction de chaque sous-surface 162 C 163 C 1. fraction de terre 164 C 165 ierr = NF_REDEF (nid) 166 #ifdef NC_DOUBLE 167 ierr = NF_DEF_VAR (nid, "FTER", NF_DOUBLE, 1, idim2,nvarid) 168 #else 169 ierr = NF_DEF_VAR (nid, "FTER", NF_FLOAT, 1, idim2,nvarid) 170 #endif 171 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 21, 172 . "fraction de continent") 173 ierr = NF_ENDDEF(nid) 174 #ifdef NC_DOUBLE 175 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,pctsrf(1 : klon, is_ter)) 176 #else 177 ierr = NF_PUT_VAR_REAL (nid,nvarid,pctsrf(1 : klon, is_ter)) 178 #endif 179 C 180 C 2. Fraction de glace de terre 181 C 182 ierr = NF_REDEF (nid) 183 #ifdef NC_DOUBLE 184 ierr = NF_DEF_VAR (nid, "FLIC", NF_DOUBLE, 1, idim2,nvarid) 185 #else 186 ierr = NF_DEF_VAR (nid, "FLIC", NF_FLOAT, 1, idim2,nvarid) 187 #endif 188 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 24, 189 . "fraction glace de terre") 190 ierr = NF_ENDDEF(nid) 191 #ifdef NC_DOUBLE 192 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,pctsrf(1 : klon,is_lic)) 193 #else 194 ierr = NF_PUT_VAR_REAL (nid,nvarid,pctsrf(1 : klon, is_lic)) 195 #endif 196 C 197 C 3. fraction ocean 198 C 199 ierr = NF_REDEF (nid) 200 #ifdef NC_DOUBLE 201 ierr = NF_DEF_VAR (nid, "FOCE", NF_DOUBLE, 1, idim2,nvarid) 202 #else 203 ierr = NF_DEF_VAR (nid, "FOCE", NF_FLOAT, 1, idim2,nvarid) 204 #endif 205 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 14, 206 . "fraction ocean") 207 ierr = NF_ENDDEF(nid) 208 #ifdef NC_DOUBLE 209 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,pctsrf(1 : klon, is_oce)) 210 #else 211 ierr = NF_PUT_VAR_REAL (nid,nvarid,pctsrf(1 : klon, is_oce)) 212 #endif 213 C 214 C 4. Fraction glace de mer 215 C 216 ierr = NF_REDEF (nid) 217 #ifdef NC_DOUBLE 218 ierr = NF_DEF_VAR (nid, "FSIC", NF_DOUBLE, 1, idim2,nvarid) 219 #else 220 ierr = NF_DEF_VAR (nid, "FSIC", NF_FLOAT, 1, idim2,nvarid) 221 #endif 222 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 18, 223 . "fraction glace mer") 224 ierr = NF_ENDDEF(nid) 225 #ifdef NC_DOUBLE 226 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,pctsrf(1 : klon, is_sic)) 227 #else 228 ierr = NF_PUT_VAR_REAL (nid,nvarid,pctsrf(1 : klon, is_sic)) 229 #endif 230 C 231 C 136 232 c 137 233 DO nsrf = 1, nbsrf … … 227 323 ierr = NF_REDEF (nid) 228 324 #ifdef NC_DOUBLE 325 ierr = NF_DEF_VAR (nid,"ALBE"//str2,NF_DOUBLE,1,idim2,nvarid) 326 #else 327 ierr = NF_DEF_VAR (nid,"ALBE"//str2,NF_FLOAT,1,idim2,nvarid) 328 #endif 329 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 23, 330 . "albedo de surface No."//str2) 331 ierr = NF_ENDDEF(nid) 332 ELSE 333 PRINT*, "Trop de sous-mailles" 334 CALL abort 335 ENDIF 336 #ifdef NC_DOUBLE 337 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,albedo(1,nsrf)) 338 #else 339 ierr = NF_PUT_VAR_REAL (nid,nvarid,albedo(1,nsrf)) 340 #endif 341 ENDDO 342 c 343 DO nsrf = 1, nbsrf 344 IF (nsrf.LE.99) THEN 345 WRITE(str2,'(i2.2)') nsrf 346 ierr = NF_REDEF (nid) 347 #ifdef NC_DOUBLE 348 ierr = NF_DEF_VAR (nid,"EVAP"//str2,NF_DOUBLE,1,idim2,nvarid) 349 #else 350 ierr = NF_DEF_VAR (nid,"EVAP"//str2,NF_FLOAT,1,idim2,nvarid) 351 #endif 352 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 28, 353 . "Evaporation de surface No."//str2) 354 ierr = NF_ENDDEF(nid) 355 ELSE 356 PRINT*, "Trop de sous-mailles" 357 CALL abort 358 ENDIF 359 #ifdef NC_DOUBLE 360 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,evap(1,nsrf)) 361 #else 362 ierr = NF_PUT_VAR_REAL (nid,nvarid,evap(1,nsrf)) 363 #endif 364 ENDDO 365 366 c 367 DO nsrf = 1, nbsrf 368 IF (nsrf.LE.99) THEN 369 WRITE(str2,'(i2.2)') nsrf 370 ierr = NF_REDEF (nid) 371 #ifdef NC_DOUBLE 229 372 ierr = NF_DEF_VAR (nid,"SNOW"//str2,NF_DOUBLE,1,idim2,nvarid) 230 373 #else … … 244 387 #endif 245 388 ENDDO 389 246 390 c 247 391 ierr = NF_REDEF (nid) … … 262 406 ierr = NF_REDEF (nid) 263 407 #ifdef NC_DOUBLE 408 ierr = NF_DEF_VAR (nid, "solsw", NF_DOUBLE, 1, idim2,nvarid) 409 #else 410 ierr = NF_DEF_VAR (nid, "solsw", NF_FLOAT, 1, idim2,nvarid) 411 #endif 412 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 32, 413 . "Rayonnement solaire a la surface") 414 ierr = NF_ENDDEF(nid) 415 #ifdef NC_DOUBLE 416 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,solsw) 417 #else 418 ierr = NF_PUT_VAR_REAL (nid,nvarid,solsw) 419 #endif 420 c 421 ierr = NF_REDEF (nid) 422 #ifdef NC_DOUBLE 423 ierr = NF_DEF_VAR (nid, "sollw", NF_DOUBLE, 1, idim2,nvarid) 424 #else 425 ierr = NF_DEF_VAR (nid, "sollw", NF_FLOAT, 1, idim2,nvarid) 426 #endif 427 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 27, 428 . "Rayonnement IF a la surface") 429 ierr = NF_ENDDEF(nid) 430 #ifdef NC_DOUBLE 431 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,sollw) 432 #else 433 ierr = NF_PUT_VAR_REAL (nid,nvarid,sollw) 434 #endif 435 c 436 ierr = NF_REDEF (nid) 437 #ifdef NC_DOUBLE 438 ierr = NF_DEF_VAR (nid, "rain_f", NF_DOUBLE, 1, idim2,nvarid) 439 #else 440 ierr = NF_DEF_VAR (nid, "rain_f", NF_FLOAT, 1, idim2,nvarid) 441 #endif 442 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 21, 443 . "precipitation liquide") 444 ierr = NF_ENDDEF(nid) 445 #ifdef NC_DOUBLE 446 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,rain_fall) 447 #else 448 ierr = NF_PUT_VAR_REAL (nid,nvarid,rain_fall) 449 #endif 450 c 451 ierr = NF_REDEF (nid) 452 #ifdef NC_DOUBLE 453 ierr = NF_DEF_VAR (nid, "snow_f", NF_DOUBLE, 1, idim2,nvarid) 454 #else 455 ierr = NF_DEF_VAR (nid, "snow_f", NF_FLOAT, 1, idim2,nvarid) 456 #endif 457 ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 20, 458 . "precipitation solide") 459 ierr = NF_ENDDEF(nid) 460 #ifdef NC_DOUBLE 461 ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,snow_fall) 462 #else 463 ierr = NF_PUT_VAR_REAL (nid,nvarid,snow_fall) 464 #endif 465 c 466 ierr = NF_REDEF (nid) 467 #ifdef NC_DOUBLE 264 468 ierr = NF_DEF_VAR (nid, "RUGMER", NF_DOUBLE, 1, idim2,nvarid) 265 469 #else -
LMDZ.3.3/branches/rel-LF/libf/phylmd/physiq.F
r88 r98 100 100 REAL soilcap(klon,nbsrf), soilflux(klon,nbsrf) 101 101 SAVE soilcap, soilflux 102 logical ok_veget 103 parameter (ok_veget = .false.) 102 104 c====================================================================== 103 105 c Dans les versions precedentes, l'eau liquide nuageuse utilisee dans … … 132 134 INTEGER iliq ! indice de traceurs pour eau liquide 133 135 PARAMETER (iliq=2) 134 c 136 135 137 INTEGER nvm ! nombre de vegetations 136 138 PARAMETER (nvm=8) 137 139 REAL veget(klon,nvm) ! couverture vegetale 138 140 SAVE veget 141 142 c 139 143 c 140 144 c Variables argument: … … 224 228 SAVE ftsoil ! temperature dans le sol 225 229 c 230 REAL fevap(klon,nbsrf) 231 SAVE fevap ! evaporation 232 c 226 233 REAL deltat(klon) 227 234 SAVE deltat ! ecart avec la SST de reference … … 232 239 REAL fsnow(klon,nbsrf) 233 240 SAVE fsnow ! epaisseur neigeuse 241 c 242 REAL falbe(klon,nbsrf) 243 SAVE falbe ! albedo par type de surface 234 244 c 235 245 REAL rugmer(klon) … … 379 389 REAL cldemi(klon,klev) ! emissivite infrarouge 380 390 c 381 REAL fluxq(klon,klev) ! flux turbulent d'humidite 382 REAL fluxt(klon,klev) ! flux turbulent de chaleur 383 REAL fluxu(klon,klev) ! flux turbulent de vitesse u 384 REAL fluxv(klon,klev) ! flux turbulent de vitesse v 385 c 391 C§§§ PB 392 REAL fluxq(klon,klev, nbsrf) ! flux turbulent d'humidite 393 REAL fluxt(klon,klev, nbsrf) ! flux turbulent de chaleur 394 REAL fluxu(klon,klev, nbsrf) ! flux turbulent de vitesse u 395 REAL fluxv(klon,klev, nbsrf) ! flux turbulent de vitesse v 396 c 397 REAL zxfluxt(klon, klev) 398 REAL zxfluxq(klon, klev) 399 REAL zxfluxu(klon, klev) 400 REAL zxfluxv(klon, klev) 401 C§§§ 386 402 REAL heat(klon,klev) ! chauffage solaire 387 403 REAL heat0(klon,klev) ! chauffage solaire ciel clair … … 424 440 c 425 441 REAL zphi(klon,klev) 426 REAL zx_tmp_x(iim), zx_tmp_yjjmp1427 442 REAL zx_relief(iim,jjmp1) 428 443 REAL zx_aire(iim,jjmp1) … … 561 576 c 562 577 IF (debut) THEN 563 c 564 565 IF (ok_oasis) THEN 566 PRINT*, "Attentions! les parametres suivants sont fixes:" 567 PRINT *,'***********************************************' 568 PRINT*, "npas, nexca, itimestep=", npas, nexca, itimestep 569 PRINT*, "Changer-les manuellement s il le faut" 570 PRINT *,'***********************************************' 571 CALL inicma( npas, nexca, itimestep) 572 ENDIF 573 c 574 IF (ok_ocean) THEN 575 PRINT*, '************************' 576 PRINT*, 'SLAB OCEAN est active, prenez precautions !' 577 PRINT*, '************************' 578 ENDIF 579 c 578 580 579 DO k = 2, nvm ! pas de vegetation 581 580 DO i = 1, klon … … 588 587 PRINT*, 'Pas de vegetation; desert partout' 589 588 c 589 c 590 590 c Initialiser les compteurs: 591 591 c … … 595 595 c 596 596 CALL phyetat0 ("startphy.nc",dtime,co2_ppm,solaire, 597 . rlat,rlon,ftsol,ftsoil,deltat,fqsol,fsnow, 598 . radsol,rugmer,agesno,clesphy0, 597 . rlat,rlon,pctsrf, ftsol,ftsoil,deltat,fqsol,fsnow, 598 . falbe, fevap, rain_fall,snow_fall,sollw, solsw, 599 . radsol,rugmer,agesno,clesphy0, 599 600 . zmea,zstd,zsig,zgam,zthe,zpic,zval,rugoro,tabcntr0, 600 601 . t_ancien, q_ancien, ancien_ok ) … … 646 647 ENDIF 647 648 c 648 IF (soil_model) THEN649 DO nsrf = 1, nbsrf650 CALL soil(dtime, nsrf, fsnow(1,nsrf),651 . ftsol(1,nsrf), ftsoil(1,1,nsrf),652 . soilcap(1,nsrf), soilflux(1,nsrf))653 ENDDO654 ENDIF655 649 c 656 650 lmt_pas = NINT(86400./dtime * 1.0) ! tous les jours … … 716 710 . "ave(X)", zsto,zout) 717 711 c 712 CALL histdef(nid_day, "tter", "Surface Temperature", "K", 713 . iim,jjmp1,nhori, 1,1,1, -99, 32, 714 . "ave(X)", zsto,zout) 715 c 716 CALL histdef(nid_day, "tlic", "Surface Temperature", "K", 717 . iim,jjmp1,nhori, 1,1,1, -99, 32, 718 . "ave(X)", zsto,zout) 719 c 720 CALL histdef(nid_day, "toce", "Surface Temperature", "K", 721 . iim,jjmp1,nhori, 1,1,1, -99, 32, 722 . "ave(X)", zsto,zout) 723 c 724 CALL histdef(nid_day, "tsic", "Surface Temperature", "K", 725 . iim,jjmp1,nhori, 1,1,1, -99, 32, 726 . "ave(X)", zsto,zout) 727 c 718 728 CALL histdef(nid_day, "psol", "Surface Pressure", "Pa", 719 729 . iim,jjmp1,nhori, 1,1,1, -99, 32, … … 768 778 . "ave(X)", zsto,zout) 769 779 c 780 C §§§ PB flux pour chauqe sous surface 781 C 782 DO nsrf = 1, nbsrf 783 C 784 call histdef(nid_day, "pourc_"//clnsurf(nsrf), 785 $ "Fraction"//clnsurf(nsrf), "W/m2", 786 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 787 $ "ave(X)", zsto,zout) 788 789 call histdef(nid_day, "sens_"//clnsurf(nsrf), 790 $ "Sensible heat flux "//clnsurf(nsrf), "W/m2", 791 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 792 $ "ave(X)", zsto,zout) 793 c 794 call histdef(nid_day, "lat_"//clnsurf(nsrf), 795 $ "Latent heat flux "//clnsurf(nsrf), "W/m2", 796 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 797 $ "ave(X)", zsto,zout) 798 C 799 call histdef(nid_day, "taux_"//clnsurf(nsrf), 800 $ "Zonal wind stress"//clnsurf(nsrf),"Pa", 801 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 802 $ "ave(X)", zsto,zout) 803 804 call histdef(nid_day, "tauy_"//clnsurf(nsrf), 805 $ "Meridional xind stress "//clnsurf(nsrf), "Pa", 806 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 807 $ "ave(X)", zsto,zout) 808 C§§§ 809 END DO 810 770 811 CALL histdef(nid_day, "ruis", "Runoff", "mm/day", 771 812 . iim,jjmp1,nhori, 1,1,1, -99, 32, … … 956 997 . "ave(X)", zsto,zout) 957 998 c 999 DO nsrf = 1, nbsrf 1000 C 1001 call histdef(nid_mth, "pourc_"//clnsurf(nsrf), 1002 $ "Fraction "//clnsurf(nsrf), "W/m2", 1003 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1004 $ "ave(X)", zsto,zout) 1005 C 1006 call histdef(nid_mth, "sens_"//clnsurf(nsrf), 1007 $ "Sensible heat flux "//clnsurf(nsrf), "W/m2", 1008 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1009 $ "ave(X)", zsto,zout) 1010 c 1011 call histdef(nid_mth, "lat_"//clnsurf(nsrf), 1012 $ "Latent heat flux "//clnsurf(nsrf), "W/m2", 1013 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1014 $ "ave(X)", zsto,zout) 1015 C 1016 call histdef(nid_mth, "taux_"//clnsurf(nsrf), 1017 $ "Zonal wind stress"//clnsurf(nsrf), "Pa", 1018 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1019 $ "ave(X)", zsto,zout) 1020 1021 call histdef(nid_mth, "tauy_"//clnsurf(nsrf), 1022 $ "Meridional xind stress "//clnsurf(nsrf), "Pa", 1023 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1024 $ "ave(X)", zsto,zout) 1025 END DO 1026 C 958 1027 CALL histdef(nid_mth, "ruis", "Runoff", "mm/day", 959 1028 . iim,jjmp1,nhori, 1,1,1, -99, 32, … … 1209 1278 c Champs 2D: 1210 1279 c 1211 CALL histdef(nid_ins, "psol", "Surface Pressure", "Pa", 1280 CALL histdef(nid_ins, "tsol", "Surface Temperature", "K", 1281 . iim,jjmp1,nhori, 1,1,1, -99, 32, 1282 . "inst(X)", zsto,zout) 1283 c 1284 CALL histdef(nid_ins, "psol", "Surface Pressure", "Pa", 1212 1285 . iim,jjmp1,nhori, 1,1,1, -99, 32, 1213 1286 . "inst(X)", zsto,zout) … … 1256 1329 . iim,jjmp1,nhori, 1,1,1, -99, 32, 1257 1330 . "inst(X)", zsto,zout) 1331 1332 DO nsrf = 1, nbsrf 1333 C 1334 call histdef(nid_ins, "pourc_"//clnsurf(nsrf), 1335 $ "Fraction"//clnsurf(nsrf), "W/m2", 1336 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1337 $ "inst(X)", zsto,zout) 1338 1339 call histdef(nid_ins, "sens_"//clnsurf(nsrf), 1340 $ "Sensible heat flux "//clnsurf(nsrf), "W/m2", 1341 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1342 $ "inst(X)", zsto,zout) 1343 c 1344 call histdef(nid_ins, "tsol_"//clnsurf(nsrf), 1345 $ "Surface Temperature"//clnsurf(nsrf), "W/m2", 1346 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1347 $ "inst(X)", zsto,zout) 1348 c 1349 call histdef(nid_ins, "lat_"//clnsurf(nsrf), 1350 $ "Latent heat flux "//clnsurf(nsrf), "W/m2", 1351 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1352 $ "inst(X)", zsto,zout) 1353 C 1354 call histdef(nid_ins, "taux_"//clnsurf(nsrf), 1355 $ "Zonal wind stress"//clnsurf(nsrf),"Pa", 1356 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1357 $ "inst(X)", zsto,zout) 1358 1359 call histdef(nid_ins, "tauy_"//clnsurf(nsrf), 1360 $ "Meridional xind stress "//clnsurf(nsrf), "Pa", 1361 $ iim,jjmp1,nhori, 1,1,1, -99, 32, 1362 $ "inst(X)", zsto,zout) 1363 C§§§ 1364 END DO 1258 1365 c 1259 1366 c Champs 3D: … … 1306 1413 cc ENDDO 1307 1414 c 1308 IF (ok_oasis) THEN1309 DO i = 1, klon1310 oas_sols(i) = 0.01311 oas_nsol(i) = 0.01312 oas_rain(i) = 0.01313 oas_snow(i) = 0.01314 oas_evap(i) = 0.01315 oas_ruis(i) = 0.01316 oas_tsol(i) = 0.01317 oas_fder(i) = 0.01318 oas_albe(i) = 0.01319 oas_taux(i) = 0.01320 oas_tauy(i) = 0.01321 ENDDO1322 ENDIF1323 1415 c 1324 1416 ENDIF … … 1421 1513 CALL ozonecm( FLOAT(julien), rlat, paprs, wo) 1422 1514 ENDIF 1423 cccccccccc1424 IF (ok_oasis .AND. MOD(itap-1,nexca).EQ.0) THEN1425 C1426 CALL fromcpl(itap,jjmp1*iim,1427 . cpl_sst,cpl_sic,cpl_alb_sst,cpl_alb_sic)1428 DO i = 1, iim-1 ! un seul point pour le pole nord1429 cpl_sst(i,1) = cpl_sst(iim,1)1430 cpl_sic(i,1) = cpl_sic(iim,1)1431 cpl_alb_sst(i,1) = cpl_alb_sst(iim,1)1432 cpl_alb_sic(i,1) = cpl_alb_sic(iim,1)1433 ENDDO1434 DO i = 2, iim ! un seul point pour le pole sud1435 cpl_sst(i,jjmp1) = cpl_sst(1,jjmp1)1436 cpl_sic(i,jjmp1) = cpl_sic(1,jjmp1)1437 cpl_alb_sst(i,jjmp1) = cpl_alb_sst(1,jjmp1)1438 cpl_alb_sic(i,jjmp1) = cpl_alb_sic(1,jjmp1)1439 ENDDO1440 c1441 ig = 11442 IF (pctsrf(ig,is_oce).GT.epsfra .OR.1443 . pctsrf(ig,is_sic).GT.epsfra) THEN1444 pctsrf(ig,is_oce) = pctsrf(ig,is_oce)1445 . - (cpl_sic(1,1)-pctsrf(ig,is_sic))1446 pctsrf(ig,is_sic) = cpl_sic(1,1)1447 lmt_sst(ig) = cpl_sst(1,1)1448 ENDIF1449 DO j = 2, jjm1450 DO i = 1, iim1451 ig = ig + 11452 IF (pctsrf(ig,is_oce).GT.epsfra .OR.1453 . pctsrf(ig,is_sic).GT.epsfra) THEN1454 pctsrf(ig,is_oce) = pctsrf(ig,is_oce)1455 . - (cpl_sic(i,j)-pctsrf(ig,is_sic))1456 pctsrf(ig,is_sic) = cpl_sic(i,j)1457 lmt_sst(ig) = cpl_sst(i,j)1458 ENDIF1459 ENDDO1460 ENDDO1461 ig = ig + 11462 IF (pctsrf(ig,is_oce).GT.epsfra .OR.1463 . pctsrf(ig,is_sic).GT.epsfra) THEN1464 pctsrf(ig,is_oce) = pctsrf(ig,is_oce)1465 . - (cpl_sic(1,jjmp1)-pctsrf(ig,is_sic))1466 pctsrf(ig,is_sic) = cpl_sic(1,jjmp1)1467 lmt_sst(ig) = cpl_sst(1,jjmp1)1468 ENDIF1469 c1470 ENDIF ! ok_oasis1471 cccccccccc1472 c1473 1474 IF (ok_ocean) THEN1475 DO i = 1, klon1476 ftsol(i,is_oce) = lmt_sst(i) + deltat(i)1477 ENDDO1478 1479 ELSE1480 DO i = 1, klon1481 ftsol(i,is_oce) = lmt_sst(i)1482 ENDDO1483 1484 ENDIF1485 1515 c 1486 1516 c Re-evaporer l'eau liquide nuageuse … … 1523 1553 c 1524 1554 CALL clmain(dtime,pctsrf, 1525 e t_seri,q_seri,u_seri,v_seri,soil_model, 1526 e ftsol,soilcap,soilflux,paprs,pplay,radsol, 1527 e fsnow,fqsol, 1528 e rlat, frugs, 1555 e t_seri,q_seri,u_seri,v_seri,ok_veget, 1556 e ftsol,paprs,pplay,radsol, 1557 e fsnow,fqsol,fevap,falbe, 1558 e rain_fall, snow_fall, solsw, sollw, 1559 e rlon, rlat, frugs, 1560 e debut, lafin, 1529 1561 s d_t_vdf,d_q_vdf,d_u_vdf,d_v_vdf,d_ts, 1530 1562 s fluxt,fluxq,fluxu,fluxv,cdragh,cdragm,rugmer, … … 1532 1564 s ycoefh,yu1,yv1) 1533 1565 c 1534 DO i = 1, klon 1535 sens(i) = - fluxt(i,1) ! flux de chaleur sensible au sol 1536 evap(i) = - fluxq(i,1) ! flux d'evaporation au sol 1566 C§§§ PB 1567 C§§§ Incrementation des flux 1568 C§§ 1569 zxfluxt=0. 1570 zxfluxq=0. 1571 zxfluxu=0. 1572 zxfluxv=0. 1573 DO nsrf = 1, nbsrf 1574 DO k = 1, klev 1575 DO i = 1, klon 1576 zxfluxt(i,k) = zxfluxt(i,k) + 1577 $ fluxt(i,k,nsrf) * pctsrf( i, nsrf) 1578 zxfluxq(i,k) = zxfluxq(i,k) + 1579 $ fluxq(i,k,nsrf) * pctsrf( i, nsrf) 1580 zxfluxu(i,k) = zxfluxu(i,k) + 1581 $ fluxu(i,k,nsrf) * pctsrf( i, nsrf) 1582 zxfluxv(i,k) = zxfluxv(i,k) + 1583 $ fluxv(i,k,nsrf) * pctsrf( i, nsrf) 1584 END DO 1585 END DO 1586 END DO 1587 DO i = 1, klon 1588 sens(i) = - zxfluxt(i,1) ! flux de chaleur sensible au sol 1589 c evap(i) = - fluxq(i,1) ! flux d'evaporation au sol 1590 evap(i) = - zxfluxq(i,1) ! flux d'evaporation au sol 1537 1591 fder(i) = dsens(i) + devap(i) 1538 1592 ENDDO … … 1551 1605 DO i = 1, klon 1552 1606 zxtsol(i) = 0.0 1607 IF ( abs( pctsrf(i, is_ter) + pctsrf(i, is_lic) + 1608 $ pctsrf(i, is_oce) + pctsrf(i, is_sic) - 1.) .GT. EPSFRA) 1609 $ THEN 1610 WRITE(*,*) 'physiq : pb sous surface au point ', i, 1611 $ pctsrf(i, 1 : nbsrf) 1612 ENDIF 1553 1613 ENDDO 1554 1614 DO nsrf = 1, nbsrf … … 1568 1628 ENDDO 1569 1629 1570 c1571 c Appeler le modele du sol1572 c1573 IF (soil_model) THEN1574 DO nsrf = 1, nbsrf1575 CALL soil(dtime, nsrf, fsnow(1,nsrf),1576 . ftsol(1,nsrf), ftsoil(1,1,nsrf),1577 . soilcap(1,nsrf), soilflux(1,nsrf))1578 ENDDO1579 ENDIF1580 1630 c 1581 1631 c Calculer la derive du flux infrarouge … … 1623 1673 ELSE IF (iflag_con.EQ.2) THEN 1624 1674 CALL conflx(dtime, paprs, pplay, t_seri, q_seri, 1625 e conv_t, conv_q, fluxq(1,1), omega,1675 e conv_t, conv_q, zxfluxq(1,1), omega, 1626 1676 s d_t_con, d_q_con, rain_con, snow_con, 1627 1677 s pmfu, pmfd, pen_u, pde_u, pen_d, pde_d, … … 1820 1870 CALL albsno(veget,agesno,alb_neig) 1821 1871 DO i = 1, klon 1822 zx_alb_oce= alb_eau(i)1872 falbe(i,is_oce) = alb_eau(i) 1823 1873 IF (pctsrf(i,is_oce).GT.epsfra .AND. ftsol(i,is_oce).LT.271.35) 1824 . zx_alb_oce= 0.6 ! pour slab_ocean1874 . falbe(i,is_oce) = 0.6 ! pour slab_ocean 1825 1875 zfra = MAX(0.0,MIN(1.0,fsnow(i,is_lic)/(fsnow(i,is_lic)+10.0))) 1826 zx_alb_lic= alb_neig(i)*zfra + 0.6*(1.0-zfra)1876 falbe(i,is_lic) = alb_neig(i)*zfra + 0.6*(1.0-zfra) 1827 1877 zfra = MAX(0.0,MIN(1.0,fsnow(i,is_ter)/(fsnow(i,is_ter)+10.0))) 1828 zx_alb_ter= alb_neig(i)*zfra + lmt_alb(i)*(1.0-zfra)1878 falbe(i,is_ter) = alb_neig(i)*zfra + lmt_alb(i)*(1.0-zfra) 1829 1879 zfra = MAX(0.0,MIN(1.0,fsnow(i,is_sic)/(fsnow(i,is_sic)+10.0))) 1830 zx_alb_sic = alb_neig(i)*zfra + 0.6*(1.0-zfra) 1831 albsol(i) = zx_alb_oce * pctsrf(i,is_oce) 1832 . + zx_alb_lic * pctsrf(i,is_lic) 1833 . + zx_alb_ter * pctsrf(i,is_ter) 1834 . + zx_alb_sic * pctsrf(i,is_sic) 1835 ENDDO 1880 falbe(i,is_sic) = alb_neig(i)*zfra + 0.6*(1.0-zfra) 1881 albsol(i) = falbe(i,is_oce) * pctsrf(i,is_oce) 1882 . + falbe(i,is_lic) * pctsrf(i,is_lic) 1883 . + falbe(i,is_ter) * pctsrf(i,is_ter) 1884 . + falbe(i,is_sic) * pctsrf(i,is_sic) 1885 ENDDO 1886 c DO nsrf = 1, nbsrf 1887 c DO i = 1, klon 1888 c albsol(i) = albsol(i) + falbe(i,nsrf)*pctsrf(i,nsrf) 1889 c ENDDO 1890 c ENDDO 1836 1891 CALL radlwsw ! nouveau rayonnement (compatible Arpege-IFS) 1837 1892 e (dist, rmu0, fract, co2_ppm, solaire, … … 1856 1911 c Calculer l'hydrologie de la surface 1857 1912 c 1858 CALL hydrol(dtime,pctsrf,rain_fall, snow_fall,evap,1859 . agesno, ftsol,fqsol,fsnow, ruis)1913 c CALL hydrol(dtime,pctsrf,rain_fall, snow_fall, zxevap, 1914 c . agesno, ftsol,fqsol,fsnow, ruis) 1860 1915 c 1861 1916 DO i = 1, klon … … 2007 2062 c Accumuler les variables a stocker dans les fichiers histoire: 2008 2063 c 2009 IF (ok_oasis) THEN ! couplage oasis2010 DO i = 1, klon2011 oas_sols(i) = oas_sols(i) + solsw(i) / FLOAT(nexca)2012 oas_nsol(i) = oas_nsol(i) + (bils(i)-solsw(i))/ FLOAT(nexca)2013 oas_rain(i) = oas_rain(i) + rain_fall(i) / FLOAT(nexca)2014 oas_snow(i) = oas_snow(i) + snow_fall(i) / FLOAT(nexca)2015 oas_evap(i) = oas_evap(i) + evap(i) / FLOAT(nexca)2016 oas_tsol(i) = oas_tsol(i) + zxtsol(i) / FLOAT(nexca)2017 oas_fder(i) = oas_fder(i) + fder(i) / FLOAT(nexca)2018 oas_albe(i) = oas_albe(i) + albsol(i) / FLOAT(nexca)2019 oas_taux(i) = oas_taux(i) + fluxu(i,1) / FLOAT(nexca)2020 oas_tauy(i) = oas_tauy(i) + fluxv(i,1) / FLOAT(nexca)2021 oas_ruis(i) = oas_ruis(i) + ruis(i) /FLOAT(nexca)/dtime2022 ENDDO2023 ENDIF2024 2064 c 2025 2065 c … … 2043 2083 CALL histwrite(nid_day,"tsol",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2044 2084 c 2085 C 2086 zx_tmp_fi2d(1 : klon) = ftsol(1 : klon, is_ter) 2087 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d ,zx_tmp_2d) 2088 CALL histwrite(nid_day,"tter",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2089 C 2090 zx_tmp_fi2d(1 : klon) = ftsol(1 : klon, is_lic) 2091 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zxtsol,zx_tmp_2d) 2092 CALL histwrite(nid_day,"tlic",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2093 C 2094 zx_tmp_fi2d(1 : klon) = ftsol(1 : klon, is_oce) 2095 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zxtsol,zx_tmp_2d) 2096 CALL histwrite(nid_day,"toce",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2097 C 2098 zx_tmp_fi2d(1 : klon) = ftsol(1 : klon, is_sic) 2099 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zxtsol,zx_tmp_2d) 2100 CALL histwrite(nid_day,"tsic",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2101 C 2045 2102 DO i = 1, klon 2046 2103 zx_tmp_fi2d(i) = paprs(i,1) … … 2085 2142 CALL histwrite(nid_day,"ruis",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2086 2143 c 2087 DO i = 1, klon 2088 zx_tmp_fi2d(i) = fluxu(i,1) 2089 ENDDO 2090 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2091 CALL histwrite(nid_day,"frtu",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2092 c 2093 DO i = 1, klon 2094 zx_tmp_fi2d(i) = fluxv(i,1) 2095 ENDDO 2096 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2097 CALL histwrite(nid_day,"frtv",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2098 c 2099 DO i = 1, klon 2100 zx_tmp_fi2d(i) = pctsrf(i,is_sic) 2101 ENDDO 2102 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2103 CALL histwrite(nid_day,"sicf",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2144 c DO i = 1, klon 2145 c zx_tmp_fi2d(i) = fluxu(i,1) 2146 c ENDDO 2147 c CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2148 c CALL histwrite(nid_day,"frtu",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2149 c 2150 c DO i = 1, klon 2151 c zx_tmp_fi2d(i) = fluxv(i,1) 2152 c ENDDO 2153 c CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2154 c CALL histwrite(nid_day,"frtv",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2155 c 2156 DO nsrf = 1, nbsrf 2157 C§§§ 2158 zx_tmp_fi2d(1 : klon) = pctsrf( 1 : klon, nsrf) 2159 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2160 CALL histwrite(nid_day,"pourc_"//clnsurf(nsrf),itap, 2161 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2162 C 2163 zx_tmp_fi2d(1 : klon) = - fluxt( 1 : klon, 1, nsrf) 2164 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2165 CALL histwrite(nid_day,"sens_"//clnsurf(nsrf),itap, 2166 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2167 C 2168 zx_tmp_fi2d(1 : klon) = - fluxq( 1 : klon, 1, nsrf) 2169 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2170 CALL histwrite(nid_day,"lat_"//clnsurf(nsrf),itap, 2171 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2172 C 2173 zx_tmp_fi2d(1 : klon) = - fluxu( 1 : klon, 1, nsrf) 2174 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2175 CALL histwrite(nid_day,"taux_"//clnsurf(nsrf),itap, 2176 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2177 C 2178 zx_tmp_fi2d(1 : klon) = - fluxv( 1 : klon, 1, nsrf) 2179 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2180 CALL histwrite(nid_day,"tauy_"//clnsurf(nsrf),itap, 2181 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2182 C 2183 END DO 2184 C 2185 c$$$ DO i = 1, klon 2186 c$$$ zx_tmp_fi2d(i) = pctsrf(i,is_sic) 2187 c$$$ ENDDO 2188 c$$$ CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2189 c$$$ CALL histwrite(nid_day,"sicf",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2104 2190 c 2105 2191 CALL gr_fi_ecrit(1, klon,iim,jjmp1, cldl,zx_tmp_2d) … … 2243 2329 CALL histwrite(nid_mth,"ruis",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2244 2330 c 2245 DO i = 1, klon 2246 zx_tmp_fi2d(i) = fluxu(i,1) 2247 ENDDO 2248 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2249 CALL histwrite(nid_mth,"frtu",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2250 c 2251 DO i = 1, klon 2252 zx_tmp_fi2d(i) = fluxv(i,1) 2253 ENDDO 2254 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2255 CALL histwrite(nid_mth,"frtv",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2256 c 2257 DO i = 1, klon 2258 zx_tmp_fi2d(i) = pctsrf(i,is_sic) 2259 ENDDO 2260 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2261 CALL histwrite(nid_mth,"sicf",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2331 c DO i = 1, klon 2332 c zx_tmp_fi2d(i) = fluxu(i,1) 2333 c ENDDO 2334 c CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2335 c CALL histwrite(nid_mth,"frtu",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2336 c 2337 c DO i = 1, klon 2338 c zx_tmp_fi2d(i) = fluxv(i,1) 2339 c ENDDO 2340 c CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2341 c CALL histwrite(nid_mth,"frtv",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2342 c 2343 DO nsrf = 1, nbsrf 2344 C§§§ 2345 zx_tmp_fi2d(1 : klon) = pctsrf( 1 : klon, nsrf) 2346 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2347 CALL histwrite(nid_mth,"pourc_"//clnsurf(nsrf),itap, 2348 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2349 C 2350 zx_tmp_fi2d(1 : klon) = - fluxt( 1 : klon, 1, nsrf) 2351 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2352 CALL histwrite(nid_mth,"sens_"//clnsurf(nsrf),itap, 2353 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2354 C 2355 zx_tmp_fi2d(1 : klon) = - fluxq( 1 : klon, 1, nsrf) 2356 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2357 CALL histwrite(nid_mth,"lat_"//clnsurf(nsrf),itap, 2358 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2359 C 2360 zx_tmp_fi2d(1 : klon) = - fluxu( 1 : klon, 1, nsrf) 2361 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2362 CALL histwrite(nid_mth,"taux_"//clnsurf(nsrf),itap, 2363 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2364 C 2365 zx_tmp_fi2d(1 : klon) = - fluxv( 1 : klon, 1, nsrf) 2366 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2367 CALL histwrite(nid_mth,"tauy_"//clnsurf(nsrf),itap, 2368 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2369 C 2370 END DO 2371 c$$$ DO i = 1, klon 2372 c$$$ zx_tmp_fi2d(i) = pctsrf(i,is_sic) 2373 c$$$ ENDDO 2374 c$$$ CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d,zx_tmp_2d) 2375 c$$$ CALL histwrite(nid_mth,"sicf",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2262 2376 c 2263 2377 CALL gr_fi_ecrit(1, klon,iim,jjmp1, albsol,zx_tmp_2d) … … 2476 2590 CALL histwrite(nid_ins,"psol",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2477 2591 c 2592 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zxtsol,zx_tmp_2d) 2593 CALL histwrite(nid_ins,"tsol",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2594 c 2478 2595 CALL gr_fi_ecrit(1, klon,iim,jjmp1, toplw,zx_tmp_2d) 2479 2596 CALL histwrite(nid_ins,"topl",itap,zx_tmp_2d,iim*jjmp1,ndex2d) … … 2508 2625 CALL gr_fi_ecrit(1, klon,iim,jjmp1, d_ts(1,is_sic),zx_tmp_2d) 2509 2626 CALL histwrite(nid_ins,"dtsvdfi",itap,zx_tmp_2d,iim*jjmp1,ndex2d) 2627 2628 DO nsrf = 1, nbsrf 2629 C§§§ 2630 zx_tmp_fi2d(1 : klon) = pctsrf( 1 : klon, nsrf) 2631 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2632 CALL histwrite(nid_ins,"pourc_"//clnsurf(nsrf),itap, 2633 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2634 C 2635 zx_tmp_fi2d(1 : klon) = - fluxt( 1 : klon, 1, nsrf) 2636 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2637 CALL histwrite(nid_ins,"sens_"//clnsurf(nsrf),itap, 2638 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2639 C 2640 zx_tmp_fi2d(1 : klon) = - fluxq( 1 : klon, 1, nsrf) 2641 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2642 CALL histwrite(nid_ins,"lat_"//clnsurf(nsrf),itap, 2643 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2644 C 2645 zx_tmp_fi2d(1 : klon) = ftsol( 1 : klon, nsrf) 2646 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2647 CALL histwrite(nid_ins,"tsol_"//clnsurf(nsrf),itap, 2648 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2649 C 2650 zx_tmp_fi2d(1 : klon) = - fluxu( 1 : klon, 1, nsrf) 2651 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2652 CALL histwrite(nid_ins,"taux_"//clnsurf(nsrf),itap, 2653 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2654 C 2655 zx_tmp_fi2d(1 : klon) = - fluxv( 1 : klon, 1, nsrf) 2656 CALL gr_fi_ecrit(1, klon,iim,jjmp1, zx_tmp_fi2d , zx_tmp_2d) 2657 CALL histwrite(nid_ins,"tauy_"//clnsurf(nsrf),itap, 2658 $ zx_tmp_2d,iim*jjmp1,ndex2d) 2659 C 2660 END DO 2510 2661 2511 2662 c … … 2546 2697 ENDIF 2547 2698 c 2548 IF (ok_oasis .AND. mod(itap,nexca).EQ.0) THEN2549 c2550 c Je ne traite pas le ruissellement, pour l'instant (qui m'aidera ?)2551 DO i = 1, klon2552 oas_ruisoce(i) = 0.02553 oas_ruisriv(i) = 0.02554 ENDDO2555 c2556 ig = 12557 DO i = 1, iim2558 z_sols(i,1) = oas_sols(ig)2559 z_nsol(i,1) = oas_nsol(ig)2560 z_rain(i,1) = oas_rain(ig)2561 z_snow(i,1) = oas_snow(ig)2562 z_evap(i,1) = oas_evap(ig)2563 z_ruisoce(i,1) = oas_ruisoce(ig)2564 z_ruisriv(i,1) = oas_ruisriv(ig)2565 z_tsol(i,1) = oas_tsol(ig)2566 z_fder(i,1) = oas_fder(ig)2567 z_albe(i,1) = oas_albe(ig)2568 z_taux(i,1) = oas_taux(ig)2569 z_tauy(i,1) = oas_tauy(ig)2570 ENDDO2571 DO j = 2, jjm2572 DO i = 1, iim2573 ig = ig + 12574 z_sols(i,j) = oas_sols(ig)2575 z_nsol(i,j) = oas_nsol(ig)2576 z_rain(i,j) = oas_rain(ig)2577 z_snow(i,j) = oas_snow(ig)2578 z_evap(i,j) = oas_evap(ig)2579 z_ruisoce(i,j) = oas_ruisoce(ig)2580 z_ruisriv(i,j) = oas_ruisriv(ig)2581 z_tsol(i,j) = oas_tsol(ig)2582 z_fder(i,j) = oas_fder(ig)2583 z_albe(i,j) = oas_albe(ig)2584 z_taux(i,j) = oas_taux(ig)2585 z_tauy(i,j) = oas_tauy(ig)2586 ENDDO2587 ENDDO2588 ig = ig + 12589 DO i = 1, iim2590 z_sols(i,jjmp1) = oas_sols(ig)2591 z_nsol(i,jjmp1) = oas_nsol(ig)2592 z_rain(i,jjmp1) = oas_rain(ig)2593 z_snow(i,jjmp1) = oas_snow(ig)2594 z_evap(i,jjmp1) = oas_evap(ig)2595 z_ruisoce(i,jjmp1) = oas_ruisoce(ig)2596 z_ruisriv(i,jjmp1) = oas_ruisriv(ig)2597 z_tsol(i,jjmp1) = oas_tsol(ig)2598 z_fder(i,jjmp1) = oas_fder(ig)2599 z_albe(i,jjmp1) = oas_albe(ig)2600 z_taux(i,jjmp1) = oas_taux(ig)2601 z_tauy(i,jjmp1) = oas_tauy(ig)2602 ENDDO2603 c2604 c Passer les champs au coupleur:2605 c2606 CALL intocpl(itap,jjmp1*iim,2607 . z_sols, z_nsol,2608 . z_rain, z_snow, z_evap,2609 . z_ruisoce, z_ruisriv,2610 . z_tsol, z_fder, z_albe,2611 . z_taux, z_tauy)2612 DO i = 1, klon2613 oas_sols(i) = 0.02614 oas_nsol(i) = 0.02615 oas_rain(i) = 0.02616 oas_snow(i) = 0.02617 oas_evap(i) = 0.02618 oas_ruis(i) = 0.02619 oas_tsol(i) = 0.02620 oas_fder(i) = 0.02621 oas_albe(i) = 0.02622 oas_taux(i) = 0.02623 oas_tauy(i) = 0.02624 ENDDO2625 ENDIF2626 2699 c 2627 2700 c Ecrire la bande regionale (binaire grads) … … 2639 2712 CALL ecriregs(84,bils) 2640 2713 CALL ecriregs(84,pctsrf(1,is_sic)) 2641 CALL ecriregs(84, fluxu(1,1))2642 CALL ecriregs(84, fluxv(1,1))2714 CALL ecriregs(84,zxfluxu(1,1)) 2715 CALL ecriregs(84,zxfluxv(1,1)) 2643 2716 CALL ecriregs(84,ue) 2644 2717 CALL ecriregs(84,ve) … … 2705 2778 ccc IF (ok_oasis) CALL quitcpl 2706 2779 CALL phyredem ("restartphy.nc",dtime,radpas,co2_ppm,solaire, 2707 . rlat,rlon,ftsol,ftsoil,deltat,fqsol,fsnow, 2708 . radsol,rugmer,agesno, 2709 . zmea,zstd,zsig,zgam,zthe,zpic,zval,rugoro, 2710 . t_ancien, q_ancien) 2780 . rlat, rlon, pctsrf, ftsol, ftsoil, deltat, fqsol, fsnow, 2781 . falbe, fevap, rain_fall, snow_fall, 2782 . solsw, sollw, 2783 . radsol,rugmer,agesno, 2784 . zmea,zstd,zsig,zgam,zthe,zpic,zval,rugoro, 2785 . t_ancien, q_ancien) 2711 2786 ENDIF 2712 2787
Note: See TracChangeset
for help on using the changeset viewer.