A base class for all nodes from which systems models are constructed.
More...
#include <system_node.h>
Inherited by sydevs::systems::atomic_node, sydevs::systems::collection_node_base, sydevs::systems::composite_node, and sydevs::systems::function_node.
|
std::mt19937 & | rng |
| Reference to the random number generator. More...
|
|
A base class for all nodes from which systems models are constructed.
The system_node
abstract base class is inherited by classes representing various types of system nodes:
Concrete derived classes must implement the following pure virtual member functions:
node_dmode
, which distinguishes between flow
(data flow, untimed) nodes and message
(message passing, timed) nodes;
time_precision
, which indicates the time quantum that must evenly divide all planned and elapsed durations associated with the node (unless the time precision is no_scale
);
adopt_component_print_flags
, which copies print flags from the components of another node to the components of this
node.
handle_initialization_event
, which is called at the beginning of a simulation;
handle_unplanned_event
, which is called whenever a message is received;
handle_planned_event
, which is called when the planned duration elapses;
handle_finalization_event
, which is called at the end of a simulation.
◆ system_node() [1/3]
sydevs::systems::system_node::system_node |
( |
const system_node & |
| ) |
|
|
delete |
◆ system_node() [2/3]
sydevs::systems::system_node::system_node |
( |
system_node && |
| ) |
|
|
delete |
◆ ~system_node()
virtual sydevs::systems::system_node::~system_node |
( |
| ) |
|
|
virtualdefault |
◆ system_node() [3/3]
sydevs::systems::system_node::system_node |
( |
const std::string & |
node_name, |
|
|
const node_context & |
external_context |
|
) |
| |
|
inlineprotected |
Constructs a system_node
.
Constructs the system node and its associated node_interface
object that associates the node with its surrounding context. The rng
reference is connected with the main random number generator.
- Parameters
-
node_name | The name of the node within the encompassing context. |
external_context | The context in which the node is constructed. |
◆ adopt_print_flags()
void sydevs::systems::system_node::adopt_print_flags |
( |
const system_node & |
node | ) |
const |
Adopts the print flags of node
.
◆ ET()
timer & sydevs::systems::system_node::ET |
( |
| ) |
const |
|
inlineprotected |
Returns a non-const reference to the node's event timer.
◆ event_timer()
const timer & sydevs::systems::system_node::event_timer |
( |
| ) |
const |
|
inline |
Returns the object that accumulated wallclock event durations.
◆ external_interface()
const node_interface & sydevs::systems::system_node::external_interface |
( |
| ) |
const |
|
inline |
Returns the object responsible for exchanging information between the node and its surrounding context.
◆ external_IO()
Returns a non-const reference to the node's external interface.
◆ full_name()
const std::string & sydevs::systems::system_node::full_name |
( |
| ) |
const |
|
inline |
Returns the full name of the node, including parent nodes.
◆ node_dmode()
virtual data_mode sydevs::systems::system_node::node_dmode |
( |
| ) |
const |
|
pure virtual |
◆ node_index()
int64 sydevs::systems::system_node::node_index |
( |
| ) |
const |
|
inline |
Returns the index of the node within the parent node.
◆ node_name()
const std::string & sydevs::systems::system_node::node_name |
( |
| ) |
const |
|
inline |
Returns the name of the node.
◆ operator=() [1/2]
◆ operator=() [2/2]
◆ print() [1/3]
void sydevs::systems::system_node::print |
( |
const char * |
raw_text | ) |
|
|
inline |
Prints raw_text
while indicating the simulation time and node.
◆ print() [2/3]
void sydevs::systems::system_node::print |
( |
const std::string & |
text | ) |
|
|
inline |
Prints text
while indicating the simulation time and node.
◆ print() [3/3]
template<typename T >
void sydevs::systems::system_node::print |
( |
const T & |
X | ) |
|
|
inline |
Prints X
while indicating the simulation time and node.
◆ print_on_event()
void sydevs::systems::system_node::print_on_event |
( |
bool |
flag = true | ) |
const |
|
inline |
If flag
is true
, all event types are printed for this node.
◆ process_finalization_event()
void sydevs::systems::system_node::process_finalization_event |
( |
duration |
elapsed_dt | ) |
|
|
inline |
Processes a finalization event after an elapsed duration elapsed_dt
.
◆ process_initialization_event()
duration sydevs::systems::system_node::process_initialization_event |
( |
| ) |
|
|
inline |
Processes an initialization event; returns a planned duration.
◆ process_planned_event()
duration sydevs::systems::system_node::process_planned_event |
( |
duration |
elapsed_dt | ) |
|
|
inline |
Processes a planned event after an elapsed duration elapsed_dt
; returns a planned duration.
◆ process_unplanned_event()
duration sydevs::systems::system_node::process_unplanned_event |
( |
duration |
elapsed_dt | ) |
|
|
inline |
Processes an unplanned event after an elapsed duration elapsed_dt
; returns a planned duration.
◆ scale_planned_dt()
duration sydevs::systems::system_node::scale_planned_dt |
( |
duration |
planned_dt | ) |
const |
|
protected |
Adjusts the planned duration obtained from other nodes' event handlers.
Checks for errors in the planned duration planned_dt
including e.g. invalidity, negativity, and loss of precision. Returns a duration that is equal except that the precision level is set to the node's time precision.
- Parameters
-
planned_dt | The unscaled planned duration value. |
- Returns
- A planned duration with a value equal to
planned_dt
, but where the precision level may be changed to match time_precision()
.
◆ time_precision()
virtual scale sydevs::systems::system_node::time_precision |
( |
| ) |
const |
|
pure virtual |
◆ rng
std::mt19937& sydevs::systems::system_node::rng |
|
protected |
Reference to the random number generator.
The documentation for this class was generated from the following files: