SyDEVS  v0.7
Simulation-based analysis of complex systems involving people, devices, physical elements, and dynamic environments.
sydevs::systems::simulation< Node > Class Template Reference

A class template for running simulations. More...

#include <simulation.h>

Inherited by sydevs::systems::real_time_simulation< Node >.

Public Member Functions

 simulation (const time_point &start_t, const time_point &end_t, bool can_end_early, int64 seed, std::ostream &stream)
 Constructs a simulation with the full set of configuration options. More...
 
 simulation (duration total_dt, int64 seed, std::ostream &stream)
 Constructs a simulation with a reduced set of configuration options. More...
 
 simulation (const simulation &)=delete
 No copy constructor. More...
 
simulationoperator= (const simulation &)=delete
 No copy assignment. More...
 
 simulation (simulation &&)=delete
 No move constructor. More...
 
simulationoperator= (simulation &&)=delete
 No move assignment. More...
 
virtual ~simulation ()=default
 Destructor
More...
 
const time_pointstart_time () const
 Returns the start time of the simulation. More...
 
const time_pointend_time () const
 Returns the end time of the simulation. More...
 
bool can_end_early () const
 Returns true if the simulation can end before the specified end time. More...
 
bool started () const
 Returns true if the simulation has started. More...
 
bool finishing () const
 Returns true if all events are finished except finalization. More...
 
bool finished () const
 Returns true if the simulation has finished. More...
 
const discrete_event_timetime () const
 Returns the current point in discrete event time. More...
 
duration imminent_duration () const
 Returns the duration until the imminent event. More...
 
void process_next_event ()
 Runs the next event of the topmost system node. More...
 
int64 process_next_events ()
 Runs all events until simulated time advances; returns the number of processed events. More...
 
int64 process_events_until (const time_point &t)
 Runs all events until simulated time advances at least to t; returns the number of processed events. More...
 
int64 process_remaining_events ()
 Runs simulation until completion; returns the number of processed events. More...
 
const timerevent_timer () const
 Returns the object that accumulated wallclock event durations. More...
 

Public Attributes

Node top
 The topmost system node. More...
 

Detailed Description

template<typename Node>
class sydevs::systems::simulation< Node >

A class template for running simulations.

The simulation class template represents a simulation run based on a system_node class specified as a template parameter. Member functions allow the represented simulation to be performed one event at a time or until completion.

Below is an example of how a simulation object can be instantiated and used.

try {
// Create an object to simulate a building for 5 minutes of simulated
// time with a random seed of 0 and printed results directed to std::cout.
simulation<building_closed_system> sim(5_min, 0, std::cout);
// Print the initial temperature.
sim.top.initial_temperature.parameter.print_on_use();
// Print every outdoor temperature send from the weather node.
sim.top.building_dynamics.weather.outdoor_temperature_output.print_on_use();
// Print every outdoor temperature received by the thermodynamics node.
sim.top.building_dynamics.thermodynamics.outdoor_temperature_input.print_on_use();
// Print every event experienced by the occupant node.
sim.top.building_dynamics.occupant.print_on_event();
// Run the simulation until completion.
sim.process_remaining_events();
}
catch (const system_node::error& e) {
std::cout << "SYSTEM NODE ERROR: " << e.what() << std::endl;
}
catch (const std::exception& e) {
std::cout << "OTHER ERROR: " << e.what() << std::endl;
}

It is also possible to obtain wallclock times at each level in a model hierarchy, the cumulative time that the computer has spent executing events.

// [...]
// Run the simulation until completion.
sim.process_remaining_events();
// Obtain and print cumulative wallclock time of all nodes.
auto sim_dt = sim.event_timer().cumulative_duration();
std::cout << "sim: " << sim_dt << std::endl;
// Obtain and print cumulative wallclock time of all event functions in single node.
auto node_dt = sim.top.building_dynamics.thermodynamics.event_timer().cumulative_duration();
std::cout << "sim.top.building_dynamics.thermodynamics: " << node_dt << std::endl;

Constructor & Destructor Documentation

◆ simulation() [1/4]

