LandscapeDNDC 1.37.0
output-vegstructure-yearly.h
1
10#ifndef LM_OUTPUT_VEGSTRUCTURE_YEARLY_H_NEW_
11#define LM_OUTPUT_VEGSTRUCTURE_YEARLY_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 OutputVegstructureYearly
18#define LMOD_OUTPUT_MODULE_ID "output:vegstructure:yearly"
19#define LMOD_OUTPUT_MODULE_DESC "Vegetation Structure Yearly Output"
20namespace ldndc {
21class substate_physiology_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 sink_handle_acquire_(
47 sink_handle_t & /*sink handle*/, int /*index*/);
48
49 private:
50 cbm::io_kcomm_t * io_kcomm;
51
52 substate_physiology_t const * phys;
53 MoBiLE_PlantVegetation * m_veg;
54
55 private:
56 lerr_t acquire_sinks_if_needed_();
57 size_t max_sink_index_() const;
58 std::vector< ldndc::sink_handle_t > m_sinks;
59 ldndc::sink_handle_t m_sinksum;
60
61 lerr_t m_writerecord( MoBiLE_Plant *, ldndc_flt64_t * /*buffer*/,
62 ldndc_flt64_t * /*average buffer*/);
63};
64} /*namespace ldndc*/
65
66
67#undef LMOD_OUTPUT_MODULE_BASE
68#undef LMOD_OUTPUT_MODULE_NAME
69#undef LMOD_OUTPUT_MODULE_ID
70#undef LMOD_OUTPUT_MODULE_DESC
71
72
73#endif /* !LM_OUTPUT_VEGSTRUCTURE_YEARLY_H_NEW_ */
74
Spatially explicit groundwater model.
Definition: airchemistryput.h:15