.. toctree::
:hidden:
:maxdepth: 2
Many of the HELICS entities have significant configuration options. Rather than comprehensively list these options while explaining the features themselves, we've created this section of the User Guide to serve as a reference as to what they are, what they do, and how to use them. This reference is oriented-around the use of JSON files for configuration and is an attempt to be comprehensive in listing and explaining those options. As will be explained below, many of these options are accessible via direct API calls though some of these calls are general in nature (such as helicsFederateInfoSetIntegrerProperty to set the logging level, among other things).
Generally, there are three ways in which a co-simulation can be configured and all the various options can be defined:
- Using direct API calls in the federate source code.
- Using command-line switches/flags while beginning execution of the federate
- Using a JSON configuration file (and calling helicsCreateValueFederateFromConfig, helicsCreateMessageFederateFromConfig, or helicsCreateComboFederateFromConfig)
Not all configuration options are available in all three forms but often they are. For example, it is not possible (nor convenient) to configure a publication for a federate from the command line but it is possible to do so with the JSON config file and with API calls.
Which method you use to configure your federate and co-simulation significantly depends on the circumstances of the co-simulation and details of any existing code-base being used. Here is some guidance, though, to help in guiding you're decision in how to do this:
- If possible, use a JSON configuration file - Using a JSON configuration file creates separation between the code base of the federation and its use in a particular co-simulation. This allows for a modularity between the functionality the federate provides and the particular co-simulation in which it is applied. For example, a power system federate can easily be reconfigured to work on one model vs another through the use of a JSON configuration file. The particular publications and subscriptions may change but the main functionality of the federate (solving the power flow) does not. To use the JSON file for configuration, one of three specific APIs needs to be called: in the file:
- JSON configuration produces a natural artifact that defines the co-simulation - Another advantage of the external configuration in the JSON file is that it is a human-readable artifact that can be distributed separately from the source code that provides a lot of information about how the co-simulation was run. In fact, its possible to just look at the configuration files of a federation and do some high-level debugging (checking to see that the subscriptions and publications are aligned, for example).
- New federates in ill-defined use cases may benefit from API configuration - The modularity that the JSON config provides may not offer many benefits if the federate is newly integrated into HELICS and/or is part of an evolving analysis. During these times the person(s) doing the integration may just want to make direct API calls instead of having to mess with writing the federate code and a configuration file. There will likely be a point in the future when the software is more codified and switching to a JSON configuration makes more sense.
- Command-line configuration (where possible) allows for small, quick changes to the configuration - Because the command line doesn't provide comprehensive access to the necessary configuration, it will never be a stand-alone configuration option but it does have the advantage of providing quick access right as a user is instantiating the federate. This is an ideal place to make small changes to the configuration (e.g. changing the minimum time step) without having to edit any files.
- API configuration is most useful for dynamic configuration - If there is a need to change the configuration of a given federate dynamically, the API is the only way to do that. Such needs are not common but there are cases where, for example, it may be necessary to define the configuration based on the participants in the federation (e.g. publications, subscriptions, timing). It's possible to use queries to understand the composition and configuration of the federation and then use the APIs to define the configuration of the federate in question.
The remainder of this reference lists the configuration options that are supported in the JSON configuration file. Where possible, the corresponding C++ API calls and the links to that documentation will be provided. Generally, the command-line options use the exact same syntax as the JSON configuration options preceded by a --
and followed by either an =
or a space and then the parameter value (i.e. --name testname
). In the cases where a single letter switch is available, that will be listed (i.e. -n testname
).
Default values are shown in "[]" following the name(s) of the option.
When an API exists, its name is shown along with links to the specific API documentation for a few (but, sadly, not all) of the supported languages. Many of the options are set with generic functions (e.g. helicsFederateInfoSetFlagOption
) and in those cases the option being set is specified by an enumerated value. In C, these values (e.g. helics_flag_uninterruptible
) are set to integer value (e.g. 1
); in this document that integer value follows the enumeration string in brackets. If using the C interface, the integer value must be used. The C++ interface supports the use of the enumerated value directly as do the Python and Julia interfaces with slight syntactical variations (Python: helics.HELICS_FLAG_INTERRUPTIBLE
and Julia: HELICS.HELICS_FLAG_INTERRUPTIBLE
).
The JSON configuration file below shows all the configuration options in a single file along with their default values and shows what section of the file they should be placed in. Most JSON configuration files will require far fewer options than shown here; items marked with "**" are required.
Many of the configuration parameters have alternate names that provide the same functionality. Only one of the names is shown in this configuration file but the alternative names are listed in the reference below. Generally, the supported names are the same string in nocase, camelCase, and snake_case.
An example of one publication, subscription, named input, endpoint, and filter is also shown. The values for each of these options is arbitrary and in the case of filters, many more values are supported and a description of each is provided.
(Note that the JSON standard does not support comments and thus the block below is not valid JSON. The JSON parser HELICS uses does support comments)
{
// General
**"name": "arbitrary federate name",**
"core_type": "zmq",
"core_name": "core name",
"core_init_string" : "",
"autobroker": false,
"connection_required": false,
"connection_optional": false,
"strict_input_type_checking": false,
"terminate_on_error": false,
"source_only": false,
"observer": false,
"only_update_on_change": false,
"only_transmit_on_change": false,
//Logging
"logfile": "output.log"
"log_level": "warning",
"force_logging_flush": false,
"file_log_level": "",
"console_log_level": "",
"dump_log": false,
"logbuffer": 10,
//Timing
"ignore_time_mismatch_warnings": false,
"uninterruptible": false,
"period": 0,
"offset": 0,
"time_delta": 0,
"minTimeDelta": 0,
"input_delay": 0,
"output_delay": 0,
"real_time": false,
"rt_tolerance": 0.2,
"rt_lag": 0.2,
"rt_lead": 0.2,
"grant_timeout": 0,
"max_cosim_duration":0,
"wait_for_current_time_update": false,
"restrictive_time_policy": false,
"slow_responding": false,
//Iteration
"rollback": false,
"max_iterations": 10,
"forward_compute": false,
//Network
"interfaceNetwork": "local",
"brokeraddress": "127.0.0.1"
"reuse_address": false,
"noack": false,
"maxsize": 4096,
"maxcount": 256,
"networkretries": 5,
"osport": false,
"brokerinit": "",
"server_mode": "",
"interface": (local IP address),
"port": 1234,
"brokerport": 22608,
"localport": 8080,
"portstart": 22608,
"encrypted": false,
"encryption_config":"encryption_config.json",
"publications" | "subscriptions" | "inputs": [
{
**"key": "publication key",**
"type": "",
"unit": "m",
"global": false,
"connection_optional": true,
"connection_required": false,
"tolerance": -1,
"targets": "",
"buffer_data": false, indication the publication should buffer data
"strict_input_type_checking": false,
"alias": "",
"ignore_unit_mismatch": false,
"info": "",
},
],
"publications" :[
{
"only_transmit_on_change": false,
}
] ,
"subscriptions": [
{
"only_update_on_change": false,
}
],
"inputs": [
{
"connections": 1,
"input_priority_location": 0,
"clear_priority_list": possible to have this as a config option?
"single_connection_only": false,
"multiple_connections_allowed": false
"multi_input_handling_method": "average",
"targets": ["pub1", "pub2"]
}
],
"endpoints": [
{
"name": "endpoint name",
"type": "endpoint type",
"global": true,
"destination" | "target" : "default endpoint destination",
"alias": "",
"subscriptions": "",
"filters": "",
"info": ""
}
],
"filters": [
{
"name": "filter name",
"source_targets": "endpoint name",
"destination_targets": "endpoint name",
"info": "",
"operation": "randomdelay",
"properties": {
"name": "delay",
"value": 600
}
}
]
}
There are a number of flags which control how a federate acts with respect to timing and its signal interfaces.
API: helicsFederateInfoSetCoreName
C++
| C
| Python
| Julia
Every federate must have a unique name across the entire federation; this is functionally the address of the federate and is used to determine where HELICS messages are sent. An error will be generated if the federate name is not unique.
API: helicsFederateInfoSetCoreTypeFromString
C++
| C
| Python
| Julia
There are a number of technologies or message buses that can be used to send HELICS messages among federates. Every HELICS enabled simulator has code in it that creates a core which connects to a HELICS broker using one of these messaging technologies. ZeroMQ (zmq) is the default core type and most commonly used but there are also cores that use TCP and UDP networking protocols directly (forgoing ZMQ's guarantee of delivery and reconnection functions), IPC (uses Boost's interprocess communication for fast in-memory message-passing but only works if all federates are running on the same physical computer), and MPI (for use on HPC clusters where MPI is installed). See the User Guide page on core types for more details.
API: helicsFederateInfoSetCoreName C++ | C | Python | Julia
Only applicable for ipc
and test
core types; otherwise can be left undefined.
API: helicsFederateInfoSetCoreInitString
C++
| C
| Python
| Julia
A command-line-like string that specifies options for the core as it connects to the federation. These options are:
--broker=
|broker_address=
|brokeraddress
: IP address of broker--brokerport=
: Port number on which the broker is communicating--broker_rank=
: For MPI cores only; identifies the MPI rank of the broker--broker_tag=
: For MPI cores only; identifies the MPI tag of the broker--localport=
: Port number to use when communicating with this core--autobroker
: When included the core will automatically generate a broker--key=
: Specifies a key to use when communicating with the broker. Only federates with this key specified will be able to talk to the broker with the samekey
value. This is used to prevent federations running on the same hardware from accidentally interfering with each other.--profiler=log
- Send the profiling messages to the default logging file.log
can be replaced with a path to an alternative file where only the profiling messages will be sent. See the User Guide page on profiling for further details.
In addition to these options, all options shown in the broker_init_string
are also valid.
API: (none)
Automatically generate a broker if one cannot be connected to. For federations with only one broker (often the case) and/or with federations containing custom federates that were developed for this particular application, it can be convenient to create the broker in the process of creating a specific federate; this option allows that to take place. The downside to this is it creates a federation with a small amount of mystery as the broker is not clearly shown to be launched as its own federate alongside the other federates and those unfamiliar with the federation composition may have to spend some extra time to understand where the broker is coming from.
API: helicsFederateInfoSetBrokerInitString
C++
| C
| Python
| Julia
String used to define the configuration of the broker if one is autogenerated. Such configuration typically includes things like broker IP addresses and port numbers. Again, if this is a co-simulation running on a single computer (and is the only HELICS co-simulation running on said computer) the default option is likely to be sufficient. The following options are available for this string:
--federates=
- The minimum number of federates expected to join a federation through the broker. Equivalent to-f
.--max_federates=
- The maximum number of federates allowed to join through a broker.--name=
- Name of the broker; can be used by federates to specify which broker to use--max_iterations=
- Maximum iterations allowed when using the re-iteration API--min_broker_count=
- The minimum number of brokers that the co-simulation must have to begin initialization. (This option is not available for cores)--max_broker_count=
- The maximum number of brokers that the co-simulation should allow. (This option is not available for cores)--slow_responding
- Removes the requirement for the broker to respond to pings from other entities in the co-simulation in a timely manner and forces the assumption that this broker is still connected to the federation.--restrictive_time_policy
- Forces the broker to use the most restrictive (conservative) timing policy when granting times to federates. Has the potential to increase co-simulation time as time grants may happen later then they actually need to.--terminate_on_error
- All errors from any member of the federation will cause the broker to terminate the co-simulation for the entire federation.--force_logging_flush
- Force writing to the log after every message.--log_file=
- Name of file use for logging for this broker.--log_level=
- Specifies the level of logging (both file and console) for this broker.--file_log_level=
- Specifies the level of logging to file for this broker.--console_log_level=
- Specifies the level of logging to file for this broker.--dumplog
- Captures a record of all logging messages and writes them out to file or console when the broker terminates.--tick=
- Heartbeat period in ms. When brokers fail to respond after 2 ticks secondary actions are taking to confirm the broker is still connected to the federation. Times can also be entered as strings such as "15s" or "75ms".--timeout=
milliseconds to wait for all the federates to connect to the broker (can also be entered as a time like '10s' or '45ms')--network_timeout=
- Time to establish a socket connection in ms. Times can also be entered as strings such as "15s" or "75ms".--error_timeout=
- Time in ms to wait after an error state is reached before terminating. Times can also be entered as strings such as "15s" or "75ms".--query_timeout=
- Time in ms to wait for a query to complete. Times can also be entered as strings such as "15s" or "75ms".--grant_timeout=
- Time in ms to wait to allow a time request to wait before triggering diagnostic actions. Times can also be entered as strings such as "15s" or "75ms".--max_cosim_duration=
- The time in ms the co-simulation should be allowed to run. If the time is exceeded the co-simulation will terminate automatically.--children=
- The minimum number of child objects the broker should expect before allowing entry to the initializing state.--subbrokers=
- The minimum number of child objects the broker should expect before allowing entry to the initializing state. Same as--children
but might be clearer in some cases with multilevel hierarchies.--brokerkey=
- A broker key to use for connections to ensure federates are connecting with a specific broker and only appropriate federates connect with the broker. See simultaneous co-simulations for more information.--profiler=log
- Send the profiling messages to the default logging file.log
can be replaced with a path to an alternative file where only the profiling messages will be sent. See the User Guide page on profiling for further details.--profiler=log
- Send the profiling messages to the default logging file.log
can be replaced with a path to an alternative file where only the profiling messages will be sent. See the User Guide page on profiling for further details.--timemonitor=
- Specify the name of the federate to monitor the time from and generate periodic log messages in the broker as the federate updates its time.--timemonitorperiod=
- can only be used with--timemonitor
, set the minimum time period which must elapse in simulation before another log message from the time monitor is generated--logbuffer
- Enable buffering recent log messages for retrieval with the "logs" query. Optionally specify the size of the circular log buffer; defaults to 10 messages if no size is supplied.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_TERMINATE_ON_ERROR
[72]
If the terminate_on_error
flag is set then a federate encountering an internal error will trigger a global error and cause the entire federation to terminate. Errors of this nature are typically the result of configuration errors, such as having a required publication that is not used or incompatible units or types on publications and subscriptions. This is the same option that is available in the broker_init_string
but applied only to a specific federate (whereas when applied at the broker level it is effectively applied to all federates).
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_SOURCE_ONLY
[4]
Used to indicate to the federation that this federate is only producing data and has no inputs/subscriptions. Specifying this when appropriate allows HELICS to more efficiently grant times to the federation.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_OBSERVER
[0]
Used to indicate to the federation that this federate produces no data and only has inputs/subscriptions. Specifying this when appropriate allows HELICS to more efficiently grant times to the federation.
API: helicsFederateSetLogFile
C++
| C
| Python
| Julia
Specifies the name of the log file where logging messages will be written.
API: helicsFederateInfoSetIntegerProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_INT_LOG_LEVEL
[271]
Valid values:
no_print
-HELICS_LOG_LEVEL_NO_PRINT
error
-HELICS_LOG_LEVEL_ERROR
warning
-HELICS_LOG_LEVEL_WARNING
summary
-HELICS_LOG_LEVEL_SUMMARY
connections
-HELICS_LOG_LEVEL_CONNECTIONS
interfaces
-HELICS_LOG_LEVEL_INTERFACES
timing
-HELICS_LOG_LEVEL_TIMING
data
-HELICS_LOG_LEVEL_DATA
trace
-HELICS_LOG_LEVEL_TRACE
Determines the level of detail for log messages. In the list above, the keywords on the left can be used when specifying the logging level via a JSON configuration file. The enumerations on the right are used when configuring via the API.
API: helicsFederateInfoSetIntegerProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_INT_FILE_LOG_LEVEL
[272]
Valid values: Same as in loglevel
Allows a distinct log level for the written log file to be specified. By default the logging level to file and console are identical and will only differ if file_log_level
or console_log_level
are defined.
API: helicsFederateInfoSetIntegerProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_INT_CONSOLE_LOG_LEVEL
[274]
Valid values: Same as in loglevel
Allows a distinct log level for the written log file to be specified. By default the logging level to file and console are identical and will only differ if file_log_level
or console_log_level
are defined.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_FORCE_LOGGING_FLUSH
[88]
Setting this option forces HELICS logging messages to be flushed to file after each one is written. This prevents the buffered IO most OSs implement to be bypassed such that all messages appear in the log file immediately after being written at the cost of slower simulation times due to more time spent writing to file.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_DUMPLOG
[89]
When set, a record of all messages is captured and written out to the log file at the conclusion of the co-simulation.
API: helicsFederateInfoSetIntegerProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_INT_LOG_BUFFER
[276]
When set to a number greater than 0 will enable the most recent X log messages of the object to be buffered for retrieval via the "logs" query. Also see discussion in Logging.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_IGNORE_TIME_MISMATCH_WARNINGS
[67]
If certain timing options (i.e. period
, or minTimeDelta
) are used it is possible for the time granted a federate to be greater than the requested time. This situation would normally generate a warning message, but if this flag is set those warnings are silenced.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_UNINTERRUPTIBLE
[1]
Normally, a federate will be granted a time earlier than it requested when it receives a message from another federate; the presence of any message implies there could be an action the federate needs to take and may generate new messages of its own. There are times, though, when it is important that the federate only be granted a time (and begin simulating/executing again) that it has previously requested. For example, there could be some controller that should only operate at fixed intervals even if new data arrives earlier. In these cases, setting the uninterruptible
flag will prevent premature time grants.
API: helicsFederateInfoSetTimeProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_TIME_PERIOD
[140]
Many time-based simulators have a minimum time-resolution or a user-configurable step size. The period
parameter can be used to effectively synchronize the times that are granted with the defined simulation period. The default units for period
are in seconds but the string for this parameter can include its own units (e.g. "2 ms" or "1 hour"). Setting period
will force all time grants to occur at times of n*period
even if subscriptions are updated, messages arrive, or the federate requests a time between periods. This value effectively makes the federates uninterruptible
during the times between periods. Relatedly...
API: helicsFederateInfoSetTimeProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_TIME_OFFSET
[141]
There may be cases where it is preferable to have a simulator receive time grants that are offset slightly in time to one or more other federates. Defining an offset
value allows this to take place; units are handled the same as in period
. Setting both period
and offset
, will result in the all times granted to the federate in question being constrained to n*period + offset
.
API: helicsFederateInfoSetTimeProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_TIME_DELTA
[137]
timeDelta has some similarities to period
; where period
constrained the granted time to regular intervals, timeDelta
constrains the grant time to a minimum amount from the last granted time. Units are handled the same as in period
.
API: helicsFederateInfoSetTimeProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_INPUT_TIME_DELAY
[148]
inputDelay
specifies a delay in simulated time between when a signal arrives at a federate and when that federate is notified that a new value is available. outputDelay
is similar but applies to signals being sent by a federate. Note that this applies to both value signals and message signals.
API: helicsFederateInfoSetTimeProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_TIME_PROPERTY_OUTPUT_TIME_DELAY
[150]
outputDelay
is similar to input_delay
but applies to signals being sent by a federate. Note that this applies to both value signals and message signals.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_REALTIME
[16]
If set to true the federate uses rt_lag
and rt_lead
to match the time grants of a federate to the computer wall clock.
If the federate is running faster than real time this will insert additional delays. If the federate is running slower than real time this will cause a force grant, which can lead to non-deterministic behavior. rt_lag
can be set to maxVal to disable force grant
API: helicsFederateInfoSetTimeProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_TIME_RT_LAG
[143] and HELICS_PROPERTY_TIME_RT_LEAD
[144]
Defines "real-time" for HELICS by setting tolerances for HELICS to use when running a real-time co-simulation. HELICS is forced to keep simulated time within this window of wall-clock time. Most general purpose OSes do not provide guarantees of execution timing and thus very small values of rt_lag
and rt_lead
(less than 0.005) are not likely to be achievable.
API: helicsFederateInfoSetTimeProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_TIME_RT_TOLERANCE
[145]
Implements the same functionality of rt_lag
and rt_lead
but does so by using a single value to set symmetrical lead and lag constraints.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_WAIT_FOR_CURRENT_TIME_UPDATE
[10]
If set to true, a federate will not be granted the requested time until all other federates have completed at least 1 iteration of the current time or have moved past it. If it is known that 1 federate depends on others in a non-cyclic fashion, this can be used to optimize the order of execution without iterating.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_RESTRICTIVE_TIME_POLICY
[11]
If set, a federate will not be granted the requested time until all other federates have completed at least 1 iteration of the current time or have moved past it. If it is known that 1 federate depends on others in a non-cyclic fashion, this can be used to optimize the order of execution without iterating.
Using the option restrictive-time-policy
forces HELICS to use a fully conservative mode in granting time. This can be useful in situations beyond the current reach of the distributed time algorithms. It is generally used in cases where it is known that some federate is executing and will trigger someone else, but most federates won't know who that might be. This prevents extra messages from being sent and a potential for time skips. It is not needed if some federates are periodic and execute every time step. The flag can be used for federates, brokers, and cores to force very conservative timing with the potential loss of performance as well.
Only applicable to Named Input interfaces (see section on value federate interface types), if enabled this flag checks that data type of the incoming signals match that specified for the input.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_SLOW_RESPONDING
[29]
If specified on a federate, setting this flag indicates the federate may be slow in responding, and to not forcibly eject the federate from the federation for the slow response. This is an uncommon scenario.
If applied to a core or broker (--slow_responding
in the core_init_string
or broker_init_string
, respectively), it is indicative that the broker doesn't respond to internal pings quickly and should not be disconnected from the federation for the slow response.
API: helicsFederateInfoSetTimeProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_EVENT_TRIGGERED
[81]
For federates that are event-driven rather than timing driven, this flag must be set (to increase timing efficiency and avoid timing lock-ups). Event-driven federates are those that don't progress through simulation time at regular timesteps but instead wait for arriving messages to act. The most common examples are controller federates which generally request infinite time (well, HELICS_TIME_MAXTIME
) and rely on HELICS to grant them an earlier time whenever a signal (often message) has arrived. Filter federates are another common federate type that must have this flag set.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_FORWARD_COMPUTE
[14]
Indicates to the broker and the rest of the federation that this federate computes ahead of its granted time and can/does roll back when necessary. Federates able to do this (and who set this flag) allow more efficient time grants to the federation as a whole.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_ROLLBACK
[12]
Indicates to the broker and the rest of the federation that this federate can/does roll back when necessary. Federates able to do this (and who set this flag) allow more efficient time grants to the federation as a whole.
API: helicsFederateInfoSetIntegerProperty
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_PROPERTY_INT_MAX_ITERATIONS
[259]
For federates engaged in iteration (recomputing values based on updated inputs at a single simulation timestep) there may be a need to enforce a maximum number of iterations. This option allows that value to be set. When any federate reaches this number of iterations, HELICS will evaluate the federation as a whole and grant the next smallest time supported by the iterating federates. This time will only be granted to the federates that would be able to execute at this time.
These options can be set globally for all subscriptions, inputs and publications for a given federate. Even after setting them globally, they can be included in the configuration for an individual subscription, input, or publication, over-riding the global setting.
only_update_on_change
| onlyupdateonchange
| onlyUpdateOnChange
[false] and only_transmit_on_change
| onlytransmitonchange
| onlyTransmitOnChange
[false]
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_ONLY_UPDATE_ON_CHANGE
[454] and HELICS_FLAG_ONLY_TRANSMIT_ON_CHANGE
[452]
Setting these flags prevents new value signals with the same value from being received by the federate or sent by the federate. Setting these flags will reduce the amount of traffic on the HELICS bus and can provide performance improvements in co-simulations with large numbers of messages.
API: helicsPublicationSetMinimumChange
and helicsInputSetMinimumChange
C++ input and C++ publication
| C input and C publication
| Python input and Python publication
| Julia input and Julia publication
This option allows the specific numerical definition of "change" when using the only_update_on_change
and only_transmit_on_change
options.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_CONNECTION_REQUIRED
[397]
When a federate is initialized, one of its tasks is to make sure the recipients of directed signals exist. If, after the federation is initialized, the recipient can't be found, then by default a warning is generated and written to the log file. If the connections_required
flag is set, this warning becomes a fatal error that stops the co-simulation.
publications
- At least one federate must subscribe to the publications.subscriptions
- The message being subscribed to must be provided by some other publisher in the federation.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_CONNECITON_OPTIONAL
[402]
When an interface requests a target it tries to find a match in the federation. If it cannot find a match at the time the federation is initialized, then the default is to generate a warning. This will not halt the federation but will display a log message. If the connections_optional
flag is set on a federate all subsequent addTarget
calls on any interface will not generate any message if the target is not available.
These options are valid for subscriptions, inputs, and/or publications (generically called "handles"). The APIs for dealing with registering these handles combine multiple options in the JSON config file and have varying levels of specificity (defining the date type for the handle or defining the handle as global). Rather than listing all APIs for the following options, the main APIs will be listed here and those using them can consult the API references to see which specific APIs are most applicable.
helicsFederateRegisterPublication
C++
| C
| Python
| Julia
helicsFederateRegisterSubscription
C++
| C
| Python
| Julia
helicsFederateRegisterInput
C++
| C
| Python
| Julia
publications
- The string in this field is the unique identifier (at the federate level) for the value that will be published to the federation. Ifglobal
is set (see below) it must be unique to the entire federation.subscriptions
- This string identifies the federation-unique value that this federate wishes to receive. Unlessglobal
has been set totrue
in the publishings JSON configuration file, the name of the value is formatted as<federate name>/<publication key>
. Both of these strings can be found in the publishing federate's JSON configuration file as thename
andkey
strings, respectively. Ifglobal
istrue
the string is just thekey
value.input
- The string in this field is the unique identifier (at the federate level) that defines the input to receive value signals.
HELICS supports data types and data type conversion (as best it can).
HELICS is able to do some levels of unit conversion, currently only on double type publications but more may be added in the future. The units can be any sort of unit string, a wide assortment is supported and can be compound units such as m/s^2 and the conversion will convert as long as things are convertible. The unit match is also checked for other types and an error if mismatching units are detected. A warning is also generated if the units are not understood and not matching. The unit checking and conversion is only active if both the publication and subscription specify units.
(publications only) global
is used to indicate that the value in key
will be used as a global name when other federates are subscribing to the message. This requires that the user ensure that the name is used only once across all federates. Setting global
to true
is handy for federations with a small number of federates and a small number of message exchanges as it allows the key
string to be short and simple. For larger federations, it is likely to be easier to set the flag to false
and accept the extra naming.
API: helicsInputSetOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_BUFFER_DATA
[411]
(only valid for inputs and subscriptions) Setting this flag will buffer the last value sent during the initialization phase of HELICS co-simulations. When the execution phase begins, that value will be resent to the receiving handle.
API: Under normal operation, handles that are connected (value signals flowing between them) are required to have units that either match or can be directly converted between. If mismatching units are connected, an error is thrown; when this flag is set that error is suppressed.
API: helicsInputSetInfo
C++
| C
| Python
| Julia
The info
field is entirely ignored by HELICS and is used as a mechanism to pass configuration information to the federate so that it can properly integrate into the federation. Thus, there is no standard content or format for this field; it is entirely up to the individual simulators to decide how the data in this field (if any) should be used. Often it is used by simulators to map the HELICS names into internal variable names as shown in the above example.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_STRICT_TYPE_CHECKING
[414]
When an interface requests a target it tries to find a match in the federation. If it cannot find a match at the time the federation is initialized, then the default is to generate a warning. This will not halt the federation but will display a log message. If the connections_optional
flag is set on a federate all subsequent addTarget
calls on any interface will not generate any message if the target is not available.x
C++ | C | Python | Julia Used to specify which inputs should receive the values from this output. This can be a list of output keys/names.
Inputs can receive values from multiple sending handles and the means by which those multiple data points for a single handle are managed can be specified with several options. See the User Guide entry for further details.
C++ | C | Python | Julia Inputs can specify which outputs (typically publications) they should be pulling from. This is similar to subscriptions but inputs can allow multiple outputs to feed to the same input. This can be a list of output keys/names.
API: helicsInputSetOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_CONNECTIONS
[522]
Allows an integer number of connections to be considered value for this input handle. Similar to multiple_connections_allowed
but allows the number of sending handles to be defined to a specific number.
API: helicsInputSetOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_INPUT_PRIORITY_LOCATION
[510]
When receiving values from multiple sending handles, when the values are received they or organized as a vector. This option is used to define which value in that vector has priority. The API can be called multiple times to set successive priorities.
API: helicsInputSetOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_CLEAR_PRIORITY_LIST
[512]
When receiving values from multiple sending handles, when the values are received they or organized as a vector. This option is used to clear that priority list and redefine which values have priority.
API: helicsInputSetOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_SINGLE_CONNECTION_ONLY
[407]
When set, this forces the input handle to have only one sending handle it will receive from. Setting this flag serves as a sort of double-check to ensure that only one other handle is sending to this input handle and that the federation has been configured as expected.
API: helicsInputSetOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_MULTIPLE_CONNECTIONS_ALLOWED
[409]
When set, this flag allows the input handle to receive valuesfrom multiple other handles.
API: helicsInputSetOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_HANDLE_OPTION_MULTI_INPUT_HANDLING_METHOD
[507]
Property values:
none
|no_op
or
sum
max
min
average
mean
vectorize
diff
Given that an input can have multiple data sources, a method of reducing those multiple values into one needs to be defined. HELICS supports a number of mathematical operation to perform this reduction.
As in the value handles, the registration of endpoints is done through a single API that incorporates multiple options. And as in the value handles, there is a global
API option to allow the name of the endpoint to be considered global to the federation.
API: helicsFederateRegisterEndpoint
C++
| C
| Python
| Julia
The name of the endpoint as it will be known to the rest of the federation.
API: (none)
HELICS supports data types and data type conversion (as best it can).
API: helicsEndpointSetDefaultDestination
C++
| C
| Python
| Julia
Defines the default destination for a message sent from this endpoint.
API: (none)
Creates a local alias for a handle that may have a long name.
API: helicsEndpointSubscribe
C++
| C
| Python
| Julia
See section on Filter Options.
API: helicsEndpointSetInfo
C++
| C
| Python
| Julia
The info
field is entirely ignored by HELICS and is used as a mechanism to pass configuration information to the federate so that it can properly integrate into the federation. Thus, there is no standard content or format for this field; it is entirely up to the individual simulators to decide how the data in this field (if any) should be used. Often it is used by simulators to map the HELICS names into internal variable names as shown in the above example.
Filters are registered with the core or through the application API. There are also Filter object that hide some of the API calls in a slightly nicer interface. Generally a filter will define a target endpoint as either a source filter or destination filter. Source filters can be chained, as in there can be more than one of them. At present there can only be a single non-cloning destination filter attached to an endpoint.
Non-cloning filters can modify the message in some ways, cloning filters just copy the message and may send it to multiple destinations.
On creation, filters have a target endpoint and an optional name. Custom filters may have input and output types associated with them. This is used for chaining and automatic ordering of filters. Filters do not have to be defined on the same core as the endpoint, and in fact can be anywhere in the federation, any messages will be automatically routed appropriately.
API: helicsFederateRegisterFilter
(C++
| C
| Python
| Julia)
to create/register the filter and then helicsFilterAddSourceTarget
(C++
| C
| Python
| Julia)
or helicsFilterAddDestinationTarget
(C++
| C
| Python
| Julia)
to associate it with a specific endpoint
API: (none)
Name of the filter; must be unique to a federate.
API: helicsFilterAddSourceTarget
C++
| C
| Python
| Julia
Acts on previously registered filter and associated with a specific endpoint of the federate.
API: helicsFilterAddDestinationTarget
C++
| C
| Python
| Julia
Acts on previously registered filter and associated with a specific endpoint of the federate.
API: helicsFilterSetInfo
C++
| C
| Python
| Julia
The info
field is entirely ignored by HELICS and is used as a mechanism to pass configuration information to the federate so that it can properly integrate into the federation. Thus, there is no standard content or format for this field; it is entirely up to the individual simulators to decide how the data in this field (if any) should be used. Often it is used by simulators to map the HELICS names into internal variable names as shown in the above example.
API: helicsFederateRegisterFilter
C++
| C
| Python
| Julia
Filters have a predefined set of operations they can perform. The following list defines the valid operations for filters. Most filters require additional specifications in properties data structure, an example of which is shown for each filter type.
This filter reroutes a message to a new destination. it also has an optional filtering mechanism that will only reroute if some patterns are matching. The patterns should be specified by "condition" in the set string the conditions are regular expression pattern matching strings.
Example property
object:
"operation": "reroute",
"properties": [
{
"name": "newdestination",
"value": "endpoint name "
},
{
"name": "condition",
"value": "regular expression string"
}
]
This filter will delay a message by a certain amount fo time.
Example property
object:
"operation": "delay",
"properties": {
"name": "delay",
"value": "76 ms",
},
This filter will randomly delay a message according to specified random distribution available options include distribution selection, and 2 parameters for the distribution some distributions only take one parameter in which case the second is ignored. The distributions available are based on those available in the C++ random library.
- constant
- param1="value" this just generates a constant value
- uniform
- param1="min"
- param2="max"
- bernoulli - the bernoulli distribution will return param2 if the bernoulli trial returns true, 0.0 otherwise. Param1 is the probability of returning param2
- param1="prob"
- param2="value"
- binomial
- param1=t (cast to int)
- param2="p"
- geometric
- param 1="prob" the output is param2*geom(param1) so multiplies the integer output of the geometric distribution by param2 to get discrete chunks
- poisson
- param1="mean"
- exponential
- param1="lambda"
- gamma
- param1="alpha"
- param2="beta"
- weibull
- param1="a"
- param2="b"
- extreme_value
- param1="a"
- param2="b"
- normal
- param1="mean"
- param2="stddev"
- lognormal
- param1="mean"
- param2="stddev"
- chi_squared
- param1="n"
- cauchy
- param1="a"
- param2="b"
- fisher_f
- param1="m"
- param2="n"
- student_t
- param1="n"
"operation": "randomdelay",
"properties": [
{
"name": "distribution",
"value": "normal"
},
{
"name": "mean",
"value": 0
},
{
"name": "stdev",
"value": 1
}
]
This filter will randomly drop a message, the drop probability is specified, and is modeled as a uniform distribution between zero and one.
"operation": "random_drop",
"properties": {
"name": "prob",
"value": 0.5,
},
This filter will copy a message and send it to the original destination plus a new one.
"operation": "clone",
"properties": {
"name": "add delivery",
"value": "endpoint name",
},
HELICS 2.8 and v3.0.1 have a profiling capability that allows users to measure the time spent waiting for HELICS to grant it time and how much time is spent executing native code. These measurements are the foundation to understanding how to improve computation performance in a federation. Further details are provided in the Profiling page in the User Guide. When enabling profiling at the federate level there are a few APIs that can be utilized.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_PROFILING
[93]
Setting this flag enables profiling for the federate.
Turns on profiling for the federate and allows the specification of the log file where profiling messages will be written. No API is possible with this option as it must be specified prior to the creation of the federates.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_LOCAL_PROFILING_CAPTURE
[96]
Setting this flag sends the profiling messages to the local federate log rather than propagating them up to the core and/or broker.
API: helicsFederateInfoSetFlagOption
C++
| C
| Python
| Julia
Property's enumerated name: HELICS_FLAG_PROFILING_MARKER
[95]
Generates an additional marker
message if logging is enabled.
For most HELICS users, most of the time, the following network options are not needed. They are most likely to be needed when working in complex networking environments, particularly when running co-simulations across multiple sites with differing network configurations. Many of these options require non-trivial knowledge of network operations and rather and it is assumed that those that needs these options will understand what they do, even with the minimal descriptions given.
API:
See multiple options for --local, --ipv4, --ipv6, --all
API: (none)
Allows the server to reuse a bound address, mostly useful for tcp cores.
Specify that a connection_ack message is not required to be connected with a broker.
API: (none)
Message buffer size. Can be increased for large messages to limit the number of retries by the underlying networking protocols.
API: (none)
Maximum number of messages in queue. Can be increased for large volumes of messages to limit the number of retries by the underlying networking protocols.
API: (none) Maximum number of network retry attempts.
API: (none) set to true to enable encryption on network types that support encryption
API: (none) specify json or a file containing the configuration options for defining the encrypted interface
API: (none) Setting this flag specifies that the OS should set the port for the HELICS message bus. HELICS will ask the operating system which port to use and will use the indicated port.
API: (none) specify that the network connection should be a server or client. By default neither option is enabled.
API: (none) Specifies the IP address (and optionally port) the rest of the federation should use when contacting this federate.
API: (none)
Specifies the IP address (and optionally port) a federate or sub-broker should use when contacting its parent broker
API: (none)
Specifies the port a federate or sub-broker should use when contacting its parent broker
API: (none)
API: (none) Specifies the port the rest of the federation should use when contacting this federate.
API: (none) starting port for automatic port definitions.