2#ifndef LM_SOILCHEMISTRYMETRX_H_
3#define LM_SOILCHEMISTRYMETRX_H_
5#include "mbe_legacymodel.h"
6#include "state/mbe_state.h"
9#include "models/soilchemistry/metrx/output-soilchemistry-metrx.h"
10#include "models/soilchemistry/metrx/soilchemistry-metrx.h.inc"
11#include "models/soilchemistry/ld_transport.h"
12#include "models/soilchemistry/ld_enhanced_efficiency_nitrogen_fertilizers.h"
14#include "eventhandler/fertilize/fertilize.h"
15#include "eventhandler/till/till.h"
17#include <math/lmath-tdma.h>
18#include <logging/cbm_logging.h>
22extern cbm::logger_t * SoilChemistryMeTrXLogger;
36 LMOD_EXPORT_MODULE_INFO(
SoilChemistryMeTrX,
"soilchemistry:metrx",
"Soilchemistry MeTrX");
45 lerr_t configure( ldndc::config_file_t
const *);
46 lerr_t register_ports( cbm::io_kcomm_t *);
52 lerr_t unregister_ports( cbm::io_kcomm_t *);
55 lerr_t sleep() {
return LDNDC_ERR_OK; }
56 lerr_t wake() {
return LDNDC_ERR_OK; }
59 cbm::io_kcomm_t * io_kcomm;
61 input_class_groundwater_t
const * gw_;
62 input_class_siteparameters_t
const & sipar_;
63 input_class_soillayers_t
const & sl_;
64 input_class_setup_t
const & se_;
66 substate_surfacebulk_t & sb_;
67 substate_airchemistry_t & ac_;
69 substate_microclimate_t
const & mc_;
70 substate_physiology_t & ph_;
71 substate_soilchemistry_t & sc_;
72 substate_watercycle_t & wc_;
74 MoBiLE_PlantVegetation * m_veg;
76 SubscribedEvent<LD_EventHandlerQueue> m_FertilizeEvents;
77 SubscribedEvent<LD_EventHandlerQueue> m_IrrigationEvents;
78 SubscribedEvent<LD_EventHandlerQueue> m_ManureEvents;
79 SubscribedEvent<LD_EventHandlerQueue> m_PlantEvents;
80 SubscribedEvent<LD_EventHandlerQueue> m_TillEvents;
83 ControlledReleaseNitrogenFertilizer crnf_;
85 timemode_e
const timemode_;
87 OutputSoilchemistryMeTrX output_writer_;
88 ldndc_flt64_t * output_data_;
90 int const TOTAL_TIME_STEPS;
91 int const INTERNAL_TIME_STEPS;
92 double const FTS_TOT_;
96 double const M_C_SCALE;
97 double const M_2C_SCALE;
98 double const M_N_SCALE;
99 double const M_2H_SCALE;
100 double const M_2N_SCALE;
101 double const M_O_SCALE;
102 double const M_2O_SCALE;
103 double const M_FE_SCALE;
105 double const N_O2_RATIO_NITRIFICATION;
106 double const ACETATE_RATIO_FERM_SYN;
108 double const H2_MOL_CH4_KG_CONVERSION;
109 double const H2_KG_CH4_KG_CONVERSION;
110 double const H2_KG_CH4_MOL_CONVERSION;
112 double const FE3_ACETATE_REDUCTION_RATIO;
113 double const FE3_HYDROGEN_REDUCTION_RATIO;
115 double const O2_CONVERSION_FOR_CH4_OX;
117 double const NO3_MOLAR_MAX_FE_RED;
118 double const FE3_MOLAR_MAX_CH4_PROD;
119 double const O2_FE2_RATIO;
121 double const MICRO_C_MIN;
123 double const MC_MO2_RATIO;
124 double const RGAS_M_O2_BAR_PA;
126 double const K_HU_DOC;
128 double const K_DC_AORG;
129 double const K_HU_AORG_HUM1;
130 double const K_HU_AORG_HUM2;
132 double const K_DC_SOL;
133 double const K_HU_SOL;
135 double const K_DC_CEL;
136 double const K_HU_CEL;
138 double const K_DC_LIG;
139 double const K_HU_LIG;
141 double const K_DC_HUM1;
142 double const K_HU_HUM1;
144 double const K_DC_HUM2;
145 double const K_HU_HUM2;
147 double const K_DC_HUM3;
148 double const KR_DENIT_CHEMO;
150 double const K_FRAG_STUBBLE;
151 double const K_FRAG_ALGAE;
152 double const K_FRAG_RAW_LITTER;
153 double const K_FRAG_WOOD;
155 double const KMM_O2_ROOT_RESPIRATION;
157 double const MUE_MAX_C_MICRO_1;
158 double const MUE_MAX_C_MICRO_2;
159 double const MUE_MAX_C_MICRO_3;
161 double const METRX_MUEMAX_C_CH4_PROD;
162 double const METRX_MUEMAX_H2_CH4_PROD;
163 double const METRX_MUEMAX_C_CH4_OX_HA;
164 double const METRX_MUEMAX_C_CH4_OX_LA;
166 double const METRX_MUEMAX_C_FE_RED;
167 double const METRX_KR_OX_FE;
169 double const MUE_MAX_N_ASSI;
171 double const PH_SURFACE_WATER;
174 double const A_MAX_ALGAE;
175 double const A_MAX_MICRO_1;
176 double const A_MAX_MICRO_2;
177 double const A_MAX_MICRO_3;
179 double const METRX_F_DENIT_N2_MIN;
180 double const METRX_F_DENIT_N2_DELTA;
182 double const D_NO_WATER_SCALE;
183 double const D_N2O_WATER_SCALE;
184 double const D_O2_WATER_SCALE;
185 double const D_CO2_WATER_SCALE;
186 double const D_CH4_WATER_SCALE;
187 double const D_NH3_WATER_SCALE;
188 double const D_NH4_WATER_SCALE;
189 double const D_NO3_WATER_SCALE;
190 double const D_NO2_WATER_SCALE;
191 double const D_DOC_WATER_SCALE;
193 double const D_O2_AIR_SCALE;
194 double const D_N2_AIR_SCALE;
195 double const D_N2O_AIR_SCALE;
196 double const D_NO_AIR_SCALE;
197 double const D_CH4_AIR_SCALE;
198 double const D_CO2_AIR_SCALE;
199 double const D_NH3_AIR_SCALE;
200 double const D_RADON_AIR_SCALE;
202 double const METRX_V_EBULLITION;
203 double const GROUNDWATER_NUTRIENT_ACCESS_RATE;
205 size_t SL_SURFACE_DISTRIBUTION;
206 double SL_SURFACE_DISTRIBUTION_INVERSE;
209 double const *mc_wind;
212 double const *mc_temp_atm;
213 lvector_t< double >
const &mc_temp_sl;
216 double *waterflux_sl;
217 double *accumulated_waterflux_old_sl;
221 double accumulated_infiltration_old;
225 PublishedField<double> StubbleCarbon;
234 cbm::string_t freeze_thaw_method;
235 bool have_surface_bulk;
236 bool have_canopy_transport;
237 bool have_river_connection;
238 bool have_litter_height_change;
239 cbm::string_t d_eff_method;
240 bool have_radon_diffusion;
241 double spinup_delta_c;
242 double spinup_delta_c_depth;
244 cbm::string_t anvf_method;
246 bool have_plant_diffusion;
247 bool have_water_table;
256 double *o2_concentration;
257 lvector_t< double > ts_co2_concentration_fl;
258 lvector_t< double > ts_ch4_concentration_fl;
259 lvector_t< double > ts_no_concentration_fl;
260 lvector_t< double > ts_radon_concentration_fl;
261 lvector_t< double > nh3_fl;
267 double tot_c_balance_1;
268 double tot_n_balance_1;
275 double day_no3_groundwater_access;
278 double day_min_n_decomp;
279 double day_min_n_aorg;
280 double day_min_n_mic_1;
281 double day_min_n_mic_2;
282 double day_min_n_mic_3;
285 double day_assi_n_mic_1;
286 double day_assi_n_mic_2;
287 double day_assi_n_mic_3;
288 double day_assi_c_mic_1;
289 double day_assi_c_mic_2;
290 double day_assi_c_mic_3;
293 double day_nit_nh4_no2;
294 double day_nit_no2_no;
295 double day_nit_no2_n2o;
298 double day_denit_no3_no2;
299 double day_denit_no2_no;
300 double day_denit_no2_n2o;
301 double day_denit_no2_n2;
302 double day_denit_no_n2o;
303 double day_denit_no_n2;
304 double day_denit_n2o_n2;
305 double day_chemodenit_no2_no;
308 double day_co2_prod_mic_1_growth;
309 double day_co2_prod_mic_1_maintenance;
310 double day_co2_prod_mic_2;
311 double day_co2_prod_mic_3_acetate_prod;
312 double day_co2_prod_mic_3_acetate_cons;
313 double day_co2_prod_ch4_prod;
314 double day_co2_prod_ch4_cons;
318 double day_leach_n2o;
321 double day_leach_nh3;
322 double day_leach_urea;
323 double day_leach_radon;
326 double accumulated_c_litter_above_old;
327 double accumulated_c_litter_below_old;
329 double dC_root_exsudates;
330 double dC_litter_algae;
333 double day_decomp_c_lit_1;
334 double day_decomp_c_lit_2;
335 double day_decomp_c_lit_3;
336 double day_decomp_n_lit_1;
337 double day_decomp_n_lit_2;
338 double day_decomp_n_lit_3;
339 lvector_t< double > day_decomp_c_hum_1_sl;
340 lvector_t< double > day_decomp_c_hum_2_sl;
341 lvector_t< double > day_decomp_c_hum_3_sl;
342 lvector_t< double > day_decay_c_mic_sl;
343 double day_decomp_n_hum_1;
344 double day_decomp_n_hum_2;
345 double day_decomp_n_hum_3;
348 lvector_t< double > day_c_humify_doc_hum_2_sl;
349 lvector_t< double > day_c_humify_sol_hum_1_sl;
350 lvector_t< double > day_c_humify_cel_hum_1_sl;
351 lvector_t< double > day_c_humify_lig_hum_1_sl;
352 lvector_t< double > day_c_humify_lig_hum_2_sl;
353 lvector_t< double > day_c_humify_mic_hum_1_sl;
354 lvector_t< double > day_c_humify_mic_hum_2_sl;
355 lvector_t< double > day_c_humify_hum_1_hum_2_sl;
356 lvector_t< double > day_c_humify_hum_2_hum_3_sl;
359 double day_n_fix_algae;
360 double day_c_fix_algae;
363 double day_doc_prod_decomp_litter;
364 double day_doc_prod_decomp_humus;
365 double day_doc_prod_decomp_aorg;
372 enum atm_eq_liq{ nh3_atm_eq_liq, o2_atm_eq_liq, co2_atm_eq_liq, ch4_atm_eq_liq, n2o_atm_eq_liq, no_atm_eq_liq, radon_atm_eq_liq };
374 size_t subdaily_time_step_;
377 lvector_t< double > co2_auto_sl;
378 lvector_t< double > co2_hetero_sl;
380 lvector< double > cn_hum_1_sl;
381 lvector< double > cn_hum_2_sl;
382 lvector< double > cn_hum_3_sl;
384 lvector< double > freeze_thaw_fact_sl;
385 lvector< double > litter_type_fact_sl;
388 lvector_t< double > day_acetate_cons_fe3_sl;
389 lvector_t< double > day_h2_c_eq_cons_fe3_sl;
390 lvector_t< double > day_fe2_oxidation_sl;
393 lvector_t< double > day_nitrify_n2o_sl;
394 lvector_t< double > day_nit_no2_no3_sl;
397 lvector_t< double > cn_opt_mic_sl;
400 lvector_t< double > h2_sl;
402 lvector_t< double > o2_liq_sl;
403 lvector_t< double > o2_gas_sl;
404 lvector_t< double > o2_consumption_sl;
406 lvector_t< double > ae_acetate_sl;
407 lvector_t< double > an_acetate_sl;
409 lvector_t< double > ch4_liq_sl;
410 lvector_t< double > ch4_gas_sl;
411 lvector_t< double > co2_liq_sl;
412 lvector_t< double > co2_gas_sl;
414 lvector_t< double > nh4_ae_sl;
415 lvector_t< double > nh4_an_sl;
417 lvector_t< double > don_ae_sl;
418 lvector_t< double > don_an_sl;
420 lvector_t< double > no3_ae_sl;
421 lvector_t< double > no3_an_sl;
423 lvector_t< double > doc_ice_sl;
424 lvector_t< double > acetate_ice_sl;
425 lvector_t< double > no3_ice_sl;
426 lvector_t< double > nh4_ice_sl;
427 lvector_t< double > don_ice_sl;
429 lvector_t< double > n2o_liq_sl;
430 lvector_t< double > n2o_gas_sl;
431 lvector_t< double > an_n2o_liq_sl;
432 lvector_t< double > an_n2o_gas_sl;
433 lvector_t< double > n2_gas_sl;
435 lvector_t< double > no_liq_sl;
436 lvector_t< double > no_gas_sl;
437 lvector_t< double > an_no_liq_sl;
438 lvector_t< double > an_no_gas_sl;
440 lvector_t< double > radon_liq_sl;
441 lvector_t< double > radon_gas_sl;
443 lvector_t< double > c_microbial_necromass_sl;
444 lvector_t< double > n_microbial_necromass_sl;
446 lvector_t< double > c_humus_1_sl;
447 lvector_t< double > c_humus_2_sl;
448 lvector_t< double > c_humus_3_sl;
450 lvector_t< double > n_humus_1_sl;
451 lvector_t< double > n_humus_2_sl;
452 lvector_t< double > n_humus_3_sl;
454 lvector_t< double > n_micro_1_sl;
455 lvector_t< double > n_micro_2_sl;
456 lvector_t< double > n_micro_3_sl;
460 lvector_t< double > D_eff_air_fl;
461 lvector_t< double > D_eff_air_sl;
462 lvector_t< double > D_eff_water_sl;
463 lvector_t< double > D_eff_dailyturbation_sl;
464 lvector_t< double > D_eff_plant_sl;
466 lvector_t< double > interface_air_sl;
467 lvector_t< double > interface_delta_x_air_sl;
468 lvector_t< double > interface_delta_x_water_sl;
469 lvector_t< double > interface_delta_x_soil_sl;
471 lvector_t< double > delta_x;
472 lvector_t< double > pore_connectivity_sl;
475 double ph_delta_pab_wl;
476 double ph_delta_urea_wl;
478 lvector_t< double > ph_delta_urea_sl;
480 lvector_t< double > soil_gas_advection_sl;
481 lvector_t< double > v_water_sl;
482 lvector_t< double > v_air_sl;
483 lvector_t< double > v_ice_sl;
485 lvector_t< double > communicate_sl;
486 lvector_t< double > communicate_fsl;
487 lvector_t< double > day_denit_factor_c_sl;
488 lvector_t< double > day_denit_factor_n_sl;
491 lvector_t< double > day_ch4_production_hydrogen_sl;
492 lvector_t< double > day_ch4_production_acetate_sl;
493 lvector_t< double > day_ch4_oxidation_sl;
495 lvector< double > subdaily_ch4_bubbling;
496 lvector< double > subdaily_ch4_plant;
497 lvector< double > subdaily_ch4_soil;
498 lvector< double > subdaily_ch4_water;
500 lvector< double > subdaily_ch4_leach;
501 lvector< double > subdaily_ch4_prod;
502 lvector< double > subdaily_ch4_ox;
503 lvector< double > subdaily_ch4_content;
505 lvector< double > subdaily_co2_bubbling;
506 lvector< double > subdaily_co2_plant;
507 lvector< double > subdaily_co2_soil;
508 lvector< double > subdaily_co2_water;
509 lvector< double > subdaily_co2_leach;
512 lvector< double > subdaily_acetate_prod;
513 lvector< double > subdaily_doc_prod;
515 lvector< double > subdaily_o2_bubbling;
516 lvector< double > subdaily_o2_plant;
517 lvector< double > subdaily_o2_soil;
518 lvector< double > subdaily_o2_water;
520 lvector< double > subdaily_n2o_bubbling;
521 lvector< double > subdaily_n2o_plant;
522 lvector< double > subdaily_n2o_soil;
523 lvector< double > subdaily_n2o_water;
525 lvector< double > subdaily_no_bubbling;
526 lvector< double > subdaily_no_plant;
527 lvector< double > subdaily_no_soil;
528 lvector< double > subdaily_no_water;
530 lvector< double > subdaily_nh3_bubbling;
531 lvector< double > subdaily_nh3_plant;
532 lvector< double > subdaily_nh3_soil;
533 lvector< double > subdaily_nh3_water;
535 lvector< double > subdaily_plant_o2_cons;
536 lvector< double > subdaily_flood_o2_conc;
537 lvector< double > subdaily_algae_o2_prod;
539 lvector< double > subdaily_radon_soil;
540 lvector< double > subdaily_radon_plant;
541 lvector< double > subdaily_radon_water;
543 lvector< double > day_doc_prod_sl;
544 lvector< double > day_acetate_prod_sl;
545 lvector< double > day_h2_c_eq_prod_sl;
547 lvector< double > plant_o2_consumption_sl;
549 lvector< double > accumulated_n_nh4_throughfall_sl;
550 lvector< double > accumulated_n_no3_throughfall_sl;
551 lvector< double > accumulated_n_nh4_throughfall_sbl;
552 lvector< double > accumulated_n_no3_throughfall_sbl;
553 double accumulated_n_nh4_throughfall_old;
554 double accumulated_n_no3_throughfall_old;
557 lvector< double > accumulated_n_to_living_plant_and_algae_from_extern_sl;
559 lvector< double > accumulated_n_algae_nh4_uptake_sbl;
560 lvector< double > accumulated_n_algae_no3_uptake_sbl;
561 lvector< double > accumulated_n_algae_nh3_uptake_sbl;
563 lvector< double > accumulated_n_litter_from_plants_below_rawlitter_sl;
564 lvector< double > accumulated_n_litter_from_plants_below_wood_sl;
565 double accumulated_n_litter_from_plants_above_rawlitter;
566 double accumulated_n_litter_from_plants_above_wood;
567 double accumulated_n_litter_from_plants_above_stubble;
568 lvector< double > accumulated_n_aboveground_raw_litter_fragmentation_sl;
569 lvector< double > accumulated_n_belowground_raw_litter_fragmentation_sl;
570 lvector< double > accumulated_n_litter_from_algae_sl;
571 lvector< double > accumulated_n_litter_from_dung_sl;
572 lvector< double > accumulated_n_urea_from_dung_sl;
574 double accumulated_n_export_harvest_cutting_grazing;
575 double accumulated_n_export_harvest_old;
576 double accumulated_c_litter_wood_above_old;
578 lvector< double > accumulated_n_nh4_fertilization_sl;
579 lvector< double > accumulated_n_no3_fertilization_sl;
580 lvector< double > accumulated_n_nh3_fertilization_sl;
581 lvector< double > accumulated_n_don_fertilization_sl;
582 lvector< double > accumulated_n_urea_fertilization_sl;
583 lvector< double > accumulated_n_litter_fertilization_sl;
584 lvector< double > accumulated_n_aorg_fertilization_sl;
585 lvector< double > accumulated_n_nh4_fertilization_sbl;
586 lvector< double > accumulated_n_no3_fertilization_sbl;
587 lvector< double > accumulated_n_nh3_fertilization_sbl;
588 lvector< double > accumulated_n_urea_fertilization_sbl;
590 lvector< double > accumulated_n_surface_litter_incorporation_via_tilling_sl;
591 lvector< double > accumulated_n_litter_tilling_sl;
592 lvector< double > accumulated_n_aorg_tilling_sl;
593 lvector< double > accumulated_n_humus_1_tilling_sl;
594 lvector< double > accumulated_n_humus_2_tilling_sl;
595 lvector< double > accumulated_n_humus_3_tilling_sl;
596 lvector< double > accumulated_n_no3_tilling_sl;
597 lvector< double > accumulated_n_no2_tilling_sl;
598 lvector< double > accumulated_n_no_tilling_sl;
599 lvector< double > accumulated_n_n2o_tilling_sl;
600 lvector< double > accumulated_n_urea_tilling_sl;
601 lvector< double > accumulated_n_don_tilling_sl;
602 lvector< double > accumulated_n_nh4_tilling_sl;
603 lvector< double > accumulated_n_nh3_tilling_sl;
604 lvector< double > accumulated_n_microbes_tilling_sl;
606 lvector< double > accumulated_n_humus_1_spinup_sl;
607 lvector< double > accumulated_n_humus_2_spinup_sl;
608 lvector< double > accumulated_n_humus_3_spinup_sl;
609 lvector< double > accumulated_n_surface_litter_spinup_sl;
610 lvector< double > accumulated_n_litter_spinup_sl;
612 lvector< double > accumulated_n_urea_nh4_hydrolysis_sl;
613 lvector< double > accumulated_n_urea_nh4_hydrolysis_sbl;
615 lvector< double > accumulated_n_nh4_assimilation_sl;
616 lvector< double > accumulated_n_no3_assimilation_sl;
617 lvector< double > accumulated_n_don_assimilation_sl;
619 lvector< double > accumulated_n_nh4_nh3_conversion_sl;
620 lvector< double > accumulated_n_nh3_nh4_conversion_sl;
621 lvector< double > accumulated_n_nh4_nh3_conversion_sbl;
622 lvector< double > accumulated_n_nh3_nh4_conversion_sbl;
624 lvector< double > accumulated_n_micro_leaching_sl;
625 lvector< double > accumulated_n_aorg_leaching_sl;
626 lvector< double > accumulated_n_litter_leaching_sl;
627 lvector< double > accumulated_n_humus_1_leaching_sl;
628 lvector< double > accumulated_n_humus_2_leaching_sl;
629 lvector< double > accumulated_n_humus_3_leaching_sl;
630 lvector< double > accumulated_n_nh4_leaching_sl;
631 lvector< double > accumulated_n_nh3_leaching_sl;
632 lvector< double > accumulated_n_don_leaching_sl;
633 lvector< double > accumulated_n_urea_leaching_sl;
634 lvector< double > accumulated_n_no_leaching_sl;
635 lvector< double > accumulated_n_n2o_leaching_sl;
637 lvector< double > accumulated_n_urea_liq_diffusion_sl;
638 lvector< double > accumulated_n_nh3_liq_diffusion_sl;
639 lvector< double > accumulated_n_nh4_liq_diffusion_sl;
640 lvector< double > accumulated_n_no3_liq_diffusion_sl;
642 lvector< double > accumulated_n_nh4_infiltration_phys_sl;
643 lvector< double > accumulated_n_nh3_infiltration_phys_sl;
644 lvector< double > accumulated_n_urea_infiltration_phys_sl;
645 lvector< double > accumulated_n_no3_infiltration_phys_sl;
646 lvector< double > accumulated_n_don_infiltration_phys_sl;
647 lvector< double > accumulated_n_aorg_infiltration_phys_sl;
649 lvector< double > accumulated_n_nh4_infiltration_leach_sl;
650 lvector< double > accumulated_n_nh3_infiltration_leach_sl;
651 lvector< double > accumulated_n_urea_infiltration_leach_sl;
652 lvector< double > accumulated_n_no3_infiltration_leach_sl;
653 lvector< double > accumulated_n_don_infiltration_leach_sl;
654 lvector< double > accumulated_n_no_infiltration_leach_sl;
655 lvector< double > accumulated_n_n2o_infiltration_leach_sl;
657 lvector< double > accumulated_n_nh4_infiltration_liqdif_sl;
658 lvector< double > accumulated_n_nh3_infiltration_liqdif_sl;
659 lvector< double > accumulated_n_urea_infiltration_liqdif_sl;
660 lvector< double > accumulated_n_no3_infiltration_liqdif_sl;
662 lvector< double > accumulated_c_ch4_bubbling_sl;
663 lvector< double > accumulated_c_ch4_bubbling_sbl;
665 lvector< double > accumulated_n_nh3_bubbling_sl;
666 lvector< double > accumulated_n_no_bubbling_sl;
667 lvector< double > accumulated_n_n2o_bubbling_sl;
668 lvector< double > accumulated_n_nh3_bubbling_sbl;
669 lvector< double > accumulated_n_no_bubbling_sbl;
670 lvector< double > accumulated_n_n2o_bubbling_sbl;
672 lvector< double > accumulated_n_nh3_dissolution_sbl;
673 lvector< double > accumulated_n_no_dissolution_sbl;
674 lvector< double > accumulated_n_n2o_dissolution_sbl;
676 lvector< double > accumulated_n_nh3_phys_diffusion_sl;
677 lvector< double > accumulated_n_no_phys_diffusion_sl;
678 lvector< double > accumulated_n_n2o_phys_diffusion_sl;
679 lvector< double > accumulated_n_nh3_gas_diffusion_sl;
680 lvector< double > accumulated_n_no_gas_diffusion_sl;
681 lvector< double > accumulated_n_n2o_gas_diffusion_sl;
683 lvector< double > accumulated_n_micro_perturbation_sl;
684 lvector< double > accumulated_n_aorg_perturbation_sl;
685 lvector< double > accumulated_n_litter_perturbation_sl;
686 lvector< double > accumulated_n_humus_1_perturbation_sl;
687 lvector< double > accumulated_n_humus_2_perturbation_sl;
688 lvector< double > accumulated_n_humus_3_perturbation_sl;
690 lvector< double > accumulated_n_nh4_no2_nitrification_sl;
691 lvector< double > accumulated_n_nh4_no_nitrification_sl;
692 lvector< double > accumulated_n_nh4_n2o_nitrification_sl;
693 lvector< double > accumulated_n_no2_no3_nitrification_sl;
695 lvector< double > accumulated_n_no3_no2_denitrification_sl;
696 lvector< double > accumulated_n_no3_no_denitrification_sl;
697 lvector< double > accumulated_n_no3_n2o_denitrification_sl;
698 lvector< double > accumulated_n_no3_n2_denitrification_sl;
699 lvector< double > accumulated_n_no2_no_denitrification_sl;
700 lvector< double > accumulated_n_no2_n2o_denitrification_sl;
701 lvector< double > accumulated_n_no2_n2_denitrification_sl;
702 lvector< double > accumulated_n_no_n2o_denitrification_sl;
703 lvector< double > accumulated_n_no_n2_denitrification_sl;
704 lvector< double > accumulated_n_n2o_n2_denitrification_sl;
706 lvector< double > accumulated_n_no2_chemodenitrification_sl;
708 lvector< double > accumulated_n_mic_naorg_decay_sl;
709 lvector< double > accumulated_n_mic_nh4_mineral_sl;
710 lvector< double > accumulated_n_mic_don_dissolve_sl;
712 lvector< double > accumulated_n_aorg_nh4_mineral_sl;
713 lvector< double > accumulated_n_aorg_don_dissolve_sl;
715 lvector< double > accumulated_n_humus_1_don_dissolve_sl;
716 lvector< double > accumulated_n_humus_1_nh4_mineral_sl;
717 lvector< double > accumulated_n_humus_2_don_dissolve_sl;
718 lvector< double > accumulated_n_humus_2_nh4_mineral_sl;
719 lvector< double > accumulated_n_humus_3_don_dissolve_sl;
720 lvector< double > accumulated_n_humus_3_nh4_mineral_sl;
722 lvector< double > accumulated_n_litter_don_dissolve_sl;
723 lvector< double > accumulated_n_litter_nh4_mineral_sl;
725 lvector< double > accumulated_n_don_humus_1_humify_sl;
726 lvector< double > accumulated_n_don_humus_2_humify_sl;
727 lvector< double > accumulated_n_don_humus_3_humify_sl;
728 lvector< double > accumulated_n_litter_humus_1_humify_sl;
730 lvector< double > accumulated_c_root_exsudates_old_sl;
732 lvector_t< double > ranvf_sl;
733 lvector_t< double > cumulative_freezing_degree_days_sl;
734 lvector_t< double > cfdd_turnover_sl;
736#ifdef METRX_ANVF_TYPES
737 lvector_t< double > anvf_pnet_sl;
738 lvector_t< double > anvf_dndccan_sl;
739 lvector_t< double > anvf_nloss_sl;
746 SpinUp(
size_t _y,
size_t _sl_cnt) : spinup_type_( 0),
748 executed_months_( 0),
750 c_to_humus_1_sl( _sl_cnt, 0.0),
751 c_to_humus_2_sl( _sl_cnt, 0.0),
752 c_to_humus_3_sl( _sl_cnt, 0.0),
753 humify_humus_1_to_humus_2_sl( _sl_cnt, 0.0),
754 humify_humus_2_to_humus_3_sl( _sl_cnt, 0.0),
755 decompose_hum_1( _sl_cnt, 0.0),
756 decompose_hum_2( _sl_cnt, 0.0),
757 decompose_hum_3( _sl_cnt, 0.0),
759 loose_lit_1( _sl_cnt, 0.0),
760 loose_lit_2( _sl_cnt, 0.0),
761 loose_lit_3( _sl_cnt, 0.0),
763 c_to_lit_1( _sl_cnt, 0.0),
764 c_to_lit_2( _sl_cnt, 0.0),
765 c_to_lit_3( _sl_cnt, 0.0),
767 loose_aorg( _sl_cnt, 0.0),
768 c_to_aorg( _sl_cnt, 0.0),
770 c_humus_1_temp_sl( _sl_cnt, 0.0),
771 c_humus_2_temp_sl( _sl_cnt, 0.0),
772 c_humus_3_temp_sl( _sl_cnt, 0.0),
774 c_litter_1_temp_sl( _sl_cnt, 0.0),
775 c_litter_2_temp_sl( _sl_cnt, 0.0),
776 c_litter_3_temp_sl( _sl_cnt, 0.0),
778 n_litter_1_temp_sl( _sl_cnt, 0.0),
779 n_litter_2_temp_sl( _sl_cnt, 0.0),
780 n_litter_3_temp_sl( _sl_cnt, 0.0),
782 c_aorg_temp_sl( _sl_cnt, 0.0),
783 n_aorg_temp_sl( _sl_cnt, 0.0),
785 cn_humus_2_temp_sl( _sl_cnt, 0.0),
786 cn_humus_3_temp_sl( _sl_cnt, 0.0),
791 this->set_spinup_years( _y);
799 void reset(
bool _reset_litter =
true)
801 c_to_humus_1_sl = 0.0;
802 c_to_humus_2_sl = 0.0;
803 c_to_humus_3_sl = 0.0;
804 humify_humus_1_to_humus_2_sl = 0.0;
805 humify_humus_2_to_humus_3_sl = 0.0;
806 decompose_hum_1 = 0.0;
807 decompose_hum_2 = 0.0;
808 decompose_hum_3 = 0.0;
827 inline size_t spinup_type()
const
829 return this->spinup_type_;
832 inline size_t spinup_months()
const
834 return this->spinup_years_ * 12;
837 inline size_t spinup_years()
const
839 return this->spinup_years_;
848 void set_spinup_type(
size_t _t)
850 this->spinup_type_ = _t;
853 void set_spinup_years(
size_t _y)
855 this->spinup_years_ = _y;
856 if ( this->spinup_years_ > 0)
858 this->execute_ =
true;
862 size_t simulated_years( cbm::sclock_t
const *)
const;
864 bool spinup_stage( cbm::sclock_t
const *)
const;
866 bool execute_spinup( cbm::sclock_t
const *);
869 size_t spinup_years_;
870 size_t executed_months_;
878 lvector< double > c_to_humus_1_sl;
879 lvector< double > c_to_humus_2_sl;
880 lvector< double > c_to_humus_3_sl;
882 lvector< double > humify_humus_1_to_humus_2_sl;
883 lvector< double > humify_humus_2_to_humus_3_sl;
885 lvector< double > decompose_hum_1;
886 lvector< double > decompose_hum_2;
887 lvector< double > decompose_hum_3;
889 lvector< double > loose_lit_1;
890 lvector< double > loose_lit_2;
891 lvector< double > loose_lit_3;
893 lvector< double > c_to_lit_1;
894 lvector< double > c_to_lit_2;
895 lvector< double > c_to_lit_3;
897 lvector< double > loose_aorg;
898 lvector< double > c_to_aorg;
900 lvector< double > c_humus_1_temp_sl;
901 lvector< double > c_humus_2_temp_sl;
902 lvector< double > c_humus_3_temp_sl;
904 lvector< double > c_litter_1_temp_sl;
905 lvector< double > c_litter_2_temp_sl;
906 lvector< double > c_litter_3_temp_sl;
908 lvector< double > n_litter_1_temp_sl;
909 lvector< double > n_litter_2_temp_sl;
910 lvector< double > n_litter_3_temp_sl;
912 lvector< double > c_aorg_temp_sl;
913 lvector< double > n_aorg_temp_sl;
915 lvector< double > cn_humus_2_temp_sl;
916 lvector< double > cn_humus_3_temp_sl;
935 MeTrX_write_output();
943 MeTrX_write_output_daily();
951 MeTrX_write_output_yearly();
959 MeTrX_write_output_layer_daily();
967 MeTrX_write_output_layer_yearly();
975 MeTrX_write_output_fluxes();
983 MeTrX_write_output_pools();
991 MeTrX_write_output_subdaily();
1042 MeTrX_reset_subdaily();
1050 MeTrX_reset_daily();
1066 MeTrX_check_for_negative_value(
1081 MeTrX_balance_check(
1109 MeTrX_groundwater_access();
1115 MeTrX_plant_respiration(
int );
1135 MeTrX_freeze_thaw();
1143 MeTrX_radon_source_sink();
1149 radon_emanation_coeff(
1162 MeTrX_fragmentation();
1168 MeTrX_litter_distribution(
1175 lvector< double > &accumulated_litter_sl);
1186 MeTrX_liq_diffusion_scale(
double &_out, lvector_t< double > &_scale);
1202 MeTrX_pertubation();
1221 MeTrX_ebullition_transfer(
1303 MeTrX_get_mineral_efficiency(
1311 MeTrX_get_micro_c_decay_max(
1318 MeTrX_get_micro_n_decay_max(
1325 MeTrX_dead_microbial_biomass_allocation(
1336 MeTrX_execute_c_growth(
1347 MeTrX_execute_co2_prod(
1357 MeTrX_execute_n_assimilation(
1382 MeTrX_urea_hydrolysis();
1390 MeTrX_pH_calculation();
1400 MeTrX_nitrogen_fertilizer_release();
1432 MeTrX_clay_nh4_equilibrium();
1440 MeTrX_nh3_nh4_equilibrium();
1466 MeTrX_get_fact_ph_som_turnover(
size_t const &);
1474 MeTrX_get_fact_tm_decomp(
size_t const &);
1476 MeTrX_get_fact_clay_decomp(
size_t const &);
1478 MeTrX_get_fact_clay_humify(
size_t const &);
1480 MeTrX_get_fact_t_mic(
size_t const &);
1482 MeTrX_get_fact_m_mic(
size_t const &);
1484 MeTrX_get_fact_tm_mic(
size_t const &);
1487 MeTrX_get_fact_t_denit(
size_t const &);
1489 MeTrX_get_fact_m_denit(
size_t const &);
1491 MeTrX_get_fact_tm_denit(
size_t const &);
1496 inline double MeTrX_get_fact_mm(
1497 double const &_conc,
1500 return (_conc / (_k + _conc));
1509 double const &_k_mm)
1511 return (_k_mm * sc_.h_sl[_sl]);
1535 MeTrX_get_atm_eq_liq(
1545 MeTrX_receive_state();
1562 MeTrX_dissolution_soil(
double const &,
1572 MeTrX_update_soil_discretization(
bool);
1575 MeTrX_forest_ecosytem();
Biogeochemical model MeTrx.
Definition: soilchemistry-metrx.h:29
void MeTrX_iron_reduction()
lerr_t MeTrX_gas_diffusion()
static const double C_SATURATION
Definition: soilchemistry-metrx.h:34
void MeTrX_denitrification()
void MeTrX_chemodenitrification()
void MeTrX_microbial_dynamics()
void MeTrX_iron_oxidation()
void MeTrX_soil_organic_matter_turnover()
static const double TNORM
Definition: soilchemistry-metrx.h:31
double MeTrX_get_k_mm_x_sl(size_t const &_sl, double const &_k_mm)
Scales Michaelis-Menten constant according to spatial discretization.
Definition: soilchemistry-metrx.h:1507
void MeTrX_ch4_oxidation()
void MeTrX_anaerobic_volume()
void MeTrX_algae_dynamics()
void MeTrX_liq_diffusion()
void MeTrX_ch4_production()
lerr_t MeTrX_dissolution()
void MeTrX_nitrification()
lerr_t MeTrX_fermentation()
Spatially explicit groundwater model.
Definition: airchemistryput.h:15