LandscapeDNDC 1.37.0
output-soilchemistry-subdaily.h
1
10#ifndef LM_OUTPUT_SOILCHEMISTRY_SUBDAILY_H_NEW_
11#define LM_OUTPUT_SOILCHEMISTRY_SUBDAILY_H_NEW_
12
13#include "mbe_legacyoutputmodel.h"
14#include "state/mbe_state.h"
15
16#define LMOD_OUTPUT_MODULE_BASE MBE_LegacyOutputModel
17#define LMOD_OUTPUT_MODULE_NAME OutputSoilchemistrySubdaily
18#define LMOD_OUTPUT_MODULE_ID "output:soilchemistry:subdaily"
19#define LMOD_OUTPUT_MODULE_DESC "Soil Chemistry Subdaily Output"
20namespace ldndc {
21class substate_soilchemistry_t;
22class LDNDC_API LMOD_OUTPUT_MODULE_NAME : public LMOD_OUTPUT_MODULE_BASE
23{
24 LMOD_EXPORT_MODULE_INFO(LMOD_OUTPUT_MODULE_NAME,LMOD_OUTPUT_MODULE_ID,LMOD_OUTPUT_MODULE_DESC);
25 public:
26 LMOD_OUTPUT_MODULE_NAME(
27 MoBiLE_State *,
28 cbm::io_kcomm_t *,
29 timemode_e _timemode);
30
31 ~LMOD_OUTPUT_MODULE_NAME();
32
33
34 lerr_t configure( ldndc::config_file_t const *);
35
36 lerr_t initialize();
37
38 lerr_t solve();
39
40 lerr_t finalize();
41
42 lerr_t wake() { return LDNDC_ERR_OK; }
43 lerr_t sleep() { return LDNDC_ERR_OK; }
44
45 private:
46 lerr_t dump_0(
47 ldndc_flt64_t *);
48
49 private:
50 cbm::io_kcomm_t * io_kcomm;
51 substate_soilchemistry_t const * soilchem;
52 private:
53 ldndc::sink_handle_t m_sink;
54
55 struct output_soilchemistry_subdaily_acc_t
56 {
57 double doc_leach;
58 double don_leach;
59 double no3_leach;
60 double nh4_leach;
61
62 double co2_emis;
63 double co2_emis_auto;
64 double co2_emis_hetero;
65
66 double no_emis;
67 double n2o_emis;
68 double n2_emis;
69 double nh3_emis;
70 };
71 output_soilchemistry_subdaily_acc_t acc;
72 void pop_accumulated_outputs();
73 void push_accumulated_outputs();
74};
75} /*namespace ldndc*/
76
77
78#undef LMOD_OUTPUT_MODULE_BASE
79#undef LMOD_OUTPUT_MODULE_NAME
80#undef LMOD_OUTPUT_MODULE_ID
81#undef LMOD_OUTPUT_MODULE_DESC
82
83
84#endif /* !LM_OUTPUT_SOILCHEMISTRY_SUBDAILY_H_NEW_ */
85
Spatially explicit groundwater model.
Definition: airchemistryput.h:15