Changeset 3776 for LMDZ6/trunk
- Timestamp:
- Oct 19, 2020, 1:24:19 PM (4 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ6/trunk/libf/phylmd/physiq_mod.F90
r3756 r3776 16 16 d_u, d_v, d_t, d_qx, d_ps) 17 17 18 ! For clarity, the "USE" section is now arranged in alphabetical order, 19 ! with a separate section for CPP keys 20 ! PLEASE try to follow this rule 21 22 USE ACAMA_GWD_rando_m, only: ACAMA_GWD_rando 23 USE aero_mod 24 USE add_phys_tend_mod, only : add_pbl_tend, add_phys_tend, diag_phys_tend, prt_enerbil, & 25 & fl_ebil, fl_cor_ebil 18 26 USE assert_m, only: assert 27 USE change_srf_frac_mod 28 USE conf_phys_m, only: conf_phys 29 USE carbon_cycle_mod, ONLY : infocfields_init, RCO2_glo, carbon_cycle_rad 30 USE CFMIP_point_locations ! IM stations CFMIP 31 USE cmp_seri_mod 32 USE dimphy 33 USE etat0_limit_unstruct_mod 34 USE FLOTT_GWD_rando_m, only: FLOTT_GWD_rando 35 USE fonte_neige_mod, ONLY : fonte_neige_get_vars 36 USE geometry_mod, ONLY: cell_area, latitude_deg, longitude_deg 19 37 USE ioipsl, only: histbeg, histvert, histdef, histend, histsync, & 20 38 histwrite, ju2ymds, ymds2ju, getin 21 USE geometry_mod, ONLY: cell_area, latitude_deg, longitude_deg 39 USE ioipsl_getin_p_mod, ONLY : getin_p 40 USE indice_sol_mod 41 USE infotrac_phy, ONLY: nqtot, nbtr, nqo, type_trac 42 USE iophy 43 USE limit_read_mod, ONLY : init_limit_read 44 USE mod_grid_phy_lmdz, ONLY: nbp_lon, nbp_lat, nbp_lev, klon_glo, grid1dTo2d_glo, grid_type, unstructured 45 USE mod_phys_lmdz_mpi_data, only: is_mpi_root 46 USE mod_phys_lmdz_para 47 USE netcdf95, only: nf95_close 48 USE netcdf, only: nf90_fill_real ! IM for NMC files 49 USE open_climoz_m, only: open_climoz ! ozone climatology from a file 50 USE ozonecm_m, only: ozonecm ! ozone of J.-F. Royer 51 USE pbl_surface_mod, ONLY : pbl_surface 52 USE phyaqua_mod, only: zenang_an 53 USE phystokenc_mod, ONLY: offline, phystokenc 22 54 USE phys_cal_mod, only: year_len, mth_len, days_elapsed, jh_1jan, & 23 55 year_cur, mth_cur,jD_cur, jH_cur, jD_ref, day_cur, hour 56 !! USE phys_local_var_mod, ONLY : a long list of variables 57 !! ==> see below, after "CPP Keys" section 58 USE phys_state_var_mod ! Variables sauvegardees de la physique 59 USE phys_output_mod 60 USE phys_output_ctrlout_mod 61 USE print_control_mod, ONLY: mydebug=>debug , lunout, prt_level 62 USE readaerosol_mod, ONLY : init_aero_fromfile 63 USE readaerosolstrato_m, ONLY : init_readaerosolstrato 64 USE radlwsw_m, only: radlwsw 65 USE regr_horiz_time_climoz_m, ONLY: regr_horiz_time_climoz 66 USE regr_pr_time_av_m, only: regr_pr_time_av 67 USE surface_data, ONLY : type_ocean, ok_veget, ok_snow 68 USE time_phylmdz_mod, only: annee_ref, current_time, day_ini, day_ref, & 69 day_step_phy, itau_phy, pdtphys, raz_date, start_time, update_time 70 USE tracinca_mod, ONLY: config_inca 71 USE tropopause_m, ONLY: dyn_tropopause 72 USE vampir 73 USE VERTICAL_LAYERS_MOD, ONLY: aps,bps, ap, bp 24 74 USE write_field_phy 25 USE dimphy 26 USE infotrac_phy, ONLY: nqtot, nbtr, nqo, type_trac 27 USE mod_grid_phy_lmdz, ONLY: nbp_lon, nbp_lat, nbp_lev, klon_glo, grid1dTo2d_glo, grid_type, unstructured 28 USE mod_phys_lmdz_para 29 USE iophy 30 USE print_control_mod, ONLY: mydebug=>debug , lunout, prt_level 31 USE phystokenc_mod, ONLY: offline, phystokenc 32 USE time_phylmdz_mod, only: raz_date, day_step_phy, update_time,current_time 33 USE vampir 34 USE pbl_surface_mod, ONLY : pbl_surface 35 USE change_srf_frac_mod 36 USE surface_data, ONLY : type_ocean, ok_veget, ok_snow 37 USE tropopause_m, ONLY: dyn_tropopause 75 76 !USE cmp_seri_mod 77 ! USE add_phys_tend_mod, only : add_pbl_tend, add_phys_tend, diag_phys_tend, prt_enerbil, & 78 ! & fl_ebil, fl_cor_ebil 79 80 !!!!!!!!!!!!!!!!!! "USE" section for CPP keys !!!!!!!!!!!!!!!!!!!!!!!! 81 ! 82 ! 38 83 #ifdef CPP_Dust 39 USE phytracr_spl_mod, ONLY: phytracr_spl 84 USE phytracr_spl_mod, ONLY: phytracr_spl, phytracr_spl_out_init 85 USE phys_output_write_spl_mod 86 #else 87 USE phytrac_mod, ONLY : phytrac_init, phytrac 88 USE phys_output_write_mod 40 89 #endif 90 91 92 #ifdef REPROBUS 93 USE CHEM_REP, ONLY : Init_chem_rep_xjour, & 94 d_q_rep,d_ql_rep,d_qi_rep,ptrop,ttrop, & 95 ztrop, gravit,itroprep, Z1,Z2,fac,B 96 #endif 97 98 99 #ifdef CPP_RRTM 100 USE YOERAD, ONLY : NRADLP 101 USE YOESW, ONLY : RSUN 102 #endif 103 104 41 105 #ifdef CPP_StratAer 42 106 USE strataer_mod, ONLY: strataer_init 43 107 #endif 44 USE phys_local_var_mod, ONLY: phys_local_var_init, phys_local_var_end, & 108 109 110 #ifdef CPP_XIOS 111 USE xios, ONLY: xios_update_calendar, xios_context_finalize, & 112 xios_get_field_attr, xios_field_is_active 113 USE wxios, ONLY: missing_val, missing_val_omp 114 #endif 115 #ifndef CPP_XIOS 116 USE paramLMDZ_phy_mod 117 #endif 118 ! 119 ! 120 !!!!!!!!!!!!!!!!!! END "USE" for CPP keys !!!!!!!!!!!!!!!!!!!!!! 121 122 USE phys_local_var_mod, ONLY: phys_local_var_init, phys_local_var_end, & 45 123 ! [Variables internes non sauvegardees de la physique] 46 124 ! Variables locales pour effectuer les appels en serie … … 216 294 zxsnow,snowhgt,qsnow,to_ice,sissnow,runoff,albsol3_lic 217 295 ! 218 USE phys_state_var_mod ! Variables sauvegardees de la physique 219 #ifdef CPP_Dust 220 USE phys_output_write_spl_mod 221 #else 222 USE phys_output_var_mod ! Variables pour les ecritures des sorties 223 #endif 224 225 USE phys_output_write_mod 226 USE fonte_neige_mod, ONLY : fonte_neige_get_vars 227 USE phys_output_mod 228 USE phys_output_ctrlout_mod 229 USE open_climoz_m, only: open_climoz ! ozone climatology from a file 230 USE regr_pr_time_av_m, only: regr_pr_time_av 231 USE netcdf95, only: nf95_close 232 !IM for NMC files 233 USE netcdf, only: nf90_fill_real 234 USE mod_phys_lmdz_mpi_data, only: is_mpi_root 235 USE aero_mod 236 USE ozonecm_m, only: ozonecm ! ozone of J.-F. Royer 237 USE conf_phys_m, only: conf_phys 238 USE radlwsw_m, only: radlwsw 239 USE phyaqua_mod, only: zenang_an 240 USE time_phylmdz_mod, only: day_step_phy, annee_ref, day_ref, itau_phy, & 241 start_time, pdtphys, day_ini 242 USE tracinca_mod, ONLY: config_inca 243 #ifdef CPP_XIOS 244 USE wxios, ONLY: missing_val, missing_val_omp 245 USE xios, ONLY: xios_get_field_attr, xios_field_is_active 246 #endif 247 #ifdef REPROBUS 248 USE CHEM_REP, ONLY : Init_chem_rep_xjour, & 249 d_q_rep,d_ql_rep,d_qi_rep,ptrop,ttrop, & 250 ztrop, gravit,itroprep, Z1,Z2,fac,B 251 #endif 252 USE indice_sol_mod 253 USE phytrac_mod, ONLY : phytrac_init, phytrac 254 USE carbon_cycle_mod, ONLY : infocfields_init, RCO2_glo, carbon_cycle_rad 255 256 #ifdef CPP_RRTM 257 USE YOERAD, ONLY : NRADLP 258 USE YOESW, ONLY : RSUN 259 #endif 260 USE ioipsl_getin_p_mod, ONLY : getin_p 261 262 #ifndef CPP_XIOS 263 USE paramLMDZ_phy_mod 264 #endif 265 266 USE cmp_seri_mod 267 USE add_phys_tend_mod, only : add_pbl_tend, add_phys_tend, diag_phys_tend, prt_enerbil, & 268 & fl_ebil, fl_cor_ebil 269 270 !IM stations CFMIP 271 USE CFMIP_point_locations 272 USE FLOTT_GWD_rando_m, only: FLOTT_GWD_rando 273 USE ACAMA_GWD_rando_m, only: ACAMA_GWD_rando 274 USE VERTICAL_LAYERS_MOD, ONLY: aps,bps, ap, bp 275 USE etat0_limit_unstruct_mod 276 #ifdef CPP_XIOS 277 USE xios, ONLY: xios_update_calendar, xios_context_finalize 278 #endif 279 USE limit_read_mod, ONLY : init_limit_read 280 USE regr_horiz_time_climoz_m, ONLY: regr_horiz_time_climoz 281 USE readaerosol_mod, ONLY : init_aero_fromfile 282 USE readaerosolstrato_m, ONLY : init_readaerosolstrato 296 283 297 284 298 IMPLICIT NONE … … 1347 1361 iflag_phytrac = 1 ! by default we do want to call phytrac 1348 1362 CALL getin_p('iflag_phytrac',iflag_phytrac) 1363 #ifdef CPP_Dust 1364 IF (iflag_phytrac.EQ.0) THEN 1365 WRITE(lunout,*) 'In order to run with SPLA, iflag_phytrac will be forced to 1' 1366 iflag_phytrac = 1 1367 ENDIF 1368 #endif 1349 1369 nvm_lmdz = 13 1350 1370 CALL getin_p('NVM',nvm_lmdz) … … 1681 1701 1682 1702 CALL iniradia(klon,klev,paprs(1,1:klev+1)) 1683 ! Initialisation des champs dans phytrac qui sont utilisés par phys_output_write 1703 1704 ! Initialisation des champs dans phytrac* qui sont utilisés par phys_output_write* 1705 #ifdef CPP_Dust 1706 ! Quand on utilise SPLA, on force iflag_phytrac=1 1707 CALL phytracr_spl_out_init() 1708 CALL phys_output_write_spl(itap, pdtphys, paprs, pphis, & 1709 pplay, lmax_th, aerosol_couple, & 1710 ok_ade, ok_aie, ivap, ok_sync, & 1711 ptconv, read_climoz, clevSTD, & 1712 ptconvth, d_t, qx, d_qx, d_tr_dyn, zmasse, & 1713 flag_aerosol, flag_aerosol_strat, ok_cdnc) 1714 #else 1715 ! phys_output_write écrit des variables traceurs seulement si iflag_phytrac == 1 1716 ! donc seulement dans ce cas on doit appeler phytrac_init() 1684 1717 IF (iflag_phytrac == 1 ) THEN 1685 1718 CALL phytrac_init() 1686 ENDIF 1687 1719 ENDIF 1688 1720 CALL phys_output_write(itap, pdtphys, paprs, pphis, & 1689 1721 pplay, lmax_th, aerosol_couple, & … … 1692 1724 ptconvth, d_u, d_t, qx, d_qx, zmasse, & 1693 1725 flag_aerosol, flag_aerosol_strat, ok_cdnc) 1726 #endif 1727 1694 1728 1695 1729 #ifdef CPP_XIOS … … 4775 4809 ENDIF 4776 4810 4777 IF (iflag_phytrac == 1 ) THEN4778 4779 4811 #ifdef CPP_Dust 4780 CALL phytracr_spl ( debut,lafin , jD_cur,jH_cur,iflag_con, & ! I 4812 ! Avec SPLA, iflag_phytrac est forcé =1 4813 CALL phytracr_spl ( debut,lafin , jD_cur,jH_cur,iflag_con, & ! I 4781 4814 pdtphys,ftsol, & ! I 4782 4815 t,q_seri,paprs,pplay,RHcl, & ! I … … 4794 4827 4795 4828 #else 4796 4797 CALL phytrac ( &4829 IF (iflag_phytrac == 1 ) THEN 4830 CALL phytrac ( & 4798 4831 itap, days_elapsed+1, jH_cur, debut, & 4799 4832 lafin, phys_tstep, u, v, t, & … … 4832 4865 4833 4866 #endif 4867 ENDIF ! (iflag_phytrac=1) 4834 4868 4835 4869 #endif 4836 ENDIF ! (iflag_phytrac=1)4870 !ENDIF ! (iflag_phytrac=1) 4837 4871 4838 4872 IF (offline) THEN … … 5134 5168 CALL phys_output_write_spl(itap, pdtphys, paprs, pphis, & 5135 5169 pplay, lmax_th, aerosol_couple, & 5136 ok_ade, ok_aie, ivap, ok_sync, &5170 ok_ade, ok_aie, ivap, ok_sync, & 5137 5171 ptconv, read_climoz, clevSTD, & 5138 5172 ptconvth, d_t, qx, d_qx, d_tr_dyn, zmasse, & … … 5153 5187 #endif 5154 5188 5155 ! On remet des variables a .false. apres un premier appel5189 ! Pour XIOS : On remet des variables a .false. apres un premier appel 5156 5190 IF (debut) THEN 5157 5191 #ifdef CPP_XIOS
Note: See TracChangeset
for help on using the changeset viewer.