我想使用 kernlab 的 ipop 函数求解以下二次规划方程:
min 0.5*x'*H*x + f'*x
subject to: A*x <= b
Aeq*x = beq
LB <= x <= UB
在我们的示例 H 3x3 矩阵中,f 是 3x1,A 是 2x3,b 是 2x1,LB 和 UB 都是 3x1。
编辑 1 我的 R 代码是:
library(kernlab)
H <- rbind(c(1,0,0),c(0,1,0),c(0,0,1))
f = rbind(0,0,0)
A = rbind(c(1,1,1), c(-1,-1,-1))
b = rbind(4.26, -1.73)
LB = rbind(0,0,0)
UB = rbind(100,100,100)
> ipop(f,H,A,b,LB,UB,0)
Error in crossprod(r, q) : non-conformable arguments
我从matlab知道是这样的:
H = eye(3);
f = [0,0,0];
nsamples=3;
eps = (sqrt(nsamples)-1)/sqrt(nsamples);
A=ones(1,nsamples);
A(2,:)=-ones(1,nsamples);
b=[nsamples*(eps+1); nsamples*(eps-1)];
Aeq = [];
beq = [];
LB = zeros(nsamples,1);
UB = ones(nsamples,1).*1000;
[beta,FVAL,EXITFLAG] = quadprog(H,f,A,b,Aeq,beq,LB,UB);
答案是 3x1 的向量等于 [0.57,0.57,0.57];
但是,当我在 R 上尝试使用 kernlab 库 ipop(f,H,A,b,LB,UB,0)) 中的 ipop 函数时,我在 crossprod(r, q) 中遇到错误:不符合要求的参数
我感谢任何评论