System Simulations are executed with the execution engine executor (cadCAD.engine.Executor
) given System Model
Configurations. There are multiple simulation Execution Modes and Execution Contexts.
cadCAD
executes a process per System Model Configuration and a thread per System Simulation.
- Local Mode (Default): Automatically selects Single Threaded or Multi-Process Modes (Example:
cadCAD.engine.ExecutionMode().local_mode
). - Single Threaded Mode: A single threaded Execution Mode for a single System Model Configuration (Example:
cadCAD.engine.ExecutionMode().single_mode
). - Multi-Process Mode: Execution Mode for System Model Simulations which executes Multiple processes within
multiple processes per given System Model Configuration (Example:
cadCAD.engine.ExecutionMode().multi_mode
).
from cadCAD.engine import ExecutionMode, ExecutionContext
exec_mode = ExecutionMode()
local_mode_ctx = ExecutionContext(context=exec_mode.local_mode)
from cadCAD.engine import Executor
from ... import exp # import of an instantiated of an `cadCAD.configuration.Experiment` object
simulation = Executor(exec_context=local_mode_ctx, configs=exp.configs)
A Simulation execution produces a System Event Dataset and the Tensor Field applied to initial states used to create it.
import pandas as pd
raw_system_events, tensor_field, sessions = simulation.execute()
# Simulation Result Types:
# raw_system_events: list[dict]
# tensor_field: pd.DataFrame
# Result System Events DataFrame
simulation_result = pd.DataFrame(raw_system_events)
+----+-----+--------------------------------+--------------------------------+
| | m | b1 | s1 |
|----+-----+--------------------------------+--------------------------------|
| 0 | 1 | <function p1m1 at 0x10c458ea0> | <function s1m1 at 0x10c464510> |
| 1 | 2 | <function p1m2 at 0x10c464048> | <function s1m2 at 0x10c464620> |
| 2 | 3 | <function p1m3 at 0x10c464400> | <function s1m3 at 0x10c464730> |
+----+-----+--------------------------------+--------------------------------+
+----+------+-----------+------------+--------+-----+---------+----------+
| | s1 | s2 | simulation | subset | run | substep | timestep |
|----+------+-----------|------------+--------+-----+---------+----------|
| 0 | 0 | 0.0 | 0 | 0 | 1 | 0 | 0 |
| 1 | 1 | 4 | 0 | 0 | 1 | 1 | 1 |
| 2 | 2 | 6 | 0 | 0 | 1 | 2 | 1 |
| 3 | 3 | [ 30 300] | 0 | 0 | 1 | 3 | 1 |
| 4 | 0 | 0.0 | 1 | 0 | 1 | 0 | 0 |
| 5 | 1 | 4 | 1 | 0 | 1 | 1 | 1 |
| 6 | 2 | 6 | 1 | 0 | 1 | 2 | 1 |
| 7 | 3 | [ 30 300] | 1 | 0 | 1 | 3 | 1 |
+----+------+-----------+------------+--------+-----+---------+----------+
Example System Model Configurations:
Example Simulation Executions:
import pandas as pd
from tabulate import tabulate
from cadCAD.engine import ExecutionMode, ExecutionContext, Executor
from documentation.examples import sys_model_A
from documentation.examples.sys_model_A import exp
exec_mode = ExecutionMode()
# Single Process Execution using a Single System Model Configuration:
# sys_model_A
local_mode_ctx = ExecutionContext(context=exec_mode.local_mode)
sys_model_A_simulation = Executor(exec_context=local_mode_ctx, configs=exp.configs)
sys_model_A_raw_result, sys_model_A_tensor_field, sessions = sys_model_A_simulation.execute()
sys_model_A_result = pd.DataFrame(sys_model_A_raw_result)
print()
print("Tensor Field: sys_model_A")
print(tabulate(sys_model_A_tensor_field, headers='keys', tablefmt='psql'))
print("Result: System Events DataFrame")
print(tabulate(sys_model_A_result, headers='keys', tablefmt='psql'))
print()
Example System Model Configurations:
Example Simulation Executions:
import pandas as pd
from tabulate import tabulate
from cadCAD.engine import ExecutionMode, ExecutionContext, Executor
from documentation.examples import sys_model_A, sys_model_B, system_model_AB_exp
exec_mode = ExecutionMode()
# # Multiple Processes Execution using Multiple System Model Configurations:
# # sys_model_A & sys_model_B
local_mode_ctx = ExecutionContext(context=exec_mode.local_mode)
sys_model_AB_simulation = Executor(exec_context=local_mode_ctx, configs=system_model_AB_exp.configs)
sys_model_AB_raw_result, sys_model_AB_tensor_field, sessions = sys_model_AB_simulation.execute()
sys_model_AB_result = pd.DataFrame(sys_model_AB_raw_result)
print()
print("Tensor Field:")
print(tabulate(sys_model_AB_tensor_field, headers='keys', tablefmt='psql'))
print("Result: System Events DataFrame:")
print(tabulate(sys_model_AB_result, headers='keys', tablefmt='psql'))
print()
System Model Parameter Sweep Info
Example: Param Sweep
import pandas as pd
from tabulate import tabulate
from cadCAD.engine import ExecutionMode, ExecutionContext, Executor
from documentation.examples import param_sweep
from documentation.examples.param_sweep import exp
exec_mode = ExecutionMode()
local_mode_ctx = ExecutionContext(context=exec_mode.local_mode)
run = Executor(exec_context=local_mode_ctx, configs=exp.configs)
raw_result, tensor_field, sessions = run.execute()
result = pd.DataFrame(raw_result)
print()
print("Tensor Field:")
print(tabulate(tensor_field, headers='keys', tablefmt='psql'))
print("Output:")
print(tabulate(result, headers='keys', tablefmt='psql'))
print()