#include <shark/Algorithms/QP/QpMcBoxDecomp.h>
Classes | |
struct | Example |
data structure describing one training example More... | |
struct | PreferedSelectionStrategy |
Working set selection eturning th S2DO working set. More... | |
struct | Variable |
data structure describing one m_variables of the problem More... | |
Public Types | |
typedef Matrix::QpFloatType | QpFloatType |
Public Member Functions | |
QpMcBoxDecomp (Matrix &kernel, QpSparseArray< QpFloatType > const &M, Data< unsigned int > const &target, RealMatrix const &linearMat, double C) | |
void | setShrinking (bool shrinking=true) |
enable/disable shrinking | |
RealMatrix | solution () const |
Return the solution found. | |
double | alpha (std::size_t i, std::size_t p) const |
RealMatrix | solutionGradient () const |
Return the gradient of the solution. | |
double | functionValue () const |
Compute the objective value of the current solution. | |
unsigned int | label (std::size_t i) |
std::size_t | dimensions () const |
std::size_t | cardP () const |
std::size_t | getNumExamples () const |
double | checkKKT () const |
return the largest KKT violation | |
void | addDeltaLinear (RealMatrix const &deltaLinear) |
change the linear part of the problem by some delta | |
void | updateSMO (std::size_t v, std::size_t w) |
bool | shrink (double epsilon) |
Shrink the problem. | |
void | unshrink () |
Activate all variables. | |
double | selectWorkingSet (std::size_t &i, std::size_t &j) |
select the working set | |
Protected Member Functions | |
void | gradientUpdate (std::size_t r, double mu, QpFloatType *q) |
void | deactivateVariable (std::size_t v) |
shrink a variable | |
void | deactivateExample (std::size_t e) |
shrink an m_examples | |
std::size_t | originalIndex (std::size_t v) const |
Returns the original index of the example of a variable in the dataset before optimization. | |
Protected Attributes | |
bool | bUnshrinked |
true if the problem has already been unshrinked | |
Matrix & | m_kernelMatrix |
kernel matrix (precomputed matrix or matrix cache) | |
QpSparseArray< QpFloatType > const & | m_M |
kernel modifiers | |
double | m_C |
complexity constant; upper bound on all variabless | |
unsigned int | m_classes |
number of m_classes in the problem | |
std::size_t | m_cardP |
number of dual m_numVariables per example | |
std::size_t | m_numExamples |
number of m_examples in the problem (size of the kernel matrix) | |
std::size_t | m_numVariables |
number of m_numVariables in the problem = m_examples times m_cardP | |
RealVector | m_linear |
m_linear part of the objective function | |
RealVector | m_alpha |
solution candidate | |
RealVector | m_gradient |
std::vector< Example > | m_examples |
information about each training example | |
std::vector< Variable > | m_variables |
information about each m_variables of the problem | |
std::vector< std::size_t > | m_storage1 |
space for the example[i].var pointers | |
std::vector< std::size_t > | m_storage2 |
space for the example[i].avar pointers | |
std::size_t | m_activeEx |
number of currently active m_examples | |
std::size_t | m_activeVar |
number of currently active variabless | |
bool | m_useShrinking |
should the m_problem use the shrinking heuristics? | |
Definition at line 50 of file QpMcBoxDecomp.h.
typedef Matrix::QpFloatType shark::QpMcBoxDecomp< Matrix >::QpFloatType |
Definition at line 53 of file QpMcBoxDecomp.h.
|
inline |
Constructor
kernel | kernel matrix - cache or pre-computed matrix |
M | kernel modifiers in the format \( M_(y_i, p, y_j, q) = _M(classes*(y_i*|P|+p_i)+y_j, q) \) |
target | the target labels for the variables |
linearMat | the linear part of the problem |
C | upper bound for all box variables, lower bound is 0. |
Definition at line 74 of file QpMcBoxDecomp.h.
References shark::Data< Type >::element(), shark::QpMcBoxDecomp< Matrix >::m_activeEx, shark::QpMcBoxDecomp< Matrix >::m_activeVar, shark::QpMcBoxDecomp< Matrix >::m_cardP, shark::QpMcBoxDecomp< Matrix >::m_classes, shark::QpMcBoxDecomp< Matrix >::m_examples, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_kernelMatrix, shark::QpMcBoxDecomp< Matrix >::m_linear, shark::QpMcBoxDecomp< Matrix >::m_M, shark::QpMcBoxDecomp< Matrix >::m_numExamples, shark::QpMcBoxDecomp< Matrix >::m_numVariables, shark::QpMcBoxDecomp< Matrix >::m_storage1, shark::QpMcBoxDecomp< Matrix >::m_storage2, shark::QpMcBoxDecomp< Matrix >::m_variables, shark::Data< Type >::numberOfElements(), and SHARK_RUNTIME_CHECK.
|
inline |
change the linear part of the problem by some delta
Definition at line 198 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_cardP, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_linear, shark::QpMcBoxDecomp< Matrix >::m_numExamples, shark::QpMcBoxDecomp< Matrix >::m_numVariables, shark::QpMcBoxDecomp< Matrix >::m_variables, shark::QpMcBoxDecomp< Matrix >::originalIndex(), and SIZE_CHECK.
|
inline |
Definition at line 144 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_alpha, and shark::QpMcBoxDecomp< Matrix >::m_cardP.
|
inline |
Definition at line 169 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_cardP.
|
inline |
return the largest KKT violation
Definition at line 178 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_activeVar, shark::QpMcBoxDecomp< Matrix >::m_alpha, shark::QpMcBoxDecomp< Matrix >::m_C, and shark::QpMcBoxDecomp< Matrix >::m_gradient.
|
inlineprotected |
shrink an m_examples
Definition at line 528 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_activeEx, shark::QpMcBoxDecomp< Matrix >::m_activeVar, shark::QpMcBoxDecomp< Matrix >::m_cardP, shark::QpMcBoxDecomp< Matrix >::m_examples, shark::QpMcBoxDecomp< Matrix >::m_kernelMatrix, shark::QpMcBoxDecomp< Matrix >::m_variables, and SHARK_ASSERT.
Referenced by shark::QpMcBoxDecomp< Matrix >::shrink().
|
inlineprotected |
shrink a variable
Definition at line 490 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::Example::active, shark::QpMcBoxDecomp< Matrix >::Example::avar, shark::QpMcBoxDecomp< Matrix >::m_activeVar, shark::QpMcBoxDecomp< Matrix >::m_alpha, shark::QpMcBoxDecomp< Matrix >::m_examples, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_linear, shark::QpMcBoxDecomp< Matrix >::m_variables, and shark::QpMcBoxDecomp< Matrix >::Example::var.
Referenced by shark::QpMcBoxDecomp< Matrix >::shrink().
|
inline |
Definition at line 166 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_numVariables.
|
inline |
Compute the objective value of the current solution.
Definition at line 158 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_alpha, shark::QpMcBoxDecomp< Matrix >::m_gradient, and shark::QpMcBoxDecomp< Matrix >::m_linear.
|
inline |
Definition at line 173 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_numExamples.
|
inlineprotected |
Definition at line 466 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::Example::active, shark::QpMcBoxDecomp< Matrix >::Example::avar, shark::QpMcBoxDecomp< Matrix >::m_activeEx, shark::QpMcBoxDecomp< Matrix >::m_classes, shark::QpMcBoxDecomp< Matrix >::m_examples, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_M, shark::QpMcBoxDecomp< Matrix >::Example::var, and shark::QpMcBoxDecomp< Matrix >::Example::y.
Referenced by shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
inline |
Definition at line 162 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_examples.
|
inlineprotected |
Returns the original index of the example of a variable in the dataset before optimization.
Shrinking is an internal detail so the communication with the outside world uses the original indizes.
Definition at line 552 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_examples, and shark::QpMcBoxDecomp< Matrix >::m_variables.
Referenced by shark::QpMcBoxDecomp< Matrix >::addDeltaLinear(), shark::QpMcBoxDecomp< Matrix >::solution(), and shark::QpMcBoxDecomp< Matrix >::solutionGradient().
|
inline |
select the working set
Select one or two numVariables for the sub-problem and return the maximal KKT violation. The method MAY select the same index for i and j. In that case the working set consists of a single variables. The working set may be invalid if the method reports a KKT violation of zero, indicating optimality.
Definition at line 390 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::Variable::diagonal, shark::QpMcBoxDecomp< Matrix >::Variable::i, shark::QpMcBoxDecomp< Matrix >::m_activeEx, shark::QpMcBoxDecomp< Matrix >::m_activeVar, shark::QpMcBoxDecomp< Matrix >::m_alpha, shark::QpMcBoxDecomp< Matrix >::m_C, shark::QpMcBoxDecomp< Matrix >::m_cardP, shark::QpMcBoxDecomp< Matrix >::m_classes, shark::QpMcBoxDecomp< Matrix >::m_examples, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_kernelMatrix, shark::QpMcBoxDecomp< Matrix >::m_M, shark::QpMcBoxDecomp< Matrix >::m_variables, shark::QpMcBoxDecomp< Matrix >::Variable::p, SHARK_ASSERT, shark::QpMcBoxDecomp< Matrix >::Example::var, and shark::QpMcBoxDecomp< Matrix >::Example::y.
|
inline |
enable/disable shrinking
Definition at line 129 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_useShrinking.
|
inline |
Shrink the problem.
Definition at line 272 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::bUnshrinked, shark::QpMcBoxDecomp< Matrix >::deactivateExample(), shark::QpMcBoxDecomp< Matrix >::deactivateVariable(), shark::QpMcBoxDecomp< Matrix >::m_activeEx, shark::QpMcBoxDecomp< Matrix >::m_activeVar, shark::QpMcBoxDecomp< Matrix >::m_alpha, shark::QpMcBoxDecomp< Matrix >::m_C, shark::QpMcBoxDecomp< Matrix >::m_examples, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_useShrinking, shark::QpMcBoxDecomp< Matrix >::m_variables, and shark::QpMcBoxDecomp< Matrix >::unshrink().
|
inline |
Return the solution found.
Definition at line 135 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_alpha, shark::QpMcBoxDecomp< Matrix >::m_cardP, shark::QpMcBoxDecomp< Matrix >::m_numVariables, shark::QpMcBoxDecomp< Matrix >::m_variables, and shark::QpMcBoxDecomp< Matrix >::originalIndex().
|
inline |
Return the gradient of the solution.
Definition at line 148 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::m_cardP, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_numVariables, shark::QpMcBoxDecomp< Matrix >::m_variables, and shark::QpMcBoxDecomp< Matrix >::originalIndex().
|
inline |
Activate all variables.
Definition at line 332 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::Example::active, shark::QpMcBoxDecomp< Matrix >::Example::avar, shark::QpMcBoxDecomp< Matrix >::m_activeEx, shark::QpMcBoxDecomp< Matrix >::m_activeVar, shark::QpMcBoxDecomp< Matrix >::m_alpha, shark::QpMcBoxDecomp< Matrix >::m_cardP, shark::QpMcBoxDecomp< Matrix >::m_classes, shark::QpMcBoxDecomp< Matrix >::m_examples, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_kernelMatrix, shark::QpMcBoxDecomp< Matrix >::m_linear, shark::QpMcBoxDecomp< Matrix >::m_M, shark::QpMcBoxDecomp< Matrix >::m_numExamples, shark::QpMcBoxDecomp< Matrix >::m_numVariables, shark::QpMcBoxDecomp< Matrix >::m_variables, SHARK_ASSERT, shark::QpMcBoxDecomp< Matrix >::Example::var, and shark::QpMcBoxDecomp< Matrix >::Example::y.
Referenced by shark::QpMcBoxDecomp< Matrix >::shrink().
|
inline |
Definition at line 210 of file QpMcBoxDecomp.h.
References shark::QpMcBoxDecomp< Matrix >::gradientUpdate(), shark::QpMcBoxDecomp< Matrix >::m_activeEx, shark::QpMcBoxDecomp< Matrix >::m_activeVar, shark::QpMcBoxDecomp< Matrix >::m_alpha, shark::QpMcBoxDecomp< Matrix >::m_C, shark::QpMcBoxDecomp< Matrix >::m_cardP, shark::QpMcBoxDecomp< Matrix >::m_classes, shark::QpMcBoxDecomp< Matrix >::m_examples, shark::QpMcBoxDecomp< Matrix >::m_gradient, shark::QpMcBoxDecomp< Matrix >::m_kernelMatrix, shark::QpMcBoxDecomp< Matrix >::m_M, shark::QpMcBoxDecomp< Matrix >::m_variables, SHARK_ASSERT, and SIZE_CHECK.
|
protected |
true if the problem has already been unshrinked
Definition at line 487 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::shrink().
|
protected |
number of currently active m_examples
Definition at line 629 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::deactivateExample(), shark::QpMcBoxDecomp< Matrix >::gradientUpdate(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::shrink(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
number of currently active variabless
Definition at line 632 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::checkKKT(), shark::QpMcBoxDecomp< Matrix >::deactivateExample(), shark::QpMcBoxDecomp< Matrix >::deactivateVariable(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::shrink(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
solution candidate
Definition at line 610 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::alpha(), shark::QpMcBoxDecomp< Matrix >::checkKKT(), shark::QpMcBoxDecomp< Matrix >::deactivateVariable(), shark::QpMcBoxDecomp< Matrix >::functionValue(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::shrink(), shark::QpMcBoxDecomp< Matrix >::solution(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
complexity constant; upper bound on all variabless
Definition at line 592 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::checkKKT(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::shrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
number of dual m_numVariables per example
Definition at line 598 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::addDeltaLinear(), shark::QpMcBoxDecomp< Matrix >::alpha(), shark::QpMcBoxDecomp< Matrix >::cardP(), shark::QpMcBoxDecomp< Matrix >::deactivateExample(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::solution(), shark::QpMcBoxDecomp< Matrix >::solutionGradient(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
number of m_classes in the problem
Definition at line 595 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::gradientUpdate(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
information about each training example
Definition at line 617 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::deactivateExample(), shark::QpMcBoxDecomp< Matrix >::deactivateVariable(), shark::QpMcBoxDecomp< Matrix >::gradientUpdate(), shark::QpMcBoxDecomp< Matrix >::label(), shark::QpMcBoxDecomp< Matrix >::originalIndex(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::shrink(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
m_gradient of the objective function The m_gradient array is of fixed size and not subject to shrinking.
Definition at line 614 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::addDeltaLinear(), shark::QpMcBoxDecomp< Matrix >::checkKKT(), shark::QpMcBoxDecomp< Matrix >::deactivateVariable(), shark::QpMcBoxDecomp< Matrix >::functionValue(), shark::QpMcBoxDecomp< Matrix >::gradientUpdate(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::shrink(), shark::QpMcBoxDecomp< Matrix >::solutionGradient(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
kernel matrix (precomputed matrix or matrix cache)
Definition at line 586 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::deactivateExample(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
m_linear part of the objective function
Definition at line 607 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::addDeltaLinear(), shark::QpMcBoxDecomp< Matrix >::deactivateVariable(), shark::QpMcBoxDecomp< Matrix >::functionValue(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), and shark::QpMcBoxDecomp< Matrix >::unshrink().
|
protected |
kernel modifiers
Definition at line 589 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::gradientUpdate(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().
|
protected |
number of m_examples in the problem (size of the kernel matrix)
Definition at line 601 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::addDeltaLinear(), shark::QpMcBoxDecomp< Matrix >::getNumExamples(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), and shark::QpMcBoxDecomp< Matrix >::unshrink().
|
protected |
number of m_numVariables in the problem = m_examples times m_cardP
Definition at line 604 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::addDeltaLinear(), shark::QpMcBoxDecomp< Matrix >::dimensions(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::solution(), shark::QpMcBoxDecomp< Matrix >::solutionGradient(), and shark::QpMcBoxDecomp< Matrix >::unshrink().
|
protected |
space for the example[i].var pointers
Definition at line 623 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp().
|
protected |
space for the example[i].avar pointers
Definition at line 626 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp().
|
protected |
should the m_problem use the shrinking heuristics?
Definition at line 635 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::setShrinking(), and shark::QpMcBoxDecomp< Matrix >::shrink().
|
protected |
information about each m_variables of the problem
Definition at line 620 of file QpMcBoxDecomp.h.
Referenced by shark::QpMcBoxDecomp< Matrix >::addDeltaLinear(), shark::QpMcBoxDecomp< Matrix >::deactivateExample(), shark::QpMcBoxDecomp< Matrix >::deactivateVariable(), shark::QpMcBoxDecomp< Matrix >::originalIndex(), shark::QpMcBoxDecomp< Matrix >::QpMcBoxDecomp(), shark::QpMcBoxDecomp< Matrix >::selectWorkingSet(), shark::QpMcBoxDecomp< Matrix >::shrink(), shark::QpMcBoxDecomp< Matrix >::solution(), shark::QpMcBoxDecomp< Matrix >::solutionGradient(), shark::QpMcBoxDecomp< Matrix >::unshrink(), and shark::QpMcBoxDecomp< Matrix >::updateSMO().