CGAL::Nonnegative_quadratic_program_from_iterators<A_it, B_it, R_it, D_it, C_it>

#include <CGAL/QP_models.h>

Definition

An object of class Nonnegative_quadratic_program_from_iterators<A_it, B_it, R_it, D_it, C_it> describes a convex quadratic program of the form

(QP) minimize xTDx+cTx+c0
subject to Ax ~ b,
x greater or equal 0

in n real variables x=(x0,...,xn-1). Here,

This class is simply a wrapper for existing iterators, and it does not copy the program data.

It frequently happens that all values in one of the vectors from above are the same, for example if the system Ax ~ b is actually a system of equations Ax=b. To get an iterator over such a vector, it is not necessary to store multiple copies of the value in some container; an instance of the class Const_oneset_iterator<T>, constructed from the value in question, does the job more efficiently.

Is Model for the Concepts

QuadraticProgram
NonnegativeQuadraticProgram

Creation

Nonnegative_quadratic_program_from_iterators<A_it, B_it, R_it, D_it, C_it> qp ( int n,
int m,
A_it a,
B_it b,
R_it r,
D_it d,
C_it c,
std::iterator_traits<C_it>value_type c0 = 0);
constructs qp from given random-access iterators and the constant c0. The passed iterators are merely stored, no copying of the program data takes place. How these iterators are supposed to encode the nonnegative quadratic program is described in NonnegativeQuadraticProgram.

Example

QP_solver/first_nonnegative_qp_from_iterators.cpp

The following example for the simpler model Nonnegative_linear_program_from_iterators<A_it, B_it, R_it, C_it> should give you a flavor of the use of this model in practice.

QP_solver/solve_convex_hull_containment_lp.h
QP_solver/convex_hull_containment.cpp

See Also

NonnegativeQuadraticProgram Quadratic_program<NT>
Quadratic_program_from_mps<NT>