FMICore.fmi2True
— ConstantSource: FMISpec2.0.2[p.16]: 2.1.2 Platform Dependent Definitions
To simplify porting, no C types are used in the function interfaces, but the alias types are defined in this section. All definitions in this section are provided in the header file “fmi2TypesPlatform.h”.
FMICore.fmi3CausalityCalculatedParameter
— Constant[TODO]
FMICore.fmi3CausalityIndependent
— Constant[TODO]
FMICore.fmi3CausalityInput
— Constant[TODO]
FMICore.fmi3CausalityLocal
— Constant[TODO]
FMICore.fmi3CausalityOutput
— Constant[TODO]
FMICore.fmi3CausalityParameter
— Constant[TODO]
FMICore.fmi3CausalityStructuralParameter
— Constant[TODO]
FMICore.fmi3False
— Constantfmi2False
Equals a binary false
in FMI3.
Source: [TODO]
FMICore.fmi3StatusDiscard
— Constantfmi3Discard: The call was not successful and the FMU is in the same state as before the call. The output argument values are not defined, but the computation can continue. Function logMessage should be called by the FMU with further information before returning this status, respecting the current logging settings. Advanced simulation algorithms can try alternative approaches to drive the simulation by calling the function with different arguments or calling another function. Otherwise the simulation algorithm has to treat this return code like fmi3Error and has to terminate the simulation. [Examples for usage of fmi3Discard are handling of min/max violation, or signal numerical problems during model evaluation forcing smaller step sizes.]
Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions
FMICore.fmi3StatusError
— Constantfmi3Error: The call failed. The output argument values are undefined and the simulation cannot be continued. Function logMessage should be called by the FMU with further information before returning this status, respecting the current logging settings. If a function returns fmi3Error, it is possible to restore a previously retrieved FMU state by calling fmi3SetFMUState. Otherwise fmi3FreeInstance or fmi3Reset must be called. When detecting illegal arguments or a function call not allowed in the current state according to the respective state machine, the FMU must return fmi3Error. Other instances of this FMU are not affected by the error.
Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions
FMICore.fmi3StatusFatal
— Constantfmi3Fatal: The state of all instances of the model is irreparably corrupted. [For example, due to a runtime exception such as access violation or integer division by zero during the execution of an FMI function.] Function logMessage should be called by the FMU with further information before returning this status, respecting the current logging settings, if still possible. It is not allowed to call any other function for any instance of the FMU.
Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions
FMICore.fmi3StatusOK
— Constantfmi3OK: The call was successful. The output argument values are defined.
Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions
FMICore.fmi3StatusWarning
— Constantfmi3Warning: A non-critical problem was detected, but the computation can continue. The output argument values are defined. Function logMessage should be called by the FMU with further information before returning this status, respecting the current logging settings. [In certain applications, e.g. in a prototyping environment, warnings may be acceptable. For production environments warnings should be treated like errors unless they can be safely ignored.]
Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions
FMICore.fmi3True
— Constantfmi2True
Equals a binary true
in FMI3.
Source: [TODO]
FMICore.fmi3VariableNamingConventionFlat
— Constant[TODO]
Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions
FMICore.fmi3VariableNamingConventionStructured
— Constant[TODO]
Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions
FMICore.fmi2Annotation
— TypeA not further specified annotation struct.
FMICore.fmi2BaseUnit
— TypeSource: FMISpec2.0.3[p.35]: 2.2.2 Definition of Units (UnitDefinitions)
fmi2BaseUnit(
kg=0, m=0, s=0, A=0, K=0, mol=0, cd=0, rad=0, factor=1.0, offset=0.0)
Type for the optional “BaseUnit” field of an fmi2Unit
.
FMICore.fmi2BooleanAttributes
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2BooleanAttributesExt
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2CallbackFunctions
— TypeSource: FMISpec2.0.2[p.19-22]: 2.1.5 Creation, Destruction and Logging of FMU Instances
The struct contains pointers to functions provided by the environment to be used by the FMU. It is not allowed to change these functions between fmi2Instantiate(..) and fmi2Terminate(..) calls. Additionally, a pointer to the environment is provided (componentEnvironment) that needs to be passed to the “logger” function, in order that the logger function can utilize data from the environment, such as mapping a valueReference to a string. In the unlikely case that fmi2Component is also needed in the logger, it has to be passed via argument componentEnvironment. Argument componentEnvironment may be a null pointer. The componentEnvironment pointer is also passed to the stepFinished(..) function in order that the environment can provide an efficient way to identify the slave that called stepFinished(..).
FMICore.fmi2Causality
— TypeSource: FMISpec2.0.2[p.48]: 2.2.7 Definition of Model Variables (ModelVariables)
Enumeration that defines the causality of the variable. Allowed values of this enumeration:
"parameter": Independent parameter (a data value that is constant during the simulation and is provided by the environment and cannot be used in connections). variability must be "fixed" or "tunable". initial must be exact or not present (meaning exact). "calculatedParameter": A data value that is constant during the simulation and is computed during initialization or when tunable parameters change. variability must be "fixed" or "tunable". initial must be "approx", "calculated" or not present (meaning calculated). "input": The variable value can be provided from another model or slave. It is not allowed to define initial. "output": The variable value can be used by another model or slave. The algebraic relationship to the inputs is defined via the dependencies attribute of <fmiModelDescription><ModelStructure><Outputs><Unknown>. "local": Local variable that is calculated from other variables or is a continuous-time state (see section 2.2.8). It is not allowed to use the variable value in another model or slave. "independent": The independent variable (usually “time”). All variables are a function of this independent variable. variability must be "continuous". At most one ScalarVariable of an FMU can be defined as "independent". If no variable is defined as "independent", it is implicitly present with name = "time" and unit = "s". If one variable is defined as "independent", it must be defined as "Real" without a "start" attribute. It is not allowed to call function fmi2SetReal on an "independent" variable. Instead, its value is initialized with fmi2SetupExperiment and after initialization set by fmi2SetTime for ModelExchange and by arguments currentCommunicationPoint and communicationStepSize of fmi2DoStep for CoSimulation. [The actual value can be inquired with fmi2GetReal.] The default of causality is “local”. A continuous-time state must have causality = "local" or "output", see also section 2.2.8. [causality = "calculatedParameter" and causality = "local" with variability = "fixed" or "tunable" are similar. The difference is that a calculatedParameter can be used in another model or slave, whereas a local variable cannot. For example, when importing an FMU in a Modelica environment, a "calculatedParameter" should be imported in a public section as final parameter, whereas a "local" variable should be imported in a protected section of the model.] Added prefix "fmi2" to help with redefinition of constans in enums.
FMICore.fmi2Char
— TypeSource: FMISpec2.0.2[p.16]: 2.1.2 Platform Dependent Definitions
FMI2 Data Types To simplify porting, no C types are used in the function interfaces, but the alias types are defined in this section. All definitions in this section are provided in the header file “fmi2TypesPlatform.h”.
FMICore.fmi2DependencyKind
— TypeTypes of dependency:
fmi2DependencyKindDependent
: no particular structure, f(v)fmi2DependencyKindConstant
: constant factor, c*v (for Real valued variables only)fmi2DependencyKindFixed
: tunable factor, p*v (for Real valued variables only)fmi2DependencyKindTunable
[ToDo]fmi2DependencyKindDiscrete
[ToDo]
Source: FMI2.0.3 Spec for fmi2VariableDependency [p.60]
FMICore.fmi2DisplayUnit
— TypeSource: FMISpec2.0.3[p.35]: 2.2.2 Definition of Units (UnitDefinitions)
fmi2DisplayUnit(name, factor=1.0, offset=0.0)
Type for the optional “DisplayUnit” field(s) of an fmi2Unit
.
FMICore.fmi2EnumerationAttributes
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2EnumerationAttributesExt
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2EventInfo
— TypeSource: FMISpec2.0.2[p.84]: 3.2.2 Evaluation of Model Equations
If return argument fmi2eventInfo.newDiscreteStatesNeeded = fmi2True, the FMU should stay in Event Mode, and the FMU requires to set new inputs to the FMU (fmi2SetXXX on inputs) to compute and get the outputs (fmi2GetXXX on outputs) and to call fmi2NewDiscreteStates again. Depending on the connection with other FMUs, the environment shall
- call fmi2Terminate, if terminateSimulation = fmi2True is returned by at least one FMU.
- call fmi2EnterContinuousTimeMode if all FMUs return newDiscreteStatesNeeded = fmi2False.
- stay in Event Mode otherwise.
When the FMU is terminated, it is assumed that an appropriate message is printed by the logger function (see section 2.1.5) to explain the reason for the termination. If nominalsOfContinuousStatesChanged = fmi2True, then the nominal values of the states have changed due to the function call and can be inquired with fmi2GetNominalsOfContinuousStates. If valuesOfContinuousStatesChanged = fmi2True. then at least one element of the continuous state vector has changed its value due to the function call. The new values of the states can be retrieved with fmi2GetContinuousStates or individually for each state for which reinit = "true" by calling getReal. If no element of the continuous state vector has changed its value, valuesOfContinuousStatesChanged must return fmi2False. [If fmi2True would be returned in this case, an infinite event loop may occur.] If nextEventTimeDefined = fmi2True, then the simulation shall integrate at most until time = nextEventTime, and shall call fmi2EnterEventMode at this time instant. If integration is stopped before nextEventTime, for example, due to a state event, the definition of nextEventTime becomes obsolete.
FMICore.fmi2FMUstate
— Typefmi2FMUstate is a pointer to a data structure in the FMU that saves the internal FMU state of the actual or a previous time instant. This allows to restart a simulation from a previous FMU state.
Source: FMI2.0.3 Spec [p.17]; See also section 2.1.8
FMICore.fmi2Initial
— TypeSource: FMISpec2.0.2[p.48]: 2.2.7 Definition of Model Variables (ModelVariables)
Enumeration that defines how the variable is initialized. It is not allowed to provide a value for initial if causality = "input" or "independent":
"exact": The variable is initialized with the start value (provided under Real, Integer, Boolean, String or Enumeration). "approx": The variable is an iteration variable of an algebraic loop and the iteration at initialization starts with the start value. "calculated": The variable is calculated from other variables during initialization. It is not allowed to provide a “start” value. If initial is not present, it is defined by the table below based on causality and variability. If initial = exact or approx, or causality = ″input″, a start value must be provided. If initial = calculated, or causality = ″independent″, it is not allowed to provide a start value. If fmiSetXXX is not called on a variable with causality = ″input″, then the FMU must use the start value as value of this input. Added prefix "fmi2" to help with redefinition of constans in enums.
FMICore.fmi2IntegerAttributes
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2IntegerAttributesExt
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2ModelDescription
— TypeSource: FMISpec2.0.2[p.34]: 2.2.1 Definition of an FMU (fmiModelDescription)
The “ModelVariables” element of fmiModelDescription is the central part of the model description. It provides the static information of all exposed variables.
FMICore.fmi2ModelDescriptionEnumerationItem
— TypeCustom helper, not part of the FMI-Spec.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2RealAttributes
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2RealAttributesExt
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2ScalarVariable
— TypeSource: FMISpec2.0.2[p.46]: 2.2.7 Definition of Model Variables (ModelVariables)
The fmi2ScalarVariable specifies the type and argument of every exposed variable in the fmu
FMICore.fmi2SimpleType
— TypeSource: FMISpec2.0.3[p.40]: 2.2.3 Definition of Types (TypeDefinitions)
The fmi2SimpleType describes the attributes of a type definition.
FMICore.fmi2Status
— TypeSource: FMISpec2.0.2[p.18]: 2.1.3 Status Returned by Functions
Status returned by functions. The status has the following meaning:
- fmi2OK – all well
- fmi2Warning – things are not quite right, but the computation can continue. Function “logger” was called in the model (see below), and it is expected that this function has shown the prepared information message to the user.
- fmi2Discard – this return status is only possible if explicitly defined for the corresponding function
(ModelExchange: fmi2SetReal, fmi2SetInteger, fmi2SetBoolean, fmi2SetString, fmi2SetContinuousStates, fmi2GetReal, fmi2GetDerivatives, fmi2GetContinuousStates, fmi2GetEventIndicators; CoSimulation: fmi2SetReal, fmi2SetInteger, fmi2SetBoolean, fmi2SetString, fmi2DoStep, fmiGetXXXStatus): For “model exchange”: It is recommended to perform a smaller step size and evaluate the model equations again, for example because an iterative solver in the model did not converge or because a function is outside of its domain (for example sqrt(<negative number>)). If this is not possible, the simulation has to be terminated. For “co-simulation”: fmi2Discard is returned also if the slave is not able to return the required status information. The master has to decide if the simulation run can be continued. In both cases, function “logger” was called in the FMU (see below) and it is expected that this function has shown the prepared information message to the user if the FMU was called in debug mode (loggingOn = fmi2True). Otherwise, “logger” should not show a message.
- fmi2Error – the FMU encountered an error. The simulation cannot be continued with this FMU instance. If one of the functions returns fmi2Error, it can be tried to restart the simulation from a formerly stored FMU state by calling fmi2SetFMUstate.
This can be done if the capability flag canGetAndSetFMUstate is true and fmi2GetFMUstate was called before in non-erroneous state. If not, the simulation cannot be continued and fmi2FreeInstance or fmi2Reset must be called afterwards.4 Further processing is possible after this call; especially other FMU instances are not affected. Function “logger” was called in the FMU (see below), and it is expected that this function has shown the prepared information message to the user.
- fmi2Fatal – the model computations are irreparably corrupted for all FMU instances. [For example, due to a run-time exception such as access violation or integer division by zero during the execution of an fmi function]. Function “logger” was called in the FMU (see below), and it is expected that this function has shown the prepared information message to the user. It is not possible to call any other function for any of the FMU instances.
- fmi2Pending – this status is returned only from the co-simulation interface, if the slave executes the function in an asynchronous way. That means the slave starts to compute but returns immediately. The master has to call fmi2GetStatus(..., fmi2DoStepStatus) to determine if the slave has finished the computation. Can be returned only by fmi2DoStep and by fmi2GetStatus (see section 4.2.3).
FMICore.fmi2StatusKind
— TypeSource: FMISpec2.0.2[p.106]: 4.2.3 Retrieving Status Information from the Slave
CoSimulation specific Enum representing state of FMU after fmi2DoStep returned fmi2Pending.
FMICore.fmi2StringAttributes
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2StringAttributesExt
— TypeToDo.
Source: 2.2.3 Definition of Types (TypeDefinitions)
FMICore.fmi2Type
— TypeSource: FMISpec2.0.2[p.19]: 2.1.5 Creation, Destruction and Logging of FMU Instances
Argument fmuType defines the type of the FMU:
- fmi2ModelExchange: FMU with initialization and events; between events simulation of continuous systems is performed with external integrators from the environment.
- fmi2CoSimulation: Black box interface for co-simulation.
FMICore.fmi2Unit
— TypeSource: FMISpec2.0.3[p.35]: 2.2.2 Definition of Units (UnitDefinitions)
Element “UnitDefinitions ” of fmiModelDescription.
FMICore.fmi2Variability
— TypeSource: FMISpec2.0.2[p.49]: 2.2.7 Definition of Model Variables (ModelVariables)
Enumeration that defines the time dependency of the variable, in other words, it defines the time instants when a variable can change its value.
"constant": The value of the variable never changes. "fixed": The value of the variable is fixed after initialization, in other words, after fmi2ExitInitializationMode was called the variable value does not change anymore. "tunable": The value of the variable is constant between external events (ModelExchange) and between Communication Points (Co-Simulation) due to changing variables with causality = "parameter" or "input" and variability = "tunable". Whenever a parameter or input signal with variability = "tunable" changes, an event is triggered externally (ModelExchange), or the change is performed at the next Communication Point (Co-Simulation) and the variables with variability = "tunable" and causality = "calculatedParameter" or "output" must be newly computed. "discrete": ModelExchange: The value of the variable is constant between external and internal events (= time, state, step events defined implicitly in the FMU). Co-Simulation: By convention, the variable is from a “real” sampled data system and its value is only changed at Communication Points (also inside the slave). "continuous": Only a variable of type = “Real” can be “continuous”. ModelExchange: No restrictions on value changes. Co-Simulation: By convention, the variable is from a differential The default is “continuous”. Added prefix "fmi2" to help with redefinition of constans in enums.
FMICore.fmi2VariableDependency
— TypeMutable Struct representing existance and kind of dependencies of an Unknown on Known Variables in Continuous-Time and Event Mode (ME) and at Communication Points (CS)
See also FMI2.0.3 Spec fmi2VariableDependency [p.60]
FMICore.fmi2VariableNamingConvention
— TypeToDo
FMICore.fmi3Annotation
— TypeA not further specified annotation struct.
Source: [ToDo]
FMICore.fmi3Binary
— Typefmi3Binary (alias for Ptr{fmi3Byte})
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Boolean
— Typefmi3Boolean (alias for Cuchar)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Byte
— Typefmi3Byte (alias for Cuchar)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Causality
— TypeSource: FMISpec3.0, Version D5ef1c1: 2.4.7.4. Variable Attributes Enumeration that defines the causality of the variable. Allowed values of this enumeration:
parameter - A data value that is constant during the simulation (except for tunable parameters, see there) and is provided by the environment and cannot be used in connections, except for parameter propagation in terminals as described in Section 2.4.9.2.6. variability must be fixed or tunable. These parameters can be changed independently, unlike calculated parameters. initial must be exact or not present (meaning exact).
calculatedParameter - A data value that is constant during the simulation and is computed during initialization or when tunable parameters change. variability must be fixed or tunable. initial must be approx, calculated or not present (meaning calculated).
input - The variable value can be provided by the importer. [For example, the importer could forward the output of another FMU into this input.]
output - The variable value can be used by the importer. [For example, this value can be forwarded to an input of another FMU.] The algebraic relationship to the inputs can be defined via the dependencies attribute of <fmiModelDescription><ModelStructure><Output>.
local - Local variables are:
- continuous states and their ContinuousStateDerivatives, ClockedStates, EventIndicators or InitialUnknowns. These variables are listed in the <fmiModelDescription><ModelStructure>.
- internal, intermediate variables or local clocks which can be read for debugging purposes and are not listed in the <fmiModelDescription><ModelStructure>.
Setting of local variables:
- In Initialization Mode and before, local variables need to be set if they do have start values or are listed as <InitialUnknown>.
- In super state Initialized, fmi3Set{VariableType} must not be called on any of the local variables. Only in Model Exchange, continuous states can be set with fmi3SetContinuousStates. Local variable values must not be used as input to another model or FMU.
independent - The independent variable (usually time [but could also be, for example, angle]). All variables are a function of this independent variable. variability must be continuous. Exactly one variable of an FMU must be defined as independent. For Model Exchange the value is the last value set by fmi3SetTime. For Co-Simulation the value of the independent variable is lastSuccessfulTime return by the last call to fmi3DoStep or the value of argument intermediateUpdateTime of fmi3CallbackIntermediateUpdate. For Scheduled Execution the value of the independent variable is not defined. [The main purpose of this variable in Scheduled Execution is to define a quantity and unit for the independent variable.] The initial value of the independent variable is the value of the argument startTime of fmi3EnterInitializationMode for both Co-Simulation and Model Exchange. If the unit for the independent variable is not defined, it is implicitly s (seconds). If one variable is defined as independent, it must be defined with a floating point type without a start attribute. It is not allowed to call function fmi3Set{VariableType} on an independent variable. Instead, its value is initialized with fmi3EnterInitializationMode and after initialization set by fmi3SetTime for Model Exchange and by arguments currentCommunicationPoint and communicationStepSize of fmi3DoStep for Co-Simulation FMUs. [The actual value can be inquired with fmi3Get{VariableType}.]
structuralParameter - The variable value can only be changed in Configuration Mode or Reconfiguration Mode. The variability attribute must be fixed or tunable. The initial attribute must be exact or not present (meaning exact). The start attribute is mandatory. A structural parameter must not have a <Dimension> element. A structural parameter may be referenced in <Dimension> elements. If a structural parameters is referenced in <Dimension> elements, it must be of type <UInt64> and its start attribute must be larger than 0. The min attribute might still be 0.
The default of causality is local. A continuous-time state or an event indicator must have causality = local or output, see also Section 2.4.8.
[causality = calculatedParameter and causality = local with variability = fixed or tunable are similar. The difference is that a calculatedParameter can be used in another model or FMU, whereas a local variable cannot. For example, when importing an FMU in a Modelica environment, a calculatedParameter should be imported in a public section as final parameter, whereas a local variable should be imported in a protected section of the model.]
The causality of variables of type Clock must be either input or output.
Added prefix "fmi3" to help with redefinition of constans in enums.
FMICore.fmi3Char
— Typefmi3Char (alias for Cuchar)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Clock
— Typefmi3Clock (alias for Cint)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3DependencyKind
— TypeSource: FMISpec3.0, Version D5ef1c1: 2.2.10. Dependencies of Variables
Enumeration that defines the dependencies a single unknown variable vunknown can have in relation to a known variable vknown. They have the following meaning: dependent - no particular structure, f(.., v_{known,i}, ..)
Only for floating point type unknowns v_{unknown}:
constant - constant factor, c ⋅ v_{known,i} where c is an expression that is evaluated before fmi3EnterInitializationMode is called.
Only for floating point type unknowns v_{unknown} in Event and Continuous-Time Mode (ME) and at communication points (CS and SE), and not for <InitialUnknown> for Initialization Mode:
fixed - fixed factor, p⋅v_{known,i} where p is an expression that is evaluated before fmi3ExitInitializationMode is called.
tunable - tunable factor, p⋅v_{known,i} where p is an expression that is evaluated before fmi3ExitInitializationMode is called and in Event Mode due to event handling (ME) or at a communication point (CS and SE)
discrete - discrete factor, d⋅v_{known,i} where d is an expression that is evaluated before fmi3ExitInitializationMode is called and in Event Mode due to an external or internal event or at a communication point (CS and SE).
FMICore.fmi3FMUState
— Typefmi3FMUState (alias for Ptr{Cvoid})
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Float32
— Typefmi3Float32 (alias for Cfloat)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Float64
— Typefmi3Float64 (alias for Cdouble)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Initial
— TypeSource: FMISpec3.0, Version D5ef1c1:2.4.7.5. Type specific properties Enumeration that defines how the variable is initialized, i.e. if a fmi3Set{VariableType} is allowed and how the FMU internally treats this value in Instantiated and Initialization Mode. For the variable with causality = independent, the attribute initial must not be provided, because its start value is set with the startTime parameter of fmi3EnterInitializationMode.
The attribute initial for other variables can have the following values and meanings:
exact - The variable is initialized with the start value (provided under the variable type element).
approx - The start value provides an approximation that may be modified during initialization, e.g., if the FMU is part of an algebraic loop where the variable might be an iteration variable and start value is taken as initial value for an iterative solution process.
calculated - The variable is calculated from other variables during initialization. It is not allowed to provide a start value.
If initial is not present, it is defined by Table 22 based on causality and variability. If initial = exact or approx, or causality = input, a start value must be provided. If initial = calculated, or causality = independent, it is not allowed to provide a start value.
[The environment decides when to use the start value of a variable with causality = input. Examples: * Automatic tests of FMUs are performed, and the FMU is tested by providing the start value as constant input. * For a Model Exchange FMU, the FMU might be part of an algebraic loop. If the input variable is iteration variable of this algebraic loop, then initialization starts with its start value.]
If fmi3Set{VariableType} is not called on a variable with causality = input, then the FMU must use the start value as value of this input.
Added prefix "fmi3" to help with redefinition of constans in enums.
FMICore.fmi3Instance
— Typefmi3Instance (alias for Ptr{Cvoid})
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3InstanceEnvironment
— Typefmi3InstanceEnvironment (alias for Ptr{Cvoid})
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Int16
— Typefmi3Int16 (alias for Cshort)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Int32
— Typefmi3Int32 (alias for Cint)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Int64
— Typefmi3Int64 (alias for Clonglong)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Int8
— Typefmi3Int8 (alias for Cchar)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3IntervalQualifier
— TypeSource: FMISpec3.0, Version D5ef1c1: 2.2.9.4. Scheduled Execution Enumeration that defines the IntervalQualifiers which describe how to treat the intervals and intervalCounters arguments. They have the following meaning: fmi3IntervalNotYetKnown - is returned for a countdown aperiodic Clock for which the next interval is not yet known. This qualifier value can only be returned directly after the Clock was active and previous calls to fmi3GetInterval never returned fmi3IntervalChanged (nor fmi3IntervalUnchanged). In Scheduled Execution this return value means that the corresponding model partition cannot be scheduled yet.
fmi3IntervalUnchanged - is returned if a previous call to fmi3GetInterval already returned a value qualified with fmi3IntervalChanged which has not changed since. In Scheduled Execution this means the corresponding model partition has already been scheduled.
fmi3IntervalChanged - is returned to indicate that the value for the interval has changed for this Clock. Any previously returned intervals (if any) are overwritten with the current value. The new Clock interval is relative to the time of the current Event Mode or Clock Update Mode in contrast to the interval of a periodic Clock, where the interval is defined as the time between consecutive Clock ticks. In Scheduled Execution this means that the corresponding model partition has to be scheduled or re-scheduled (if a previous call to fmi3GetInterval returned fmi3IntervalChanged).
FMICore.fmi3ModelDescription
— TypeSource: FMISpec3.0, Version D5ef1c1: 2.4.1. Definition of an FMU
The central FMU data structure defining all variables of the FMU that are visible/accessible via the FMU functions.
FMICore.fmi3SimpleType
— TypeToDo: Not implemented
FMICore.fmi3Status
— TypeDefines the status flag (an enumeration of type fmi3Status defined in file fmi3FunctionTypes.h) that is returned by functions to indicate the success of the function call: The status has the following meaning:
- fmi3OK: The call was successful. The output argument values are defined.
- fmi3Warning: A non-critical problem was detected, but the computation can continue. The output argument values are defined. Function logMessage should be called by the FMU with further information before returning this status, respecting the current logging settings.
[In certain applications, e.g. in a prototyping environment, warnings may be acceptable. For production environments warnings should be treated like errors unless they can be safely ignored.]
- fmi3Discard: The call was not successful and the FMU is in the same state as before the call. The output argument values are not defined, but the computation can continue. Function logMessage should be called by the FMU with further information before returning this status, respecting the current logging settings. Advanced simulation algorithms can try alternative approaches to drive the simulation by calling the function with different arguments or calling another function. Otherwise the simulation algorithm has to treat this return code like fmi3Error and has to terminate the simulation.
[Examples for usage of fmi3Discard are handling of min/max violation, or signal numerical problems during model evaluation forcing smaller step sizes.]
- fmi3Error: The call failed. The output argument values are undefined and the simulation cannot be continued. Function logMessage should be called by the FMU with further information before returning this status, respecting the current logging settings. If a function returns fmi3Error, it is possible to restore a previously retrieved FMU state by calling fmi3SetFMUState. Otherwise fmi3FreeInstance or fmi3Reset must be called. When detecting illegal arguments or a function call not allowed in the current state according to the respective state machine, the FMU must return fmi3Error. Other instances of this FMU are not affected by the error.
- fmi3Fatal: The state of all instances of the model is irreparably corrupted. [For example, due to a runtime exception such as access violation or integer division by zero during the execution of an FMI function.] Function logMessage should be called by the FMU with further information before returning this status, respecting the current logging settings, if still possible. It is not allowed to call any other function for any instance of the FMU.
Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions
FMICore.fmi3String
— Typefmi3String (alias for Ptr{fmi3Char})
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Type
— TypeSource: FMISpec3.0, Version D5ef1c1: 2.3.1. Super State: FMU State Setable
Argument fmuType defines the type of the FMU:
- fmi3ModelExchange: FMU with initialization and events; between events simulation of continuous systems is performed with external integrators from the environment.
- fmi3CoSimulation: Black box interface for co-simulation.
- fmi3ScheduledExecution: Concurrent computation of model partitions on a single computational resource (e.g. CPU-core)
FMICore.fmi3UInt16
— Typefmi3UInt16 (alias for Cushort)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3UInt32
— Typefmi3UInt32 (alias for Cuint)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3UInt64
— Typefmi3UInt64 (alias for Culonglong)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3UInt8
— Typefmi3UInt8 (alias for Cuchar)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Unit
— TypeToDo: Not implemented
FMICore.fmi3ValueReference
— Typefmi3ValueReference (alias for Cuint)
Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions
FMICore.fmi3Variability
— TypeSource: FMISpec3.0, Version D5ef1c1: 2.4.7.4. Variable Attributes Enumeration that defines the time dependency of the variable, in other words, it defines the time instants when a variable can change its value. [The purpose of this attribute is to define when a result value needs to be inquired and to be stored. For example, discrete variables change their values only at event instants (ME) or at a communication point (CS and SE) and it is therefore only necessary to inquire them with fmi3Get{VariableType} and store them at event times.] Allowed values of this enumeration: constant - The value of the variable never changes.
fixed - The value of the variable is fixed after initialization, in other words, after fmi3ExitInitializationMode was called the variable value does not change anymore.
tunable - The value of the variable is constant between events (ME) and between communication points (CS and SE) due to changing variables with causality = parameter and variability = tunable. Whenever a parameter with variability = tunable changes, an event is triggered externally (ME or CS if events are supported), or the change is performed at the next communication point (CS and SE) and the variables with variability = tunable and causality = calculatedParameter or output must be newly computed. [tunable inputs are not allowed, see Table 18.]
discrete - Model Exchange: The value of the variable is constant between external and internal events (= time, state, step events defined implicitly in the FMU). Co-Simulation: By convention, the variable is from a real sampled data system and its value is only changed at communication points (including event handling). During intermediateUpdate, discrete variables are not allowed to change. [If the simulation algorithm notices a change in a discrete variable during intermediateUpdate, the simulation algorithm will delay the change, raise an event with earlyReturnRequested == fmi3True and during the communication point it can change the discrete variable, followed by event handling.]
continuous - Only a variable of type == fmi3GetFloat32 or type == fmi3GetFloat64 can be continuous. Model Exchange: No restrictions on value changes (see Section 4.1.1).
The default is continuous for variables of type <Float32> and <Float64>, and discrete for all other types.
For variables of type Clock and clocked variables the variability is always discrete or tunable.
[Note that the information about continuous states is defined with elements <ContinuousStateDerivative> in <ModelStructure>.]
Added prefix "fmi3" to help with redefinition of constans in enums.
FMICore.fmi3Variable
— TypeSource: FMISpec3.0, Version D5ef1c1: 2.4.7. Definition of Model Variables
A fmi3Variable describes the the type, name, valueRefence and optional information for every variable in the Modeldescription.
FMICore.fmi3VariableDependency
— TypeMutable Struct representing existance and kind of dependencies of an Unknown on Known Variables.
See also FMI3.0.1 Spec [fig 30]
FMICore.fmi3VariableNamingConvention
— Type[TODO]
Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions
Base.show
— MethodOverload the Base.show() function for custom printing of the fmi2ModelDescription.
Base.show
— MethodOverload the Base.show() function for custom printing of the fmi2ScalarVariable.
FMICore.fmi2CancelStep
— MethodSource: FMISpec2.0.2[p.105]: 4.2.2 Computation
Can be called if fmi2DoStep returned fmi2Pending in order to stop the current asynchronous execution.
FMICore.fmi2CompletedIntegratorStep!
— MethodSource: FMISpec2.0.2[p.85]: 3.2.2 Evaluation of Model Equations
This function must be called by the environment after every completed step of the integrator provided the capability flag completedIntegratorStepNotNeeded = false. If enterEventMode == fmi2True, the event mode must be entered If terminateSimulation == fmi2True, the simulation shall be terminated
FMICore.fmi2DeSerializeFMUstate!
— MethodSource: FMISpec2.0.2[p.26]: 2.1.8 Getting and Setting the Complete FMU State
fmi2DeSerializeFMUstate deserializes the byte vector serializedState of length size, constructs a copy of the FMU state and returns FMUstate, the pointer to this copy.
FMICore.fmi2DoStep
— MethodSource: FMISpec2.0.2[p.104]: 4.2.2 Computation
The computation of a time step is started.
FMICore.fmi2EnterContinuousTimeMode
— MethodSource: FMISpec2.0.2[p.85]: 3.2.2 Evaluation of Model Equations
The model enters Continuous-Time Mode and all discrete-time equations become inactive and all relations are “frozen”. This function has to be called when changing from Event Mode (after the global event iteration in Event Mode over all involved FMUs and other models has converged) into Continuous-Time Mode.
FMICore.fmi2EnterEventMode
— MethodSource: FMISpec2.0.2[p.84]: 3.2.2 Evaluation of Model Equations
The model enters Event Mode from the Continuous-Time Mode and discrete-time equations may become active (and relations are not “frozen”).
FMICore.fmi2EnterInitializationMode
— MethodSource: FMISpec2.0.2[p.23]: 2.1.6 Initialization, Termination, and Resetting an FMU
Informs the FMU to enter Initialization Mode. Before calling this function, all variables with attribute <ScalarVariable initial = "exact" or "approx"> can be set with the “fmi2SetXXX” functions (the ScalarVariable attributes are defined in the Model Description File, see section 2.2.7). Setting other variables is not allowed. Furthermore, fmi2SetupExperiment must be called at least once before calling fmi2EnterInitializationMode, in order that startTime is defined.
FMICore.fmi2ExitInitializationMode
— MethodSource: FMISpec2.0.2[p.23]: 2.1.6 Initialization, Termination, and Resetting an FMU
Informs the FMU to exit Initialization Mode.
FMICore.fmi2FreeFMUstate
— MethodSource: FMISpec2.0.2[p.26]: 2.1.8 Getting and setting the complete FMU state
fmi2FreeFMUstate frees all memory and other resources allocated with the fmi2GetFMUstate call for this FMUstate.
FMICore.fmi2FreeInstance
— MethodSource: FMISpec2.0.2[p.22]: 2.1.5 Creation, Destruction and Logging of FMU Instances
Disposes the given instance, unloads the loaded model, and frees all the allocated memory and other resources that have been allocated by the functions of the FMU interface. If a null pointer is provided for “c”, the function call is ignored (does not have an effect).
Removes the component from the FMUs component list.
FMICore.fmi2GetBoolean!
— MethodSource: FMISpec2.0.2[p.24]: 2.1.7 Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference
FMICore.fmi2GetBooleanStatus!
— MethodSource: FMISpec2.0.2[p.106]: 4.2.3 Retrieving Status Information from the Slave
Informs the master about the actual status of the simulation run. Which status information is to be returned is specified by the argument fmi2StatusKind.
FMICore.fmi2GetContinuousStates!
— MethodSource: FMISpec2.0.2[p.86]: 3.2.2 Evaluation of Model Equations
Return the new (continuous) state vector x.
FMICore.fmi2GetDerivatives!
— MethodSource: FMISpec2.0.2[p.86]: 3.2.2 Evaluation of Model Equations
Compute state derivatives at the current time instant and for the current states.
FMICore.fmi2GetDirectionalDerivative!
— MethodSource: FMISpec2.0.2[p.26]: 2.1.9 Getting Partial Derivatives
This function computes the directional derivatives of an FMU.
ΔvUnknown = ∂h / ∂vKnown ⋅ ΔvKnown
FMICore.fmi2GetEventIndicators!
— MethodSource: FMISpec2.0.2[p.86]: 3.2.2 Evaluation of Model Equations
Compute event indicators at the current time instant and for the current states.
FMICore.fmi2GetFMUstate!
— MethodSource: FMISpec2.0.2[p.26]: 2.1.8 Getting and Setting the Complete FMU State
fmi2GetFMUstate makes a copy of the internal FMU state and returns a pointer to this copy
FMICore.fmi2GetInteger!
— MethodSource: FMISpec2.0.2[p.24]: 2.1.7 Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference
FMICore.fmi2GetIntegerStatus!
— MethodSource: FMISpec2.0.2[p.106]: 4.2.3 Retrieving Status Information from the Slave
Informs the master about the actual status of the simulation run. Which status information is to be returned is specified by the argument fmi2StatusKind.
FMICore.fmi2GetNominalsOfContinuousStates!
— MethodSource: FMISpec2.0.2[p.86]: 3.2.2 Evaluation of Model Equations
Return the nominal values of the continuous states.
FMICore.fmi2GetReal!
— MethodSource: FMISpec2.0.2[p.24]: 2.1.7 Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference
FMICore.fmi2GetRealOutputDerivatives!
— MethodSource: FMISpec2.0.2[p.104]: 4.2.1 Transfer of Input / Output Values and Parameters
Retrieves the n-th derivative of output values. vr defines the value references of the variables the array order specifies the corresponding order of derivation of the variables
FMICore.fmi2GetRealStatus!
— MethodSource: FMISpec2.0.2[p.106]: 4.2.3 Retrieving Status Information from the Slave
Informs the master about the actual status of the simulation run. Which status information is to be returned is specified by the argument fmi2StatusKind.
FMICore.fmi2GetStatus!
— MethodSource: FMISpec2.0.2[p.106]: 4.2.3 Retrieving Status Information from the Slave
Informs the master about the actual status of the simulation run. Which status information is to be returned is specified by the argument fmi2StatusKind.
FMICore.fmi2GetString!
— MethodSource: FMISpec2.0.2[p.24]: 2.1.7 Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference
FMICore.fmi2GetStringStatus!
— MethodSource: FMISpec2.0.2[p.106]: 4.2.3 Retrieving Status Information from the Slave
Informs the master about the actual status of the simulation run. Which status information is to be returned is specified by the argument fmi2StatusKind.
FMICore.fmi2GetTypesPlatform
— MethodSource: FMISpec2.0.2[p.22]: 2.1.4 Inquire Platform and Version Number of Header Files
Returns the string to uniquely identify the “fmi2TypesPlatform.h” header file used for compilation of the functions of the FMU. The standard header file, as documented in this specification, has fmi2TypesPlatform set to “default” (so this function usually returns “default”).
FMICore.fmi2GetVersion
— MethodSource: FMISpec2.0.2[p.22]: 2.1.4 Inquire Platform and Version Number of Header Files
Returns the version of the “fmi2Functions.h” header file which was used to compile the functions of the FMU. The function returns “fmiVersion” which is defined in this header file. The standard header file as documented in this specification has version “2.0”
FMICore.fmi2Instantiate
— MethodSource: FMISpec2.0.2[p.19]: 2.1.5 Creation, Destruction and Logging of FMU Instances
The function returns a new instance of an FMU.
FMICore.fmi2NewDiscreteStates!
— MethodSource: FMISpec2.0.2[p.84]: 3.2.2 Evaluation of Model Equations
The FMU is in Event Mode and the super dense time is incremented by this call.
FMICore.fmi2Reset
— MethodSource: FMISpec2.0.2[p.24]: 2.1.6 Initialization, Termination, and Resetting an FMU
Is called by the environment to reset the FMU after a simulation run. The FMU goes into the same state as if fmi2Instantiate would have been called.
FMICore.fmi2SerializeFMUstate!
— MethodSource: FMISpec2.0.2[p.26]: 2.1.8 Getting and Setting the Complete FMU State
fmi2SerializeFMUstate serializes the data which is referenced by pointer FMUstate and copies this data in to the byte vector serializedState of length size
FMICore.fmi2SerializedFMUstateSize!
— MethodSource: FMISpec2.0.2[p.26]: 2.1.8 Getting and Setting the Complete FMU State
fmi2SerializedFMUstateSize returns the size of the byte vector, in order that FMUstate can be stored in it.
FMICore.fmi2SetBoolean
— MethodSource: FMISpec2.0.2[p.24]: 2.1.7 Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference
FMICore.fmi2SetContinuousStates
— MethodSource: FMISpec2.0.2[p.83]: 3.2.1 Providing Independent Variables and Re-initialization of Caching
Set a new (continuous) state vector and re-initialize caching of variables that depend on the states. Argument nx is the length of vector x and is provided for checking purposes
FMICore.fmi2SetDebugLogging
— MethodSource: FMISpec2.0.2[p.22]: 2.1.5 Creation, Destruction and Logging of FMU Instances
The function controls debug logging that is output via the logger function callback. If loggingOn = fmi2True, debug logging is enabled, otherwise it is switched off.
FMICore.fmi2SetFMUstate
— MethodSource: FMISpec2.0.2[p.26]: 2.1.8 Getting and Setting the Complete FMU State
fmi2SetFMUstate copies the content of the previously copied FMUstate back and uses it as actual new FMU state.
FMICore.fmi2SetInteger
— MethodSource: FMISpec2.0.2[p.24]: 2.1.7 Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference
FMICore.fmi2SetReal
— MethodSource: FMISpec2.0.2[p.24]: 2.1.7 Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference
FMICore.fmi2SetRealInputDerivatives
— MethodSource: FMISpec2.0.2[p.104]: 4.2.1 Transfer of Input / Output Values and Parameters
Sets the n-th time derivative of real input variables. vr defines the value references of the variables the array order specifies the corresponding order of derivation of the variables
FMICore.fmi2SetString
— MethodSource: FMISpec2.0.2[p.24]: 2.1.7 Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference
FMICore.fmi2SetTime
— MethodSource: FMISpec2.0.2[p.83]: 3.2.1 Providing Independent Variables and Re-initialization of Caching
Set a new time instant and re-initialize caching of variables that depend on time, provided the newly provided time value is different to the previously set time value (variables that depend solely on constants or parameters need not to be newly computed in the sequel, but the previously computed values can be reused).
FMICore.fmi2SetupExperiment
— MethodSource: FMISpec2.0.2[p.23]: 2.1.6 Initialization, Termination, and Resetting an FMU
Informs the FMU to setup the experiment. This function must be called after fmi2Instantiate and before fmi2EnterInitializationMode is called.The function controls debug logging that is output via the logger function callback. If loggingOn = fmi2True, debug logging is enabled, otherwise it is switched off.
FMICore.fmi2Terminate
— MethodSource: FMISpec2.0.2[p.24]: 2.1.6 Initialization, Termination, and Resetting an FMU
Informs the FMU that the simulation run is terminated.
FMICore.fmi3CompletedIntegratorStep!
— MethodSource: FMISpec3.0, Version D5ef1c1: 3.2.1. State: Continuous-Time Mode
This function must be called by the environment after every completed step of the integrator provided the capability flag needsCompletedIntegratorStep = true. If enterEventMode == fmi3True, the event mode must be entered If terminateSimulation == fmi3True, the simulation shall be terminated
FMICore.fmi3DeSerializeFMUState!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.4. Getting and Setting the Complete FMU State
fmi3DeSerializeFMUstate deserializes the byte vector serializedState of length size, constructs a copy of the FMU state and returns FMUstate, the pointer to this copy.
FMICore.fmi3DoStep!
— MethodSource: FMISpec3.0, Version D5ef1c1: 4.2.1. State: Step Mode
The computation of a time step is started.
FMICore.fmi3EnterConfigurationMode
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.2. State: Instantiated
If the importer needs to change structural parameters, it must move the FMU into Configuration Mode using fmi3EnterConfigurationMode.
FMICore.fmi3EnterContinuousTimeMode
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.5. State: Event Mode
The model enters Continuous-Time Mode and all discrete-time equations become inactive and all relations are “frozen”. This function has to be called when changing from Event Mode (after the global event iteration in Event Mode over all involved FMUs and other models has converged) into Continuous-Time Mode.
FMICore.fmi3EnterEventMode
— MethodSource: FMISpec3.0, Version D5ef1c1: 3.2.1. State: Continuous-Time Mode
The model enters Event Mode from the Continuous-Time Mode in ModelExchange oder Step Mode in CoSimulation and discrete-time equations may become active (and relations are not “frozen”).
FMICore.fmi3EnterInitializationMode
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.2. State: Instantiated
Informs the FMU to enter Initialization Mode. Before calling this function, all variables with attribute <Datatype initial = "exact" or "approx"> can be set with the “fmi3SetXXX” functions (the ScalarVariable attributes are defined in the Model Description File, see section 2.4.7). Setting other variables is not allowed. Also sets the simulation start and stop time.
FMICore.fmi3EnterStepMode
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.5. State: Event Mode
This function must be called to change from Event Mode into Step Mode in Co-Simulation (see 4.2.).
FMICore.fmi3EvaluateDiscreteStates
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.3. State: Initialization Mode
This function is called to trigger the evaluation of fdisc to compute the current values of discrete states from previous values. The FMU signals the support of fmi3EvaluateDiscreteStates via the capability flag providesEvaluateDiscreteStates.
FMICore.fmi3ExitConfigurationMode
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.6. State: Configuration Mode
Exits the Configuration Mode and returns to state Instantiated.
FMICore.fmi3ExitInitializationMode
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.3. State: Initialization Mode
Informs the FMU to exit Initialization Mode.
FMICore.fmi3FreeFMUState
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.4. Getting and Setting the Complete FMU State
fmi3FreeFMUstate frees all memory and other resources allocated with the fmi3GetFMUstate call for this FMUstate.
FMICore.fmi3FreeInstance
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.1. Super State: FMU State Setable
Disposes the given instance, unloads the loaded model, and frees all the allocated memory and other resources that have been allocated by the functions of the FMU interface. If a NULL pointer is provided for argument instance, the function call is ignored (does not have an effect).
FMICore.fmi3GetAdjointDerivative!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.11. Getting Partial Derivatives
This function computes the adjoint derivatives v^T{sensitivity}= v^T{seed} ⋅ J of an FMU.
unknowns - contains value references to the unknowns.
nUnknowns - contains the length of argument unknowns.
knowns - contains value references of the knowns.
nKnowns - contains the length of argument knowns.
seed - contains the components of the seed vector.
nSeed - contains the length of seed.
sensitivity - contains the components of the sensitivity vector.
nSensitivity - contains the length of sensitivity.
This function can only be called if the 'ProvidesAdjointDerivatives' tag in the ModelDescription is set.
FMICore.fmi3GetBinary!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValues - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetBoolean!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetClock!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetContinuousStateDerivatives!
— MethodSource: FMISpec3.0, Version D5ef1c1: 3.2.1. State: Continuous-Time Mode
Compute first-oder state derivatives at the current time instant and for the current states.
FMICore.fmi3GetContinuousStates!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.3. State: Initialization Mode
Return the states at the current time instant.
This function must be called if fmi3UpdateDiscreteStates returned with valuesOfContinuousStatesChanged == fmi3True. Not allowed in Co-Simulation and Scheduled Execution.
FMICore.fmi3GetDirectionalDerivative!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.11. Getting Partial Derivatives
This function computes the directional derivatives v{sensitivity} = J ⋅ v{seed} of an FMU.
unknowns - contains value references to the unknowns.
nUnknowns - contains the length of argument unknowns.
knowns - contains value references of the knowns.
nKnowns - contains the length of argument knowns.
seed - contains the components of the seed vector.
nSeed - contains the length of seed.
sensitivity - contains the components of the sensitivity vector.
nSensitivity - contains the length of sensitivity.
This function can only be called if the 'ProvidesDirectionalDerivatives' tag in the ModelDescription is set.
FMICore.fmi3GetEventIndicators!
— MethodSource: FMISpec3.0, Version D5ef1c1: 3.2.1. State: Continuous-Time Mode
Compute event indicators at the current time instant and for the current states. EventIndicators signal Events by their sign change.
FMICore.fmi3GetFMUState!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.4. Getting and Setting the Complete FMU State
fmi3GetFMUstate makes a copy of the internal FMU state and returns a pointer to this copy
FMICore.fmi3GetFloat32!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetFloat64!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetInt16!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetInt32!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetInt64!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetInt8!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetNominalsOfContinuousStates!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.3. State: Initialization Mode
Return the nominal values of the continuous states.
If fmi3UpdateDiscreteStates returned with nominalsOfContinuousStatesChanged == fmi3True, then at least one nominal value of the states has changed and can be inquired with fmi3GetNominalsOfContinuousStates. Not allowed in Co-Simulation and Scheduled Execution.
FMICore.fmi3GetNumberOfContinuousStates!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.2. State: Instantiated
This function returns the number of continuous states. This function can only be called in Model Exchange.
fmi3GetNumberOfContinuousStates must be called after a structural parameter is changed. As long as no structural parameters changed, the number of states is given in the modelDescription.xml, alleviating the need to call this function.
FMICore.fmi3GetNumberOfEventIndicators!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.2. State: Instantiated
This function returns the number of event indicators. This function can only be called in Model Exchange.
fmi3GetNumberOfEventIndicators must be called after a structural parameter is changed. As long as no structural parameters changed, the number of states is given in the modelDescription.xml, alleviating the need to call this function.
FMICore.fmi3GetOutputDerivatives!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.12. Getting Derivatives of Continuous Outputs
Retrieves the n-th derivative of output values.
valueReferences - is a vector of value references that define the variables whose derivatives shall be retrieved. If multiple derivatives of a variable shall be retrieved, list the value reference multiple times.
nValueReferences - is the dimension of the arguments valueReferences and orders.
orders - contains the orders of the respective derivative (1 means the first derivative, 2 means the second derivative, …, 0 is not allowed). If multiple derivatives of a variable shall be retrieved, provide a list of them in the orders array, corresponding to a multiply occurring value reference in the valueReferences array. The highest order of derivatives retrievable can be determined by the 'maxOutputDerivativeOrder' tag in the ModelDescription.
values - is a vector with the values of the derivatives. The order of the values elements is derived from a twofold serialization: the outer level corresponds to the combination of a value reference (e.g., valueReferences[k]) and order (e.g., orders[k]), and the inner level to the serialization of variables as defined in Section 2.2.6.1. The inner level does not exist for scalar variables.
nValues - is the size of the argument values. nValues only equals nValueReferences if all corresponding output variables are scalar variables.
FMICore.fmi3GetString!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetUInt16!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetUInt32!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetUInt64!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetUInt8!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3GetVersion
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.4. Inquire Version Number of Header Files
This function returns fmi3Version of the fmi3Functions.h header file which was used to compile the functions of the FMU. This function call is allowed always and in all interface types.
The standard header file as documented in this specification has version "3.0-beta.2", so this function returns "3.0-beta.2".
FMICore.fmi3InstantiateCoSimulation
— MethodSource: FMISpec3.0, Version D5ef1c1:: 2.3.1. Super State: FMU State Setable
This function instantiates a Co-Simulation FMU (see Section 4). It is allowed to call this function only if modelDescription.xml includes a <CoSimulation> element.
FMICore.fmi3InstantiateModelExchange
— MethodSource: FMISpec3.0, Version D5ef1c1:: 2.3.1. Super State: FMU State Setable
This function instantiates a Model Exchange FMU (see Section 3). It is allowed to call this function only if modelDescription.xml includes a <ModelExchange> element.
FMICore.fmi3InstantiateScheduledExecution
— MethodSource: FMISpec3.0, Version D5ef1c1:: 2.3.1. Super State: FMU State Setable
This function instantiates a Scheduled Execution FMU (see Section 4). It is allowed to call this function only if modelDescription.xml includes a <ScheduledExecution> element.
FMICore.fmi3Reset
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.1. Super State: FMU State Setable
Is called by the environment to reset the FMU after a simulation run. The FMU goes into the same state as if fmi3InstantiateXXX would have been called.
FMICore.fmi3SerializeFMUState!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.4. Getting and Setting the Complete FMU State
fmi3SerializeFMUstate serializes the data which is referenced by pointer FMUstate and copies this data in to the byte vector serializedState of length size
FMICore.fmi3SerializedFMUStateSize!
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.4. Getting and Setting the Complete FMU State
fmi3SerializedFMUstateSize returns the size of the byte vector which is needed to store FMUstate in it.
FMICore.fmi3SetBinary
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetBoolean
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetClock
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetContinuousStates
— MethodSource: FMISpec3.0, Version D5ef1c1: 3.2.1. State: Continuous-Time Mode
Set a new (continuous) state vector and re-initialize caching of variables that depend on the states. Argument nx is the length of vector x and is provided for checking purposes
FMICore.fmi3SetDebugLogging
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.1. Super State: FMU State Setable
The function controls debug logging that is output via the logger function callback. If loggingOn = fmi3True, debug logging is enabled, otherwise it is switched off.
FMICore.fmi3SetFMUState
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.4. Getting and Setting the Complete FMU State
fmi3SetFMUstate copies the content of the previously copied FMUstate back and uses it as actual new FMU state.
FMICore.fmi3SetFloat32
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetFloat64
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetInt16
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetInt32
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetInt64
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetInt8
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetString
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetTime
— MethodSource: FMISpec3.0, Version D5ef1c1: 3.2.1. State: Continuous-Time Mode
Set a new time instant and re-initialize caching of variables that depend on time, provided the newly provided time value is different to the previously set time value (variables that depend solely on constants or parameters need not to be newly computed in the sequel, but the previously computed values can be reused).
FMICore.fmi3SetUInt16
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetUInt32
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetUInt64
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3SetUInt8
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.2.6.2. Getting and Setting Variable Values
Functions to get and set values of variables idetified by their valueReference.
nValue - is different from nvr if the value reference represents an array and therefore are more values tied to a single value reference.
FMICore.fmi3Terminate
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.4. Super State: Initialized
Informs the FMU that the simulation run is terminated.
FMICore.fmi3UpdateDiscreteStates
— MethodSource: FMISpec3.0, Version D5ef1c1: 2.3.5. State: Event Mode
This function is called to signal a converged solution at the current super-dense time instant. fmi3UpdateDiscreteStates must be called at least once per super-dense time instant.