piecewiseLinFit
Syntax
piecewiseLinFit(X, Y, numSegments, [XC], [YC], [bounds],
[lapackDriver='gelsd'], [degree=1], [weights], [method='de'], [maxIter],
[initialGuess], [seed])
Arguments
X is a numeric vector indicating the data point locations of x. Null value is not allowed.
Y is a numeric vector indicating the data point locations of y. Null value is not allowed.
numSegments is a positive integer indicating the desired number of line segments.
XC (optional) is a numeric vector indicating the x locations of the data points that the piecewise linear function will be forced to go through. It only takes effect when method='de'.
YC (optional) is a numeric vector indicating the y locations of the data points that the piecewise linear function will be forced to go through. It only takes effect when method='de'.
bounds (optional) is a numeric matrix of shape (numSegments-1, 2), indicating the bounds for each breakpoint location within the optimization.
lapackDriver (optional) is a string indicating which LAPACK driver is used to solve the least-squares problem. It can be 'gelsd' (default), 'gelsy' and 'gelss'.
degree (optional) is a non-negative integer indicating the degree of polynomial to use. The default is 1 for linear models. Use 0 for constant models.
weights (optional) is a numeric vector indicating the weights used in least-squares algorithms. The individual weights are typically the reciprocal of the standard deviation for each data point, where weights[i] corresponds to one over the standard deviation of the ith data point. Null value is not allowed.
method (optional) is a string indicating the model used. It can be:
- 'nm' (default): Nelder-Mead simplex algorithm.
- 'bfgs': BFGS algorithm.
- 'lbfgs': LBFGS algorithm.
- 'slsqp': Sequential Least Squares Programming algorithm.
- 'de': Differential Evolution algorithm.
maxIter (optional) is an integral scalar or vector indicating the maximum number of iterations for the optimization algorithm during the fitting process.
initialGuess (optional) is a numeric vector indicating the initial guess for the parameters that optimize the function. Its length is numSegments-1.
seed (optional) is an integer indicating the random number seed used in the differential evolution algorithm to ensure the reproducibility of results. It only takes effect when method='de' or initialGuess is null. If not specified, a non-deterministic random number generator is used.
Details
Fit a continuous piecewise linear function for a specified number of line segments. Use differential evolution to find the optimal location of breakpoints for a given number of line segments by minimizing the sum of the square error. Note: Due to the randomness of the differential evolution, the results of this function may vary slightly each time.
The fitted model can be used as an input for function
pwlfPredict
.
Return value: A dictionary with the following keys:
-
breaks: A floating-point vector indicating the breakpoint locations.
-
beta: A floating-point vector indicating the beta parameter for the linear fit.
-
xData: A floating-point vector indicating the input data point locations of x.
-
yData: A floating-point vector indicating the input data point locations of y.
-
XC: A floating-point vector indicating the x locations of the data points that the piecewise linear function will be forced to go through.
-
YC: A floating-point vector indicating the y locations of the data points that the piecewise linear function will be forced to go through.
-
weights: A floating-point vector indicating the weights used in least-squares algorithms.
-
degree: A non-negative integer indicating the degree of polynomial.
-
lapackDriver: A string indicating the LAPACK driver used to solve the least-squares problem.
-
numParameters: An integer indicating the number of parameters.
-
predict: The function used for prediction. The method is called by
model.predict(X, [beta], [breaks])
. See pwlfPredict. -
modelName: A string "Piecewise Linear Regression" indicating the model name.
Examples
def linspace(start, end, num, endpoint=true){
if(endpoint) return end$DOUBLE\(num-1), start + end$DOUBLE\(num-1)*0..(num-1)
else return start + end$DOUBLE\(num-1)*0..(num-1)
}
X = linspace(0.0, 1.0, 10)[1]
Y = [0.41703981, 0.80028691, 0.12593987, 0.58373723, 0.77572962, 0.41156172, 0.72300284, 0.32559528, 0.21812564, 0.41776427]
model = piecewiseLinFit(X, Y, 3)
model;
Output:
breaks->[0.0,0.258454644769,0.366954310101,1.000000000000]
numParameters->4
degree->1
xData->[0.0,0.111111111111,0.222222222222,0.333333333333,0.444444444444,0.555555555555,0.666666666666,0.777777777777,0.888888888888,1.000000000000]
predict->pwlfPredict
yData->[0.417039810000,0.800286910000,0.125939870000,0.583737230000,0.775729620000,0.411561720000,0.723002840000,0.325595280000,0.218125640000,0.417764270000]
yC->
xC->
weights->
beta->[0.593305500750,-1.309949743583,5.703647584013,-5.105351630664]
lapackDriver->gelsd
piecewiseLinFit
can be used with pwlfPredict
for
predication based on the model:
xHat = linspace(0.0, 1.0, 20)[1]
model.predict(xHat)
// output: [0.593305499919518 0.524360777381737 0.455416054843957 0.386471332306177 0.317526609768396 0.368043438179296 0.529813781212159 0.691584124245021 0.69295837868457 0.655502915538459 0.618047452392347 0.580591989246236 0.543136526100125 0.505681062954014 0.468225599807903 0.430770136661792 0.393314673515681 0.35585921036957 0.318403747223459 0.280948284077348]
Related function: pwlfPredict