12 #ifndef _H_SST_CORE_STATISTICS_ENGINE
13 #define _H_SST_CORE_STATISTICS_ENGINE
15 #include "sst/core/sst_types.h"
16 #include "sst/core/statapi/statfieldinfo.h"
17 #include "sst/core/statapi/statgroup.h"
18 #include "sst/core/statapi/statbase.h"
19 #include "sst/core/statapi/statnull.h"
20 #include "sst/core/unitAlgebra.h"
21 #include "sst/core/clock.h"
22 #include "sst/core/oneshot.h"
23 #include "sst/core/threadsafe.h"
24 #include "sst/core/factory.h"
27 extern int main(
int argc,
char **argv);
28 extern void finalize_statEngineConfig(
void);
33 class Simulation_impl;
35 class ConfigStatGroup;
36 class ConfigStatOutput;
39 namespace Statistics {
43 class StatisticOutput;
75 const std::string& statName,
const std::string& statSubId,
79 return Factory::getFactory()->Create<
Statistic<T>>(type, params, comp, statName, statSubId, params);
82 bool registerStatisticWithEngine(
StatisticBase* stat) {
return registerStatisticCore(stat); }
84 uint8_t statLoadLevel()
const {
return m_statLoadLevel; }
86 const std::vector<StatisticOutput*>& getStatOutputs()
const {
return m_statOutputs; }
90 friend int ::main(
int argc,
char **argv);
91 friend void ::finalize_statEngineConfig(
void);
112 void finalizeInitialization();
113 void startOfSimulation();
114 void endOfSimulation();
117 void performStatisticOutputImpl(
StatisticBase* stat,
bool endOfSimFlag);
118 void performStatisticGroupOutputImpl(
StatisticGroup& group,
bool endOfSimFlag);
120 bool handleStatisticEngineClockEvent(Cycle_t CycleNum, SimTime_t timeFactor);
121 bool handleGroupClockEvent(Cycle_t CycleNum,
StatisticGroup* group);
122 void handleStatisticEngineStartTimeEvent(SimTime_t timeFactor);
123 void handleStatisticEngineStopTimeEvent(SimTime_t timeFactor);
124 StatisticBase* isStatisticInCompStatMap(
const std::string& compName,
const ComponentId_t& compId,
125 const std::string& statName,
const std::string& statSubId,
126 StatisticFieldInfo::fieldType_t fieldType);
127 void addStatisticToCompStatMap(
StatisticBase* Stat, StatisticFieldInfo::fieldType_t fieldType);
128 void castError(
const std::string& type,
const std::string& statName,
const std::string& fieldName);
131 typedef std::vector<StatisticBase*> StatArray_t;
132 typedef std::map<SimTime_t, StatArray_t*> StatMap_t;
133 typedef std::map<ComponentId_t, StatArray_t*> CompStatMap_t;
135 StatArray_t m_EventStatisticArray;
136 StatMap_t m_PeriodicStatisticMap;
137 StatMap_t m_StartTimeMap;
138 StatMap_t m_StopTimeMap;
139 CompStatMap_t m_CompStatMap;
140 bool m_SimulationStarted;
143 uint8_t m_statLoadLevel;
144 std::vector<StatisticOutput*> m_statOutputs;
146 std::vector<StatisticGroup> m_statGroups;
Output object provides consistent method for outputting data to stdout, stderr and/or sst debug file...
Definition: output.h:54
Forms the base class for statistics output generation within the SST core.
Definition: statoutput.h:49
A Configuration Graph A graph representing Components and Links.
Definition: configGraph.h:358
void performStatisticOutput(StatisticBase *stat, bool endOfSimFlag=false)
Called by the Components and Subcomponent to perform a statistic Output.
Definition: statengine.cc:430
Forms the base class for statistics gathering within SST.
Definition: statbase.h:64
void setup()
Perform the setup() and run phases of the simulation.
Definition: simulation.cc:558
Forms the template defined base class for statistics gathering within SST.
Definition: elementinfo.h:42
Main control class for a SST Simulation.
Definition: simulation_impl.h:72
Main component object for the simulation.
Definition: baseComponent.h:53
Parameter store.
Definition: params.h:44
Definition: configGraph.h:194
void performGlobalStatisticOutput(bool endOfSimFlag=false)
Called by the Components and Subcomponent to perform a global statistic Output.
Definition: statengine.cc:494
An SST core component that handles timing and event processing informing all registered Statistics to...
Definition: statengine.h:52
Definition: statgroup.h:29
Performs Unit math in full precision.
Definition: unitAlgebra.h:107
Definition: threadsafe.h:50