For xSup1 ≤ x ≤ xSupn, where n is the size of the support points xSup, which must be strictly monotonically increasing, this function interpolates using cubic hermite spline. For x outside this interval, the function linearly extrapolates.
If n=2, linear interpolation is used an if n=1, the function value y1 is returned.
Note that if xSup and ySup only depend
on parameters or constants, and therefore will not change during
the simulation, it is more efficient to first call Buildings.Utilities.Math.Functions.splineDerivatives
to find the derivatives, and then call Buildings.Utilities.Math.Functions.interpolate
to perform the interpolation. This way the derivatives only need to
be computed once upon initialisation, not at each step during the
simulation. See the example implemented in
Buildings.Utilities.Math.Functions.Examples.Interpolate.
In contrast to the function Modelica.Math.Vectors.interpolate which provides linear interpolation, this function does not trigger events.
For how to use this function, see Buildings.Utilities.Math.Functions.Examples.SmoothInterpolation.
function smoothInterpolation extends Modelica.Icons.Function; input Real x "Abscissa value"; input Real xSup[:] "Support points (strictly increasing)"; input Real ySup[size(xSup, 1)] "Function values at xSup"; input Boolean ensureMonotonicity = isMonotonic(ySup, strict = false) "Set to true to ensure monotonicity of the cubic hermite"; output Real yInt "Interpolated ordinate value"; end smoothInterpolation;