From e578fae2fb0f9004b6e9cf4a118c68efb2243236 Mon Sep 17 00:00:00 2001 From: Simon Exner Date: Tue, 10 Oct 2023 08:18:37 +0200 Subject: [PATCH 1/3] doc fixes --- src/FMI2/cconst.jl | 40 +++++++++++++++++++++---- src/FMI3/cconst.jl | 74 ++++++++++++++++++++++++++++++++++++++++++---- 2 files changed, 103 insertions(+), 11 deletions(-) diff --git a/src/FMI2/cconst.jl b/src/FMI2/cconst.jl index 53d0b03..ecd5bdc 100644 --- a/src/FMI2/cconst.jl +++ b/src/FMI2/cconst.jl @@ -20,6 +20,10 @@ const fmi2Real = Creal # defined in FMICore.jl, dependent on the Julia arch const fmi2Integer = Cint const fmi2Byte = Char const fmi2ValueReference = Cuint + +""" +TODO +""" const fmi2FMUstate = Ptr{Cvoid} const fmi2Component = Ptr{Cvoid} const fmi2ComponentEnvironment = Ptr{Cvoid} @@ -30,19 +34,36 @@ export fmi2Char, fmi2String, fmi2Boolean, fmi2Real, fmi2Integer, fmi2Byte, fmi2V Source: 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 +- 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()). 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. +- 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). +- 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). """ const fmi2Status = Cuint + +""" +Source: 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()). 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). +""" const fmi2StatusOK = Cuint(0) const fmi2StatusWarning = Cuint(1) const fmi2StatusDiscard = Cuint(2) @@ -121,6 +142,13 @@ To simplify porting, no C types are used in the function interfaces, but the ali All definitions in this section are provided in the header file “fmi2TypesPlatform.h”. """ const fmi2True = fmi2Boolean(true) + +""" +Source: 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”. +""" const fmi2False = fmi2Boolean(false) export fmi2True, fmi2False diff --git a/src/FMI3/cconst.jl b/src/FMI3/cconst.jl index 2ab4eb4..9c660ef 100644 --- a/src/FMI3/cconst.jl +++ b/src/FMI3/cconst.jl @@ -10,13 +10,48 @@ To simplify porting, no C types are used in the function interfaces, but the ali All definitions in this section are provided in the header file fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. """ const fmi3Float32 = Cfloat + +""" +Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. +""" const fmi3Float64 = Cdouble + +""" +Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. +""" const fmi3Int8 = Cchar const fmi3UInt8 = Cuchar + +""" +Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. +""" const fmi3Int16 = Cshort const fmi3UInt16 = Cushort + +""" +Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. +""" const fmi3Int32 = Cint const fmi3UInt32 = Cuint + +""" +Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. +""" const fmi3Int64 = Clonglong const fmi3UInt64 = Culonglong const fmi3Boolean = Cuchar @@ -37,19 +72,36 @@ export fmi3Boolean, fmi3Char, fmi3String, fmi3Byte, fmi3Binary, fmi3ValueReferen Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions Defines 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. +- 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. +- 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. +- 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. +- 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. +- 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. """ const fmi3Status = Cuint + +""" +Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions +Defines 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. +""" const fmi3StatusOK = Cuint(0) const fmi3StatusWarning = Cuint(1) const fmi3StatusDiscard = Cuint(2) @@ -173,6 +225,10 @@ export fmi3Initial, fmi3InitialExact, fmi3InitialApprox, fmi3InitialCalculated ToDo. """ const fmi3False = fmi3Boolean(false) + +""" +ToDo. +""" const fmi3True = fmi3Boolean(true) export fmi3False, fmi3True @@ -209,7 +265,15 @@ export fmi3IntervalQualifier, fmi3IntervalQualifierIntervalNotYetKnown, fmi3Inte Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions """ const fmi3VariableNamingConvention = Cuint + +""" +Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions +""" const fmi3VariableNamingConventionFlat = Cuint(0) + +""" +Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions +""" const fmi3VariableNamingConventionStructured = Cuint(1) export fmi3VariableNamingConvention, fmi3VariableNamingConventionFlat, fmi3VariableNamingConventionStructured From 76753b67a2cae223201ca8cfe34e55498f505010 Mon Sep 17 00:00:00 2001 From: Simon Exner Date: Mon, 16 Oct 2023 09:27:42 +0200 Subject: [PATCH 2/3] doc fixes --- src/FMI2/cconst.jl | 14 ++++++++++++-- src/FMI2/convert.jl | 16 ++++++++-------- src/FMI2/ctype.jl | 4 +++- src/FMI2/struct.jl | 9 +++++++-- src/FMI3/cconst.jl | 4 ++-- src/FMI3/convert.jl | 28 ++++++++++++++-------------- src/FMI3/ctype.jl | 8 +++++--- src/FMI3/struct.jl | 6 ++++-- src/FMICore.jl | 6 +++--- 9 files changed, 58 insertions(+), 37 deletions(-) diff --git a/src/FMI2/cconst.jl b/src/FMI2/cconst.jl index ecd5bdc..501bd50 100644 --- a/src/FMI2/cconst.jl +++ b/src/FMI2/cconst.jl @@ -22,7 +22,10 @@ const fmi2Byte = Char const fmi2ValueReference = Cuint """ -TODO +fmi2FMUstate 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 """ const fmi2FMUstate = Ptr{Cvoid} const fmi2Component = Ptr{Cvoid} @@ -178,7 +181,14 @@ export fmi2StatusKind, fmi2StatusKindDoStepStatus, fmi2StatusKindPendingStatus, # Custom helper, not part of the FMI-Spec. """ -ToDo. +Types 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) +- `fmi2DependencyKindDependent`: discrete factor, d*v (for Real valued variables only) + +Source: FMI2.0.3 Spec for fmi2VariableDependency [p.60] """ const fmi2DependencyKind = Cuint const fmi2DependencyKindDependent = Cuint(0) diff --git a/src/FMI2/convert.jl b/src/FMI2/convert.jl index 7bc8a3f..d592fcf 100644 --- a/src/FMI2/convert.jl +++ b/src/FMI2/convert.jl @@ -26,7 +26,7 @@ end export fmi2StatusToString """ -ToDo. +converts a [`fmi2Causality`](@ref) to the corresponding String ("parameter", "calculatedParameter", "input", "output", "local", "independent") """ function fmi2CausalityToString(c::fmi2Causality) if c == fmi2CausalityParameter @@ -48,7 +48,7 @@ end export fmi2CausalityToString """ -ToDo. +converts a String ("parameter", "calculatedParameter", "input", "output", "local", "independent") to the corresponding [`fmi2Causality`](@ref) """ function fmi2StringToCausality(s::AbstractString) if s == "parameter" @@ -70,7 +70,7 @@ end export fmi2StringToCausality """ -ToDo. +converts a String ("constant", "fixed", "tunable", "discrete", "continuous") to the corresponding [`fmi2Variability`](@ref) """ function fmi2VariabilityToString(c::fmi2Variability) if c == fmi2VariabilityConstant @@ -90,7 +90,7 @@ end export fmi2VariabilityToString """ -ToDo. +converts a [`fmi2Variability`](@ref) to the corresponding String ("constant", "fixed", "tunable", "discrete", "continuous") """ function fmi2StringToVariability(s::AbstractString) if s == "constant" @@ -110,7 +110,7 @@ end export fmi2StringToVariability """ -ToDo. +converts a [`fmi2Initial`](@ref) to the corresponding String ("approx", "exact", "calculated") """ function fmi2InitialToString(c::fmi2Initial) if c == fmi2InitialApprox @@ -126,7 +126,7 @@ end export fmi2InitialToString """ -ToDo. +converts a String ("approx", "exact", "calculated") to the corresponding [`fmi2Initial`](@ref) """ function fmi2StringToInitial(s::AbstractString) if s == "approx" @@ -142,7 +142,7 @@ end export fmi2StringToInitial """ -ToDo. +converts a [`fmi2DependencyKind`](@ref) to the corresponding String ("dependent", "constant", "fixed", "tunable", "discrete") """ function fmi2DependencyKindToString(c::fmi2DependencyKind) if c == fmi2DependencyKindDependent @@ -162,7 +162,7 @@ end export fmi2DependencyKindToString """ -ToDo. +converts a String ("dependent", "constant", "fixed", "tunable", "discrete") to the corresponding [`fmi2DependencyKind`](@ref) """ function fmi2StringToDependencyKind(s::AbstractString) if s == "dependent" diff --git a/src/FMI2/ctype.jl b/src/FMI2/ctype.jl index 6122923..18b91db 100644 --- a/src/FMI2/ctype.jl +++ b/src/FMI2/ctype.jl @@ -62,7 +62,9 @@ end export fmi2Annotation """ -ToDo +Mutable 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] """ mutable struct fmi2VariableDependency # mandatory diff --git a/src/FMI2/struct.jl b/src/FMI2/struct.jl index 1e54d4d..052d9d2 100644 --- a/src/FMI2/struct.jl +++ b/src/FMI2/struct.jl @@ -38,7 +38,7 @@ Overload the Base.show() function for custom printing of the FMU2. Base.show(io::IO, e::FMU2Event) = print(io, e.indicator == 0 ? "Time-Event @ $(round(e.t; digits=4))s" : "State-Event #$(e.indicator) @ $(round(e.t; digits=4))s") """ -ToDo +The mutable struct representing a specific Solution of a FMI2 FMU. """ mutable struct FMU2Solution{C} <: FMUSolution where {C} component::C # FMU2Component @@ -191,7 +191,12 @@ function Base.show(io::IO, sol::FMU2Solution) end """ -ToDo. +Source: FMISpec 2.0.3 [p.16f] + +This is a pointer to a data structure in the simulation environment that calls the FMU. Using this +pointer, data from the modelDescription.xml file [(for example, mapping of valueReferences to +variable names)] can be transferred between the simulation environment and the logger function +(see [FMISpec 2.0.3] section 2.1.5). """ mutable struct FMU2ComponentEnvironment logStatusOK::Bool diff --git a/src/FMI3/cconst.jl b/src/FMI3/cconst.jl index 9c660ef..99f0db6 100644 --- a/src/FMI3/cconst.jl +++ b/src/FMI3/cconst.jl @@ -222,12 +222,12 @@ const fmi3InitialCalculated = Cuint(2) export fmi3Initial, fmi3InitialExact, fmi3InitialApprox, fmi3InitialCalculated """ -ToDo. +`fmi3Boolean`(false) """ const fmi3False = fmi3Boolean(false) """ -ToDo. +`fmi3Boolean`(true) """ const fmi3True = fmi3Boolean(true) export fmi3False, fmi3True diff --git a/src/FMI3/convert.jl b/src/FMI3/convert.jl index 662801a..afbd105 100644 --- a/src/FMI3/convert.jl +++ b/src/FMI3/convert.jl @@ -24,7 +24,7 @@ end export fmi3StatusToString """ -ToDo. +converts a [`fmi3Causality`](@ref) to the corresponding String ("parameter", "calculatedParameter", "structuralParameter", "input", "output", "local", "independent") """ function fmi3CausalityToString(c::fmi3Causality) if c == fmi3CausalityParameter @@ -48,7 +48,7 @@ end export fmi3CausalityToString """ -ToDo. +converts a String ("parameter", "calculatedParameter", "structuralParameter", "input", "output", "local", "independent") to the corresponding [`fmi3Causality`](@ref) """ function fmi3StringToCausality(s::AbstractString) if s == "parameter" @@ -72,7 +72,7 @@ end export fmi3StringToCausality """ -ToDo. +converts a String ("constant", "fixed", "tunable", "discrete", "continuous") to the corresponding [`fmi3Variability`](@ref) """ function fmi3VariabilityToString(c::fmi3Variability) if c == fmi3VariabilityConstant @@ -92,7 +92,7 @@ end export fmi3VariabilityToString """ -ToDo. +converts a [`fmi3Variability`](@ref) to the corresponding String ("constant", "fixed", "tunable", "discrete", "continuous") """ function fmi3StringToVariability(s::AbstractString) if s == "constant" @@ -112,7 +112,7 @@ end export fmi3StringToVariability """ -ToDo. +converts a [`fmi3Initial`](@ref) to the corresponding String ("approx", "exact", "calculated") """ function fmi3InitialToString(c::fmi3Initial) if c == fmi3InitialApprox @@ -128,7 +128,7 @@ end export fmi3InitialToString """ -ToDo. +converts a String ("approx", "exact", "calculated") to the corresponding [`fmi3Initial`](@ref) """ function fmi3StringToInitial(s::AbstractString) if s == "approx" @@ -144,7 +144,7 @@ end export fmi3StringToInitial """ -ToDo. +converts a [`fmi3DependencyKind`](@ref) to the corresponding String ("independent", "dependent", "constant", "fixed", "tunable", "discrete") """ function fmi3DependencyKindToString(c::fmi3DependencyKind) if c == fmi3DependencyKindIndependent @@ -166,7 +166,7 @@ end export fmi3DependencyKindToString """ -ToDo. +converts a String ("independent", "dependent", "constant", "fixed", "tunable", "discrete") to the corresponding [`fmi3DependencyKind`](@ref) """ function fmi3StringToDependencyKind(s::AbstractString) if s == "independent" @@ -188,7 +188,7 @@ end export fmi3StringToDependencyKind """ -ToDo. +converts a [`fmi3VariableNamingConvention`](@ref) to the corresponding String ("flat", "structured") """ function fmi3VariableNamingConventionToString(c::fmi3VariableNamingConvention) if c == fmi3VariableNamingConventionFlat @@ -202,7 +202,7 @@ end export fmi3VariableNamingConventionToString """ -ToDo. +converts a String ("flat", "structured") to the corresponding [`fmi3VariableNamingConvention`](@ref) """ function fmi3StringToVariableNamingConvention(s::AbstractString) if s == "flat" @@ -216,7 +216,7 @@ end export fmi3StringToVariableNamingConvention """ -ToDo. +converts a [`fmi3Type`](@ref)String to the corresponding ("coSimulation", "modelExchange", "scheduledExecution") """ function fmi3TypeToString(c::fmi3Type) if c == fmi3TypeCoSimulation @@ -232,7 +232,7 @@ end export fmi3TypeToString """ -ToDo. +converts a String ("coSimulation", "modelExchange", "scheduledExecution") to the corresponding [`fmi3Type`](@ref) """ function fmi3StringToType(s::AbstractString) if s == "coSimulation" @@ -248,7 +248,7 @@ end export fmi3StringToType """ -ToDo. +converts a [`fmi3IntervalQualifier`](@ref) to the corresponding String ("intervalNotYetKnown", "intervalUnchanged", "intervalChanged") """ function fmi3IntervalQualifierToString(c::fmi3IntervalQualifier) if c == fmi3IntervalQualifierIntervalNotYetKnown @@ -264,7 +264,7 @@ end export fmi3IntervalQualifierToString """ -ToDo. +converts a String ("intervalNotYetKnown", "intervalUnchanged", "intervalChanged") to the corresponding [`fmi3IntervalQualifier`](@ref) """ function fmi3StringToIntervalQualifier(s::AbstractString) if s == "intervalNotYetKnown" diff --git a/src/FMI3/ctype.jl b/src/FMI3/ctype.jl index a16d2b4..a312670 100644 --- a/src/FMI3/ctype.jl +++ b/src/FMI3/ctype.jl @@ -12,7 +12,9 @@ abstract type fmi3Variable end export fmi3Variable """ -ToDo +Mutable Struct representing existance and kind of dependencies of an Unknown on Known Variables. + +See also FMI3.0.1 Spec [fig 30] """ mutable struct fmi3VariableDependency # mandatory @@ -1068,7 +1070,7 @@ mutable struct fmi3ModelDescriptionScheduledExecution end """ -ToDo +ToDo: Not implemented """ mutable struct fmi3Unit # ToDo @@ -1076,7 +1078,7 @@ end export fmi3Unit """ -ToDo +ToDo: Not implemented """ mutable struct fmi3SimpleType # ToDo diff --git a/src/FMI3/struct.jl b/src/FMI3/struct.jl index b47e03c..14bde1f 100644 --- a/src/FMI3/struct.jl +++ b/src/FMI3/struct.jl @@ -10,7 +10,9 @@ # - string/enum-converters for FMI-attribute-structs (e.g. `fmi3StatusToString`, ...) """ -ToDo. +This is a pointer to a data structure in the importer. Using this pointer, data may be transferred between the importer and callback functions the importer provides with the instantiation functions. + +Source: FMISpec 3.0.1 [2.2.3. Platform Dependent Definitions] """ mutable struct FMU3InstanceEnvironment logStatusOK::Bool @@ -274,7 +276,7 @@ Base.show(io::IO, e::FMU3Event) = print(io, e.indicator == 0 ? "Time-Event @ $(r """ -ToDo +The mutable struct representing a specific Solution of a FMI2 FMU. """ mutable struct FMU3Solution{F} <: FMUSolution where {F} fmu::F # FMU3 diff --git a/src/FMICore.jl b/src/FMICore.jl index 2dde7f3..4e5094b 100644 --- a/src/FMICore.jl +++ b/src/FMICore.jl @@ -20,19 +20,19 @@ abstract type FMU end export FMU """ -ToDo. +The mutable struct representing an abstract Solution of a (version unknown) FMU. """ abstract type FMUSolution end export FMUSolution """ -ToDo. +The mutable struct representing an abstract Configuration of a (version unknown) FMU. """ abstract type FMUExecutionConfiguration end export FMUExecutionConfiguration """ -ToDo. +The mutable struct representing an abstract Event of a (version unknown) FMU. """ abstract type FMUEvent end export FMUEvent From 8a9812f44a93dc88415bbb508e8a2fff721037e0 Mon Sep 17 00:00:00 2001 From: Simon Exner Date: Wed, 1 Nov 2023 20:12:39 +0100 Subject: [PATCH 3/3] doc fixes --- src/FMI2/cconst.jl | 39 ++++------------ src/FMI2/convert.jl | 36 +++++++++++---- src/FMI3/cconst.jl | 106 ++++++++++---------------------------------- src/FMI3/convert.jl | 60 ++++++++++++++++++------- 4 files changed, 104 insertions(+), 137 deletions(-) diff --git a/src/FMI2/cconst.jl b/src/FMI2/cconst.jl index 501bd50..459c0f0 100644 --- a/src/FMI2/cconst.jl +++ b/src/FMI2/cconst.jl @@ -33,23 +33,13 @@ const fmi2ComponentEnvironment = Ptr{Cvoid} const fmi2Enum = Array{Array{String}} # TODO: remove, this is not part of the spec! export fmi2Char, fmi2String, fmi2Boolean, fmi2Real, fmi2Integer, fmi2Byte, fmi2ValueReference, fmi2FMUstate, fmi2Component, fmi2ComponentEnvironment, fmi2Enum -""" -Source: 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()). 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). -""" const fmi2Status = Cuint +const fmi2StatusOK = Cuint(0) +const fmi2StatusWarning = Cuint(1) +const fmi2StatusDiscard = Cuint(2) +const fmi2StatusError = Cuint(3) +const fmi2StatusFatal = Cuint(4) +const fmi2StatusPending = Cuint(5) """ Source: FMISpec2.0.2[p.18]: 2.1.3 Status Returned by Functions @@ -67,12 +57,7 @@ This can be done if the capability flag canGetAndSetFMUstate is true and fmi2Get - 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). """ -const fmi2StatusOK = Cuint(0) -const fmi2StatusWarning = Cuint(1) -const fmi2StatusDiscard = Cuint(2) -const fmi2StatusError = Cuint(3) -const fmi2StatusFatal = Cuint(4) -const fmi2StatusPending = Cuint(5) +fmi2Status, fmi2StatusOK, fmi2StatusWarning, fmi2StatusDiscard, fmi2StatusError, fmi2StatusFatal, fmi2StatusPending export fmi2Status, fmi2StatusOK, fmi2StatusWarning, fmi2StatusDiscard, fmi2StatusError, fmi2StatusFatal, fmi2StatusPending """ @@ -138,21 +123,15 @@ const fmi2InitialApprox = Cuint(1) const fmi2InitialCalculated = Cuint(2) export fmi2Initial, fmi2InitialExact, fmi2InitialApprox, fmi2InitialCalculated -""" -Source: 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”. -""" const fmi2True = fmi2Boolean(true) - +const fmi2False = fmi2Boolean(false) """ Source: 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”. """ -const fmi2False = fmi2Boolean(false) +fmi2True, fmi2False export fmi2True, fmi2False """ diff --git a/src/FMI2/convert.jl b/src/FMI2/convert.jl index d592fcf..189eac1 100644 --- a/src/FMI2/convert.jl +++ b/src/FMI2/convert.jl @@ -4,7 +4,9 @@ # """ -Formats a fmi2Status/Integer to String. + fmi2StatusToString(status::Union{fmi2Status, Integer}) + +Convert `fmi2Status` `status` into a String ("OK", "Warning", "Discard", "Error", "Fatal", "Pending"). """ function fmi2StatusToString(status::Union{fmi2Status, Integer}) if status == fmi2StatusOK @@ -26,7 +28,9 @@ end export fmi2StatusToString """ -converts a [`fmi2Causality`](@ref) to the corresponding String ("parameter", "calculatedParameter", "input", "output", "local", "independent") + fmi2CausalityToString(c::fmi2Causality) + +Convert [`fmi2Causality`](@ref) `c` to the corresponding String ("parameter", "calculatedParameter", "input", "output", "local", "independent"). """ function fmi2CausalityToString(c::fmi2Causality) if c == fmi2CausalityParameter @@ -48,7 +52,9 @@ end export fmi2CausalityToString """ -converts a String ("parameter", "calculatedParameter", "input", "output", "local", "independent") to the corresponding [`fmi2Causality`](@ref) + fmi2StringToCausality(s::AbstractString) + +Convert `s` ("parameter", "calculatedParameter", "input", "output", "local", "independent") to the corresponding [`fmi2Causality`](@ref). """ function fmi2StringToCausality(s::AbstractString) if s == "parameter" @@ -70,7 +76,9 @@ end export fmi2StringToCausality """ -converts a String ("constant", "fixed", "tunable", "discrete", "continuous") to the corresponding [`fmi2Variability`](@ref) + fmi2VariabilityToString(c::fmi2Variability) + +Convert [`fmi2Variability`](@ref) `c` to the corresponding String ("constant", "fixed", "tunable", "discrete", "continuous"). """ function fmi2VariabilityToString(c::fmi2Variability) if c == fmi2VariabilityConstant @@ -90,7 +98,9 @@ end export fmi2VariabilityToString """ -converts a [`fmi2Variability`](@ref) to the corresponding String ("constant", "fixed", "tunable", "discrete", "continuous") + fmi2StringToVariability(s::AbstractString) + +Convert `s` ("constant", "fixed", "tunable", "discrete", "continuous") to the corresponding [`fmi2Variability`](@ref). """ function fmi2StringToVariability(s::AbstractString) if s == "constant" @@ -110,7 +120,9 @@ end export fmi2StringToVariability """ -converts a [`fmi2Initial`](@ref) to the corresponding String ("approx", "exact", "calculated") + fmi2InitialToString(c::fmi2Initial) + +Convert [`fmi2Initial`](@ref) `c` to the corresponding String ("approx", "exact", "calculated"). """ function fmi2InitialToString(c::fmi2Initial) if c == fmi2InitialApprox @@ -126,7 +138,9 @@ end export fmi2InitialToString """ -converts a String ("approx", "exact", "calculated") to the corresponding [`fmi2Initial`](@ref) + fmi2StringToInitial(s::AbstractString) + +Convert `s` ("approx", "exact", "calculated") to the corresponding [`fmi2Initial`](@ref). """ function fmi2StringToInitial(s::AbstractString) if s == "approx" @@ -142,7 +156,9 @@ end export fmi2StringToInitial """ -converts a [`fmi2DependencyKind`](@ref) to the corresponding String ("dependent", "constant", "fixed", "tunable", "discrete") + fmi2DependencyKindToString(c::fmi2DependencyKind) + +Convert [`fmi2DependencyKind`](@ref) `c` to the corresponding String ("dependent", "constant", "fixed", "tunable", "discrete") """ function fmi2DependencyKindToString(c::fmi2DependencyKind) if c == fmi2DependencyKindDependent @@ -162,7 +178,9 @@ end export fmi2DependencyKindToString """ -converts a String ("dependent", "constant", "fixed", "tunable", "discrete") to the corresponding [`fmi2DependencyKind`](@ref) + fmi2StringToDependencyKind(s::AbstractString) + +Convert `s` ("dependent", "constant", "fixed", "tunable", "discrete") to the corresponding [`fmi2DependencyKind`](@ref) """ function fmi2StringToDependencyKind(s::AbstractString) if s == "dependent" diff --git a/src/FMI3/cconst.jl b/src/FMI3/cconst.jl index 99f0db6..73effd1 100644 --- a/src/FMI3/cconst.jl +++ b/src/FMI3/cconst.jl @@ -3,55 +3,14 @@ # Licensed under the MIT license. See LICENSE file in the project root for details. # -""" -Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. -""" const fmi3Float32 = Cfloat - -""" -Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. -""" const fmi3Float64 = Cdouble - -""" -Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. -""" const fmi3Int8 = Cchar const fmi3UInt8 = Cuchar - -""" -Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. -""" const fmi3Int16 = Cshort const fmi3UInt16 = Cushort - -""" -Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. -""" const fmi3Int32 = Cint const fmi3UInt32 = Cuint - -""" -Source: FMISpec3.0-dev, Version D5ef1c1:2.2.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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. -""" const fmi3Int64 = Clonglong const fmi3UInt64 = Culonglong const fmi3Boolean = Cuchar @@ -65,48 +24,37 @@ const fmi3Instance = Ptr{Cvoid} const fmi3InstanceEnvironment = Ptr{Cvoid} const fmi3Enum = Array{Array{String}} # TODO: correct it const fmi3Clock = Cint -export fmi3Float32, fmi3Float64, fmi3Int8, fmi3UInt8, fmi3Int16, fmi3UInt16, fmi3Int32, fmi3UInt32, fmi3Int64, fmi3UInt64 -export fmi3Boolean, fmi3Char, fmi3String, fmi3Byte, fmi3Binary, fmi3ValueReference, fmi3FMUState, fmi3Instance, fmi3InstanceEnvironment, fmi3Enum, fmi3Clock """ -Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions -Defines 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. +Source: FMISpec3.0-dev, Version D5ef1c1:2.2.2. Platform Dependent Definitions -- 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. +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 fmi3PlatformTypes.h. It is required to use this definition for all binary FMUs. """ +fmi3Float32, fmi3Float64, fmi3Int8, fmi3UInt8, fmi3Int16, fmi3UInt16, fmi3Int32, fmi3UInt32, fmi3Int64, fmi3UInt64 +export fmi3Float32, fmi3Float64, fmi3Int8, fmi3UInt8, fmi3Int16, fmi3UInt16, fmi3Int32, fmi3UInt32, fmi3Int64, fmi3UInt64 +export fmi3Boolean, fmi3Char, fmi3String, fmi3Byte, fmi3Binary, fmi3ValueReference, fmi3FMUState, fmi3Instance, fmi3InstanceEnvironment, fmi3Enum, fmi3Clock + const fmi3Status = Cuint +const fmi3StatusOK = Cuint(0) +const fmi3StatusWarning = Cuint(1) +const fmi3StatusDiscard = Cuint(2) +const fmi3StatusError = Cuint(3) +const fmi3StatusFatal = Cuint(4) """ Source: FMISpec3.0, Version D5ef1c1: 2.2.3. Status Returned by Functions Defines 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. +- 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. +- 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. +- 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. """ -const fmi3StatusOK = Cuint(0) -const fmi3StatusWarning = Cuint(1) -const fmi3StatusDiscard = Cuint(2) -const fmi3StatusError = Cuint(3) -const fmi3StatusFatal = Cuint(4) +fmi3Status, fmi3StatusOK, fmi3StatusWarning, fmi3StatusDiscard, fmi3StatusError, fmi3StatusFatal export fmi3Status, fmi3StatusOK, fmi3StatusWarning, fmi3StatusDiscard, fmi3StatusError, fmi3StatusFatal """ @@ -221,15 +169,13 @@ const fmi3InitialApprox = Cuint(1) const fmi3InitialCalculated = Cuint(2) export fmi3Initial, fmi3InitialExact, fmi3InitialApprox, fmi3InitialCalculated -""" -`fmi3Boolean`(false) -""" const fmi3False = fmi3Boolean(false) +const fmi3True = fmi3Boolean(true) """ -`fmi3Boolean`(true) +`fmi3Boolean` TODO """ -const fmi3True = fmi3Boolean(true) +fmi3False, fmi3True export fmi3False, fmi3True """ @@ -261,20 +207,14 @@ const fmi3IntervalQualifierIntervalUnchanged = Cuint(1) const fmi3IntervalQualifierIntervalChanged = Cuint(2) export fmi3IntervalQualifier, fmi3IntervalQualifierIntervalNotYetKnown, fmi3IntervalQualifierIntervalUnchanged, fmi3IntervalQualifierIntervalChanged -""" -Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions -""" const fmi3VariableNamingConvention = Cuint - -""" -Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions -""" const fmi3VariableNamingConventionFlat = Cuint(0) +const fmi3VariableNamingConventionStructured = Cuint(1) """ Source: FMISpec3.0, Version D5ef1c1: 2.4.7.5.1. Variable Naming Conventions """ -const fmi3VariableNamingConventionStructured = Cuint(1) +fmi3VariableNamingConvention, fmi3VariableNamingConventionFlat, fmi3VariableNamingConventionStructured export fmi3VariableNamingConvention, fmi3VariableNamingConventionFlat, fmi3VariableNamingConventionStructured # this is a custom type to catch the internal state of the instance diff --git a/src/FMI3/convert.jl b/src/FMI3/convert.jl index afbd105..c2c2543 100644 --- a/src/FMI3/convert.jl +++ b/src/FMI3/convert.jl @@ -4,7 +4,9 @@ # """ -Formats the fmi3Status/Integer into a String. + fmi3StatusToString(status::Union{fmi3Status, Integer}) + +Convert `fmi3Status` `status` into a String ("OK", "Warning", "Discard", "Error", "Fatal", "Unknown"). """ function fmi3StatusToString(status::Union{fmi3Status, Integer}) if status == fmi3StatusOK @@ -24,7 +26,9 @@ end export fmi3StatusToString """ -converts a [`fmi3Causality`](@ref) to the corresponding String ("parameter", "calculatedParameter", "structuralParameter", "input", "output", "local", "independent") + fmi3CausalityToString(c::fmi3Causality) + +Convert [`fmi3Causality`](@ref) `c` to the corresponding String ("parameter", "calculatedParameter", "structuralParameter", "input", "output", "local", "independent"). """ function fmi3CausalityToString(c::fmi3Causality) if c == fmi3CausalityParameter @@ -48,7 +52,9 @@ end export fmi3CausalityToString """ -converts a String ("parameter", "calculatedParameter", "structuralParameter", "input", "output", "local", "independent") to the corresponding [`fmi3Causality`](@ref) + fmi3StringToCausality(s::AbstractString) + +Convert `s` ("parameter", "calculatedParameter", "structuralParameter", "input", "output", "local", "independent") to the corresponding [`fmi3Causality`](@ref). """ function fmi3StringToCausality(s::AbstractString) if s == "parameter" @@ -72,7 +78,9 @@ end export fmi3StringToCausality """ -converts a String ("constant", "fixed", "tunable", "discrete", "continuous") to the corresponding [`fmi3Variability`](@ref) + fmi3VariabilityToString(c::fmi3Variability) + +Convert [`fmi3Variability`](@ref) `c` to the corresponding String ("constant", "fixed", "tunable", "discrete", "continuous"). """ function fmi3VariabilityToString(c::fmi3Variability) if c == fmi3VariabilityConstant @@ -92,7 +100,9 @@ end export fmi3VariabilityToString """ -converts a [`fmi3Variability`](@ref) to the corresponding String ("constant", "fixed", "tunable", "discrete", "continuous") + fmi3StringToVariability(s::AbstractString) + +Convert `s` ("constant", "fixed", "tunable", "discrete", "continuous") to the corresponding [`fmi3Variability`](@ref). """ function fmi3StringToVariability(s::AbstractString) if s == "constant" @@ -112,7 +122,9 @@ end export fmi3StringToVariability """ -converts a [`fmi3Initial`](@ref) to the corresponding String ("approx", "exact", "calculated") + fmi3InitialToString(c::fmi3Initial) + +Convert [`fmi3Initial`](@ref) `c` to the corresponding String ("approx", "exact", "calculated"). """ function fmi3InitialToString(c::fmi3Initial) if c == fmi3InitialApprox @@ -128,7 +140,9 @@ end export fmi3InitialToString """ -converts a String ("approx", "exact", "calculated") to the corresponding [`fmi3Initial`](@ref) + fmi3StringToInitial(s::AbstractString) + +Convert `s` ("approx", "exact", "calculated") to the corresponding [`fmi3Initial`](@ref). """ function fmi3StringToInitial(s::AbstractString) if s == "approx" @@ -144,7 +158,9 @@ end export fmi3StringToInitial """ -converts a [`fmi3DependencyKind`](@ref) to the corresponding String ("independent", "dependent", "constant", "fixed", "tunable", "discrete") + fmi3DependencyKindToString(c::fmi3DependencyKind) + +Convert [`fmi3DependencyKind`](@ref) `c` to the corresponding String ("independent", "dependent", "constant", "fixed", "tunable", "discrete"). """ function fmi3DependencyKindToString(c::fmi3DependencyKind) if c == fmi3DependencyKindIndependent @@ -166,7 +182,9 @@ end export fmi3DependencyKindToString """ -converts a String ("independent", "dependent", "constant", "fixed", "tunable", "discrete") to the corresponding [`fmi3DependencyKind`](@ref) + fmi3StringToDependencyKind(s::AbstractString) + +Convert `s` ("independent", "dependent", "constant", "fixed", "tunable", "discrete") to the corresponding [`fmi3DependencyKind`](@ref). """ function fmi3StringToDependencyKind(s::AbstractString) if s == "independent" @@ -188,7 +206,9 @@ end export fmi3StringToDependencyKind """ -converts a [`fmi3VariableNamingConvention`](@ref) to the corresponding String ("flat", "structured") + fmi3VariableNamingConventionToString(c::fmi3VariableNamingConvention) + +Convert [`fmi3VariableNamingConvention`](@ref) `c` to the corresponding String ("flat", "structured"). """ function fmi3VariableNamingConventionToString(c::fmi3VariableNamingConvention) if c == fmi3VariableNamingConventionFlat @@ -202,7 +222,9 @@ end export fmi3VariableNamingConventionToString """ -converts a String ("flat", "structured") to the corresponding [`fmi3VariableNamingConvention`](@ref) + fmi3StringToVariableNamingConvention(s::AbstractString) + +Convert `s` ("flat", "structured") to the corresponding [`fmi3VariableNamingConvention`](@ref). """ function fmi3StringToVariableNamingConvention(s::AbstractString) if s == "flat" @@ -216,7 +238,9 @@ end export fmi3StringToVariableNamingConvention """ -converts a [`fmi3Type`](@ref)String to the corresponding ("coSimulation", "modelExchange", "scheduledExecution") + fmi3TypeToString(c::fmi3Type) + +Convert [`fmi3Type`](@ref) `c` to the corresponding String ("coSimulation", "modelExchange", "scheduledExecution"). """ function fmi3TypeToString(c::fmi3Type) if c == fmi3TypeCoSimulation @@ -232,7 +256,9 @@ end export fmi3TypeToString """ -converts a String ("coSimulation", "modelExchange", "scheduledExecution") to the corresponding [`fmi3Type`](@ref) + fmi3StringToType(s::AbstractString) + +Convert `s` ("coSimulation", "modelExchange", "scheduledExecution") to the corresponding [`fmi3Type`](@ref). """ function fmi3StringToType(s::AbstractString) if s == "coSimulation" @@ -248,7 +274,9 @@ end export fmi3StringToType """ -converts a [`fmi3IntervalQualifier`](@ref) to the corresponding String ("intervalNotYetKnown", "intervalUnchanged", "intervalChanged") + fmi3IntervalQualifierToString(c::fmi3IntervalQualifier) + +Convert [`fmi3IntervalQualifier`](@ref) `c` to the corresponding String ("intervalNotYetKnown", "intervalUnchanged", "intervalChanged"). """ function fmi3IntervalQualifierToString(c::fmi3IntervalQualifier) if c == fmi3IntervalQualifierIntervalNotYetKnown @@ -264,7 +292,9 @@ end export fmi3IntervalQualifierToString """ -converts a String ("intervalNotYetKnown", "intervalUnchanged", "intervalChanged") to the corresponding [`fmi3IntervalQualifier`](@ref) + fmi3StringToIntervalQualifier(s::AbstractString) + +Convert `s` ("intervalNotYetKnown", "intervalUnchanged", "intervalChanged") to the corresponding [`fmi3IntervalQualifier`](@ref). """ function fmi3StringToIntervalQualifier(s::AbstractString) if s == "intervalNotYetKnown"