Changeset 3768 for LMDZ6/branches/Optimisation_LMDZ
- Timestamp:
- Jul 21, 2020, 11:08:53 AM (4 years ago)
- Location:
- LMDZ6/branches/Optimisation_LMDZ
- Files:
-
- 1 added
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ6/branches/Optimisation_LMDZ/DefLists/context_lmdz.xml
r3655 r3768 3 3 <context id="LMDZ"> 4 4 <!-- <calendar type="D360" start_date="1980-01-01 00:00:00" /> --> 5 5 <variable_definition src="./var_def_lmdz.xml"/> 6 6 <!-- Define available variables --> 7 7 <field_definition src="./field_def_lmdz.xml"/> -
LMDZ6/branches/Optimisation_LMDZ/DefLists/context_lmdz_sans_cosp.xml
r3474 r3768 2 2 <context id="LMDZ"> 3 3 <!-- <calendar type="D360" start_date="1980-01-01 00:00:00" /> --> 4 4 <variable_definition src="./var_def_lmdz.xml"/> 5 5 <!-- Define available variables --> 6 6 <field_definition src="./field_def_lmdz.xml"/> -
LMDZ6/branches/Optimisation_LMDZ/DefLists/field_def_lmdz.xml
r3656 r3768 6 6 <!-- <field id="Bp" long_name="Hybrid coordinate: sigma part" unit="-" /> --> 7 7 <!-- <field id="Alt" long_name="Pseudo-altitude (for an 8km scale height)" unit="km" /> --> 8 <!-- </field_group> --> 9 8 <!-- </field_group> --> 10 9 <field_group id="remap_expr" level="_reset_" prec="_reset_" operation="_reset_" freq_op="_reset_" enabled="_reset_" default_value="_reset_"> 11 10 <field_group id="remap_1ts" /> … … 38 37 <field id="phis" long_name="Surface geop.height" unit="m2/s2" /> 39 38 <field id="aire" long_name="Grid area" unit="m2" /> 40 <field id="contfracATM" long_name="% sfce ter+lic" unit="-" />41 <field id="contfracOR" long_name="% sfce terre OR" unit="-" />39 <field id="contfracATM" long_name="% sfce ter+lic" unit="-" > fract_ter + fract_lic </field> 40 <field id="contfracOR" long_name="% sfce terre OR" unit="-" > fract_ter </field> 42 41 <field id="sza" long_name="Solar zenithal angle " unit="deg" /> 43 42 <field id="flat" long_name="Latent heat flux" unit="W/m2" /> … … 49 48 <field id="tasmax" field_ref="t2m" operation="maximum" /> 50 49 <field id="tasmin" field_ref="t2m" operation="minimum" /> 51 <field id="t2m_min" long_name="Temp 2m min" unit="K" operation="minimum" />52 <field id="t2m_max" long_name="Temp 2m max" unit="K"operation="maximum" />50 <field id="t2m_min" field_ref="t2m" long_name="Temp 2m min" operation="minimum" /> 51 <field id="t2m_max" field_ref="t2m" long_name="Temp 2m max" operation="maximum" /> 53 52 <field id="t2m_ter" long_name="Temp 2m ter" unit="K" /> 54 53 <field id="t2m_max_mon" long_name="Monthly average max 2m temperature" unit="K" /> … … 61 60 <field id="t2m_probsup30" field_ref="t2m" long_name="Prob. t2m exceeds 30 degC" unit="-"> t2m > 303.15 </field> 62 61 <field id="gusts" long_name="surface gustiness" unit="m2/s2" /> 63 <field id="wind10m" long_name="10-m wind speed" unit="m/s" />64 <field id="wind10max" long_name="10m wind speed max" unit="m/s" operation="maximum" />62 <field id="wind10m" long_name="10-m wind speed" unit="m/s" > sqrt(v10m*v10m + u10m*u10m) </field> 63 <field id="wind10max" long_name="10m wind speed max" unit="m/s" operation="maximum"> wind10m </field> 65 64 <field id="wind100m" long_name="100-m wind speed" unit="m/s" /> 66 65 <field id="sfcWindmax" field_ref="wind10m" operation="maximum" /> 67 <field id="sicf" long_name="Sea-ice fraction" unit="-" />66 <field id="sicf" long_name="Sea-ice fraction" unit="-" > fract_sic </field> 68 67 <field id="q2m" long_name="Specific humidity 2m" unit="kg/kg" /> 69 68 <field id="ustar" long_name="Friction velocity" unit="m/s" /> … … 91 90 <field id="qsol" long_name="Soil watter content" unit="mm" /> 92 91 <field id="JrNt" long_name="1 if Day 0 if Night" unit="-" /> 93 <field id="cldhjn" long_name="High-level cloudiness Day" unit="-" />94 <field id="cldmjn" long_name="Mid-level cloudiness Day" unit="-" />95 <field id="cldljn" long_name="Low-level cloudiness Day" unit="-" />96 <field id="cldtjn" long_name="Total cloudiness Day" unit="-" />92 <field id="cldhjn" long_name="High-level cloudiness Day" unit="-" > cldh/JrNt </field> 93 <field id="cldmjn" long_name="Mid-level cloudiness Day" unit="-" > cldm/JrNt </field> 94 <field id="cldljn" long_name="Low-level cloudiness Day" unit="-" > cldl/JrNt </field> 95 <field id="cldtjn" long_name="Total cloudiness Day" unit="-" > cldt/JrNt </field> 97 96 <field id="rnebjn" long_name="Cloud fraction in day" unit="-" /> 98 97 <field id="ndayrain" long_name="Number of dayrain(liq+sol)" unit="-" operation="instant"/> 99 <field id="precip" long_name="Precip Totale liq+sol" unit="kg/(s*m2)" />98 <field id="precip" long_name="Precip Totale liq+sol" unit="kg/(s*m2)" > rain_fall+snow </field> 100 99 <field id="prhmax" field_ref="precip" operation="maximum" /> 101 100 <field id="rain_fall" long_name="Precip Totale liq" unit="kg/(s*m2)" /> 102 101 <field id="rain_con" long_name="Precip convective liq" unit="kg/(s*m2)" /> 103 <field id="plul" long_name="Large-scale Precip." unit="kg/(s*m2)" />102 <field id="plul" long_name="Large-scale Precip." unit="kg/(s*m2)" > this+snowl </field> 104 103 <field id="plun" long_name="Numerical Precip." unit="kg/(s*m2)" /> 105 <field id="pluc" long_name="Convective Precip." unit="kg/(s*m2)" />104 <field id="pluc" long_name="Convective Precip." unit="kg/(s*m2)" > rain_con + this </field> 106 105 <field id="snow" long_name="Snow fall" unit="kg/(s*m2)" /> 107 106 <field id="evap" long_name="Evaporat" unit="kg/(s*m2)" /> … … 112 111 <field id="msnow" long_name="Surface snow amount" unit="kg/m2" /> 113 112 <field id="fsnow" long_name="Surface snow area fraction" unit="-" /> 114 <field id="tops" long_name="Solar rad. at TOA" unit="W/m2" /> 115 <field id="tops0" long_name="CS Solar rad. at TOA" unit="W/m2" /> 113 <field id="swradcorr" long_name="Temporary" /> 114 <field id="tops" long_name="Solar rad. at TOA" unit="W/m2" > this*swradcorr </field> 115 <field id="tops0" long_name="CS Solar rad. at TOA" unit="W/m2" > this*swradcorr </field> 116 116 <field id="topl" long_name="IR rad. at TOA" unit="W/m2" /> 117 117 <field id="topl0" long_name="IR rad. at TOA" unit="W/m2" /> 118 <field id="SWupTOA" long_name="SWup at TOA" unit="W/m2" />119 <field id="SWupTOAclr" long_name="SWup clear sky at TOA" unit="W/m2" />120 <field id="SWupTOAcleanclr" long_name="SWup clean (no aerosol) clear sky at TOA" unit="W/m2" />121 <field id="SWdnTOA" long_name="SWdn at TOA" unit="W/m2" />122 <field id="SWdnTOAclr" long_name="SWdn clear sky at TOA" unit="W/m2" />123 <field id="nettop" long_name="Net dn radiatif flux at TOA" unit="W/m2" />124 <field id="SWup200" long_name="SWup at 200mb" unit="W/m2" />125 <field id="SWup200clr" long_name="SWup clear sky at 200mb" unit="W/m2" />126 <field id="SWdn200" long_name="SWdn at 200mb" unit="W/m2" />127 <field id="SWdn200clr" long_name="SWdn clear sky at 200mb" unit="W/m2" />118 <field id="SWupTOA" long_name="SWup at TOA" unit="W/m2" > this*swradcorr </field> 119 <field id="SWupTOAclr" long_name="SWup clear sky at TOA" unit="W/m2" > this*swradcorr </field> 120 <field id="SWupTOAcleanclr" long_name="SWup clean (no aerosol) clear sky at TOA" unit="W/m2" > this*swradcorr </field> 121 <field id="SWdnTOA" long_name="SWdn at TOA" unit="W/m2" > this*swradcorr </field> 122 <field id="SWdnTOAclr" long_name="SWdn clear sky at TOA" unit="W/m2"> this*swradcorr </field> 123 <field id="nettop" long_name="Net dn radiatif flux at TOA" unit="W/m2" > tops - topl </field> 124 <field id="SWup200" long_name="SWup at 200mb" unit="W/m2" > this*swradcorr </field> 125 <field id="SWup200clr" long_name="SWup clear sky at 200mb" unit="W/m2" > this*swradcorr </field> 126 <field id="SWdn200" long_name="SWdn at 200mb" unit="W/m2" > this*swradcorr </field> 127 <field id="SWdn200clr" long_name="SWdn clear sky at 200mb" unit="W/m2" > this*swradcorr </field> 128 128 <field id="LWup200" long_name="LWup at 200mb" unit="W/m2" /> 129 129 <field id="LWup200clr" long_name="LWup clear sky at 200mb" unit="W/m2" /> 130 130 <field id="LWdn200" long_name="LWdn at 200mb" unit="W/m2" /> 131 131 <field id="LWdn200clr" long_name="LWdn clear sky at 200mb" unit="W/m2" /> 132 <field id="sols" long_name="Solar rad. at surf." unit="W/m2" />133 <field id="sols0" long_name="Solar rad. at surf." unit="W/m2" />132 <field id="sols" long_name="Solar rad. at surf." unit="W/m2" > this*swradcorr </field> 133 <field id="sols0" long_name="Solar rad. at surf." unit="W/m2" > this*swradcorr </field> 134 134 <field id="soll" long_name="IR rad. at surface" unit="W/m2" /> 135 135 <field id="soll0" long_name="IR rad. at surface" unit="W/m2" /> 136 136 <field id="radsol" long_name="Rayonnement au sol" unit="W/m2" /> 137 <field id="SWupSFC" long_name="SWup at surface" unit="W/m2" /> 138 <field id="SWupSFCclr" long_name="SWup clear sky at surface" unit="W/m2" /> 139 <field id="SWupSFCcleanclr" long_name="SWup clean (no aerosol) clear sky at surface" unit="W/m2" /> 140 <field id="SWdnSFC" long_name="SWdn at surface" unit="W/m2" /> 141 <field id="SWdnSFCclr" long_name="SWdn clear sky at surface" unit="W/m2" /> 142 <field id="SWdnSFCcleanclr" long_name="SWdn clean (no aerosol) clear sky at surface" unit="W/m2" /> 143 <field id="LWupSFC" long_name="Upwd. IR rad. at surface" unit="W/m2" /> 144 <field id="LWupSFCclr" long_name="CS Upwd. IR rad. at surface" unit="W/m2" /> 137 138 <field id="SWupSFC" long_name="SWup at surface" unit="W/m2" > this*swradcorr </field> 139 <field id="SWupSFCclr" long_name="SWup clear sky at surface" unit="W/m2" > this*swradcorr </field> 140 <field id="SWupSFCcleanclr" long_name="SWup clean (no aerosol) clear sky at surface" unit="W/m2" > this*swradcorr </field> 141 <field id="SWdnSFC" long_name="SWdn at surface" unit="W/m2" > this*swradcorr </field> 142 <field id="SWdnSFCclr" long_name="SWdn clear sky at surface" unit="W/m2" > this*swradcorr </field> 143 <field id="SWdnSFCcleanclr" long_name="SWdn clean (no aerosol) clear sky at surface" unit="W/m2" > this*swradcorr </field> 144 <field id="LWupSFC" long_name="Upwd. IR rad. at surface" unit="W/m2"> LWdnSFC - soll </field> 145 146 <field id="LWupSFCclr" long_name="CS Upwd. IR rad. at surface" unit="W/m2" > LWdnSFCclr - soll0 </field> 145 147 <field id="LWupTOAcleanclr" long_name="CS clean (no aerosol) Upwd. IR rad. at TOA" unit="W/m2" /> 146 <field id="LWdnSFC" long_name="Down. IR rad. at surface" unit="W/m2" />147 <field id="LWdnSFCclr" long_name="Down. CS IR rad. at surface" unit="W/m2" />148 <field id="LWdnSFCcleanclr" long_name="Down. CS clean (no aerosol) IR rad. at surface" unit="W/m2" />148 <field id="LWdnSFC" long_name="Down. IR rad. at surface" unit="W/m2" /> 149 <field id="LWdnSFCclr" long_name="Down. CS IR rad. at surface" unit="W/m2" > -this </field> 150 <field id="LWdnSFCcleanclr" long_name="Down. CS clean (no aerosol) IR rad. at surface" unit="W/m2" > -this </field> 149 151 <field id="bils" long_name="Surf. total heat flux" unit="W/m2" /> 150 152 <field id="bils_tke" long_name="Surf. total heat flux" unit="W/m2" /> … … 161 163 <field id="ustr_gwd_rando" long_name="zonal wind stress random gravity waves" unit="Pa" /> 162 164 <field id="vstr_gwd_rando" long_name="meridinal wind stress random gravity waves" unit="Pa" /> 163 <field id="sens" long_name="Sensible heat flux" unit="W/m2" />165 <field id="sens" long_name="Sensible heat flux" unit="W/m2" > -this </field> 164 166 <field id="sens_x" long_name="sens off-wake" unit="W/m2" /> 165 167 <field id="sens_w" long_name="sens within-wake" unit="W/m2" /> 166 168 <field id="flat_x" long_name="flat off-wake" unit="W/m2" /> 167 169 <field id="flat_w" long_name="flat within-wake" unit="W/m2" /> 168 <field id="delta_tsurf" long_name="Temperature difference (w-x)" unit="K" enabled="false" /> <!-- ym --field disabled--delta_tsurf is not conform to the associated grid (the is an arry containing all sub_surface) -->170 <field id="delta_tsurf" long_name="Temperature difference (w-x)" unit="K" enabled="false" /> <!-- ym field disabled delta_tsurf is not conform to the associated grid (the is an arry containing all sub_surface) --> 169 171 <field id="cdragh_x" long_name="cdragh off-wake" unit="-" /> 170 172 <field id="cdragh_w" long_name="cdragh within-wake" unit="-" /> … … 179 181 <field id="fqfonte" long_name="Land ice melt" unit="kg/m2/s" /> 180 182 <field id="runofflic" long_name="Land ice melt to ocean" unit="kg/m2/s" /> 181 <field id="mrroli" long_name="Runoff flux over land ice" unit="kg/m2/s" />182 <field id="taux" long_name="Zonal wind stress" unit="Pa" />183 <field id="tauy" long_name="Meridional wind stress" unit="Pa" />183 <field id="mrroli" long_name="Runoff flux over land ice" unit="kg/m2/s"> (fqfonte + rain_fall)*fract_lic </field> 184 <field id="taux" long_name="Zonal wind stress" unit="Pa" > fract_ter*taux_ter + fract_lic*taux_lic + fract_oce*taux_oce +fract_sic*taux_sic </field> 185 <field id="tauy" long_name="Meridional wind stress" unit="Pa" > fract_ter*tauy_ter + fract_lic*tauy_lic + fract_oce*tauy_oce +fract_sic*tauy_sic </field> 184 186 <field id="taux_ter" long_name="Zonal wind stress ter" unit="Pa" /> 185 187 <field id="taux_lic" long_name="Zonal wind stress lic" unit="Pa" /> … … 190 192 <field id="tauy_oce" long_name="Meridional wind stress oce" unit="Pa" /> 191 193 <field id="tauy_sic" long_name="Meridional wind stress sic" unit="Pa" /> 192 <field id="pourc_ter" long_name="% ter" unit="%" />193 <field id="pourc_lic" long_name="% lic" unit="%" />194 <field id="pourc_oce" long_name="% oce" unit="%" />195 <field id="pourc_sic" long_name="% sic" unit="%" />194 <field id="pourc_ter" long_name="% ter" unit="%" > 100*fract_ter </field> 195 <field id="pourc_lic" long_name="% lic" unit="%" > 100*fract_lic </field> 196 <field id="pourc_oce" long_name="% oce" unit="%" > 100*fract_oce </field> 197 <field id="pourc_sic" long_name="% sic" unit="%" > 100*fract_sic </field> 196 198 <field id="fract_ter" long_name="Fraction ter" unit="1" /> 197 199 <field id="fract_lic" long_name="Fraction lic" unit="1" /> … … 335 337 <field id="z50" long_name="Geopotential height 50hPa" unit="m" detect_missing_value=".true." /> 336 338 <field id="z10" long_name="Geopotential height 10hPa" unit="m" detect_missing_value=".true." /> 337 <field id="t_oce_sic" long_name="Temp mixte oce-sic" unit="K" /> 339 <field id="t_oce_sic" long_name="Temp mixte oce-sic" unit="K" > ((fract_oce > 1.0E-05)+(fract_sic > 1.0E-05))?(tsol_oce*fract_oce+tsol_sic*fract_sic)/(fract_oce+fract_sic):273.15 </field> 340 <!--<field id="t_oce_sic" long_name="Temp mixte oce-sic" unit="K" > (fract_oce > 1.0E-05 || fract_sic > 1.0E-05)?(tsol_oce*fract_oce+tsol_sic*fract_sic)/(fract_oce+fract_sic):273.15 </field > --> 338 341 <field id="weakinv" long_name="Weak inversion" unit="-" /> 339 342 <field id="dthmin" long_name="dTheta mini" unit="K/m" /> … … 346 349 <field id="v10_oce" long_name="-" unit="-" /> 347 350 <field id="v10_sic" long_name="-" unit="-" /> 348 <field id="rh2m" long_name="Relative humidity at 2m" unit="%" />351 <field id="rh2m" long_name="Relative humidity at 2m" unit="%" > (this > 1.) ? 100. : this*100. </field> 349 352 <field id="rh2m_max" field_ref="rh2m" operation="maximum" enabled="false"/> <!-- ym Problem : field is disabled check rh2m_min has a reference (field_ref) to rh2 but is also sent by model which is not compatible--> 350 353 <field id="rh2m_min" field_ref="rh2m" operation="minimum" enabled="false"/> <!-- ym Problem : field is disabled check rh2m_max has a reference (field_ref) to rh2 but is also sent by model which is not compatible--> … … 354 357 <field id="tpot" long_name="Surface air potential temperature" unit="K" /> 355 358 <field id="tpote" long_name="Surface air equivalent potential temperature" unit="K" /> 356 <field id="SWnetOR" long_name="Sfce net SW radiation OR" unit="W/m2" />359 <field id="SWnetOR" field_ref="fsw_ter" long_name="Sfce net SW radiation OR" unit="W/m2" /> 357 360 <field id="SWdownOR" long_name="Sfce incident SW radiation OR" unit="W/m2" /> 358 <field id="LWdownOR" long_name="Sfce incident LW radiation OR" unit="W/m2" />361 <field id="LWdownOR" field_ref="LWdnSFC" long_name="Sfce incident LW radiation OR" unit="W/m2" /> 359 362 <field id="snowl" long_name="Solid Large-scale Precip." unit="kg/(m2*s)" /> 360 <field id="cape_max" long_name="CAPE max." unit="J/kg"operation="maximum"/>361 <field id="solldown" long_name="Down. IR rad. at surface" unit="W/m2" />363 <field id="cape_max" field_ref="cape" long_name="CAPE max." operation="maximum"/> 364 <field id="solldown" field_ref="LWdnSFC" long_name="Down. IR rad. at surface" unit="W/m2" /> 362 365 <field id="dtsvdfo" long_name="Boundary-layer dTs(o)" unit="K/s" /> 363 366 <field id="dtsvdft" long_name="Boundary-layer dTs(t)" unit="K/s" /> … … 369 372 <field id="topswad" long_name="ADE at TOA" unit="W/m2" /> 370 373 <field id="topswad0" long_name="ADE clear-sky at TOA" unit="W/m2" /> 371 <field id="topswai" long_name="AIE at TOA" unit="W/m2" />372 <field id="solswad" long_name="ADE at SRF" unit="W/m2" />374 <field id="topswai" long_name="AIE at TOA" unit="W/m2" > this/swradcorr </field> 375 <field id="solswad" long_name="ADE at SRF" unit="W/m2" > this/swradcorr </field> 373 376 <field id="solswad0" long_name="ADE clear-sky at SRF" unit="W/m2" /> 374 <field id="solswai" long_name="AIE at SFR" unit="W/m2" />375 <field id="toplwad" long_name="LW-ADE at TOA" unit="W/m2" />376 <field id="toplwad0" long_name="LW-ADE clear-sky at TOA" unit="W/m2" />377 <field id="toplwai" long_name="LW-AIE clear-sky at TOA" unit="W/m2" />377 <field id="solswai" long_name="AIE at SFR" unit="W/m2" > this/swradcorr </field> 378 <field id="toplwad" long_name="LW-ADE at TOA" unit="W/m2" > this/swradcorr </field> 379 <field id="toplwad0" long_name="LW-ADE clear-sky at TOA" unit="W/m2" > this/swradcorr </field> 380 <field id="toplwai" long_name="LW-AIE clear-sky at TOA" unit="W/m2" > this/swradcorr </field> 378 381 <field id="sollwad" long_name="LW-ADE at SRF" unit="W/m2" /> 379 382 <field id="sollwad0" long_name="LW-ADE clear-sky at SRF" unit="W/m2" /> 380 <field id="sollwai" long_name="LW-AIE at SRF" unit="W/m2" />383 <field id="sollwai" long_name="LW-AIE at SRF" unit="W/m2" > this/swradcorr </field> 381 384 <field id="od550_ASBCM" long_name="Aerosol Optical depth at 550 nm " unit="1" /> 382 385 <field id="od550_ASPOMM" long_name="Aerosol Optical depth at 550 nm " unit="1" /> … … 425 428 <field id="loaddust" long_name="Column Load of Dust " unit="kg/m2" /> 426 429 <field id="loadno3" long_name="Column Load of Nitrate " unit="kg/m2" /> 427 <field id="swtoaas_nat" long_name="Natural aerosol radiative forcing all-sky at TOA" unit="W/m2" />428 <field id="swsrfas_nat" long_name="Natural aerosol radiative forcing all-sky at SRF" unit="W/m2" />429 <field id="swtoacs_nat" long_name="Natural aerosol radiative forcing clear-sky at TOA" unit="W/m2" />430 <field id="swsrfcs_nat" long_name="Natural aerosol radiative forcing clear-sky at SRF" unit="W/m2" />431 <field id="swtoaas_ant" long_name="Anthropogenic aerosol radiative forcing all-sky at TOA" unit="W/m2" />432 <field id="swsrfas_ant" long_name="Anthropogenic aerosol radiative forcing all-sky at SRF" unit="W/m2" />433 <field id="swtoacs_ant" long_name="Anthropogenic aerosol radiative forcing clear-sky at TOA" unit="W/m2" />434 <field id="swsrfcs_ant" long_name="Anthropogenic aerosol radiative forcing clear-sky at SRF" unit="W/m2" />435 <field id="swtoacf_nat" long_name="Natural aerosol impact on cloud radiative forcing at TOA" unit="W/m2" />436 <field id="swsrfcf_nat" long_name="Natural aerosol impact on cloud radiative forcing at SRF" unit="W/m2" />437 <field id="swtoacf_ant" long_name="Anthropogenic aerosol impact on cloud radiative forcing at TOA" unit="W/m2" />438 <field id="swsrfcf_ant" long_name="Anthropogenic aerosol impact on cloud radiative forcing at SRF" unit="W/m2" />439 <field id="swtoacf_zero" long_name="Cloud radiative forcing (allsky-clearsky fluxes) at TOA" unit="W/m2" />440 <field id="swsrfcf_zero" long_name="Cloud radiative forcing (allsky-clearsky fluxes) at SRF" unit="W/m2" />430 <field id="swtoaas_nat" long_name="Natural aerosol radiative forcing all-sky at TOA" unit="W/m2" > this/swradcorr </field> 431 <field id="swsrfas_nat" long_name="Natural aerosol radiative forcing all-sky at SRF" unit="W/m2" > this/swradcorr </field> 432 <field id="swtoacs_nat" long_name="Natural aerosol radiative forcing clear-sky at TOA" unit="W/m2" > this/swradcorr </field> 433 <field id="swsrfcs_nat" long_name="Natural aerosol radiative forcing clear-sky at SRF" unit="W/m2" > this/swradcorr </field> 434 <field id="swtoaas_ant" long_name="Anthropogenic aerosol radiative forcing all-sky at TOA" unit="W/m2" > this/swradcorr </field> 435 <field id="swsrfas_ant" long_name="Anthropogenic aerosol radiative forcing all-sky at SRF" unit="W/m2" > this/swradcorr </field> 436 <field id="swtoacs_ant" long_name="Anthropogenic aerosol radiative forcing clear-sky at TOA" unit="W/m2" > this/swradcorr </field> 437 <field id="swsrfcs_ant" long_name="Anthropogenic aerosol radiative forcing clear-sky at SRF" unit="W/m2" > this/swradcorr </field> 438 <field id="swtoacf_nat" long_name="Natural aerosol impact on cloud radiative forcing at TOA" unit="W/m2" > this/swradcorr </field> 439 <field id="swsrfcf_nat" long_name="Natural aerosol impact on cloud radiative forcing at SRF" unit="W/m2" > this/swradcorr </field> 440 <field id="swtoacf_ant" long_name="Anthropogenic aerosol impact on cloud radiative forcing at TOA" unit="W/m2" > this/swradcorr </field> 441 <field id="swsrfcf_ant" long_name="Anthropogenic aerosol impact on cloud radiative forcing at SRF" unit="W/m2" > this/swradcorr </field> 442 <field id="swtoacf_zero" long_name="Cloud radiative forcing (allsky-clearsky fluxes) at TOA" unit="W/m2" > this/swradcorr </field> 443 <field id="swsrfcf_zero" long_name="Cloud radiative forcing (allsky-clearsky fluxes) at SRF" unit="W/m2" > this/swradcorr </field> 441 444 <field id="cldncl" long_name="CDNC at top of liquid water cloud" unit="m-3" /> 442 445 <field id="reffclwtop" long_name="Droplet effective radius at top of liquid water cloud" unit="m" /> … … 478 481 <field id="alb1" long_name="Surface VIS albedo" unit="-" /> 479 482 <field id="alb2" long_name="Surface Near IR albedo" unit="-" /> 480 <field id="ftime_con" long_name="Fraction of time convection Occurs" unit="-" operation="instant" />483 <field id="ftime_con" long_name="Fraction of time convection Occurs" unit="-" operation="instant" > (ftime_th>ftime_deepcv)?ftime_th:ftime_deepcv </field> 481 484 <field id="ftime_deepcv" long_name="Fraction of time deep convection Occurs" unit="-" /> 482 485 <field id="wake_h" long_name="wake height" unit="m" /> … … 490 493 <field id="f0_th" long_name="Thermal closure mass flux" unit="K/s" /> 491 494 <field id="zmax_th" long_name="Thermal plume height" unit="K/s" /> 492 <field id="rsut4co2" long_name="TOA Out SW in 4xCO2 atmosphere" unit="W/m2" />495 <field id="rsut4co2" long_name="TOA Out SW in 4xCO2 atmosphere" unit="W/m2" > this*swradcorr </field> 493 496 <field id="rlut4co2" long_name="TOA Out LW in 4xCO2 atmosphere" unit="W/m2" /> 494 <field id="rsutcs4co2" long_name="TOA Out CS SW in 4xCO2 atmosphere" unit="W/m2" />497 <field id="rsutcs4co2" long_name="TOA Out CS SW in 4xCO2 atmosphere" unit="W/m2" > this*swradcorr </field> 495 498 <field id="rlutcs4co2" long_name="TOA Out CS LW in 4xCO2 atmosphere" unit="W/m2" /> 496 499 <field id="dqphy2d" long_name="Physics dQ" unit="(kg/m2)/s" /> … … 527 530 <field id="tke_oce" long_name="Max Turb. Kinetic Energy oce" unit="m2/s2" /> 528 531 <field id="tke_sic" long_name="Max Turb. Kinetic Energy sic" unit="m2/s2" /> 529 <field id="tke_max_ter" long_name="Max Turb. Kinetic Energy ter" unit="m2/s2" operation="maximum"/>530 <field id="tke_max_lic" long_name="Max Turb. Kinetic Energy lic" unit="m2/s2" operation="maximum"/>531 <field id="tke_max_oce" long_name="Max Turb. Kinetic Energy oce" unit="m2/s2" operation="maximum"/>532 <field id="tke_max_sic" long_name="Max Turb. Kinetic Energy sic" unit="m2/s2" operation="maximum"/>532 <field id="tke_max_ter" field_ref="tke_ter" operation="maximum"/> 533 <field id="tke_max_lic" field_ref="tke_lic" operation="maximum"/> 534 <field id="tke_max_oce" field_ref="tke_oce" operation="maximum"/> 535 <field id="tke_max_sic" field_ref="tke_sic" operation="maximum"/> 533 536 <field id="l_mix_ter" long_name="PBL mixing length ter" unit="m" /> 534 537 <field id="l_mix_lic" long_name="PBL mixing length lic" unit="m" /> … … 549 552 <field id="cldtau" long_name="Cloud optical thickness" unit="1" /> 550 553 <field id="cldemi" long_name="Cloud optical emissivity" unit="1" /> 551 <field id="tke_max" long_name="TKE max" unit="m2/s2"operation="maximum"/>554 <field id="tke_max" long_name="TKE max" field_ref="tke" operation="maximum"/> 552 555 <field id="kz" long_name="Kz melange" unit="m2/s" enabled="FALSE" /> 553 <field id="kz_max" long_name="Kz melange max" unit="m2/s"enabled="FALSE" operation="maximum" />556 <field id="kz_max" field_ref="kz" long_name="Kz melange max" enabled="FALSE" operation="maximum" /> 554 557 <field id="concso4" long_name="Concentration of Sulfate " unit="kg/m3" /> 555 558 <field id="concno3" long_name="Concentration of Nitrate " unit="kg/m3" /> … … 566 569 <field id="ovapinit" long_name="Specific humidity (begin of timestep)" unit="kg/kg" /> 567 570 <field id="oliq" long_name="Liquid water" unit="kg/kg" /> 568 <field id="ocond" long_name="Condensed water" unit="kg/kg" />571 <field id="ocond" long_name="Condensed water" unit="kg/kg" >oliq+this</field> 569 572 <field id="geop" long_name="Geopotential height" unit="m2/s2" /> 570 573 <field id="geoph" field_ref="geop" long_name="Geopotential height" unit="m" > geop/9.80665 </field> … … 575 578 <field id="paprs" long_name="Air pressure Inter-Couches" unit="Pa" /> 576 579 <field id="mass" long_name="Masse Couches" unit="kg/m2" /> 577 <field id="zfull" long_name="Altitude of full pressure levels" unit="m" />580 <field id="zfull" long_name="Altitude of full pressure levels" unit="m" > geop / $RG </field> 578 581 <field id="zhalf" long_name="Altitude of half pressure levels" unit="m" /> 579 582 <field id="rneb" long_name="Cloud fraction" unit="-" /> … … 582 585 <field id="rneblsvol" long_name="LS Cloud fraction by volume" unit="-" /> 583 586 <field id="rhum" long_name="Relative humidity" unit="-" /> 584 <field id="ozone" long_name="Ozone mole fraction" unit="-" /> 585 <field id="ozone_daylight" long_name="Daylight ozone mole fraction" unit="-" /> 587 <field id="wo_1" long_name="Temporary"/> 588 <field id="ozone" long_name="Ozone mole fraction" unit="-" > wo_1 * $dobson_u * 1E3 / mass / $rmo3 * $rmd </field> 589 <field id="ozone_daylight" long_name="Daylight ozone mole fraction" unit="-" > this * $dobson_u * 1E3 / mass / $rmo3 * $rmd </field> 586 590 <field id="upwd" long_name="saturated updraft" unit="kg/m2/s" /> 587 591 <field id="ep" long_name="ep" unit="su" /> … … 603 607 <field id="lcc3dcon" long_name="Convective cloud liquid fraction" unit="1" /> 604 608 <field id="lcc3dstra" long_name="Stratiform cloud liquid fraction" unit="1" /> 605 <field id="cldwatmxrat" long_name="Cloud Water Mixing Ratio" unit="1" />609 <field id="cldwatmxrat" long_name="Cloud Water Mixing Ratio" unit="1" > 1-this </field> 606 610 <field id="icc3dcon" long_name="Mass Fraction of Convective Cloud Ice" unit="kg/kg" /> 607 611 <field id="icc3dstra" long_name="Mass Fraction of Stratiform Cloud Ice " unit="kg/kg" /> … … 612 616 <field id="dnwd" long_name="saturated downdraft" unit="kg/m2/s" /> 613 617 <field id="dnwd0" long_name="unsat. downdraft" unit="kg/m2/s" /> 614 <field id="mc" long_name="Convective mass flux" unit="kg/m2/s" />618 <field id="mc" long_name="Convective mass flux" unit="kg/m2/s" > -dnwd + dnwd0 + upwd + f_th </field> 615 619 <field id="dtdyn" long_name="Dynamics dT" unit="K/s" /> 616 620 <field id="dqdyn" long_name="Dynamics dQ" unit="(kg/kg)/s" /> … … 619 623 <field id="dudyn" long_name="Dynamics dU" unit="m/s2" /> 620 624 <field id="dvdyn" long_name="Dynamics dV" unit="m/s2" /> 621 <field id="dtcon" long_name="Convection dT" unit="K/s" />622 <field id="ducon" long_name="Convection du" unit="m/s2" />623 <field id="dvcon" long_name="Convection dv" unit="m/s2" />624 <field id="dqcon" long_name="Convection dQ" unit="(kg/kg)/s" />625 <field id="dtwak" long_name="Wake dT" unit="K/s" />626 <field id="dqwak" long_name="Wake dQ" unit="(kg/kg)/s" />625 <field id="dtcon" long_name="Convection dT" unit="K/s" > this/$pdtphys </field> 626 <field id="ducon" long_name="Convection du" unit="m/s2" > this/$pdtphys </field> 627 <field id="dvcon" long_name="Convection dv" unit="m/s2" > this/$pdtphys </field> 628 <field id="dqcon" long_name="Convection dQ" unit="(kg/kg)/s" > this/$pdtphys </field> 629 <field id="dtwak" long_name="Wake dT" unit="K/s" > this/$pdtphys </field> 630 <field id="dqwak" long_name="Wake dQ" unit="(kg/kg)/s" > this/$pdtphys </field> 627 631 <field id="wake_deltat" long_name="wake_deltat" unit="-" /> 628 632 <field id="wake_deltaq" long_name="wake_deltaq" unit="-" /> … … 640 644 <field id="dqlsc" long_name="Condensation dQ" unit="(kg/kg)/s" /> 641 645 <field id="beta_prec" long_name="LS Conversion rate to prec" unit="(kg/kg)/s" /> 642 <field id="dtvdf" long_name="Boundary-layer dT" unit="K/s" />643 <field id="dtvdf_x" long_name="dtvdf off_wake" unit="K/s" />644 <field id="dtvdf_w" long_name="dtvdf within_wake" unit="K/s" />645 <field id="dtdis" long_name="TKE dissipation dT" unit="K/s" />646 <field id="dqvdf" long_name="Boundary-layer dQ" unit="(kg/kg)/s" />647 <field id="dqvdf_x" long_name="dqvdf off_wake" unit="(kg/kg)/s" />648 <field id="dqvdf_w" long_name="dqvdf within_wake" unit="(kg/kg)/s" />649 <field id="dteva" long_name="Reevaporation dT" unit="K/s" />650 <field id="dqeva" long_name="Reevaporation dQ" unit="(kg/kg)/s" />651 <field id="dqlscth" long_name="dQ therm." unit="(kg/kg)/s" />652 <field id="dqlscst" long_name="dQ strat." unit="(kg/kg)/s" />653 <field id="dtlscth" long_name="dQ therm." unit="K/s" />654 <field id="dtlscst" long_name="dQ strat." unit="K/s" />655 <field id="ptconvth" long_name="POINTS CONVECTIFS therm." unit="-" />646 <field id="dtvdf" long_name="Boundary-layer dT" unit="K/s" > this/$pdtphys </field> 647 <field id="dtvdf_x" long_name="dtvdf off_wake" unit="K/s"> this/$pdtphys </field> 648 <field id="dtvdf_w" long_name="dtvdf within_wake" unit="K/s"> this/$pdtphys </field> 649 <field id="dtdis" long_name="TKE dissipation dT" unit="K/s" > this/$pdtphys </field> 650 <field id="dqvdf" long_name="Boundary-layer dQ" unit="(kg/kg)/s" > this/$pdtphys </field> 651 <field id="dqvdf_x" long_name="dqvdf off_wake" unit="(kg/kg)/s" > this/$pdtphys </field> 652 <field id="dqvdf_w" long_name="dqvdf within_wake" unit="(kg/kg)/s" > this/$pdtphys </field> 653 <field id="dteva" long_name="Reevaporation dT" unit="K/s" > this/$pdtphys </field> 654 <field id="dqeva" long_name="Reevaporation dQ" unit="(kg/kg)/s" > this/$pdtphys </field> 655 <field id="dqlscth" long_name="dQ therm." unit="(kg/kg)/s" > this/$pdtphys </field> 656 <field id="dqlscst" long_name="dQ strat." unit="(kg/kg)/s" > this/$pdtphys </field> 657 <field id="dtlscth" long_name="dQ therm." unit="K/s" > this/$pdtphys </field> 658 <field id="dtlscst" long_name="dQ strat." unit="K/s" > this/$pdtphys </field> 659 <field id="ptconvth" long_name="POINTS CONVECTIFS therm." unit="-" > this/=0 </field> 656 660 <field id="ptconv" long_name="POINTS CONVECTIFS" unit="-" /> 657 661 <field id="ratqs" long_name="RATQS" unit="-" /> 658 <field id="dtthe" long_name="Thermal dT" unit="K/s" />659 <field id="duthe" long_name="Thermal du" unit="m/s2" />660 <field id="dvthe" long_name="Thermal dv" unit="m/s2" />662 <field id="dtthe" long_name="Thermal dT" unit="K/s" > this/$pdtphys - dtajs </field> 663 <field id="duthe" long_name="Thermal du" unit="m/s2" > this/$pdtphys </field> 664 <field id="dvthe" long_name="Thermal dv" unit="m/s2" > this/$pdtphys </field> 661 665 <field id="f_th" long_name="Thermal plume mass flux" unit="kg/(m2*s)" /> 662 666 <field id="e_th" long_name="Thermal plume entrainment" unit="K/s" /> … … 671 675 <field id="d_th" long_name="Thermal plume detrainment" unit="K/s" /> 672 676 <field id="dqthe" long_name="Thermal dQ" unit="(kg/kg)/s" /> 673 <field id="dtajs" long_name="Dry adjust. dT" unit="K/s" />674 <field id="dqajs" long_name="Dry adjust. dQ" unit="(kg/kg)/s" />675 <field id="dtswr" long_name="SW radiation dT" unit="K/s" />676 <field id="dtsw0" long_name="CS SW radiation dT" unit="K/s" />677 <field id="dtlwr" long_name="LW radiation dT" unit="K/s" />678 <field id="dtlw0" long_name="CS LW radiation dT" unit="K/s" />679 <field id="dtec" long_name="Cinetic dissip dT" unit="K/s" />680 <field id="duvdf" long_name="Boundary-layer dU" unit="m/s2" />681 <field id="dvvdf" long_name="Boundary-layer dV" unit="m/s2" />682 <field id="duoro" long_name="Orography dU" unit="m/s2" />683 <field id="dvoro" long_name="Orography dV" unit="m/s2" />684 <field id="dulif" long_name="Orography dU" unit="m/s2" />685 <field id="dvlif" long_name="Orography dV" unit="m/s2" />686 <field id="du_gwd_rando" long_name="peu importe" unit="W/m2" />687 <field id="dv_gwd_rando" long_name="peu importe" unit="W/m2" />688 <field id="du_gwd_hines" long_name="Hines GWD dU" unit="m/s2" />689 <field id="dv_gwd_hines" long_name="Hines GWD dV" unit="m/s2" />690 <field id="du_gwd_front" long_name="Fronts GWD dU" unit="m/s2" />691 <field id="dv_gwd_front" long_name="Fronts GWD dV" unit="m/s2" />677 <field id="dtajs" long_name="Dry adjust. dT" unit="K/s" > this/$pdtphys </field> 678 <field id="dqajs" long_name="Dry adjust. dQ" unit="(kg/kg)/s" > this/$pdtphys </field> 679 <field id="dtswr" long_name="SW radiation dT" unit="K/s" > this/$pdtphys </field> 680 <field id="dtsw0" long_name="CS SW radiation dT" unit="K/s" > this/$pdtphys </field> 681 <field id="dtlwr" long_name="LW radiation dT" unit="K/s" > this/$pdtphys </field> 682 <field id="dtlw0" long_name="CS LW radiation dT" unit="K/s" > this/$pdtphys </field> 683 <field id="dtec" long_name="Cinetic dissip dT" unit="K/s" > this/$pdtphys </field> 684 <field id="duvdf" long_name="Boundary-layer dU" unit="m/s2" > this/$pdtphys </field> 685 <field id="dvvdf" long_name="Boundary-layer dV" unit="m/s2" > this/$pdtphys </field> 686 <field id="duoro" long_name="Orography dU" unit="m/s2" > this/$pdtphys </field> 687 <field id="dvoro" long_name="Orography dV" unit="m/s2" > this/$pdtphys </field> 688 <field id="dulif" long_name="Orography dU" unit="m/s2" > this/$pdtphys </field> 689 <field id="dvlif" long_name="Orography dV" unit="m/s2" > this/$pdtphys </field> 690 <field id="du_gwd_rando" long_name="peu importe" unit="W/m2" > this/$pdtphys </field> 691 <field id="dv_gwd_rando" long_name="peu importe" unit="W/m2" > this/$pdtphys </field> 692 <field id="du_gwd_hines" long_name="Hines GWD dU" unit="m/s2" > this/$pdtphys </field> 693 <field id="dv_gwd_hines" long_name="Hines GWD dV" unit="m/s2" > this/$pdtphys </field> 694 <field id="du_gwd_front" long_name="Fronts GWD dU" unit="m/s2" > this/$pdtphys </field> 695 <field id="dv_gwd_front" long_name="Fronts GWD dV" unit="m/s2" > this/$pdtphys </field> 692 696 <field id="east_gwstress" long_name="Eastward GW Stress" unit="Pa" /> 693 697 <field id="west_gwstress" long_name="Westward GW Stress" unit="Pa" /> 694 <field id="dtoro" long_name="Orography dT" unit="K/s" />695 <field id="dtlif" long_name="Orography dT" unit="K/s" />696 <field id="dthin" long_name="Hines GWD dT" unit="K/s" />698 <field id="dtoro" long_name="Orography dT" unit="K/s" > this/$pdtphys </field> 699 <field id="dtlif" long_name="Orography dT" unit="K/s" > this/$pdtphys </field> 700 <field id="dthin" long_name="Hines GWD dT" unit="K/s" > this/$pdtphys </field> 697 701 <field id="rsu" long_name="SW upward radiation" unit="W m-2" /> 698 702 <field id="rsd" long_name="SW downward radiation" unit="W m-2" /> … … 705 709 <field id="rlucs" long_name="LW CS upward radiation" unit="W m-2" /> 706 710 <field id="rldcs" long_name="LW CS downward radiation" unit="W m-2" /> 707 <field id="tnt" long_name="Tendency of air temperature" unit="K s-1" />711 <field id="tnt" long_name="Tendency of air temperature" unit="K s-1" > dtphy + dtdyn </field> 708 712 <field id="tntc" long_name="Tendency of air temperature due to Moist Convection" unit="K s-1" /> 709 <field id="tntr" long_name="Air temperature tendency due to Radiative heating" unit="K s-1" />710 <field id="tntscpbl" long_name="Air temperature tendency due to St cloud and precipitation and BL mixing" unit="K s-1" />711 <field id="tnhus" long_name="Tendency of specific humidity" unit="s-1" />713 <field id="tntr" long_name="Air temperature tendency due to Radiative heating" unit="K s-1" > dtswr + dtlwr </field> 714 <field id="tntscpbl" long_name="Air temperature tendency due to St cloud and precipitation and BL mixing" unit="K s-1" > dtlsc + dteva + dtvdf </field> 715 <field id="tnhus" long_name="Tendency of specific humidity" unit="s-1" > dqphy + dqdyn </field> 712 716 <field id="tnhusc" long_name="Tendency of specific humidity due to convection" unit="s-1" /> 713 <field id="tnhusscpbl" long_name="Tendency of Specific humidity due to ST cl, precip and BL mixing" unit="s-1" />717 <field id="tnhusscpbl" long_name="Tendency of Specific humidity due to ST cl, precip and BL mixing" unit="s-1" > dqlsc + dqeva </field> 714 718 <field id="evu" long_name="Eddy viscosity coefficient for Momentum Variables" unit="m2 s-1" /> 715 <field id="h2o" long_name="Mass Fraction of Water" unit="1" />719 <field id="h2o" long_name="Mass Fraction of Water" unit="1" > ovap + oliq </field> 716 720 <field id="mcd" long_name="Downdraft COnvective Mass Flux" unit="kg/(m2*s)" /> 717 721 <field id="dmc" long_name="Deep COnvective Mass Flux" unit="kg/(m2*s)" /> … … 783 787 <field id="wap" long_name="Lagrangian tendency of air pressure" unit="Pa s-1" detect_missing_value=".true." /> 784 788 <!-- <field id="psbg" long_name="Pressure sfce below ground" unit="%" detect_missing_value=".true." /> --> 785 <field id="tro3" long_name="Ozone mole fraction" unit="1e-9" detect_missing_value=".true." />786 <field id="tro3_daylight" long_name="Daylight ozone mole fraction" unit="1e-9" detect_missing_value=".true." />789 <field id="tro3" long_name="Ozone mole fraction" unit="1e-9" detect_missing_value=".true." > (this/=$missing_val)?this*1.e+9:$missing_val </field> 790 <field id="tro3_daylight" long_name="Daylight ozone mole fraction" unit="1e-9" detect_missing_value=".true." > (this/=$missing_val)?this*1.e+9:$missing_val </field> 787 791 <field id="uv" long_name="uv" unit="m2/s2" detect_missing_value=".true." /> 788 792 <field id="vxq" long_name="vxq" unit="m/s * (kg/kg)" detect_missing_value=".true." /> -
LMDZ6/branches/Optimisation_LMDZ/libf/phylmd/phys_output_write_xios_mod.f90
r3754 r3768 353 353 INTEGER :: flag_aerosol_strat 354 354 INTEGER :: flag_aerosol 355 LOGICAL :: ok_cdnc 355 LOGICAL :: ok_cdnc, var_is_set 356 356 357 357 ! Local … … 374 374 INTEGER ISW 375 375 CHARACTER*1 ch1 376 CHARACTER(len=3) :: isrf_str 376 377 CHARACTER*20 varname 377 378 … … 381 382 REAL, DIMENSION(klon, klev) :: z, dz 382 383 REAL, DIMENSION(klon) :: zrho, zt 384 385 type(ctrl_out), SAVE :: o_wo_1 = ctrl_out(flag=0, name="wo_1", description = "Temporary", unit = "-", type_ecrit = "") 386 type(ctrl_out), SAVE :: o_swradcorr = ctrl_out(flag=0, name="swradcorr", description = "Temporary", unit = "-", type_ecrit = "") 383 387 384 388 if( .not. CPP_XIOS_defined ) call abort_physic("phys_output_write_xios", "This io backend can only be used when LMDZ is compiled with XIOS support",1 ) … … 420 424 421 425 !$omp MASTER 426 IF (.not. vars_defined) THEN 427 var_is_set = xios_setVar("pdtphys", pdtphys) 428 var_is_set = xios_setVar("RG", RG) 429 !wo_coeff = dobson_u*1e3/rmo3*rmd 430 var_is_set = xios_setVar("dobson_u", dobson_u) 431 var_is_set = xios_setVar("rmo3", rmo3) 432 var_is_set = xios_setVar("rmd", rmd) 433 var_is_set = xios_setVar("missing_val", missing_val) 434 ENDIF 422 435 IF (.not. vars_defined .and. ok_strataer) THEN 423 436 !On ajoute les variables 3D traceurs par l interface fortran … … 510 523 CALL histwrite_phy(o_aire, zx_tmp_fi2d) 511 524 512 DO i = 1, klon513 zx_tmp_fi2d(i) = pctsrf(i, is_ter) + pctsrf(i, is_lic)514 ENDDO515 CALL histwrite_phy(o_contfracATM, zx_tmp_fi2d)516 CALL histwrite_phy(o_contfracOR, pctsrf(:, is_ter))525 ! DO i = 1, klon 526 ! zx_tmp_fi2d(i) = pctsrf(i, is_ter) + pctsrf(i, is_lic) 527 ! ENDDO 528 ! CALL histwrite_phy(o_contfracATM, zx_tmp_fi2d) 529 !CALL histwrite_phy(o_contfracOR, pctsrf(:, is_ter)) 517 530 CALL histwrite_phy("R_ecc", R_ecc) 518 531 CALL histwrite_phy("R_peri", R_peri) … … 580 593 CALL histwrite_phy(o_tsol, zxtsol) 581 594 CALL histwrite_phy(o_t2m, zt2m_cor) 582 CALL histwrite_phy(o_t2m_min, zt2m_cor)583 CALL histwrite_phy(o_t2m_max, zt2m_cor)595 !CALL histwrite_phy(o_t2m_min, zt2m_cor) 596 !CALL histwrite_phy(o_t2m_max, zt2m_cor) 584 597 CALL histwrite_phy(o_t2m_max_mon, t2m_max_mon) 585 598 CALL histwrite_phy(o_t2m_min_mon, t2m_min_mon) 586 DO i = 1, klon587 zx_tmp_fi2d(i) = SQRT(zu10m_cor(i)*zu10m_cor(i) + zv10m_cor(i)*zv10m_cor(i))588 ENDDO589 CALL histwrite_phy(o_wind10m, zx_tmp_fi2d)590 DO i = 1, klon591 zx_tmp_fi2d(i) = SQRT(zu10m_cor(i)*zu10m_cor(i) + zv10m_cor(i)*zv10m_cor(i))592 ENDDO593 CALL histwrite_phy(o_wind10max, zx_tmp_fi2d)599 ! DO i = 1, klon 600 ! zx_tmp_fi2d(i) = SQRT(zu10m_cor(i)*zu10m_cor(i) + zv10m_cor(i)*zv10m_cor(i)) 601 ! ENDDO 602 ! CALL histwrite_phy(o_wind10m, zx_tmp_fi2d) 603 ! DO i = 1, klon 604 ! zx_tmp_fi2d(i) = SQRT(zu10m_cor(i)*zu10m_cor(i) + zv10m_cor(i)*zv10m_cor(i)) 605 ! ENDDO 606 ! CALL histwrite_phy(o_wind10max, zx_tmp_fi2d) 594 607 595 608 CALL histwrite_phy(o_gusts, gustiness) … … 615 628 ENDDO 616 629 ENDDO 617 CALL histwrite_phy(o_wind100m, zx_tmp_fi2d) 618 IF (vars_defined) THEN 619 DO i = 1, klon 620 zx_tmp_fi2d(i) = pctsrf(i, is_sic) 621 ENDDO 622 ENDIF 623 CALL histwrite_phy(o_sicf, zx_tmp_fi2d) 630 CALL histwrite_phy(o_wind100m, zx_tmp_fi2d) 631 !CALL histwrite_phy(o_sicf, pctsrf(1:klon, is_sic)) 624 632 CALL histwrite_phy(o_q2m, zq2m_cor) 625 633 CALL histwrite_phy(o_ustar, zustar) 626 634 CALL histwrite_phy(o_u10m, zu10m_cor) 627 635 CALL histwrite_phy(o_v10m, zv10m_cor) 628 DO i = 1, klon 629 zx_tmp_fi2d(i) = paprs(i, 1) 630 ENDDO 631 632 CALL histwrite_phy(o_psol, zx_tmp_fi2d) 636 CALL histwrite_phy(o_psol, paprs(1:klon, 1)) 633 637 CALL histwrite_phy(o_mass, zmasse) 634 638 CALL histwrite_phy(o_qsurf, zxqsurf) … … 638 642 ENDIF 639 643 640 DO i = 1, klon 641 zx_tmp_fi2d(i) = rain_fall(i) + snow_fall(i) 642 ENDDO 643 644 CALL histwrite_phy(o_precip, zx_tmp_fi2d) 644 ! DO i = 1, klon 645 ! zx_tmp_fi2d(i) = rain_fall(i) + snow_fall(i) 646 ! ENDDO 647 ! CALL histwrite_phy(o_precip, zx_tmp_fi2d) 645 648 CALL histwrite_phy(o_rain_fall, rain_fall) 646 649 CALL histwrite_phy(o_ndayrain, nday_rain) 647 650 CALL histwrite_phy(o_ep, ep) 648 651 649 DO i = 1, klon 650 zx_tmp_fi2d(i) = rain_lsc(i) + snow_lsc(i) 651 ENDDO 652 CALL histwrite_phy(o_plul, zx_tmp_fi2d) 652 ! DO i = 1, klon 653 ! zx_tmp_fi2d(i) = rain_lsc(i) + snow_lsc(i) 654 ! ENDDO 655 ! CALL histwrite_phy(o_plul, zx_tmp_fi2d) 656 CALL histwrite_phy(o_plul, rain_lsc) 653 657 CALL histwrite_phy(o_plun, rain_num) 654 658 655 DO i = 1, klon 656 zx_tmp_fi2d(i) = rain_con(i) + snow_con(i) 657 ENDDO 658 CALL histwrite_phy(o_pluc, zx_tmp_fi2d) 659 CALL histwrite_phy(o_rain_con, rain_con) 659 ! DO i = 1, klon 660 ! zx_tmp_fi2d(i) = rain_con(i) + snow_con(i) 661 ! ENDDO 662 ! CALL histwrite_phy(o_pluc, zx_tmp_fi2d) 663 CALL histwrite_phy(o_pluc, snow_con) 664 CALL histwrite_phy(o_rain_con, rain_con) 660 665 CALL histwrite_phy(o_snow, snow_fall) 661 666 CALL histwrite_phy(o_msnow, zxsnow) … … 663 668 CALL histwrite_phy(o_evap, evap) 664 669 665 666 zx_tmp_fi2d = topsw*swradcorr 667 CALL histwrite_phy(o_tops, zx_tmp_fi2d) 668 zx_tmp_fi2d = topsw0*swradcorr 669 CALL histwrite_phy(o_tops0, zx_tmp_fi2d) 670 671 670 672 CALL histwrite_phy(o_topl, toplw) 671 673 CALL histwrite_phy(o_topl0, toplw0) 672 zx_tmp_fi2d(:) = swup(:, klevp1)*swradcorr(:) 673 CALL histwrite_phy(o_SWupTOA, zx_tmp_fi2d) 674 zx_tmp_fi2d(:) = swup0(:, klevp1)*swradcorr(:) 675 CALL histwrite_phy(o_SWupTOAclr, zx_tmp_fi2d) 676 zx_tmp_fi2d(:) = swupc0(:, klevp1)*swradcorr(:) 677 CALL histwrite_phy(o_SWupTOAcleanclr, zx_tmp_fi2d) 678 zx_tmp_fi2d(:) = swdn(:, klevp1)*swradcorr(:) 679 CALL histwrite_phy(o_SWdnTOA, zx_tmp_fi2d) 680 zx_tmp_fi2d(:) = swdn0(:, klevp1)*swradcorr(:) 681 CALL histwrite_phy(o_SWdnTOAclr, zx_tmp_fi2d) 682 zx_tmp_fi2d(:) = topsw(:)*swradcorr(:) - toplw(:) 683 CALL histwrite_phy(o_nettop, zx_tmp_fi2d) 684 zx_tmp_fi2d = SWup200*swradcorr 685 CALL histwrite_phy(o_SWup200, zx_tmp_fi2d) 686 zx_tmp_fi2d = SWup200clr*swradcorr 687 CALL histwrite_phy(o_SWup200clr, zx_tmp_fi2d) 688 zx_tmp_fi2d = SWdn200*swradcorr 689 CALL histwrite_phy(o_SWdn200, zx_tmp_fi2d) 690 zx_tmp_fi2d = SWdn200clr*swradcorr 691 CALL histwrite_phy(o_SWdn200clr, zx_tmp_fi2d) 674 675 ! zx_tmp_fi2d = topsw*swradcorr 676 ! CALL histwrite_phy(o_tops, zx_tmp_fi2d) 677 ! zx_tmp_fi2d = topsw0*swradcorr 678 ! CALL histwrite_phy(o_tops0, zx_tmp_fi2d) 679 ! zx_tmp_fi2d(:) = swup(:, klevp1)*swradcorr(:) 680 ! CALL histwrite_phy(o_SWupTOA, zx_tmp_fi2d) 681 ! zx_tmp_fi2d(:) = swup0(:, klevp1)*swradcorr(:) 682 ! CALL histwrite_phy(o_SWupTOAclr, zx_tmp_fi2d) 683 ! zx_tmp_fi2d(:) = swupc0(:, klevp1)*swradcorr(:) 684 ! CALL histwrite_phy(o_SWupTOAcleanclr, zx_tmp_fi2d) 685 ! zx_tmp_fi2d(:) = swdn(:, klevp1)*swradcorr(:) 686 ! CALL histwrite_phy(o_SWdnTOA, zx_tmp_fi2d) 687 ! zx_tmp_fi2d(:) = swdn0(:, klevp1)*swradcorr(:) 688 ! CALL histwrite_phy(o_SWdnTOAclr, zx_tmp_fi2d) 689 ! zx_tmp_fi2d(:) = topsw(:)*swradcorr(:) - toplw(:) 690 ! CALL histwrite_phy(o_nettop, zx_tmp_fi2d) 691 ! zx_tmp_fi2d = SWup200*swradcorr 692 ! CALL histwrite_phy(o_SWup200, zx_tmp_fi2d) 693 ! zx_tmp_fi2d = SWup200clr*swradcorr 694 ! CALL histwrite_phy(o_SWup200clr, zx_tmp_fi2d) 695 ! zx_tmp_fi2d = SWdn200*swradcorr 696 ! CALL histwrite_phy(o_SWdn200, zx_tmp_fi2d) 697 ! zx_tmp_fi2d = SWdn200clr*swradcorr 698 ! CALL histwrite_phy(o_SWdn200clr, zx_tmp_fi2d) 699 ! zx_tmp_fi2d = solsw*swradcorr 700 ! CALL histwrite_phy(o_sols, zx_tmp_fi2d) 701 ! zx_tmp_fi2d = solsw0*swradcorr 702 ! CALL histwrite_phy(o_sols0, zx_tmp_fi2d) 703 ! zx_tmp_fi2d(:) = swup(:, 1)*swradcorr(:) 704 ! CALL histwrite_phy(o_SWupSFC, zx_tmp_fi2d) 705 ! zx_tmp_fi2d(:) = swup0(:, 1)*swradcorr(:) 706 ! CALL histwrite_phy(o_SWupSFCclr, zx_tmp_fi2d) 707 ! zx_tmp_fi2d(:) = swupc0(:, 1)*swradcorr(:) 708 ! CALL histwrite_phy(o_SWupSFCcleanclr, zx_tmp_fi2d) 709 ! zx_tmp_fi2d(:) = swdn(:, 1)*swradcorr(:) 710 ! CALL histwrite_phy(o_SWdnSFC, zx_tmp_fi2d) 711 ! zx_tmp_fi2d(:) = swdn0(:, 1)*swradcorr(:) 712 ! CALL histwrite_phy(o_SWdnSFCclr, zx_tmp_fi2d) 713 ! zx_tmp_fi2d(:) = swdnc0(:, 1)*swradcorr(:) 714 ! CALL histwrite_phy(o_SWdnSFCcleanclr, zx_tmp_fi2d) 715 CALL histwrite_phy(o_swradcorr, swradcorr) 716 CALL histwrite_phy(o_tops, topsw) 717 CALL histwrite_phy(o_tops0, topsw0) 718 CALL histwrite_phy(o_SWupTOA, swup(:, klevp1)) 719 CALL histwrite_phy(o_SWupTOAclr, swup0(:, klevp1)) 720 CALL histwrite_phy(o_SWupTOAcleanclr, swupc0(:, klevp1)) 721 CALL histwrite_phy(o_SWdnTOA, swdn(:, klevp1)) 722 CALL histwrite_phy(o_SWdnTOAclr, swdn0(:, klevp1)) 723 CALL histwrite_phy(o_SWup200, SWup200) 724 CALL histwrite_phy(o_SWup200clr, SWup200clr) 725 CALL histwrite_phy(o_SWdn200, SWdn200) 726 CALL histwrite_phy(o_SWdn200clr, SWdn200clr) 727 728 CALL histwrite_phy(o_SWupSFC, swup(:, 1)) 729 CALL histwrite_phy(o_SWupSFCclr, swup0(:, 1)) 730 CALL histwrite_phy(o_SWupSFCcleanclr, swupc0(:, 1)) 731 CALL histwrite_phy(o_SWdnSFC, swdn(:, 1)) 732 CALL histwrite_phy(o_SWdnSFCclr, swdn0(:, 1)) 733 CALL histwrite_phy(o_SWdnSFCcleanclr, swdnc0(:, 1)) 734 692 735 CALL histwrite_phy(o_LWup200, LWup200) 693 736 CALL histwrite_phy(o_LWup200clr, LWup200clr) 694 737 CALL histwrite_phy(o_LWdn200, LWdn200) 695 738 CALL histwrite_phy(o_LWdn200clr, LWdn200clr) 696 zx_tmp_fi2d = solsw*swradcorr 697 CALL histwrite_phy(o_sols, zx_tmp_fi2d) 698 zx_tmp_fi2d = solsw0*swradcorr 699 CALL histwrite_phy(o_sols0, zx_tmp_fi2d) 739 740 CALL histwrite_phy(o_sols, solsw) 741 CALL histwrite_phy(o_sols0, solsw0) 700 742 CALL histwrite_phy(o_soll, sollw) 701 743 CALL histwrite_phy(o_soll0, sollw0) 702 744 CALL histwrite_phy(o_radsol, radsol) 703 zx_tmp_fi2d(:) = swup(:, 1)*swradcorr(:) 704 CALL histwrite_phy(o_SWupSFC, zx_tmp_fi2d) 705 zx_tmp_fi2d(:) = swup0(:, 1)*swradcorr(:) 706 CALL histwrite_phy(o_SWupSFCclr, zx_tmp_fi2d) 707 zx_tmp_fi2d(:) = swupc0(:, 1)*swradcorr(:) 708 CALL histwrite_phy(o_SWupSFCcleanclr, zx_tmp_fi2d) 709 zx_tmp_fi2d(:) = swdn(:, 1)*swradcorr(:) 710 CALL histwrite_phy(o_SWdnSFC, zx_tmp_fi2d) 711 zx_tmp_fi2d(:) = swdn0(:, 1)*swradcorr(:) 712 CALL histwrite_phy(o_SWdnSFCclr, zx_tmp_fi2d) 713 zx_tmp_fi2d(:) = swdnc0(:, 1)*swradcorr(:) 714 CALL histwrite_phy(o_SWdnSFCcleanclr, zx_tmp_fi2d) 715 zx_tmp_fi2d(:) = sollwdown(:) - sollw(:) 716 CALL histwrite_phy(o_LWupSFC, zx_tmp_fi2d) 745 717 746 CALL histwrite_phy(o_LWdnSFC, sollwdown) 718 sollwdownclr(1:klon) = -1.*lwdn0(1:klon, 1) 719 zx_tmp_fi2d(1:klon) = sollwdownclr(1:klon) - sollw0(1:klon) 720 CALL histwrite_phy(o_LWupSFCclr, zx_tmp_fi2d) 721 CALL histwrite_phy(o_LWdnSFCclr, sollwdownclr) 722 zx_tmp_fi2d(:) = lwupc0(:, klevp1) 723 CALL histwrite_phy(o_LWupTOAcleanclr, zx_tmp_fi2d) 724 zx_tmp_fi2d(:) = -1.*lwdnc0(:, 1) 725 CALL histwrite_phy(o_LWdnSFCcleanclr, zx_tmp_fi2d) 747 748 !sollwdownclr(1:klon) = -1.*lwdn0(1:klon, 1) 749 !zx_tmp_fi2d(1:klon) = sollwdownclr(1:klon) - sollw0(1:klon) 750 !CALL histwrite_phy(o_LWupSFCclr, zx_tmp_fi2d) 751 !CALL histwrite_phy(o_LWdnSFCclr, sollwdownclr) 752 CALL histwrite_phy(o_LWdnSFCclr, lwdn0(1:klon, 1)) 753 CALL histwrite_phy(o_LWupTOAcleanclr, lwupc0(:, klevp1)) 754 ! zx_tmp_fi2d(:) = -1.*lwdnc0(:, 1) 755 ! CALL histwrite_phy(o_LWdnSFCcleanclr, zx_tmp_fi2d) 756 CALL histwrite_phy(o_LWdnSFCcleanclr, lwdnc0(:, 1)) 726 757 CALL histwrite_phy(o_bils, bils) 727 758 CALL histwrite_phy(o_bils_diss, bils_diss) … … 732 763 CALL histwrite_phy(o_bils_latent, bils_latent) 733 764 CALL histwrite_phy(o_bils_enthalp, bils_enthalp) 734 zx_tmp_fi2d(1:klon) = -1*sens(1:klon) 735 CALL histwrite_phy(o_sens, zx_tmp_fi2d) 765 ! zx_tmp_fi2d(1:klon) = -1*sens(1:klon) 766 ! CALL histwrite_phy(o_sens, zx_tmp_fi2d) 767 CALL histwrite_phy(o_sens, sens(1:klon)) 736 768 CALL histwrite_phy(o_fder, fder) 737 769 CALL histwrite_phy(o_ffonte, zxffonte) 738 770 CALL histwrite_phy(o_fqcalving, zxfqcalving) 739 771 CALL histwrite_phy(o_fqfonte, zxfqfonte) 740 zx_tmp_fi2d(1:klon) = (zxfqfonte(1:klon) + rain_fall(1:klon))*pctsrf(1:klon, is_lic)741 CALL histwrite_phy(o_mrroli, zx_tmp_fi2d)772 ! zx_tmp_fi2d(1:klon) = (zxfqfonte(1:klon) + rain_fall(1:klon))*pctsrf(1:klon, is_lic) 773 ! CALL histwrite_phy(o_mrroli, zx_tmp_fi2d) 742 774 CALL histwrite_phy(o_runofflic, zxrunofflic) 743 zx_tmp_fi2d = 0. 744 DO nsrf = 1, nbsrf 745 zx_tmp_fi2d(:) = zx_tmp_fi2d(:) + pctsrf(:, nsrf)*fluxu(:, 1, nsrf) 746 ENDDO 747 CALL histwrite_phy(o_taux, zx_tmp_fi2d) 748 749 zx_tmp_fi2d = 0. 750 DO nsrf = 1, nbsrf 751 zx_tmp_fi2d(:) = zx_tmp_fi2d(:) + pctsrf(:, nsrf)*fluxv(:, 1, nsrf) 752 ENDDO 753 CALL histwrite_phy(o_tauy, zx_tmp_fi2d) 775 ! zx_tmp_fi2d = 0. 776 ! DO nsrf = 1, nbsrf 777 ! zx_tmp_fi2d(:) = zx_tmp_fi2d(:) + pctsrf(:, nsrf)*fluxu(:, 1, nsrf) 778 ! ENDDO 779 ! CALL histwrite_phy(o_taux, zx_tmp_fi2d) 780 ! zx_tmp_fi2d = 0. 781 ! DO nsrf = 1, nbsrf 782 ! zx_tmp_fi2d(:) = zx_tmp_fi2d(:) + pctsrf(:, nsrf)*fluxv(:, 1, nsrf) 783 ! ENDDO 784 ! CALL histwrite_phy(o_tauy, zx_tmp_fi2d) 754 785 755 786 IF (ok_snow) THEN … … 764 795 765 796 DO nsrf = 1, nbsrf 766 zx_tmp_fi2d(1:klon) = pctsrf(1:klon, nsrf)*100. 767 CALL histwrite_phy(o_pourc_srf(nsrf), zx_tmp_fi2d) 768 zx_tmp_fi2d(1:klon) = pctsrf(1:klon, nsrf) 769 CALL histwrite_phy(o_fract_srf(nsrf), zx_tmp_fi2d) 770 zx_tmp_fi2d(1:klon) = fluxu(1:klon, 1, nsrf) 771 CALL histwrite_phy(o_taux_srf(nsrf), zx_tmp_fi2d) 772 zx_tmp_fi2d(1:klon) = fluxv(1:klon, 1, nsrf) 773 CALL histwrite_phy(o_tauy_srf(nsrf), zx_tmp_fi2d) 774 zx_tmp_fi2d(1:klon) = ftsol(1:klon, nsrf) 775 CALL histwrite_phy(o_tsol_srf(nsrf), zx_tmp_fi2d) 776 zx_tmp_fi2d(1:klon) = evap_pot(1:klon, nsrf) 777 CALL histwrite_phy(o_evappot_srf(nsrf), zx_tmp_fi2d) 778 zx_tmp_fi2d(1:klon) = ustar(1:klon, nsrf) 779 CALL histwrite_phy(o_ustar_srf(nsrf), zx_tmp_fi2d) 780 zx_tmp_fi2d(1:klon) = u10m(1:klon, nsrf) 781 CALL histwrite_phy(o_u10m_srf(nsrf), zx_tmp_fi2d) 782 zx_tmp_fi2d(1:klon) = v10m(1:klon, nsrf) 783 CALL histwrite_phy(o_v10m_srf(nsrf), zx_tmp_fi2d) 784 zx_tmp_fi2d(1:klon) = t2m(1:klon, nsrf) 785 CALL histwrite_phy(o_t2m_srf(nsrf), zx_tmp_fi2d) 786 zx_tmp_fi2d(1:klon) = fevap(1:klon, nsrf) 787 CALL histwrite_phy(o_evap_srf(nsrf), zx_tmp_fi2d) 788 zx_tmp_fi2d(1:klon) = fluxt(1:klon, 1, nsrf) 789 CALL histwrite_phy(o_sens_srf(nsrf), zx_tmp_fi2d) 790 zx_tmp_fi2d(1:klon) = fluxlat(1:klon, nsrf) 791 CALL histwrite_phy(o_lat_srf(nsrf), zx_tmp_fi2d) 792 zx_tmp_fi2d(1:klon) = fsollw(1:klon, nsrf) 793 CALL histwrite_phy(o_flw_srf(nsrf), zx_tmp_fi2d) 794 zx_tmp_fi2d(1:klon) = fsolsw(1:klon, nsrf) 795 CALL histwrite_phy(o_fsw_srf(nsrf), zx_tmp_fi2d) 796 zx_tmp_fi2d(1:klon) = wfbils(1:klon, nsrf) 797 CALL histwrite_phy(o_wbils_srf(nsrf), zx_tmp_fi2d) 798 zx_tmp_fi2d(1:klon) = wfbilo(1:klon, nsrf) 799 CALL histwrite_phy(o_wbilo_srf(nsrf), zx_tmp_fi2d) 800 zx_tmp_fi2d(1:klon) = wfevap(1:klon, nsrf) 801 CALL histwrite_phy(o_wevap_srf(nsrf), zx_tmp_fi2d) 802 zx_tmp_fi2d(1:klon) = wfrain(1:klon, nsrf) 803 CALL histwrite_phy(o_wrain_srf(nsrf), zx_tmp_fi2d) 804 zx_tmp_fi2d(1:klon) = wfsnow(1:klon, nsrf) 805 CALL histwrite_phy(o_wsnow_srf(nsrf), zx_tmp_fi2d) 797 ! zx_tmp_fi2d(1:klon) = pctsrf(1:klon, nsrf)*100. 798 ! CALL histwrite_phy(o_pourc_srf(nsrf), zx_tmp_fi2d) 799 CALL histwrite_phy(o_fract_srf(nsrf), pctsrf(1:klon, nsrf)) 800 CALL histwrite_phy(o_taux_srf(nsrf), fluxu(1:klon, 1, nsrf)) 801 CALL histwrite_phy(o_tauy_srf(nsrf), fluxv(1:klon, 1, nsrf)) 802 CALL histwrite_phy(o_tsol_srf(nsrf), ftsol(1:klon, nsrf)) 803 CALL histwrite_phy(o_evappot_srf(nsrf), evap_pot(1:klon, nsrf)) 804 CALL histwrite_phy(o_ustar_srf(nsrf), ustar(1:klon, nsrf)) 805 CALL histwrite_phy(o_u10m_srf(nsrf), u10m(1:klon, nsrf)) 806 CALL histwrite_phy(o_v10m_srf(nsrf), v10m(1:klon, nsrf)) 807 CALL histwrite_phy(o_t2m_srf(nsrf), t2m(1:klon, nsrf)) 808 CALL histwrite_phy(o_evap_srf(nsrf), fevap(1:klon, nsrf)) 809 CALL histwrite_phy(o_sens_srf(nsrf), fluxt(1:klon, 1, nsrf)) 810 CALL histwrite_phy(o_lat_srf(nsrf), fluxlat(1:klon, nsrf)) 811 CALL histwrite_phy(o_flw_srf(nsrf), fsollw(1:klon, nsrf)) 812 CALL histwrite_phy(o_fsw_srf(nsrf), fsolsw(1:klon, nsrf)) 813 CALL histwrite_phy(o_wbils_srf(nsrf), wfbils(1:klon, nsrf)) 814 CALL histwrite_phy(o_wbilo_srf(nsrf), wfbilo(1:klon, nsrf)) 815 CALL histwrite_phy(o_wevap_srf(nsrf), wfevap(1:klon, nsrf)) 816 CALL histwrite_phy(o_wrain_srf(nsrf), wfrain(1:klon, nsrf)) 817 CALL histwrite_phy(o_wsnow_srf(nsrf), wfsnow(1:klon, nsrf)) 806 818 807 819 IF (iflag_pbl > 1) THEN 808 820 CALL histwrite_phy(o_tke_srf(nsrf), pbl_tke(:, 1:klev, nsrf)) 809 821 CALL histwrite_phy(o_l_mixmin(nsrf), l_mixmin(:, 1:klev, nsrf)) 810 CALL histwrite_phy(o_tke_max_srf(nsrf), pbl_tke(:, 1:klev, nsrf))822 !CALL histwrite_phy(o_tke_max_srf(nsrf), pbl_tke(:, 1:klev, nsrf)) 811 823 ENDIF 812 824 IF (iflag_pbl > 1 .AND. iflag_wake >= 1 .AND. iflag_pbl_split >= 1) THEN … … 815 827 ENDDO 816 828 817 zx_tmp_fi2d(1:klon) = sens_prec_liq_o(1:klon, 1) 818 CALL histwrite_phy(o_sens_prec_liq_oce, zx_tmp_fi2d) 819 zx_tmp_fi2d(1:klon) = sens_prec_liq_o(1:klon, 2) 820 CALL histwrite_phy(o_sens_prec_liq_sic, zx_tmp_fi2d) 821 zx_tmp_fi2d(1:klon) = sens_prec_sol_o(1:klon, 1) 822 CALL histwrite_phy(o_sens_prec_sol_oce, zx_tmp_fi2d) 823 zx_tmp_fi2d(1:klon) = sens_prec_sol_o(1:klon, 2) 824 CALL histwrite_phy(o_sens_prec_sol_sic, zx_tmp_fi2d) 825 826 zx_tmp_fi2d(1:klon) = lat_prec_liq_o(1:klon, 1) 827 CALL histwrite_phy(o_lat_prec_liq_oce, zx_tmp_fi2d) 828 zx_tmp_fi2d(1:klon) = lat_prec_liq_o(1:klon, 2) 829 CALL histwrite_phy(o_lat_prec_liq_sic, zx_tmp_fi2d) 830 zx_tmp_fi2d(1:klon) = lat_prec_sol_o(1:klon, 1) 831 CALL histwrite_phy(o_lat_prec_sol_oce, zx_tmp_fi2d) 832 zx_tmp_fi2d(1:klon) = lat_prec_sol_o(1:klon, 2) 833 CALL histwrite_phy(o_lat_prec_sol_sic, zx_tmp_fi2d) 829 CALL histwrite_phy(o_sens_prec_liq_oce, sens_prec_liq_o(1:klon, 1)) 830 CALL histwrite_phy(o_sens_prec_liq_sic, sens_prec_liq_o(1:klon, 2)) 831 CALL histwrite_phy(o_sens_prec_sol_oce, sens_prec_sol_o(1:klon, 1)) 832 CALL histwrite_phy(o_sens_prec_sol_sic, sens_prec_sol_o(1:klon, 2)) 833 834 CALL histwrite_phy(o_lat_prec_liq_oce, lat_prec_liq_o(1:klon, 1)) 835 CALL histwrite_phy(o_lat_prec_liq_sic, lat_prec_liq_o(1:klon, 2)) 836 CALL histwrite_phy(o_lat_prec_sol_oce, lat_prec_sol_o(1:klon, 1)) 837 CALL histwrite_phy(o_lat_prec_sol_sic, lat_prec_sol_o(1:klon, 2)) 834 838 835 839 DO nsrf = 1, nbsrf + 1 … … 845 849 CALL histwrite_phy(o_JrNt, JrNt) 846 850 847 zx_tmp_fi2d = cldl*JrNt 848 CALL histwrite_phy(o_cldljn, zx_tmp_fi2d) 849 850 zx_tmp_fi2d = cldm*JrNt 851 CALL histwrite_phy(o_cldmjn, zx_tmp_fi2d) 852 853 zx_tmp_fi2d = cldh*JrNt 854 CALL histwrite_phy(o_cldhjn, zx_tmp_fi2d) 855 856 zx_tmp_fi2d = cldt*JrNt 857 CALL histwrite_phy(o_cldtjn, zx_tmp_fi2d) 851 ! zx_tmp_fi2d = cldl*JrNt 852 ! CALL histwrite_phy(o_cldljn, zx_tmp_fi2d) 853 ! zx_tmp_fi2d = cldm*JrNt 854 ! CALL histwrite_phy(o_cldmjn, zx_tmp_fi2d) 855 ! zx_tmp_fi2d = cldh*JrNt 856 ! CALL histwrite_phy(o_cldhjn, zx_tmp_fi2d) 857 ! zx_tmp_fi2d = cldt*JrNt 858 ! CALL histwrite_phy(o_cldtjn, zx_tmp_fi2d) 858 859 859 860 CALL histwrite_phy(o_cldq, cldq) 860 zx_tmp_fi2d(1:klon) = flwp(1:klon) 861 CALL histwrite_phy(o_lwp, zx_tmp_fi2d) 862 zx_tmp_fi2d(1:klon) = fiwp(1:klon) 863 CALL histwrite_phy(o_iwp, zx_tmp_fi2d) 861 CALL histwrite_phy(o_lwp, flwp(1:klon)) 862 CALL histwrite_phy(o_iwp, fiwp(1:klon)) 864 863 CALL histwrite_phy(o_ue, ue) 865 864 CALL histwrite_phy(o_ve, ve) … … 868 867 CALL histwrite_phy(o_uwat, uwat) 869 868 CALL histwrite_phy(o_vwat, vwat) 870 869 871 870 IF (iflag_con .GE. 3) THEN ! sb 872 871 CALL histwrite_phy(o_cape, cape) … … 881 880 ENDIF 882 881 883 CALL histwrite_phy(o_cape_max, cape)882 !CALL histwrite_phy(o_cape_max, cape) 884 883 885 884 CALL histwrite_phy(o_upwd, upwd) … … 891 890 !! convection (output of the 3 fields: ftime_deepcv, ftime_th and 892 891 !! ftime_con). 893 IF (iflag_thermals >= 1) THEN894 zx_tmp_fi3d = -dnwd + dnwd0 + upwd + fm_therm(:, 1:klev)895 ELSE896 zx_tmp_fi3d = -dnwd + dnwd0 + upwd897 ENDIF898 CALL histwrite_phy(o_mc, zx_tmp_fi3d)892 ! IF (iflag_thermals >= 1) THEN 893 ! zx_tmp_fi3d = -dnwd + dnwd0 + upwd + fm_therm(:, 1:klev) 894 ! ELSE 895 ! zx_tmp_fi3d = -dnwd + dnwd0 + upwd 896 ! ENDIF 897 ! CALL histwrite_phy(o_mc, zx_tmp_fi3d) 899 898 ENDIF !iflag_con .GE. 3 900 899 CALL histwrite_phy(o_prw, prw) … … 922 921 ENDIF !(bb2.EQ."850".OR.bb2.EQ."700".OR. 923 922 ENDDO 924 DO i = 1, klon 925 IF (pctsrf(i, is_oce) .GT. epsfra .OR. & 926 pctsrf(i, is_sic) .GT. epsfra) THEN 927 zx_tmp_fi2d(i) = (ftsol(i, is_oce)*pctsrf(i, is_oce) + & 928 ftsol(i, is_sic)*pctsrf(i, is_sic))/ & 929 (pctsrf(i, is_oce) + pctsrf(i, is_sic)) 930 ELSE 931 zx_tmp_fi2d(i) = 273.15 932 ENDIF 933 ENDDO 934 CALL histwrite_phy(o_t_oce_sic, zx_tmp_fi2d) 923 924 if( epsfra /= 1.0E-05 ) call abort_physic("phys_output_write_xios", "epsfra changed and is not synchronized with field_def_lmdz.xml", 1) 925 ! DO i = 1, klon 926 ! IF (pctsrf(i, is_oce) .GT. epsfra .OR. & 927 ! pctsrf(i, is_sic) .GT. epsfra) THEN 928 ! zx_tmp_fi2d(i) = (ftsol(i, is_oce)*pctsrf(i, is_oce) + & 929 ! ftsol(i, is_sic)*pctsrf(i, is_sic))/ & 930 ! (pctsrf(i, is_oce) + pctsrf(i, is_sic)) 931 ! ELSE 932 ! zx_tmp_fi2d(i) = 273.15 933 ! ENDIF 934 ! ENDDO 935 ! CALL histwrite_phy(o_t_oce_sic, zx_tmp_fi2d) 935 936 936 937 ! Couplage convection-couche limite … … 948 949 CALL histwrite_phy(o_alp_wk, alp_wake) 949 950 IF (iflag_pbl_split >= 1) THEN 950 zx_tmp_fi3d(1:klon, 1:klev) = d_t_vdf_x(1:klon, 1:klev)/pdtphys 951 CALL histwrite_phy(o_dtvdf_x, zx_tmp_fi3d) 952 zx_tmp_fi3d(1:klon, 1:klev) = d_t_vdf_w(1:klon, 1:klev)/pdtphys 953 CALL histwrite_phy(o_dtvdf_w, zx_tmp_fi3d) 954 zx_tmp_fi3d(1:klon, 1:klev) = d_q_vdf_x(1:klon, 1:klev)/pdtphys 955 CALL histwrite_phy(o_dqvdf_x, zx_tmp_fi3d) 956 zx_tmp_fi3d(1:klon, 1:klev) = d_q_vdf_w(1:klon, 1:klev)/pdtphys 957 CALL histwrite_phy(o_dqvdf_w, zx_tmp_fi3d) 951 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_vdf_x(1:klon, 1:klev)/pdtphys 952 ! CALL histwrite_phy(o_dtvdf_x, zx_tmp_fi3d) 953 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_vdf_w(1:klon, 1:klev)/pdtphys 954 ! CALL histwrite_phy(o_dtvdf_w, zx_tmp_fi3d) 955 ! zx_tmp_fi3d(1:klon, 1:klev) = d_q_vdf_x(1:klon, 1:klev)/pdtphys 956 ! CALL histwrite_phy(o_dqvdf_x, zx_tmp_fi3d) 957 ! zx_tmp_fi3d(1:klon, 1:klev) = d_q_vdf_w(1:klon, 1:klev)/pdtphys 958 ! CALL histwrite_phy(o_dqvdf_w, zx_tmp_fi3d) 959 CALL histwrite_phy(o_dtvdf_x, d_t_vdf_x(1:klon, 1:klev)) 960 CALL histwrite_phy(o_dtvdf_w, d_t_vdf_w(1:klon, 1:klev)) 961 CALL histwrite_phy(o_dqvdf_x, d_q_vdf_x(1:klon, 1:klev)) 962 CALL histwrite_phy(o_dqvdf_w, d_q_vdf_w(1:klon, 1:klev)) 963 958 964 CALL histwrite_phy(o_sens_x, sens_x) 959 965 CALL histwrite_phy(o_sens_w, sens_w) … … 980 986 CALL histwrite_phy(o_wake_deltaq, wake_deltaq) 981 987 CALL histwrite_phy(o_wake_omg, wake_omg) 982 zx_tmp_fi3d(1:klon, 1:klev) = d_t_wake(1:klon, 1:klev) & 983 /pdtphys 984 CALL histwrite_phy(o_dtwak, zx_tmp_fi3d) 988 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_wake(1:klon, 1:klev) & 989 ! /pdtphys 990 ! CALL histwrite_phy(o_dtwak, zx_tmp_fi3d) 991 ! zx_tmp_fi3d(1:klon, 1:klev) = d_q_wake(1:klon, 1:klev)/pdtphys 992 ! CALL histwrite_phy(o_dqwak, zx_tmp_fi3d) 993 CALL histwrite_phy(o_dtwak, d_t_wake(1:klon, 1:klev)) 994 CALL histwrite_phy(o_dqwak, d_q_wake(1:klon, 1:klev)) 985 995 zx_tmp_fi3d(1:klon, 1:klev) = d_q_wake(1:klon, 1:klev)/pdtphys 986 CALL histwrite_phy(o_dqwak, zx_tmp_fi3d)987 996 CALL water_int(klon, klev, zx_tmp_fi3d, zmasse, zx_tmp_fi2d) 988 997 CALL histwrite_phy(o_dqwak2d, zx_tmp_fi2d) … … 1021 1030 CALL histwrite_phy(o_slab_bils, slab_wfbils) 1022 1031 IF (nslay .EQ. 1) THEN 1023 zx_tmp_fi2d(:) = tslab(:, 1) 1024 CALL histwrite_phy(o_tslab, zx_tmp_fi2d) 1025 zx_tmp_fi2d(:) = dt_qflux(:, 1) 1026 CALL histwrite_phy(o_slab_qflux, zx_tmp_fi2d) 1032 CALL histwrite_phy(o_tslab, tslab(:, 1)) 1033 CALL histwrite_phy(o_slab_qflux, dt_qflux(:, 1)) 1027 1034 ELSE 1028 1035 CALL histwrite_phy(o_tslab, tslab(:, 1:nslay)) … … 1039 1046 IF (slab_hdiff) THEN 1040 1047 IF (nslay .EQ. 1) THEN 1041 zx_tmp_fi2d(:) = dt_hdiff(:, 1) 1042 CALL histwrite_phy(o_slab_hdiff, zx_tmp_fi2d) 1048 CALL histwrite_phy(o_slab_hdiff, dt_hdiff(:, 1)) 1043 1049 ELSE 1044 1050 CALL histwrite_phy(o_slab_hdiff, dt_hdiff(:, 1:nslay)) … … 1047 1053 IF (slab_ekman .GT. 0) THEN 1048 1054 IF (nslay .EQ. 1) THEN 1049 zx_tmp_fi2d(:) = dt_ekman(:, 1) 1050 CALL histwrite_phy(o_slab_ekman, zx_tmp_fi2d) 1055 CALL histwrite_phy(o_slab_ekman, dt_ekman(:, 1)) 1051 1056 ELSE 1052 1057 CALL histwrite_phy(o_slab_ekman, dt_ekman(:, 1:nslay)) … … 1064 1069 CALL histwrite_phy(o_re, re) 1065 1070 CALL histwrite_phy(o_fl, fl) 1066 DO i = 1, klon 1067 zx_tmp_fi2d(i) = MIN(100., rh2m(i)*100.) 1068 ENDDO 1069 CALL histwrite_phy(o_rh2m, zx_tmp_fi2d) 1071 ! DO i = 1, klon 1072 ! zx_tmp_fi2d(i) = MIN(100., rh2m(i)*100.) 1073 ! ENDDO 1074 ! CALL histwrite_phy(o_rh2m, zx_tmp_fi2d) 1075 CALL histwrite_phy(o_rh2m, rh2m) 1070 1076 CALL histwrite_phy(o_qsat2m, zqsat2m_cor) 1071 1077 CALL histwrite_phy(o_tpot, tpot) 1072 1078 CALL histwrite_phy(o_tpote, tpote) 1073 zx_tmp_fi2d(1:klon) = fsolsw(1:klon, is_ter) 1074 CALL histwrite_phy(o_SWnetOR, zx_tmp_fi2d) 1075 CALL histwrite_phy(o_LWdownOR, sollwdown) 1079 !CALL histwrite_phy(o_SWnetOR, fsolsw(1:klon, is_ter)) 1080 !CALL histwrite_phy(o_LWdownOR, sollwdown) 1076 1081 CALL histwrite_phy(o_snowl, snow_lsc) 1077 CALL histwrite_phy(o_solldown, sollwdown)1082 !CALL histwrite_phy(o_solldown, sollwdown) 1078 1083 CALL histwrite_phy(o_dtsvdfo, d_ts(:, is_oce)) 1079 1084 CALL histwrite_phy(o_dtsvdft, d_ts(:, is_ter)) … … 1141 1146 END DO 1142 1147 CALL histwrite_phy(o_col_O3_tropo, zx_tmp_fi2d) ! Added ThL 1148 CALL histwrite_phy(o_wo_1, wo(:,:,1)) 1143 1149 1144 1150 IF (ok_strataer .and. type_trac == 'coag') THEN … … 1182 1188 ENDDO 1183 1189 CALL histwrite_phy(o_heat_volc, zx_tmp_fi3d) 1184 DO k = 1, klev 1185 zx_tmp_fi3d(:, k) = cool_volc(:, k) 1186 ENDDO 1187 CALL histwrite_phy(o_cool_volc, zx_tmp_fi3d) 1190 ! DO k = 1, klev 1191 ! zx_tmp_fi3d(:, k) = cool_volc(:, k) 1192 ! ENDDO 1193 ! CALL histwrite_phy(o_cool_volc, zx_tmp_fi3d) 1194 CALL histwrite_phy(o_cool_volc, cool_volc) 1188 1195 ENDIF 1189 1196 IF (ok_ade) THEN 1190 zx_tmp_fi2d(:) = topswad_aero*swradcorr 1191 CALL histwrite_phy(o_topswad, zx_tmp_fi2d) 1192 1193 zx_tmp_fi2d(:) = topswad0_aero*swradcorr 1194 CALL histwrite_phy(o_topswad0, zx_tmp_fi2d) 1195 1196 zx_tmp_fi2d(:) = solswad_aero*swradcorr 1197 CALL histwrite_phy(o_solswad, zx_tmp_fi2d) 1198 1199 zx_tmp_fi2d(:) = solswad0_aero*swradcorr 1200 CALL histwrite_phy(o_solswad0, zx_tmp_fi2d) 1197 ! zx_tmp_fi2d(:) = topswad_aero*swradcorr 1198 ! CALL histwrite_phy(o_topswad, zx_tmp_fi2d) 1199 1200 ! zx_tmp_fi2d(:) = topswad0_aero*swradcorr 1201 ! CALL histwrite_phy(o_topswad0, zx_tmp_fi2d) 1202 1203 ! zx_tmp_fi2d(:) = solswad_aero*swradcorr 1204 ! CALL histwrite_phy(o_solswad, zx_tmp_fi2d) 1205 1206 ! zx_tmp_fi2d(:) = solswad0_aero*swradcorr 1207 ! CALL histwrite_phy(o_solswad0, zx_tmp_fi2d) 1208 1209 CALL histwrite_phy(o_topswad, topswad_aero) 1210 CALL histwrite_phy(o_topswad0, topswad0_aero) 1211 CALL histwrite_phy(o_solswad, solswad_aero) 1212 CALL histwrite_phy(o_solswad0, solswad0_aero) 1201 1213 1202 1214 CALL histwrite_phy(o_toplwad, toplwad_aero) … … 1208 1220 !ym => init to 0 in radlwsw_m.F90 ztopsw_aero, zsolsw_aero, ztopsw0_aero, zsolsw0_aero 1209 1221 1210 zx_tmp_fi2d(:) = topsw_aero(:, 1)*swradcorr(:) 1211 CALL histwrite_phy(o_swtoaas_nat, zx_tmp_fi2d) 1212 zx_tmp_fi2d(:) = solsw_aero(:, 1)*swradcorr(:) 1213 CALL histwrite_phy(o_swsrfas_nat, zx_tmp_fi2d) 1214 zx_tmp_fi2d(:) = topsw0_aero(:, 1)*swradcorr(:) 1215 CALL histwrite_phy(o_swtoacs_nat, zx_tmp_fi2d) 1216 zx_tmp_fi2d(:) = solsw0_aero(:, 1)*swradcorr(:) 1217 CALL histwrite_phy(o_swsrfcs_nat, zx_tmp_fi2d) 1222 ! zx_tmp_fi2d(:) = topsw_aero(:, 1)*swradcorr(:) 1223 ! CALL histwrite_phy(o_swtoaas_nat, zx_tmp_fi2d) 1224 ! zx_tmp_fi2d(:) = solsw_aero(:, 1)*swradcorr(:) 1225 ! CALL histwrite_phy(o_swsrfas_nat, zx_tmp_fi2d) 1226 ! zx_tmp_fi2d(:) = topsw0_aero(:, 1)*swradcorr(:) 1227 ! CALL histwrite_phy(o_swtoacs_nat, zx_tmp_fi2d) 1228 ! zx_tmp_fi2d(:) = solsw0_aero(:, 1)*swradcorr(:) 1229 ! CALL histwrite_phy(o_swsrfcs_nat, zx_tmp_fi2d) 1230 ! !ant 1231 ! zx_tmp_fi2d(:) = topsw_aero(:, 2)*swradcorr(:) 1232 ! CALL histwrite_phy(o_swtoaas_ant, zx_tmp_fi2d) 1233 ! zx_tmp_fi2d(:) = solsw_aero(:, 2)*swradcorr(:) 1234 ! CALL histwrite_phy(o_swsrfas_ant, zx_tmp_fi2d) 1235 ! zx_tmp_fi2d(:) = topsw0_aero(:, 2)*swradcorr(:) 1236 ! CALL histwrite_phy(o_swtoacs_ant, zx_tmp_fi2d) 1237 ! zx_tmp_fi2d(:) = solsw0_aero(:, 2)*swradcorr(:) 1238 ! CALL histwrite_phy(o_swsrfcs_ant, zx_tmp_fi2d) 1239 1240 CALL histwrite_phy(o_swtoaas_nat, topsw_aero(:, 1)) 1241 CALL histwrite_phy(o_swsrfas_nat, solsw_aero(:, 1)) 1242 CALL histwrite_phy(o_swtoacs_nat, topsw0_aero(:, 1)) 1243 CALL histwrite_phy(o_swsrfcs_nat, solsw0_aero(:, 1)) 1218 1244 !ant 1219 zx_tmp_fi2d(:) = topsw_aero(:, 2)*swradcorr(:) 1220 CALL histwrite_phy(o_swtoaas_ant, zx_tmp_fi2d) 1221 zx_tmp_fi2d(:) = solsw_aero(:, 2)*swradcorr(:) 1222 CALL histwrite_phy(o_swsrfas_ant, zx_tmp_fi2d) 1223 zx_tmp_fi2d(:) = topsw0_aero(:, 2)*swradcorr(:) 1224 CALL histwrite_phy(o_swtoacs_ant, zx_tmp_fi2d) 1225 zx_tmp_fi2d(:) = solsw0_aero(:, 2)*swradcorr(:) 1226 CALL histwrite_phy(o_swsrfcs_ant, zx_tmp_fi2d) 1245 CALL histwrite_phy(o_swtoaas_ant, topsw_aero(:, 2)) 1246 CALL histwrite_phy(o_swsrfas_ant, solsw_aero(:, 2)) 1247 CALL histwrite_phy(o_swtoacs_ant, topsw0_aero(:, 2)) 1248 CALL histwrite_phy(o_swsrfcs_ant, solsw0_aero(:, 2)) 1227 1249 !cf 1228 1250 IF (.not. aerosol_couple) THEN 1229 zx_tmp_fi2d(:) = topswcf_aero(:, 1)*swradcorr(:) 1230 CALL histwrite_phy(o_swtoacf_nat, zx_tmp_fi2d) 1231 zx_tmp_fi2d(:) = solswcf_aero(:, 1)*swradcorr(:) 1232 CALL histwrite_phy(o_swsrfcf_nat, zx_tmp_fi2d) 1233 zx_tmp_fi2d(:) = topswcf_aero(:, 2)*swradcorr(:) 1234 CALL histwrite_phy(o_swtoacf_ant, zx_tmp_fi2d) 1235 zx_tmp_fi2d(:) = solswcf_aero(:, 2)*swradcorr(:) 1236 CALL histwrite_phy(o_swsrfcf_ant, zx_tmp_fi2d) 1237 zx_tmp_fi2d(:) = topswcf_aero(:, 3)*swradcorr(:) 1238 CALL histwrite_phy(o_swtoacf_zero, zx_tmp_fi2d) 1239 zx_tmp_fi2d(:) = solswcf_aero(:, 3)*swradcorr(:) 1240 CALL histwrite_phy(o_swsrfcf_zero, zx_tmp_fi2d) 1251 ! zx_tmp_fi2d(:) = topswcf_aero(:, 1)*swradcorr(:) 1252 ! CALL histwrite_phy(o_swtoacf_nat, zx_tmp_fi2d) 1253 ! zx_tmp_fi2d(:) = solswcf_aero(:, 1)*swradcorr(:) 1254 ! CALL histwrite_phy(o_swsrfcf_nat, zx_tmp_fi2d) 1255 ! zx_tmp_fi2d(:) = topswcf_aero(:, 2)*swradcorr(:) 1256 ! CALL histwrite_phy(o_swtoacf_ant, zx_tmp_fi2d) 1257 ! zx_tmp_fi2d(:) = solswcf_aero(:, 2)*swradcorr(:) 1258 ! CALL histwrite_phy(o_swsrfcf_ant, zx_tmp_fi2d) 1259 ! zx_tmp_fi2d(:) = topswcf_aero(:, 3)*swradcorr(:) 1260 ! CALL histwrite_phy(o_swtoacf_zero, zx_tmp_fi2d) 1261 ! zx_tmp_fi2d(:) = solswcf_aero(:, 3)*swradcorr(:) 1262 ! CALL histwrite_phy(o_swsrfcf_zero, zx_tmp_fi2d) 1263 1264 CALL histwrite_phy(o_swtoacf_nat, topswcf_aero(:, 1)) 1265 CALL histwrite_phy(o_swsrfcf_nat, solswcf_aero(:, 1)) 1266 CALL histwrite_phy(o_swtoacf_ant, topswcf_aero(:, 2)) 1267 CALL histwrite_phy(o_swsrfcf_ant, solswcf_aero(:, 2)) 1268 CALL histwrite_phy(o_swtoacf_zero, topswcf_aero(:, 3)) 1269 CALL histwrite_phy(o_swsrfcf_zero, solswcf_aero(:, 3)) 1241 1270 ENDIF 1242 1271 !====MS forcing diagnostics 1243 1272 ENDIF 1244 1273 IF (ok_aie) THEN 1245 zx_tmp_fi2d(:) = topswai_aero*swradcorr 1246 CALL histwrite_phy(o_topswai, zx_tmp_fi2d) 1247 1248 zx_tmp_fi2d(:) = toplwai_aero*swradcorr 1249 CALL histwrite_phy(o_toplwai, zx_tmp_fi2d) 1250 1251 zx_tmp_fi2d(:) = solswai_aero*swradcorr 1252 CALL histwrite_phy(o_solswai, zx_tmp_fi2d) 1253 1254 zx_tmp_fi2d(:) = sollwai_aero*swradcorr 1255 CALL histwrite_phy(o_sollwai, zx_tmp_fi2d) 1274 CALL histwrite_phy(o_topswai, topswai_aero) 1275 CALL histwrite_phy(o_toplwai, toplwai_aero) 1276 CALL histwrite_phy(o_solswai, solswai_aero) 1277 CALL histwrite_phy(o_sollwai, sollwai_aero) 1256 1278 ENDIF 1257 1279 IF (flag_aerosol .GT. 0 .AND. ok_cdnc) THEN … … 1268 1290 CALL histwrite_phy(o_icc3dstra, icc3dstra) 1269 1291 CALL histwrite_phy(o_cldicemxrat, zfice) 1270 zx_tmp_fi3d(:, :) = 1 - zfice(:, :) 1271 CALL histwrite_phy(o_cldwatmxrat, zx_tmp_fi3d) 1292 ! zx_tmp_fi3d(:, :) = 1 - zfice(:, :) 1293 ! CALL histwrite_phy(o_cldwatmxrat, zx_tmp_fi3d) 1294 CALL histwrite_phy(o_cldwatmxrat, zfice) 1272 1295 CALL histwrite_phy(o_reffclwtop, reffclwtop) 1273 1296 ENDIF … … 1284 1307 CALL histwrite_phy(o_oliq, ql_seri) 1285 1308 1286 zx_tmp_fi3d = ql_seri + qs_seri 1287 CALL histwrite_phy(o_ocond, zx_tmp_fi3d) 1309 ! zx_tmp_fi3d = ql_seri + qs_seri 1310 ! CALL histwrite_phy(o_ocond, zx_tmp_fi3d) 1311 CALL histwrite_phy(o_ocond, qs_seri) 1288 1312 1289 1313 CALL histwrite_phy(o_geop, zphi) … … 1294 1318 CALL histwrite_phy(o_paprs, paprs(:, 1:klev)) 1295 1319 1296 zx_tmp_fi3d = zphi/RG1297 CALL histwrite_phy(o_zfull, zx_tmp_fi3d)1320 ! zx_tmp_fi3d = zphi/RG 1321 ! CALL histwrite_phy(o_zfull, zx_tmp_fi3d) 1298 1322 1299 1323 IF (ok_rrtm .and. iflag_rrtm .EQ. 1) THEN … … 1304 1328 ENDIF 1305 1329 1306 IF (flag_aerosol_strat .EQ. 2) THEN1330 !IF (flag_aerosol_strat .EQ. 2) THEN 1307 1331 CALL histwrite_phy(o_stratomask, stratomask) 1308 ENDIF1332 !ENDIF 1309 1333 1310 1334 zx_tmp_fi3d(:, 1) = pphis(:)/RG … … 1329 1353 CALL histwrite_phy(o_rhum, zx_rh) 1330 1354 1331 zx_tmp_fi3d = wo(:, :, 1)*dobson_u*1e3/zmasse/rmo3*rmd 1332 CALL histwrite_phy(o_ozone, zx_tmp_fi3d) 1355 1356 ! zx_tmp_fi3d = wo(:, :, 1)*dobson_u*1e3/zmasse/rmo3*rmd 1357 ! CALL histwrite_phy(o_ozone, zx_tmp_fi3d) ! o_wo_1*dobson_u*1e3/o_mass/rmo3*rmd 1333 1358 1334 1359 IF (read_climoz == 2) THEN 1335 zx_tmp_fi3d = wo(:, :, 2)*dobson_u*1e3/zmasse/rmo3*rmd 1336 CALL histwrite_phy(o_ozone_light, zx_tmp_fi3d) 1360 ! zx_tmp_fi3d = wo(:, :, 2)*dobson_u*1e3/zmasse/rmo3*rmd 1361 ! CALL histwrite_phy(o_ozone_light, zx_tmp_fi3d) 1362 CALL histwrite_phy(o_ozone_light, wo(:, :, 2)) 1337 1363 ENDIF 1338 1364 … … 1361 1387 1362 1388 DO nsrf = 1, nbsrf 1363 zx_tmp_fi2d(1:klon) = falb1(1:klon, nsrf) 1364 CALL histwrite_phy(o_albe_srf(nsrf), zx_tmp_fi2d) 1365 zx_tmp_fi2d(1:klon) = z0m(1:klon, nsrf) 1366 CALL histwrite_phy(o_z0m_srf(nsrf), zx_tmp_fi2d) 1367 zx_tmp_fi2d(1:klon) = z0h(1:klon, nsrf) 1368 CALL histwrite_phy(o_z0h_srf(nsrf), zx_tmp_fi2d) 1369 zx_tmp_fi2d(1:klon) = agesno(1:klon, nsrf) 1370 CALL histwrite_phy(o_ages_srf(nsrf), zx_tmp_fi2d) 1371 zx_tmp_fi2d(1:klon) = snow(1:klon, nsrf) 1372 CALL histwrite_phy(o_snow_srf(nsrf), zx_tmp_fi2d) 1389 CALL histwrite_phy(o_albe_srf(nsrf), falb1(1:klon, nsrf)) 1390 CALL histwrite_phy(o_z0m_srf(nsrf), z0m(1:klon, nsrf)) 1391 CALL histwrite_phy(o_z0h_srf(nsrf), z0h(1:klon, nsrf)) 1392 CALL histwrite_phy(o_ages_srf(nsrf), agesno(1:klon, nsrf)) 1393 CALL histwrite_phy(o_snow_srf(nsrf), snow(1:klon, nsrf)) 1373 1394 ENDDO !nsrf=1, nbsrf 1374 1395 CALL histwrite_phy(o_alb1, albsol1) … … 1383 1404 ENDDO 1384 1405 ENDDO 1385 CALL histwrite_phy(o_tke, zx_tmp_fi3d) 1386 1387 CALL histwrite_phy(o_tke_max, zx_tmp_fi3d) 1406 ! reduce( sum(nsrf[1,4], o_fract_srf(nsrf)(:) * o_tke_srf(nsrf)(:,:)) ) 1407 ! == sum( o_fract_srf(nsrf)(:) * reduce(o_tke_srf(nsrf)(:,:)) ) 1408 CALL histwrite_phy(o_tke, zx_tmp_fi3d) 1409 !CALL histwrite_phy(o_tke_max, zx_tmp_fi3d) 1388 1410 ENDIF 1389 1411 1390 1412 CALL histwrite_phy(o_kz, coefh(:, :, is_ave)) 1391 1413 1392 CALL histwrite_phy(o_kz_max, coefh(:, :, is_ave))1414 !CALL histwrite_phy(o_kz_max, coefh(:, :, is_ave)) 1393 1415 1394 1416 CALL histwrite_phy(o_clwcon, clwcon0) … … 1410 1432 CALL histwrite_phy(o_dvdyn, d_v_dyn) 1411 1433 1412 zx_tmp_fi3d(1:klon, 1:klev) = d_t_con(1:klon, 1:klev)/pdtphys 1413 CALL histwrite_phy(o_dtcon, zx_tmp_fi3d) 1434 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_con(1:klon, 1:klev)/pdtphys 1435 ! CALL histwrite_phy(o_dtcon, zx_tmp_fi3d) 1436 CALL histwrite_phy(o_dtcon, d_t_con(:, 1:klev)) 1437 1414 1438 IF (iflag_thermals .EQ. 0) THEN 1415 1439 zx_tmp_fi3d(1:klon, 1:klev) = d_t_con(1:klon, 1:klev)/pdtphys + & 1416 1440 d_t_ajsb(1:klon, 1:klev)/pdtphys 1417 CALL histwrite_phy(o_tntc, zx_tmp_fi3d) 1441 CALL histwrite_phy(o_tntc, zx_tmp_fi3d) ! o_tntc = dtcon + o_dtthe 1418 1442 ELSE IF (iflag_thermals .GE. 1 .AND. iflag_wake .EQ. 1) THEN 1419 1443 zx_tmp_fi3d(1:klon, 1:klev) = d_t_con(1:klon, 1:klev)/pdtphys + & 1420 1444 d_t_ajs(1:klon, 1:klev)/pdtphys + & 1421 1445 d_t_wake(1:klon, 1:klev)/pdtphys 1422 CALL histwrite_phy(o_tntc, zx_tmp_fi3d) 1423 ENDIF 1424 zx_tmp_fi3d(1:klon, 1:klev) = d_u_con(1:klon, 1:klev)/pdtphys 1425 CALL histwrite_phy(o_ducon, zx_tmp_fi3d) 1426 zx_tmp_fi3d(1:klon, 1:klev) = d_v_con(1:klon, 1:klev)/pdtphys 1427 CALL histwrite_phy(o_dvcon, zx_tmp_fi3d) 1446 CALL histwrite_phy(o_tntc, zx_tmp_fi3d) ! o_tntc = dtcon + ? + o_dtwak 1447 ENDIF 1448 ! zx_tmp_fi3d(1:klon, 1:klev) = d_u_con(1:klon, 1:klev)/pdtphys 1449 ! CALL histwrite_phy(o_ducon, zx_tmp_fi3d) 1450 ! zx_tmp_fi3d(1:klon, 1:klev) = d_v_con(1:klon, 1:klev)/pdtphys 1451 ! CALL histwrite_phy(o_dvcon, zx_tmp_fi3d) 1452 ! zx_tmp_fi3d(1:klon, 1:klev) = d_q_con(1:klon, 1:klev)/pdtphys 1453 ! CALL histwrite_phy(o_dqcon, zx_tmp_fi3d) 1454 CALL histwrite_phy(o_ducon, d_u_con(1:klon, 1:klev)) 1455 CALL histwrite_phy(o_dvcon, d_v_con(1:klon, 1:klev)) 1456 CALL histwrite_phy(o_dqcon, d_q_con(1:klon, 1:klev)) 1457 1428 1458 zx_tmp_fi3d(1:klon, 1:klev) = d_q_con(1:klon, 1:klev)/pdtphys 1429 CALL histwrite_phy(o_dqcon, zx_tmp_fi3d)1430 1459 CALL water_int(klon, klev, zx_tmp_fi3d, zmasse, zx_tmp_fi2d) 1431 1460 CALL histwrite_phy(o_dqcon2d, zx_tmp_fi2d) 1432 1461 1433 1462 IF (iflag_thermals .EQ. 0) THEN 1434 zx_tmp_fi3d(1:klon, 1:klev) = d_q_con(1:klon, 1:klev)/pdtphys 1435 CALL histwrite_phy(o_tnhusc, zx_tmp_fi3d) 1463 ! zx_tmp_fi3d(1:klon, 1:klev) = d_q_con(1:klon, 1:klev)/pdtphys 1464 ! CALL histwrite_phy(o_tnhusc, d_q_con) 1465 CALL histwrite_phy(o_tnhusc, d_q_con(1:klon, 1:klev)) 1436 1466 ELSE IF (iflag_thermals .GE. 1 .AND. iflag_wake .EQ. 1) THEN 1437 1467 zx_tmp_fi3d(1:klon, 1:klev) = d_q_con(1:klon, 1:klev)/pdtphys + & … … 1455 1485 ! Sorties specifiques a la separation thermiques/non thermiques 1456 1486 IF (iflag_thermals >= 1) THEN 1457 zx_tmp_fi3d(1:klon, 1:klev) = d_t_lscth(1:klon, 1:klev)/pdtphys 1458 CALL histwrite_phy(o_dtlscth, zx_tmp_fi3d) 1459 zx_tmp_fi3d(1:klon, 1:klev) = d_t_lscst(1:klon, 1:klev)/pdtphys 1460 CALL histwrite_phy(o_dtlscst, zx_tmp_fi3d) 1487 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_lscth(1:klon, 1:klev)/pdtphys 1488 ! CALL histwrite_phy(o_dtlscth, zx_tmp_fi3d) 1489 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_lscst(1:klon, 1:klev)/pdtphys 1490 ! CALL histwrite_phy(o_dtlscst, zx_tmp_fi3d) 1491 ! zx_tmp_fi3d(1:klon, 1:klev) = d_q_lscth(1:klon, 1:klev)/pdtphys 1492 ! CALL histwrite_phy(o_dqlscth, zx_tmp_fi3d) 1493 ! zx_tmp_fi3d(1:klon, 1:klev) = d_q_lscst(1:klon, 1:klev)/pdtphys 1494 ! CALL histwrite_phy(o_dqlscst, zx_tmp_fi3d) 1495 1496 CALL histwrite_phy(o_dtlscth, d_t_lscth(1:klon, 1:klev)) 1497 CALL histwrite_phy(o_dtlscst, d_t_lscst(1:klon, 1:klev)) 1498 CALL histwrite_phy(o_dqlscth, d_q_lscth(1:klon, 1:klev)) 1499 CALL histwrite_phy(o_dqlscst, d_q_lscst(1:klon, 1:klev)) 1500 1461 1501 zx_tmp_fi3d(1:klon, 1:klev) = d_q_lscth(1:klon, 1:klev)/pdtphys 1462 CALL histwrite_phy(o_dqlscth, zx_tmp_fi3d)1463 1502 CALL water_int(klon, klev, zx_tmp_fi3d, zmasse, zx_tmp_fi2d) 1464 CALL histwrite_phy(o_dqlscth2d, zx_tmp_fi2d) 1503 CALL histwrite_phy(o_dqlscth2d, zx_tmp_fi2d) 1465 1504 zx_tmp_fi3d(1:klon, 1:klev) = d_q_lscst(1:klon, 1:klev)/pdtphys 1466 CALL histwrite_phy(o_dqlscst, zx_tmp_fi3d)1467 1505 CALL water_int(klon, klev, zx_tmp_fi3d, zmasse, zx_tmp_fi2d) 1468 1506 CALL histwrite_phy(o_dqlscst2d, zx_tmp_fi2d) 1469 1507 CALL histwrite_phy(o_plulth, plul_th) 1470 1508 CALL histwrite_phy(o_plulst, plul_st) 1471 DO i = 1, klon 1472 zx_tmp_fi2d(1:klon) = lmax_th(:) 1473 ENDDO 1509 zx_tmp_fi2d(:) = lmax_th(1:klon) ! Cast from int to real 1474 1510 CALL histwrite_phy(o_lmaxth, zx_tmp_fi2d) 1475 DO k = 1, klev 1476 DO i = 1, klon 1477 IF (ptconvth(i, k)) THEN 1478 zx_tmp_fi3d(i, k) = 1. 1479 ELSE 1480 zx_tmp_fi3d(i, k) = 0. 1481 ENDIF 1482 ENDDO 1483 ENDDO 1511 ! DO k = 1, klev 1512 ! DO i = 1, klon 1513 ! IF (ptconvth(i, k)) THEN 1514 ! zx_tmp_fi3d(i, k) = 1. 1515 ! ELSE 1516 ! zx_tmp_fi3d(i, k) = 0. 1517 ! ENDIF 1518 ! ENDDO 1519 ! ENDDO 1520 ! CALL histwrite_phy(o_ptconvth, zx_tmp_fi3d) 1521 zx_tmp_fi3d(:,:) = MERGE(1., 0., ptconvth(:,:)) ! Cast from logical to real 1484 1522 CALL histwrite_phy(o_ptconvth, zx_tmp_fi3d) 1485 1523 ENDIF ! iflag_thermals>=1 1486 1524 1487 zpt_conv = 0. 1488 WHERE (ptconv) zpt_conv = 1. 1525 zpt_conv(:,:) = MERGE(1., 0., ptconv(:,:)) 1489 1526 CALL histwrite_phy(o_ptconv, zpt_conv) 1490 1527 zpt_conv2d(:) = 0. … … 1498 1535 ENDDO 1499 1536 CALL histwrite_phy(o_ftime_th, zx_tmp_fi2d) 1500 zx_tmp_fi2d(:) = max(zx_tmp_fi2d(:), zpt_conv2d(:))1501 CALL histwrite_phy(o_ftime_con, zx_tmp_fi2d)1537 ! zx_tmp_fi2d(:) = max(zx_tmp_fi2d(:), zpt_conv2d(:)) 1538 ! CALL histwrite_phy(o_ftime_con, zx_tmp_fi2d) 1502 1539 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 1503 zx_tmp_fi3d(1:klon, 1:klev) = d_t_vdf(1:klon, 1:klev)/pdtphys 1504 CALL histwrite_phy(o_dtvdf, zx_tmp_fi3d) 1505 zx_tmp_fi3d(1:klon, 1:klev) = d_t_diss(1:klon, 1:klev)/pdtphys 1506 CALL histwrite_phy(o_dtdis, zx_tmp_fi3d) 1540 CALL histwrite_phy(o_dtvdf, d_t_vdf(1:klon, 1:klev)) 1541 CALL histwrite_phy(o_dtdis, d_t_diss(1:klon, 1:klev)) 1542 CALL histwrite_phy(o_dqvdf, d_q_vdf(1:klon, 1:klev)) 1543 CALL histwrite_phy(o_dteva, d_t_eva(1:klon, 1:klev)) 1544 CALL histwrite_phy(o_dqeva, d_q_eva(1:klon, 1:klev)) 1545 CALL histwrite_phy(o_duthe, d_u_ajs(1:klon, 1:klev)) 1546 CALL histwrite_phy(o_dvthe, d_v_ajs(1:klon, 1:klev)) 1547 1507 1548 zx_tmp_fi3d(1:klon, 1:klev) = d_q_vdf(1:klon, 1:klev)/pdtphys 1508 CALL histwrite_phy(o_dqvdf, zx_tmp_fi3d)1509 1549 CALL water_int(klon, klev, zx_tmp_fi3d, zmasse, zx_tmp_fi2d) 1510 1550 CALL histwrite_phy(o_dqvdf2d, zx_tmp_fi2d) 1511 zx_tmp_fi3d(1:klon, 1:klev) = d_t_eva(1:klon, 1:klev)/pdtphys1512 CALL histwrite_phy(o_dteva, zx_tmp_fi3d)1513 1551 zx_tmp_fi3d(1:klon, 1:klev) = d_q_eva(1:klon, 1:klev)/pdtphys 1514 CALL histwrite_phy(o_dqeva, zx_tmp_fi3d)1515 1552 CALL water_int(klon, klev, zx_tmp_fi3d, zmasse, zx_tmp_fi2d) 1516 1553 CALL histwrite_phy(o_dqeva2d, zx_tmp_fi2d) 1554 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_ajs(1:klon, 1:klev)/pdtphys - & 1555 ! d_t_ajsb(1:klon, 1:klev)/pdtphys 1556 ! CALL histwrite_phy(o_dtthe, zx_tmp_fi3d) ! d_t_ajs(1:klon, 1:klev)/pdtphys + o_dtajs 1557 CALL histwrite_phy(o_dtthe, d_t_ajs(1:klon, 1:klev)) 1517 1558 CALL histwrite_phy(o_ratqs, ratqs) 1518 zx_tmp_fi3d(1:klon, 1:klev) = d_t_ajs(1:klon, 1:klev)/pdtphys - & 1519 d_t_ajsb(1:klon, 1:klev)/pdtphys 1520 CALL histwrite_phy(o_dtthe, zx_tmp_fi3d) 1521 zx_tmp_fi3d(1:klon, 1:klev) = d_u_ajs(1:klon, 1:klev)/pdtphys 1522 CALL histwrite_phy(o_duthe, zx_tmp_fi3d) 1523 zx_tmp_fi3d(1:klon, 1:klev) = d_v_ajs(1:klon, 1:klev)/pdtphys 1524 CALL histwrite_phy(o_dvthe, zx_tmp_fi3d) 1559 1525 1560 1526 1561 IF (iflag_thermals >= 1) THEN … … 1546 1581 CALL water_int(klon, klev, zx_tmp_fi3d, zmasse, zx_tmp_fi2d) 1547 1582 CALL histwrite_phy(o_dqthe2d, zx_tmp_fi2d) 1583 ELSE 1584 zx_tmp_fi2d(:) = 0 1585 CALL histwrite_phy(o_f_th, zx_tmp_fi2d) 1548 1586 ENDIF !iflag_thermals 1549 zx_tmp_fi3d(1:klon, 1:klev) = d_t_ajsb(1:klon, 1:klev)/pdtphys1550 CALL histwrite_phy(o_dtajs, zx_tmp_fi3d)1551 1587 zx_tmp_fi3d(1:klon, 1:klev) = d_q_ajsb(1:klon, 1:klev)/pdtphys 1552 CALL histwrite_phy(o_dqajs, zx_tmp_fi3d)1553 1588 CALL water_int(klon, klev, zx_tmp_fi3d, zmasse, zx_tmp_fi2d) 1554 1589 CALL histwrite_phy(o_dqajs2d, zx_tmp_fi2d) 1555 zx_tmp_fi3d(1:klon, 1:klev) = d_t_swr(1:klon, 1:klev)/pdtphys 1556 CALL histwrite_phy(o_dtswr, zx_tmp_fi3d) 1557 zx_tmp_fi3d(1:klon, 1:klev) = d_t_sw0(1:klon, 1:klev)/pdtphys 1558 CALL histwrite_phy(o_dtsw0, zx_tmp_fi3d) 1559 zx_tmp_fi3d(1:klon, 1:klev) = d_t_lwr(1:klon, 1:klev)/pdtphys 1560 CALL histwrite_phy(o_dtlwr, zx_tmp_fi3d) 1561 zx_tmp_fi3d(1:klon, 1:klev) = d_t_lw0(1:klon, 1:klev)/pdtphys 1562 CALL histwrite_phy(o_dtlw0, zx_tmp_fi3d) 1563 zx_tmp_fi3d(1:klon, 1:klev) = d_t_ec(1:klon, 1:klev)/pdtphys 1564 CALL histwrite_phy(o_dtec, zx_tmp_fi3d) 1565 zx_tmp_fi3d(1:klon, 1:klev) = d_u_vdf(1:klon, 1:klev)/pdtphys 1566 CALL histwrite_phy(o_duvdf, zx_tmp_fi3d) 1567 zx_tmp_fi3d(1:klon, 1:klev) = d_v_vdf(1:klon, 1:klev)/pdtphys 1568 CALL histwrite_phy(o_dvvdf, zx_tmp_fi3d) 1590 1591 CALL histwrite_phy(o_dtajs, d_t_ajsb(1:klon, 1:klev)) 1592 CALL histwrite_phy(o_dqajs, d_q_ajsb(1:klon, 1:klev)) 1593 CALL histwrite_phy(o_dtswr, d_t_swr(1:klon, 1:klev)) 1594 CALL histwrite_phy(o_dtsw0, d_t_sw0(1:klon, 1:klev)) 1595 CALL histwrite_phy(o_dtlwr, d_t_lwr(1:klon, 1:klev)) 1596 CALL histwrite_phy(o_dtlw0, d_t_lw0(1:klon, 1:klev)) 1597 CALL histwrite_phy(o_dtec, d_t_ec(1:klon, 1:klev)) 1598 CALL histwrite_phy(o_duvdf, d_u_vdf(1:klon, 1:klev)) 1599 CALL histwrite_phy(o_dvvdf, d_v_vdf(1:klon, 1:klev)) 1600 1569 1601 IF (ok_orodr) THEN 1570 zx_tmp_fi3d(1:klon, 1:klev) = d_u_oro(1:klon, 1:klev)/pdtphys 1571 CALL histwrite_phy(o_duoro, zx_tmp_fi3d) 1572 zx_tmp_fi3d(1:klon, 1:klev) = d_v_oro(1:klon, 1:klev)/pdtphys 1573 CALL histwrite_phy(o_dvoro, zx_tmp_fi3d) 1574 zx_tmp_fi3d(1:klon, 1:klev) = d_t_oro(1:klon, 1:klev)/pdtphys 1575 CALL histwrite_phy(o_dtoro, zx_tmp_fi3d) 1602 ! zx_tmp_fi3d(1:klon, 1:klev) = d_u_oro(1:klon, 1:klev)/pdtphys 1603 ! CALL histwrite_phy(o_duoro, zx_tmp_fi3d) 1604 ! zx_tmp_fi3d(1:klon, 1:klev) = d_v_oro(1:klon, 1:klev)/pdtphys 1605 ! CALL histwrite_phy(o_dvoro, zx_tmp_fi3d) 1606 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_oro(1:klon, 1:klev)/pdtphys 1607 ! CALL histwrite_phy(o_dtoro, zx_tmp_fi3d) 1608 1609 CALL histwrite_phy(o_duoro, d_u_oro(1:klon, 1:klev)) 1610 CALL histwrite_phy(o_dvoro, d_v_oro(1:klon, 1:klev)) 1611 CALL histwrite_phy(o_dtoro, d_t_oro(1:klon, 1:klev)) 1576 1612 ENDIF 1577 1613 IF (ok_orolf) THEN 1578 zx_tmp_fi3d(1:klon, 1:klev) = d_u_lif(1:klon, 1:klev)/pdtphys 1579 CALL histwrite_phy(o_dulif, zx_tmp_fi3d) 1580 1581 zx_tmp_fi3d(1:klon, 1:klev) = d_v_lif(1:klon, 1:klev)/pdtphys 1582 CALL histwrite_phy(o_dvlif, zx_tmp_fi3d) 1583 1584 zx_tmp_fi3d(1:klon, 1:klev) = d_t_lif(1:klon, 1:klev)/pdtphys 1585 CALL histwrite_phy(o_dtlif, zx_tmp_fi3d) 1614 ! zx_tmp_fi3d(1:klon, 1:klev) = d_u_lif(1:klon, 1:klev)/pdtphys 1615 ! CALL histwrite_phy(o_dulif, zx_tmp_fi3d) 1616 ! zx_tmp_fi3d(1:klon, 1:klev) = d_v_lif(1:klon, 1:klev)/pdtphys 1617 ! CALL histwrite_phy(o_dvlif, zx_tmp_fi3d) 1618 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_lif(1:klon, 1:klev)/pdtphys 1619 ! CALL histwrite_phy(o_dtlif, zx_tmp_fi3d) 1620 1621 CALL histwrite_phy(o_dulif, d_u_lif(1:klon, 1:klev)) 1622 CALL histwrite_phy(o_dvlif, d_v_lif(1:klon, 1:klev)) 1623 CALL histwrite_phy(o_dtlif, d_t_lif(1:klon, 1:klev)) 1586 1624 ENDIF 1587 1625 1588 1626 IF (ok_hines) THEN 1589 zx_tmp_fi3d = du_gwd_hines/pdtphys 1590 CALL histwrite_phy(o_du_gwd_hines, zx_tmp_fi3d) 1591 1592 zx_tmp_fi3d = dv_gwd_hines/pdtphys 1593 CALL histwrite_phy(o_dv_gwd_hines, zx_tmp_fi3d) 1594 1595 zx_tmp_fi3d(1:klon, 1:klev) = d_t_hin(1:klon, 1:klev)/pdtphys 1596 CALL histwrite_phy(o_dthin, zx_tmp_fi3d) 1627 ! zx_tmp_fi3d = du_gwd_hines/pdtphys 1628 ! CALL histwrite_phy(o_du_gwd_hines, zx_tmp_fi3d) 1629 ! zx_tmp_fi3d = dv_gwd_hines/pdtphys 1630 ! CALL histwrite_phy(o_dv_gwd_hines, zx_tmp_fi3d) 1631 ! zx_tmp_fi3d = d_t_hin(1:klon, 1:klev)/pdtphys 1632 1633 CALL histwrite_phy(o_du_gwd_hines, du_gwd_hines) 1634 CALL histwrite_phy(o_dv_gwd_hines, dv_gwd_hines) 1635 CALL histwrite_phy(o_dthin, d_t_hin) 1636 1597 1637 CALL histwrite_phy(o_ustr_gwd_hines, zustr_gwd_hines) 1598 1638 CALL histwrite_phy(o_vstr_gwd_hines, zvstr_gwd_hines) … … 1600 1640 1601 1641 IF (.not. ok_hines .and. ok_gwd_rando) THEN 1602 zx_tmp_fi3d = du_gwd_front/pdtphys 1603 CALL histwrite_phy(o_du_gwd_front, zx_tmp_fi3d) 1604 1605 zx_tmp_fi3d = dv_gwd_front/pdtphys 1606 CALL histwrite_phy(o_dv_gwd_front, zx_tmp_fi3d) 1642 ! zx_tmp_fi3d = du_gwd_front/pdtphys 1643 ! CALL histwrite_phy(o_du_gwd_front, zx_tmp_fi3d) 1644 ! zx_tmp_fi3d = dv_gwd_front/pdtphys 1645 ! CALL histwrite_phy(o_dv_gwd_front, zx_tmp_fi3d) 1646 1647 CALL histwrite_phy(o_du_gwd_front, du_gwd_front) 1648 CALL histwrite_phy(o_dv_gwd_front, dv_gwd_front) 1607 1649 1608 1650 CALL histwrite_phy(o_ustr_gwd_front, zustr_gwd_front) … … 1611 1653 1612 1654 IF (ok_gwd_rando) THEN 1613 zx_tmp_fi3d = du_gwd_rando/pdtphys 1614 CALL histwrite_phy(o_du_gwd_rando, zx_tmp_fi3d) 1615 1616 zx_tmp_fi3d = dv_gwd_rando/pdtphys 1617 CALL histwrite_phy(o_dv_gwd_rando, zx_tmp_fi3d) 1655 ! zx_tmp_fi3d = du_gwd_rando/pdtphys 1656 ! CALL histwrite_phy(o_du_gwd_rando, zx_tmp_fi3d) 1657 ! zx_tmp_fi3d = dv_gwd_rando/pdtphys 1658 ! CALL histwrite_phy(o_dv_gwd_rando, zx_tmp_fi3d) 1659 1660 CALL histwrite_phy(o_du_gwd_rando, du_gwd_rando) 1661 CALL histwrite_phy(o_dv_gwd_rando, dv_gwd_rando) 1662 1618 1663 CALL histwrite_phy(o_ustr_gwd_rando, zustr_gwd_rando) 1619 1664 CALL histwrite_phy(o_vstr_gwd_rando, zvstr_gwd_rando) … … 1623 1668 1624 1669 IF (ok_qch4) THEN 1670 ! GLITCHY : not in field_def_lmdz.xml 1625 1671 zx_tmp_fi3d = d_q_ch4/pdtphys 1626 1672 CALL histwrite_phy(o_dqch4, zx_tmp_fi3d) … … 1630 1676 zx_tmp_fi3d1(:, k) = swup(:, k)*swradcorr(:) 1631 1677 ENDDO 1632 1633 1678 CALL histwrite_phy(o_rsu, zx_tmp_fi3d1) 1634 1679 … … 1636 1681 zx_tmp_fi3d1(:, k) = swdn(:, k)*swradcorr(:) 1637 1682 ENDDO 1638 1639 1640 1683 CALL histwrite_phy(o_rsd, zx_tmp_fi3d1) 1684 1641 1685 DO k = 1, klevp1 1642 1686 zx_tmp_fi3d1(:, k) = swup0(:, k)*swradcorr(:) 1643 1687 ENDDO 1644 1645 1688 CALL histwrite_phy(o_rsucs, zx_tmp_fi3d1) 1689 1646 1690 DO k = 1, klevp1 1647 1691 zx_tmp_fi3d1(:, k) = swupc0(:, k)*swradcorr(:) … … 1664 1708 CALL histwrite_phy(o_rldcs, lwdn0) 1665 1709 1666 zx_tmp_fi3d(1:klon, 1:klev) = d_t(1:klon, 1:klev) + &1667 d_t_dyn(1:klon, 1:klev)1668 CALL histwrite_phy(o_tnt, zx_tmp_fi3d)1669 1670 zx_tmp_fi3d(1:klon, 1:klev) = d_t_swr(1:klon, 1:klev)/pdtphys + &1671 d_t_lwr(1:klon, 1:klev)/pdtphys1672 CALL histwrite_phy(o_tntr, zx_tmp_fi3d)1673 zx_tmp_fi3d(1:klon, 1:klev) = (d_t_lsc(1:klon, 1:klev) + &1674 d_t_eva(1:klon, 1:klev) + &1675 d_t_vdf(1:klon, 1:klev))/pdtphys1676 CALL histwrite_phy(o_tntscpbl, zx_tmp_fi3d)1677 zx_tmp_fi3d(1:klon, 1:klev) = d_qx(1:klon, 1:klev, ivap) + &1678 d_q_dyn(1:klon, 1:klev)1679 CALL histwrite_phy(o_tnhus, zx_tmp_fi3d)1680 zx_tmp_fi3d(1:klon, 1:klev) = d_q_lsc(1:klon, 1:klev)/pdtphys + &1681 d_q_eva(1:klon, 1:klev)/pdtphys1682 CALL histwrite_phy(o_tnhusscpbl, zx_tmp_fi3d)1683 1710 CALL histwrite_phy(o_evu, coefm(:, :, is_ave)) 1684 zx_tmp_fi3d(1:klon, 1:klev) = q_seri(1:klon, 1:klev) + & 1685 ql_seri(1:klon, 1:klev) 1686 CALL histwrite_phy(o_h2o, zx_tmp_fi3d) 1711 1712 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t(1:klon, 1:klev) + & 1713 ! d_t_dyn(1:klon, 1:klev) 1714 ! CALL histwrite_phy(o_tnt, zx_tmp_fi3d) ! o_dtphy + o_dtdyn 1715 ! zx_tmp_fi3d(1:klon, 1:klev) = d_t_swr(1:klon, 1:klev)/pdtphys + & 1716 ! d_t_lwr(1:klon, 1:klev)/pdtphys 1717 ! CALL histwrite_phy(o_tntr, zx_tmp_fi3d)!o_dtswr + o_dtlwr 1718 ! zx_tmp_fi3d(1:klon, 1:klev) = (d_t_lsc(1:klon, 1:klev) + & 1719 ! d_t_eva(1:klon, 1:klev) + & 1720 ! d_t_vdf(1:klon, 1:klev))/pdtphys 1721 ! CALL histwrite_phy(o_tntscpbl, zx_tmp_fi3d) ! o_dtlsc + o_dteva + o_dtvdf 1722 ! zx_tmp_fi3d(1:klon, 1:klev) = d_qx(1:klon, 1:klev, ivap) + & 1723 ! d_q_dyn(1:klon, 1:klev) 1724 ! CALL histwrite_phy(o_tnhus, zx_tmp_fi3d) ! o_dqphy + o_dqdyn 1725 ! zx_tmp_fi3d(1:klon, 1:klev) = d_q_lsc(1:klon, 1:klev)/pdtphys + & 1726 ! d_q_eva(1:klon, 1:klev)/pdtphys 1727 ! CALL histwrite_phy(o_tnhusscpbl, zx_tmp_fi3d) ! o_dqlsc + o_dqeva 1728 ! zx_tmp_fi3d(1:klon, 1:klev) = q_seri(1:klon, 1:klev) + & 1729 ! ql_seri(1:klon, 1:klev) 1730 ! CALL histwrite_phy(o_h2o, zx_tmp_fi3d) ! o_ovap + o_oliq 1687 1731 IF (iflag_con >= 3) THEN 1688 1732 zx_tmp_fi3d(1:klon, 1:klev) = -1*(dnwd(1:klon, 1:klev) + & 1689 1733 dnwd0(1:klon, 1:klev)) 1690 CALL histwrite_phy(o_mcd, zx_tmp_fi3d) 1734 CALL histwrite_phy(o_mcd, zx_tmp_fi3d) ! - (o_dnwd + dnwd0) 1691 1735 zx_tmp_fi3d(1:klon, 1:klev) = upwd(1:klon, 1:klev) + & 1692 1736 dnwd(1:klon, 1:klev) + dnwd0(1:klon, 1:klev) 1693 CALL histwrite_phy(o_dmc, zx_tmp_fi3d) 1737 CALL histwrite_phy(o_dmc, zx_tmp_fi3d) ! o_upwd - o_mcd 1694 1738 ELSE IF (iflag_con == 2) THEN 1695 1739 CALL histwrite_phy(o_mcd, pmfd) 1696 1740 zx_tmp_fi3d = pmfu + pmfd 1697 CALL histwrite_phy(o_dmc, zx_tmp_fi3d) 1741 CALL histwrite_phy(o_dmc, zx_tmp_fi3d) ! pmfu + o_mcd 1698 1742 ENDIF 1699 1743 CALL histwrite_phy(o_ref_liq, ref_liq) … … 1701 1745 1702 1746 IF (ok_4xCO2atm) THEN 1703 zx_tmp_fi2d(:) = swupp(:, klevp1)*swradcorr(:) 1704 CALL histwrite_phy(o_rsut4co2, zx_tmp_fi2d) 1705 zx_tmp_fi2d(:) = lwupp(:, klevp1) 1706 CALL histwrite_phy(o_rlut4co2, zx_tmp_fi2d) 1707 zx_tmp_fi2d(:) = swup0p(:, klevp1)*swradcorr(:) 1708 CALL histwrite_phy(o_rsutcs4co2, zx_tmp_fi2d) 1709 zx_tmp_fi2d(:) = lwup0p(:, klevp1) 1710 CALL histwrite_phy(o_rlutcs4co2, zx_tmp_fi2d) 1711 DO k = 1, klevp1 1712 zx_tmp_fi3d1(:, k) = swupp(:, k)*swradcorr(:) 1713 ENDDO 1714 CALL histwrite_phy(o_rsu4co2, zx_tmp_fi3d1) 1715 DO k = 1, klevp1 1716 zx_tmp_fi3d1(:, k) = swup0p(:, k)*swradcorr(:) 1717 ENDDO 1718 CALL histwrite_phy(o_rsucs4co2, zx_tmp_fi3d1) 1719 DO k = 1, klevp1 1720 zx_tmp_fi3d1(:, k) = swdnp(:, k)*swradcorr(:) 1721 ENDDO 1722 CALL histwrite_phy(o_rsd4co2, zx_tmp_fi3d1) 1723 DO k = 1, klevp1 1724 zx_tmp_fi3d1(:, k) = swdn0p(:, k)*swradcorr(:) 1725 ENDDO 1726 CALL histwrite_phy(o_rsdcs4co2, zx_tmp_fi3d1) 1747 ! zx_tmp_fi2d(:) = swupp(:, klevp1)*swradcorr(:) 1748 ! CALL histwrite_phy(o_rsut4co2, zx_tmp_fi2d) 1749 ! zx_tmp_fi2d(:) = lwupp(:, klevp1) 1750 ! CALL histwrite_phy(o_rlut4co2, zx_tmp_fi2d) 1751 ! zx_tmp_fi2d(:) = swup0p(:, klevp1)*swradcorr(:) 1752 ! CALL histwrite_phy(o_rsutcs4co2, zx_tmp_fi2d) 1753 ! zx_tmp_fi2d(:) = lwup0p(:, klevp1) 1754 ! CALL histwrite_phy(o_rlutcs4co2, zx_tmp_fi2d) 1755 CALL histwrite_phy(o_rsut4co2, swupp(:, klevp1)) 1756 CALL histwrite_phy(o_rlut4co2, lwupp(:, klevp1)) 1757 CALL histwrite_phy(o_rsutcs4co2, swup0p(:, klevp1)) 1758 CALL histwrite_phy(o_rlutcs4co2, lwup0p(:, klevp1)) 1759 1760 if( any(swradcorr(:) /= 1.0) ) then 1761 DO k = 1, klevp1 1762 zx_tmp_fi3d1(:, k) = swupp(:, k)*swradcorr(:) 1763 ENDDO 1764 CALL histwrite_phy(o_rsu4co2, zx_tmp_fi3d1) 1765 DO k = 1, klevp1 1766 zx_tmp_fi3d1(:, k) = swup0p(:, k)*swradcorr(:) 1767 ENDDO 1768 CALL histwrite_phy(o_rsucs4co2, zx_tmp_fi3d1) 1769 DO k = 1, klevp1 1770 zx_tmp_fi3d1(:, k) = swdnp(:, k)*swradcorr(:) 1771 ENDDO 1772 CALL histwrite_phy(o_rsd4co2, zx_tmp_fi3d1) 1773 DO k = 1, klevp1 1774 zx_tmp_fi3d1(:, k) = swdn0p(:, k)*swradcorr(:) 1775 ENDDO 1776 CALL histwrite_phy(o_rsdcs4co2, zx_tmp_fi3d1) 1777 else 1778 CALL histwrite_phy(o_rsu4co2, swupp) 1779 CALL histwrite_phy(o_rsucs4co2, swup0p) 1780 CALL histwrite_phy(o_rsd4co2, swdnp) 1781 CALL histwrite_phy(o_rsdcs4co2, swdn0p) 1782 endif 1727 1783 CALL histwrite_phy(o_rlu4co2, lwupp) 1728 1784 CALL histwrite_phy(o_rlucs4co2, lwup0p) … … 1738 1794 CALL histwrite_phy(o_va, vlevSTD(:, :)) 1739 1795 CALL histwrite_phy(o_wap, wlevSTD(:, :)) 1740 DO k = 1, nlevSTD 1741 DO i = 1, klon 1742 IF (O3STD(i, k) .NE. missing_val) THEN 1743 zx_tmp_fi3d_STD(i, k) = O3STD(i, k)*1.e+9 1744 ELSE 1745 zx_tmp_fi3d_STD(i, k) = missing_val 1746 ENDIF 1747 ENDDO 1748 ENDDO !k=1, nlevSTD 1749 CALL histwrite_phy(o_tro3, zx_tmp_fi3d_STD) 1796 ! DO k = 1, nlevSTD 1797 ! DO i = 1, klon 1798 ! IF (O3STD(i, k) .NE. missing_val) THEN 1799 ! zx_tmp_fi3d_STD(i, k) = O3STD(i, k)*1.e+9 1800 ! ELSE 1801 ! zx_tmp_fi3d_STD(i, k) = missing_val 1802 ! ENDIF 1803 ! ENDDO 1804 ! ENDDO !k=1, nlevSTD 1805 ! CALL histwrite_phy(o_tro3, zx_tmp_fi3d_STD) 1806 ! !(this/=missing_val)?this*1.e+9:missing_val 1807 CALL histwrite_phy(o_tro3, O3STD(1:klon, 1:nlevSTD)) 1808 ! IF (read_climoz == 2) THEN 1809 ! DO k = 1, nlevSTD 1810 ! DO i = 1, klon 1811 ! IF (O3daySTD(i, k) .NE. missing_val) THEN 1812 ! zx_tmp_fi3d_STD(i, k) = O3daySTD(i, k)*1.e+9 1813 ! ELSE 1814 ! zx_tmp_fi3d_STD(i, k) = missing_val 1815 ! ENDIF 1816 ! ENDDO 1817 ! ENDDO !k=1, nlevSTD 1818 ! ENDIF 1819 ! CALL histwrite_phy(o_tro3_daylight, zx_tmp_fi3d_STD) 1820 ! !(this/=missing_val)?this*1.e+9:missing_val 1750 1821 IF (read_climoz == 2) THEN 1751 DO k = 1, nlevSTD 1752 DO i = 1, klon 1753 IF (O3daySTD(i, k) .NE. missing_val) THEN 1754 zx_tmp_fi3d_STD(i, k) = O3daySTD(i, k)*1.e+9 1755 ELSE 1756 zx_tmp_fi3d_STD(i, k) = missing_val 1757 ENDIF 1758 ENDDO 1759 ENDDO !k=1, nlevSTD 1760 ENDIF 1761 CALL histwrite_phy(o_tro3_daylight, zx_tmp_fi3d_STD) 1822 CALL histwrite_phy(o_tro3_daylight, O3daySTD(1:klon, 1:nlevSTD)) 1823 else 1824 CALL histwrite_phy(o_tro3_daylight, O3STD(1:klon, 1:nlevSTD)) 1825 ENDIF 1762 1826 CALL histwrite_phy(o_uxv, uvSTD(:, :)) 1763 1827 CALL histwrite_phy(o_vxq, vqSTD(:, :)) … … 1790 1854 !--2D fields 1791 1855 CALL histwrite_phy(o_dtr_dry(iq - nqo), flux_tr_dry(:, iq - nqo)) 1792 zx_tmp_fi2d = 0.1793 DO k = 1, klev1794 zx_tmp_fi2d(:) = zx_tmp_fi2d(:) + zmasse(:, k)*tr_seri(:, k, iq - nqo)1795 ENDDO1796 1856 if (.not. ok_reprobus) then 1857 zx_tmp_fi2d = 0. 1858 DO k = 1, klev 1859 zx_tmp_fi2d(:) = zx_tmp_fi2d(:) + zmasse(:, k)*tr_seri(:, k, iq - nqo) 1860 ENDDO 1797 1861 CALL histwrite_phy(o_trac_cum(iq - nqo), zx_tmp_fi2d) 1798 1862 end if
Note: See TracChangeset
for help on using the changeset viewer.