14 #ifndef SST_CORE_TIMELORD_H
15 #define SST_CORE_TIMELORD_H
17 #include "sst/core/sst_types.h"
22 #include "sst/core/simulation.h"
23 #include "sst/core/unitAlgebra.h"
24 #include "sst/core/threadsafe.h"
26 extern int main(
int argc,
char **argv);
37 typedef std::map<SimTime_t,TimeConverter*> TimeConverterMap_t;
38 typedef std::map<std::string,TimeConverter*> StringToTCMap_t;
75 SimTime_t
getSimCycles(
const std::string& timeString,
const std::string& where);
80 friend int ::main(
int argc,
char **argv);
82 void init(
const std::string& timeBaseString);
91 TimeLord(TimeLord
const&);
92 void operator=(TimeLord
const&);
95 std::recursive_mutex slock;
98 std::string timeBaseString;
99 TimeConverterMap_t tcMap;
100 UnitAlgebra timeBase;
103 StringToTCMap_t parseCache;
106 TimeConverter* micro;
107 TimeConverter* milli;
113 #endif //SST_CORE_TIMELORD_H
TimeConverter * getTimeConverter(const std::string &ts)
Create a new TimeConverter object using specified SI Units.
Definition: timeLord.cc:29
Main control class for a SST Simulation.
Definition: simulation.h:73
A class to convert between a component's view of time and the core's view of time.
Definition: timeConverter.h:25
SimTime_t getSimCycles(const std::string &timeString, const std::string &where)
Not a Public API.
Definition: timeLord.cc:114
TimeConverter * getNano()
Return a TimeConverter which represents Nanoseconds.
Definition: timeLord.h:66
UnitAlgebra getTimeBase() const
Return the Time Base of the TimeLord.
Definition: timeLord.h:63
TimeConverter * getMicro()
Return a TimeConverter which represents Microseconds.
Definition: timeLord.h:68
TimeConverter * getMilli()
Return a TimeConverter which represents Milliseconds.
Definition: timeLord.h:70
Class for creating and managing TimeConverter objects.
Definition: timeLord.h:36
Performs Unit math in full precision.
Definition: unitAlgebra.h:107