This library is implemented with the
Modelica 3.1 language.
Additionally, some extensions to the Modelica language are used, in order to
guarantee that only valid StateGraph2 graphs are accepted by a Modelica tool.
It is planned to introduce these new language elements into the next version 3.2
of the Modelica language. This means, only Modelica tools will be able to process
this Modelica_StateGraph2 package, if the following (non-standard)
extensions of Modelica are supported:
Connection Graphs for State Diagrams (new section 9.4.2)
In order that a Modelica translator can guarantee the connection structure of hierarchical state diagrams, some additional operators are needed for the virtual connection graph. This special virtual connection graph is called "virtual state diagram graph" in the sequel. Virtual state diagram graphs are undirected graphs having overdetermined type or record instances as nodes. The branches are defined by connect(..) and by Connections.branch(..) statements. With the new operators Connections.uniqueRoot(..) and Connections.uniqueRootIndices(..) restrictions to the graph are introduced, as defined in the following table. If one node of a virtual connection graph is marked with uniqueRoot(..), then a virtual state diagram graph is present and it is not allowed to apply the operators Connections.root(..), Connections.potentialRoot, or Connections.isRoot(..) on a node of this graph.
- New operator: Connections.uniqueRoot(root, message="")
The overdetermined type or record instance "root" is a unique root node in a virtual state diagram graph. Every virtual state diagram graph must have exactly one uniqueRoot(..) definition, before breakable branches are removed. Argument "root" may be a vector. Then, the operator is applied on every element of this vector.
The second argument is a message that shall be reported if the root is not unique. From all uniqueRoot(..) definitions of the same graph, only one of the message arguments shall (arbitrarily) be selected and used in the error message. [The error message should additionally include the path (= instance names) between the unique root definitions. A typical value for message is: "Two or more state diagram graphs are connected that should not be connected"]
- New operator: rootIndices = Connections.uniqueRootIndices(roots, nodes, message="")
The two first input arguments are vectors of overdetermined types or record instances with the restriction that size(nodes,1) ≤ size(roots,1).
Vector "roots" must contain unique roots in the virtual state diagram graphs. The function returns an Integer vector which is a permuted version of vector "1:size(roots,1)":
- rootIndices[i], i = 1,.., size(nodes,1):
There is a path from roots[rootIndices[i]] to nodes[i].
It is an error, if such a path does not exist.
In such a case, the error message should include the third argument "message".
- rootIndices[j], j = size(nodes,1) + 1, ..., size(roots,1):
There is no path from roots[rootIndices[j]] to an element of nodes[:].
[The typical use is to verify the connection structure of a Parallel component.
Furthermore, it is determined at which entry index a branch starts and at which exit index the branch stops. This information might be used to determine that every "loop"
has at least one delayed transition. Example:
EntryPort entry [nEntry];
ExitPort exit [nExit];
Integer indices[nEntry];
equation
Connections.uniqueRoot(entry, "...");
indices = Connections.uniqueRootIndices(entry, exit, "...");
]
Generated at 2025-01-21T19:25:52Z
by OpenModelicaOpenModelica 1.24.3 using GenerateDoc.mos