SST
8.0.0
StructuralSimulationToolkit
|
Main component object for the simulation. More...
#include <baseComponent.h>
Public Member Functions | |
ComponentId_t | getId () const |
Returns unique component ID. | |
virtual void | emergencyShutdown (void) |
Called when SIGINT or SIGTERM has been seen. More... | |
const std::string & | getName () const |
Returns component Name. | |
virtual void | init (unsigned int UNUSED(phase)) |
Used during the init phase. More... | |
virtual void | complete (unsigned int UNUSED(phase)) |
Used during the init phase. More... | |
virtual void | setup () |
Called after all components have been constructed and initialization has completed, but before simulation time has begun. More... | |
virtual void | finish () |
Called after simulation completes, but before objects are destroyed. More... | |
virtual bool | Status () |
Currently unused function. | |
virtual void | printStatus (Output &UNUSED(out)) |
Called by the Simulation to request that the component print it's current status. More... | |
bool | isPortConnected (const std::string &name) const |
Determine if a port name is connected to any links. | |
Link * | configureLink (std::string name, TimeConverter *time_base, Event::HandlerBase *handler=NULL) |
Configure a Link. More... | |
Link * | configureLink (std::string name, std::string time_base, Event::HandlerBase *handler=NULL) |
Configure a Link. More... | |
Link * | configureLink (std::string name, Event::HandlerBase *handler=NULL) |
Configure a Link. More... | |
Link * | configureSelfLink (std::string name, TimeConverter *time_base, Event::HandlerBase *handler=NULL) |
Configure a SelfLink (Loopback link) More... | |
Link * | configureSelfLink (std::string name, std::string time_base, Event::HandlerBase *handler=NULL) |
Configure a SelfLink (Loopback link) More... | |
Link * | configureSelfLink (std::string name, Event::HandlerBase *handler=NULL) |
Configure a SelfLink (Loopback link) More... | |
TimeConverter * | registerClock (std::string freq, Clock::HandlerBase *handler, bool regAll=true) |
Registers a clock for this component. More... | |
TimeConverter * | registerClock (const UnitAlgebra &freq, Clock::HandlerBase *handler, bool regAll=true) |
void | unregisterClock (TimeConverter *tc, Clock::HandlerBase *handler) |
Removes a clock handler from the component. | |
Cycle_t | reregisterClock (TimeConverter *freq, Clock::HandlerBase *handler) |
Reactivates an existing Clock and Handler. More... | |
Cycle_t | getNextClockCycle (TimeConverter *freq) |
Returns the next Cycle that the TimeConverter would fire. | |
TimeConverter * | registerOneShot (std::string timeDelay, OneShot::HandlerBase *handler) |
Registers a OneShot event for this component. More... | |
TimeConverter * | registerOneShot (const UnitAlgebra &timeDelay, OneShot::HandlerBase *handler) |
TimeConverter * | registerTimeBase (std::string base, bool regAll=true) |
Registers a default time base for the component and optionally sets the the component's links to that timebase. More... | |
TimeConverter * | getTimeConverter (const std::string &base) |
TimeConverter * | getTimeConverter (const UnitAlgebra &base) |
SimTime_t | getCurrentSimTime (TimeConverter *tc) const |
return the time since the simulation began in units specified by the parameter. More... | |
SimTime_t | getCurrentSimTime () const |
return the time since the simulation began in the default timebase | |
SimTime_t | getCurrentSimTime (std::string base) |
return the time since the simulation began in timebase specified More... | |
SimTime_t | getCurrentSimTimeNano () const |
Utility function to return the time since the simulation began in nanoseconds. | |
SimTime_t | getCurrentSimTimeMicro () const |
Utility function to return the time since the simulation began in microseconds. | |
SimTime_t | getCurrentSimTimeMilli () const |
Utility function to return the time since the simulation began in milliseconds. | |
template<typename T > | |
Statistic< T > * | registerStatistic (std::string statName, std::string statSubId="") |
Registers a statistic. More... | |
template<typename T > | |
Statistic< T > * | registerStatistic (const char *statName, const char *statSubId="") |
Module * | loadModule (std::string type, Params ¶ms) |
Loads a module from an element Library. More... | |
Module * | loadModuleWithComponent (std::string type, Component *comp, Params ¶ms) |
Loads a module from an element Library. More... | |
SubComponent * | loadSubComponent (std::string type, Component *comp, Params ¶ms) |
Loads a SubComponent from an element Library. More... | |
SubComponent * | loadNamedSubComponent (std::string name) |
SubComponent * | loadNamedSubComponent (std::string name, Params ¶ms) |
SubComponentSlotInfo * | getSubComponentSlotInfo (std::string name, bool fatalOnEmptyIndex=false) |
const std::vector< double > & | getCoordinates () const |
Retrieve the X,Y,Z coordinates of this component. | |
Protected Member Functions | |
void | setDefaultTimeBase (TimeConverter *tc) |
Manually set the default detaulTimeBase. | |
Link * | selfLink (std::string name, Event::HandlerBase *handler=NULL) |
Creates a new selfLink. | |
SharedRegion * | getLocalSharedRegion (const std::string &key, size_t size) |
Find a lookup table. | |
SharedRegion * | getGlobalSharedRegion (const std::string &key, size_t size, SharedRegionMerger *merger=NULL) |
Simulation * | getSimulation () const |
virtual bool | doesComponentInfoStatisticExist (const std::string &statisticName) const =0 |
uint8_t | getComponentInfoStatisticEnableLevel (const std::string &statisticName) const |
std::string | getComponentInfoStatisticUnits (const std::string &statisticName) const |
virtual Component * | getTrueComponent () const =0 |
virtual BaseComponent * | getStatisticOwner () const =0 |
Returns self if Component If sub-component, returns self if a "modern" subcomponent otherwise, return base component. | |
Protected Attributes | |
TimeConverter * | defaultTimeBase |
Timebase used if no other timebase is specified for calls like BaseComponent::getCurrentSimTime(). More... | |
ComponentInfo * | my_info |
Simulation * | sim |
ComponentInfo * | currentlyLoadingSubComponent |
Friends | |
class | SubComponentSlotInfo_impl |
class | SST::Statistics::StatisticProcessingEngine |
Main component object for the simulation.
|
inlinevirtual |
Used during the init phase.
The method will be called each phase of initialization. Initialization ends when no components have sent any data.
Reimplemented in SST::Interfaces::SimpleNetwork.
Link * SST::BaseComponent::configureLink | ( | std::string | name, |
TimeConverter * | time_base, | ||
Event::HandlerBase * | handler = NULL |
||
) |
Configure a Link.
name | - Port Name on which the link to configure is attached. |
time_base | - Time Base of the link |
handler | - Optional Handler to be called when an Event is received |
References SST::LinkMap::getLink(), SST::Link::setDefaultTimeBase(), SST::Link::setFunctor(), and SST::Link::setPolling().
Referenced by configureLink(), and configureSelfLink().
Link * SST::BaseComponent::configureLink | ( | std::string | name, |
std::string | time_base, | ||
Event::HandlerBase * | handler = NULL |
||
) |
Configure a Link.
name | - Port Name on which the link to configure is attached. |
time_base | - Time Base of the link |
handler | - Optional Handler to be called when an Event is received |
References configureLink().
Link * SST::BaseComponent::configureLink | ( | std::string | name, |
Event::HandlerBase * | handler = NULL |
||
) |
Configure a Link.
name | - Port Name on which the link to configure is attached. |
handler | - Optional Handler to be called when an Event is received |
References SST::LinkMap::getLink(), SST::Link::setFunctor(), and SST::Link::setPolling().
Link * SST::BaseComponent::configureSelfLink | ( | std::string | name, |
TimeConverter * | time_base, | ||
Event::HandlerBase * | handler = NULL |
||
) |
Configure a SelfLink (Loopback link)
name | - Name of the self-link port |
time_base | - Time Base of the link |
handler | - Optional Handler to be called when an Event is received |
References configureLink().
Link * SST::BaseComponent::configureSelfLink | ( | std::string | name, |
std::string | time_base, | ||
Event::HandlerBase * | handler = NULL |
||
) |
Configure a SelfLink (Loopback link)
name | - Name of the self-link port |
time_base | - Time Base of the link |
handler | - Optional Handler to be called when an Event is received |
References configureLink().
Link * SST::BaseComponent::configureSelfLink | ( | std::string | name, |
Event::HandlerBase * | handler = NULL |
||
) |
Configure a SelfLink (Loopback link)
name | - Name of the self-link port |
handler | - Optional Handler to be called when an Event is received |
References configureLink().
|
inlinevirtual |
Called when SIGINT or SIGTERM has been seen.
Allows components opportunity to clean up external state.
|
inlinevirtual |
Called after simulation completes, but before objects are destroyed.
A good place to print out statistics.
Reimplemented in SST::Interfaces::SimpleNetwork, and SST::SubComponent.
SimTime_t SST::BaseComponent::getCurrentSimTime | ( | TimeConverter * | tc | ) | const |
return the time since the simulation began in units specified by the parameter.
tc | TimeConverter specifying the units |
References SST::TimeConverter::convertFromCoreTime().
SimTime_t SST::BaseComponent::getCurrentSimTime | ( | std::string | base | ) |
return the time since the simulation began in timebase specified
base | Timebase frequency in SI Units |
References getCurrentSimTime().
|
inlinevirtual |
Used during the init phase.
The method will be called each phase of initialization. Initialization ends when no components have sent any data.
Reimplemented in SST::Interfaces::SimpleNetwork, and SST::SubComponent.
Loads a module from an element Library.
type | Fully Qualified library.moduleName |
params | Parameters the module should use for configuration |
Module * SST::BaseComponent::loadModuleWithComponent | ( | std::string | type, |
Component * | comp, | ||
Params & | params | ||
) |
Loads a module from an element Library.
type | Fully Qualified library.moduleName |
comp | Pointer to component to pass to Module's constructor |
params | Parameters the module should use for configuration |
SubComponent * SST::BaseComponent::loadSubComponent | ( | std::string | type, |
Component * | comp, | ||
Params & | params | ||
) |
Loads a SubComponent from an element Library.
type | Fully Qualified library.moduleName |
comp | Pointer to component to pass to SuBaseComponent's constructor |
params | Parameters the module should use for configuration |
|
inlinevirtual |
Called by the Simulation to request that the component print it's current status.
Useful for debugging.
out | The Output class which should be used to print component status. |
TimeConverter * SST::BaseComponent::registerClock | ( | std::string | freq, |
Clock::HandlerBase * | handler, | ||
bool | regAll = true |
||
) |
Registers a clock for this component.
freq | Frequency for the clock in SI units |
handler | Pointer to Clock::HandlerBase which is to be invoked at the specified interval |
regAll | Should this clock period be used as the default time base for all of the links connected to this component |
References defaultTimeBase, SST::LinkMap::getLinkMap(), and SST::Simulation::registerClock().
TimeConverter * SST::BaseComponent::registerOneShot | ( | std::string | timeDelay, |
OneShot::HandlerBase * | handler | ||
) |
Registers a OneShot event for this component.
Note: OneShot cannot be canceled, and will always callback after the timedelay.
timeDelay | Time delay for the OneShot in SI units |
handler | Pointer to OneShot::HandlerBase which is to be invoked at the specified interval |
References SST::Simulation::registerOneShot().
|
inline |
Registers a statistic.
If Statistic is allowed to run (controlled by Python runtime parameters), then a statistic will be created and returned. If not allowed to run, then a NullStatistic will be returned. In either case, the returned value should be used for all future Statistic calls. The type of Statistic and the Collection Rate is set by Python runtime parameters. If no type is defined, then an Accumulator Statistic will be provided by default. If rate set to 0 or not provided, then the statistic will output results only at end of sim (if output is enabled).
statName | Primary name of the statistic. This name must match the defined ElementInfoStatistic in the component, and must also be enabled in the Python input file. |
statSubId | An additional sub name for the statistic |
TimeConverter * SST::BaseComponent::registerTimeBase | ( | std::string | base, |
bool | regAll = true |
||
) |
Registers a default time base for the component and optionally sets the the component's links to that timebase.
Useful for components which do not have a clock, but would like a default timebase.
base | Frequency for the clock in SI units |
regAll | Should this clock period be used as the default time base for all of the links connected to this component |
References defaultTimeBase, SST::LinkMap::getLinkMap(), SST::TimeLord::getTimeConverter(), and SST::Simulation::getTimeLord().
Cycle_t SST::BaseComponent::reregisterClock | ( | TimeConverter * | freq, |
Clock::HandlerBase * | handler | ||
) |
Reactivates an existing Clock and Handler.
References SST::Simulation::reregisterClock().
|
inlinevirtual |
Called after all components have been constructed and initialization has completed, but before simulation time has begun.
Reimplemented in SST::Interfaces::SimpleNetwork, and SST::SubComponent.
|
protected |
Timebase used if no other timebase is specified for calls like BaseComponent::getCurrentSimTime().
Often set by BaseComponent::registerClock() function
Referenced by registerClock(), and registerTimeBase().