This model is a combination of a multi-body system with a kinematic loop
and a Move block, where symbolic transformation is difficult:
Standard symbolic transformation works in the following way if functions
are present with annotation "InineAfterIndexReduction = true".
- These functions are not inlined, the Pantelides algorithm
is applied and the equations are symbolically differentiated.
- The functions are inlined and further symbolic transformation
is performed (sorting the equations, dummy derivative method etc..
The model contains the following functions that have annotation
"InineAfterIndexReduction = true":
- MultiBody.Frames.resolve1/resolve2(..) functions are used to transform the coordinates
of a vector in another coordinate system. When these functions need to be differentiated
in the Pantelides algorithm, then Euler's differentiation rule is applied with the angular velocity
that is usually a factor of 2-3 more efficient as if direct differentiation
is applied. The drawback is that the sparsity structure is more "coarse" and
this lets the Pantelides algorithm fail in this example (this happens usually only
in systems with kinematic loops). This means that the differentiated equation system
is structurally singular, after the functions with annotation "InineAfterIndexReduction = true"
are inlined.
- The Rotational.Sources.Move block is using internally functions to express that
an input u[2] is the derivative of input u[1]. In order that this is possible, the functions
have the annotation "InineAfterIndexReduction = true" so that the differentiation takes place
with the not inlined functions. After the Pantelides algorithm and the differentiation
is applied, the functions are inlined to enhance efficiency.
The problem with (1) is that after inlining the functions with
annotation "InineAfterIndexReduction = true", the equations are structurally singular, but the
source of the singularity is now known. One remedy is to restart symbolic processing and to
inline all functions with "InineAfterIndexReduction = true" before the Pantelides algorithm
is applied. In the model, this approach is in principal successful and the model would
be structurally regular. However, the Move block is no longer working correctly if the Pantelides
algorithm is applied with inlining. For this reason in MSL 3.2.1 build 3, the annotation
"InineAfterIndexReduction = true" in the Move block has been replaced by
annotation "Inline = false". This results in slightly less efficient code, but is more robust
in the situation at hand.
Generated at 2025-01-01T19:25:55Z
by OpenModelicaOpenModelica 1.24.3 using GenerateDoc.mos