我正在做一些实验,我当然知道为什么很少需要约束系数,但是这里有。
在以下数据中,我使用了 quadprog 来求解线性模型。请注意,X1 只是截距。
X1 <- 1
X2 <- c(4.374, 2.3708, -7.3033, 12.0803, -0.4098, 53.0631, 13.1304, 7.3617, 16.6252, 27.3394)
X3 <- c(2.6423, 2.6284, 36.9398, 15.9278, 18.3124, 54.5039, 3.764, 19.0552, 25.4906, 13.0112)
X4 <- c(4.381, 3.144, 9.506, 15.329, 21.008, 38.091, 22.399, 13.223, 17.419, 19.87)
X <- as.matrix(cbind(X1,X2,X3,X4))
Y <- as.matrix(c(37.7,27.48,24.08,25.97,16.65,73.77,45.10,53.35,61.95,71.15))
M1 <- solve.QP(t(X) %*% X, t(Y) %*% X, matrix(0, 4, 0), c())$solution
挑战在于使某些系数受到约束。我知道我应该改变 Amet 和 bvac 参数(根据带有约束系数的线性回归)。但是,我不确定如何设置它,以便满足以下约束。
输出为 [1] 37.3468790 1.2872473 -0.0177749 -0.5988443,其中的值将是 X1、X2、X3 和 X4 的预测拟合值。
约束(受制于)……</p>
X2 <= .899
0 <= X3 <= .500
0 <= X4 <= .334