1
0
This repository has been archived on 2025-03-06. You can view files and clone it, but cannot push or open issues or pull requests.

24 lines
763 B
MiniZinc

include "fzn_piecewise_linear.mzn";
include "fzn_piecewise_linear_reif.mzn";
/** @group globals
Return a piecewise-linear interpolation
of the given point sequence as a function of \a x
*/
function var float: piecewise_linear(var float: x, array[int] of float: xi, array[int] of float: vi) ::promise_total =
let {
var float: res,
constraint piecewise_linear(x,res,xi,vi),
} in res;
/** @group globals
Constrains \a y(\a x) to be a piecewise-linear interpolation of
the provided point sequence.
*/
predicate piecewise_linear(var float: x, var float: y,
array[int] of float: xi, array[int] of float: vi) =
fzn_piecewise_linear(x, y, xi, vi);
%-----------------------------------------------------------------------------%