qp_solve ======== linear quadratic programming solver builtin Calling Sequence ~~~~~~~~~~~~~~~~ :: [x [,iact [,iter [,f]]]]=qp_solve(Q,p1,C1,b,me) Arguments ~~~~~~~~~ :Q real positive definite symmetric matrix (dimension `n x n` ). : :p real (column) vector (dimension `n`) : :C real matrix (dimension `(me + md) x n`). This matrix may be dense or sparse. : :b RHS column vector (dimension `m=(me + md)` ) : :me number of equality constraints (i.e. `x'*C(:,1:me) = b(1:me)'` ) : :x optimal solution found. : :iact vector, indicator of active constraints. The first non zero entries give the index of the active constraints : :iter 2x1 vector, first component gives the number of "main" iterations, the second one says how many constraints were deleted after they became active. : Description ~~~~~~~~~~~ This function requires `Q` to be symmetric positive definite. If this hypothesis is not satisfied, one may use the contributed **quapro toolbox**. Examples ~~~~~~~~ :: // Find x in R^6 such that: // x'*C1 = b1 (3 equality constraints i.e me=3) C1= [ 1,-1, 2; -1, 0, 5; 1,-3, 3; 0,-4, 0; 3, 5, 1; 1, 6, 0]; b1=[1;2;3]; // x'*C2 >= b2 (2 inequality constraints) C2= [ 0 ,1; -1, 0; 0,-2; -1,-1; -2,-1; 1, 0]; b2=[ 1;-2.5]; // and minimize 0.5*x'*Q*x - p'*x with p=[-1;-2;-3;-4;-5;-6]; Q=`eye`_(6,6); me=3; [x,iact,iter,f]=qp_solve(Q,p,[C1 C2],[b1;b2],me) // Only linear constraints (1 to 4) are active See Also ~~~~~~~~ + `optim`_ non-linear optimization routine + `qld`_ linear quadratic programming solver + `qpsolve`_ linear quadratic programming solver The contributed toolbox "quapro" may also be of interest, in particular for singular `Q`. Memory requirements ~~~~~~~~~~~~~~~~~~~ Let r be :: r=`min`_(m,n) Then the memory required by qp_solve during the computations is :: 2*n+r*(r+5)/2 + 2*m +1 References ~~~~~~~~~~ + Goldfarb, D. and Idnani, A. (1982). "Dual and Primal-Dual Methods for Solving Strictly Convex Quadratic Programs", in J.P. Hennart (ed.), Numerical Analysis, Proceedings, Cocoyoc, Mexico 1981, Vol. 909 of Lecture Notes in Mathematics, Springer-Verlag, Berlin, pp. 226-239. + Goldfarb, D. and Idnani, A. (1983). "A numerically stable dual method for solving strictly convex quadratic programs", Mathematical Programming 27: 1-33. + QuadProg (Quadratic Programming Routines), Berwin A Turlach,`http://www.maths.uwa.edu.au/~berwin/software/quadprog.html`_ Used Functions ~~~~~~~~~~~~~~ qpgen2.f and >qpgen1.f (also named QP.solve.f) developed by Berwin A. Turlach according to the Goldfarb/Idnani algorithm .. _qld: qld.html .. _optim: optim.html .. _qpsolve: qpsolve.html .. _http://www.maths.uwa.edu.au/~berwin/software/quadprog.html: http://www.maths.uwa.edu.au/~berwin/software/quadprog.html