template<typename Node >
sydevs::systems::simulation< Node >::simulation ( const time_point start_t,
const time_point end_t,
bool  can_end_early,
int64  seed,
std::ostream &  stream 
)
inline

Constructs a simulation with the full set of configuration options.

Parameters
start_tThe starting point in simulated time.
end_tThe end point in simulated time; only finalization events can occur at this time.
can_end_earlyFlag indicating that the simulation will end before the specified end time if all events are exhausted.
seedThe integer used to seed the random number generator.
streamThe output steam onto which printed results are directed.
Template Parameters
NodeThe port-free system_node on which the simulation is based.

◆ simulation() [2/4]

template<typename Node >
sydevs::systems::simulation< Node >::simulation ( duration  total_dt,
int64  seed,
std::ostream &  stream 
)
inline

Constructs a simulation with a reduced set of configuration options.

Parameters
total_dtThe duration of the simulation in simulated time; the simulation starts at time zero and does not end early.
seedThe integer used to seed the random number generator.
streamThe output steam onto which printed results are directed.
Template Parameters
NodeThe port-free system_node on which the simulation is based.

◆ simulation() [3/4]

template<typename Node >
sydevs::systems::simulation< Node >::simulation ( const simulation< Node > &  )
delete

No copy constructor.

◆ simulation() [4/4]

template<typename Node >
sydevs::systems::simulation< Node >::simulation ( simulation< Node > &&  )
delete

No move constructor.

◆ ~simulation()

template<typename Node >
virtual sydevs::systems::simulation< Node >::~simulation ( )
virtualdefault

Destructor

Member Function Documentation

◆ can_end_early()

template<typename Node >
bool sydevs::systems::simulation< Node >::can_end_early
inline

Returns true if the simulation can end before the specified end time.

◆ end_time()

template<typename Node >
const time_point & sydevs::systems::simulation< Node >::end_time
inline

Returns the end time of the simulation.

◆ event_timer()

template<typename Node >
const timer & sydevs::systems::simulation< Node >::event_timer
inline

Returns the object that accumulated wallclock event durations.

◆ finished()

template<typename Node >
bool sydevs::systems::simulation< Node >::finished
inline

Returns true if the simulation has finished.

◆ finishing()

template<typename Node >
bool sydevs::systems::simulation< Node >::finishing
inline

Returns true if all events are finished except finalization.

◆ imminent_duration()

template<typename Node >
duration sydevs::systems::simulation< Node >::imminent_duration
inline

Returns the duration until the imminent event.

◆ operator=() [1/2]

template<typename Node >
simulation& sydevs::systems::simulation< Node >::operator= ( const simulation< Node > &  )
delete

No copy assignment.

◆ operator=() [2/2]

template<typename Node >
simulation& sydevs::systems::simulation< Node >::operator= ( simulation< Node > &&  )
delete

No move assignment.

◆ process_events_until()

template<typename Node >
int64 sydevs::systems::simulation< Node >::process_events_until ( const time_point t)
inline

Runs all events until simulated time advances at least to t; returns the number of processed events.

◆ process_next_event()

template<typename Node >
void sydevs::systems::simulation< Node >::process_next_event
inline

Runs the next event of the topmost system node.

◆ process_next_events()

template<typename Node >
int64 sydevs::systems::simulation< Node >::process_next_events
inline

Runs all events until simulated time advances; returns the number of processed events.

◆ process_remaining_events()

template<typename Node >
int64 sydevs::systems::simulation< Node >::process_remaining_events
inline

Runs simulation until completion; returns the number of processed events.

◆ start_time()

template<typename Node >
const time_point & sydevs::systems::simulation< Node >::start_time
inline

Returns the start time of the simulation.

◆ started()

template<typename Node >
bool sydevs::systems::simulation< Node >::started
inline

Returns true if the simulation has started.

◆ time()

template<typename Node >
const discrete_event_time & sydevs::systems::simulation< Node >::time
inline

Returns the current point in discrete event time.

Member Data Documentation

◆ top

template<typename Node >
Node sydevs::systems::simulation< Node >::top

The topmost system node.


The documentation for this class was generated from the following file: