! ! $Header$ ! IF (ok_hf) THEN c$OMP MASTER c zstohf = ecrit_hf zstophy = dtime zstoday = ecrit_day zout = ecrit_hf c idayref = day_ref CALL ymds2ju(annee_ref, 1, idayref, 0.0, zjulian) c cym CALL gr_fi_ecrit(1,klon,iim,jjmp1,rlon,zx_lon) cym DO i = 1, iim cym zx_lon(i,1) = rlon(i+1) cym zx_lon(i,jjmp1) = rlon(i+1) cym ENDDO cym CALL gr_fi_ecrit(1,klon,iim,jjmp1,rlat,zx_lat) cccIM CALL histbeg("histhf", iim,zx_lon, jjmp1,zx_lat, cym CALL histbeg("histhf", iim,zx_lon(:,1), jjmp1,zx_lat(1,:), cym . 1,iim,1,jjmp1, itau_phy, zjulian, dtime, cym . nhori, nid_hf) CALL histbeg_phy("histhf", itau_phy, zjulian, dtime, . nhori, nid_hf) CALL histvert(nid_hf, "presnivs", "Vertical levels", "mb", . klev, presnivs/100., nvert) c IF(type_run.EQ."CLIM".OR.type_run.EQ."ENSP") THEN c IF(lev_histhf.GE.1) THEN c CALL histdef(nid_hf, "aireTER","Grid area CONT","-", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "once", zstohf,zout) c CALL histdef(nid_hf, "contfracATM","% sfce ter+lic ","-", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "once", zstohf,zout) c CALL histdef(nid_hf, "contfracOR","% sfce terre OR", "-", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "once", zstohf,zout) c c Champs 2D: c CALL histdef(nid_hf, "t2m", "Temperature 2m", "K", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "q2m", "Specific humidity", "kg/kg", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "psol", "Surface Pressure", "Pa", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "precip", "Precipitation", "kg/(s*m2)", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstophy,zout) c cIM ENSEMBLES BEG CALL histdef(nid_hf, "tsol", "Surface Temperature", "K", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "slp", "Sea Level Pressure", "Pa", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "u10m", "Vent zonal 10m", "m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "v10m", "Vent meridien 10m", "m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "wind10m","10-m wind speed","m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c DO k=1, nlevSTD c c bb=clevSTD(k) c IF(k.GE.2.AND.k.LE.12) bb2=clevSTD(k) IF(k.GE.13.AND.k.LE.17) bb3=clevSTD(k) c c IF(k.GE.2) THEN c aa=clevSTD(k) c bb=aa(1:lnblnk1(aa)) c ENDIF c IF(bb2.EQ."500") THEN CALL histdef(nid_hf, "phi"//bb2, . "Geopotential "//bb2//"mb", "m", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) ENDIF !bb2.EQ."500" ENDDO !k=1, nlevSTD c ENDIF !lev_histhf.GE.1 c IF(lev_histhf.GE.2) THEN c CALL histdef(nid_hf, "cldt", "Total cloudiness", "%", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstophy,zout) c CALL histdef(nid_hf, "SWnetOR", . "Sfce net SW radiation OR", "W/m2", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstophy,zout) c CALL histdef(nid_hf, "SWdownOR", . "Sfce incident SW radiation OR", "W/m2", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstophy,zout) c CALL histdef(nid_hf, "LWdownOR", . "Sfce incident LW radiation OR", "W/m2", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstophy,zout) ENDIF !lev_histhf.GE.2 c cIM ENSEMBLES END c IF(lev_histhf.GE.3) THEN c DO k=1, nlevSTD c c bb=clevSTD(k) c c IF(k.GE.2) THEN IF(k.GE.2.AND.k.LE.12) bb2=clevSTD(k) IF(k.GE.13.AND.k.LE.17) bb3=clevSTD(k) c aa=clevSTD(k) c bb=aa(1:lnblnk1(aa)) c ENDIF c IF(bb2.EQ."850".or.bb2.EQ."700".OR. $ bb2.EQ."500".or.bb2.EQ."200") THEN c CALL histdef(nid_hf, "t"//bb2, . "Temperature "//bb2//"mb","K", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c IF(bb2.NE."500") THEN CALL histdef(nid_hf, "phi"//bb2, . "Geopotential "//bb2//"mb", "m", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) ENDIF c CALL histdef(nid_hf, "q"//bb2, . "Specific humidity "//bb2//"mb","kg/kg", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "u"//bb2, . "Zonal wind "//bb2//"mb","m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "v"//bb2, . "Meridional wind "//bb2//"mb","m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c ENDIF !IF(bb2.EQ."850".or.bb2.EQ."700".OR. c ENDDO !nlevSTD c ENDIF !lev_histhf.GE.3 c IF(lev_histhf.GE.4) THEN c cIM sorties hf 3D c #undef histhf3d #define histhf3d #ifdef histhf3d #include "ini_histhf3d.h" #endif ENDIF !lev_histhf.GE.4 c ELSE IF(type_run.EQ."AMIP".OR.type_run.EQ."CFMI") THEN c IF(lev_histhf.GE.1) THEN c DO k=1, nlevSTD c c c bb=clevSTD(k) c c IF(k.GE.2) THEN IF(k.GE.2.AND.k.LE.12) bb2=clevSTD(k) IF(k.GE.13.AND.k.LE.17) bb3=clevSTD(k) c aa=clevSTD(k) c bb=aa(1:lnblnk1(aa)) c ENDIF c IF(bb2.EQ."850".or.bb2.EQ."200") THEN c CALL histdef(nid_hf, "u"//bb2, . "Zonal wind "//bb2//"mb","m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) c CALL histdef(nid_hf, "v"//bb2, . "Meridional wind "//bb2//"mb","m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) c ENDIF !bb2.EQ."850".or.bb2.EQ."200" ENDDO !k=1, nlevSTD c CALL histdef(nid_hf, "topl", . "Outgoing longwave radiation", "W/m2", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstophy,zout) c CALL histdef(nid_hf, "precip","Total precipitation rate", . "kg/(s*m2)",iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstophy,zout) c CALL histdef(nid_hf, "slp", . "Mean sea-level pressure", "Pa", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c cIM 280504 BEG ENDIF !(lev_histhf.GE.1) THEN c IF(lev_histhf.GE.2) THEN c DO k=1, nlevSTD c c bb=clevSTD(k) c c IF(k.GE.2) THEN IF(k.GE.2.AND.k.LE.12) bb2=clevSTD(k) IF(k.GE.13.AND.k.LE.17) bb3=clevSTD(k) c aa=clevSTD(k) c bb=aa(1:lnblnk1(aa)) c ENDIF c IF(bb2.EQ."850".OR.bb2.EQ."500") THEN c CALL histdef(nid_hf, "t"//bb2, . "Temperature "//bb2//"mb","K", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) c CALL histdef(nid_hf, "q"//bb2, . "Specific humidity "//bb2//"mb","kg/kg", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) c ENDIF !bb2 c IF(bb2.EQ."500") THEN c CALL histdef(nid_hf, "phi"//bb2, . "Geopotential "//bb2//"mb", "m", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) c CALL histdef(nid_hf, "w"//bb2, . "Vertical motion "//bb2//"mb","Pa/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) ENDIF !bb2.EQ."500" c IF(bb3.EQ."50") THEN c CALL histdef(nid_hf, "t"//bb3, . "Temperature "//bb3//"mb","K", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) c CALL histdef(nid_hf, "u"//bb3, . "Zonal wind "//bb3//"mb","m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) c CALL histdef(nid_hf, "v"//bb3, . "Meridional wind "//bb3//"mb","m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zstohf) c ENDIF !bb3 c ENDDO !k=1, nlevSTD c CALL histdef(nid_hf, "u10m", "Vent zonal 10m", "m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "v10m", "Vent meridien 10m", "m/s", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "t2m", "Temperature 2m", "K", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "q2m", "Specific humidity", "kg/kg", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "psol", "Surface Pressure", "Pa", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "inst(X)", zstohf,zout) c CALL histdef(nid_hf, "cldt", "Total cloudiness", "%", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstohf,zout) c CALL histdef(nid_hf, "taux", $ "Zonal wind stress","Pa", $ iim,jj_nb,nhori, 1,1,1, -99, 32, $ "ave(X)", zstohf,zout) c CALL histdef(nid_hf, "tauy", $ "Meridional wind stress ", "Pa", $ iim,jj_nb,nhori, 1,1,1, -99, 32, $ "ave(X)", zstohf,zout) c CALL histdef(nid_hf, "prw", "Precipitable water", "kg/m2", . iim,jj_nb,nhori, 1,1,1, -99, 32, cIM 090904 . "ave(X)", zstohf,zout) . "ave(X)", zstophy,zout) c CALL histdef(nid_hf, "sens", "Sensible heat flux", "W/m2", . iim,jj_nb,nhori, 1,1,1, -99, 32, cIM 090904 . "ave(X)", zstohf,zout) . "ave(X)", zstophy,zout) c CALL histdef(nid_hf, "flat", "Latent heat flux", "W/m2", . iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstohf,zout) c c CALL histdef(nid_hf, "snow_mass", "Snow Mass", "kg/m2", c . iim,jj_nb,nhori, 1,1,1, -99, 32, c . "ave(X)", zstohf,zout) c CALL histdef(nid_hf, "SWdnSFC", "SWdn at surface","W/m2", . iim,jj_nb,nhori, 1,1,1,-99, . 32, "ave(X)", zstohf,zout) c CALL histdef(nid_hf, "SWupSFC", "SWup at surface","W/m2", . iim,jj_nb,nhori, 1,1,1,-99, . 32, "ave(X)", zstohf,zout) c CALL histdef(nid_hf,"LWdnSFC","Down. IR rad. at surface", . "W/m2", iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstohf,zout) c CALL histdef(nid_hf,"LWupSFC","Upwd. IR rad. at surface", . "W/m2", iim,jj_nb,nhori, 1,1,1, -99, 32, . "ave(X)", zstohf,zout) c CALL histdef(nid_hf, "SWdnTOA", "SWdn at TOA","W/m2", . iim,jj_nb,nhori, 1,1,1,-99, . 32, "ave(X)", zstohf,zout) c CALL histdef(nid_hf, "SWupTOA", "SWup at TOA","W/m2", . iim,jj_nb,nhori, 1,1,1,-99, . 32, "ave(X)", zstohf,zout) c DO k=1, nbteta CALL histdef(nid_hf, "PV"//ctetaSTD(k), $ "Vorticite potentielle "//ctetaSTD(k)//"K", $ "1/(Pa*s)",iim,jj_nb,nhori, 1,1,1, -99, $ 32, "inst(X)", zstohf,zout) ENDDO !k=1, nbteta c c planetary boundary layer height c c ENDIF !1.EQ.0 c ENDIF !(lev_histhf.GE.2) THEN cIM 280504 END c ENDIF !type_run c CALL histend(nid_hf) c c$OMP END MASTER ENDIF ! ok_hf