#include <shark/Algorithms/QP/QpMcSimplexDecomp.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 variable of the problem More... | |
Public Types | |
typedef Matrix::QpFloatType | QpFloatType |
Public Member Functions | |
QpMcSimplexDecomp (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 |
Returns the solution found. | |
RealMatrix | solutionGradient () const |
Returns 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 |
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 m_numVariables. | |
double | selectWorkingSet (std::size_t &i, std::size_t &j) |
select the working set | |
double | checkKKT () const |
return the largest KKT violation | |
Protected Member Functions | |
std::pair< std::pair< std::size_t, std::size_t >, double > | maxGainBox (std::size_t i) const |
Finds the second variable of a working set using maximum gain and returns the pair and gain. | |
std::pair< std::pair< std::size_t, std::size_t >, double > | maxGainSimplex (std::size_t e) const |
Returns the best variable pair (i,j) and gain for a given example. | |
std::pair< std::pair< double, std::size_t >, std::pair< double, std::size_t > > | getSimplexMVP (Example const &ex) const |
For a given simplex returns the MVP indicies (max_up,min_down) | |
void | updateVarsum (std::size_t exampleId, double mu) |
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 example | |
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 | |
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 | |
std::size_t | m_classes |
number of classes in the problem | |
std::size_t | m_cardP |
number of dual variables per example | |
std::size_t | m_numExamples |
number of examples in the problem (size of the kernel matrix) | |
std::size_t | m_numVariables |
number of variables in the problem = m_numExamples * m_cardP | |
RealVector | m_linear |
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 variable 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 examples | |
std::size_t | m_activeVar |
number of currently active variables | |
bool | m_useShrinking |
should the m_problem use the shrinking heuristics? | |
bool | bUnshrinked |
true if the problem has already been unshrinked | |
Definition at line 50 of file QpMcSimplexDecomp.h.
typedef Matrix::QpFloatType shark::QpMcSimplexDecomp< Matrix >::QpFloatType |
Definition at line 53 of file QpMcSimplexDecomp.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 QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::bUnshrinked, shark::Data< Type >::element(), shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_activeVar, shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_classes, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_kernelMatrix, shark::QpMcSimplexDecomp< Matrix >::m_linear, shark::QpMcSimplexDecomp< Matrix >::m_M, shark::QpMcSimplexDecomp< Matrix >::m_numExamples, shark::QpMcSimplexDecomp< Matrix >::m_numVariables, shark::QpMcSimplexDecomp< Matrix >::m_storage1, shark::QpMcSimplexDecomp< Matrix >::m_storage2, shark::QpMcSimplexDecomp< 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 176 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_linear, shark::QpMcSimplexDecomp< Matrix >::m_numExamples, shark::QpMcSimplexDecomp< Matrix >::m_numVariables, shark::QpMcSimplexDecomp< Matrix >::m_variables, shark::QpMcSimplexDecomp< Matrix >::originalIndex(), and SIZE_CHECK.
|
inline |
Definition at line 167 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_cardP.
|
inline |
return the largest KKT violation
Definition at line 468 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::getSimplexMVP(), shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_C, shark::QpMcSimplexDecomp< Matrix >::m_examples, and shark::QpMcSimplexDecomp< Matrix >::Example::varsum.
Referenced by shark::QpMcSimplexDecomp< Matrix >::shrink().
|
inlineprotected |
shrink an example
Definition at line 800 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_activeVar, shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_kernelMatrix, shark::QpMcSimplexDecomp< Matrix >::m_variables, and SHARK_ASSERT.
Referenced by shark::QpMcSimplexDecomp< Matrix >::deactivateVariable().
|
inlineprotected |
shrink a variable
Definition at line 758 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::Example::active, shark::QpMcSimplexDecomp< Matrix >::Example::avar, shark::QpMcSimplexDecomp< Matrix >::deactivateExample(), shark::QpMcSimplexDecomp< Matrix >::m_activeVar, shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_linear, shark::QpMcSimplexDecomp< Matrix >::m_variables, and shark::QpMcSimplexDecomp< Matrix >::Example::var.
Referenced by shark::QpMcSimplexDecomp< Matrix >::shrink().
|
inline |
Definition at line 164 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_numVariables.
|
inline |
Compute the objective value of the current solution.
Definition at line 156 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_gradient, and shark::QpMcSimplexDecomp< Matrix >::m_linear.
|
inline |
Definition at line 171 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_numExamples.
|
inlineprotected |
For a given simplex returns the MVP indicies (max_up,min_down)
Definition at line 694 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::Example::active, shark::QpMcSimplexDecomp< Matrix >::Example::avar, shark::QpMcSimplexDecomp< Matrix >::m_activeVar, shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_gradient, and SHARK_ASSERT.
Referenced by shark::QpMcSimplexDecomp< Matrix >::checkKKT(), shark::QpMcSimplexDecomp< Matrix >::selectWorkingSet(), and shark::QpMcSimplexDecomp< Matrix >::shrink().
|
inlineprotected |
Definition at line 737 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::Example::active, shark::QpMcSimplexDecomp< Matrix >::Example::avar, shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_classes, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_M, shark::QpMcSimplexDecomp< Matrix >::Example::var, and shark::QpMcSimplexDecomp< Matrix >::Example::y.
Referenced by shark::QpMcSimplexDecomp< Matrix >::updateSMO().
|
inline |
Definition at line 160 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_examples.
|
inlineprotected |
Finds the second variable of a working set using maximum gain and returns the pair and gain.
The variable is searched in-between samples. And not inside the simplex of i. It returns the best pair (i,j) as well as the gain. If the first variable can't make a step, gain 0 is returned with pair(i,i).
Definition at line 529 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_activeVar, shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_C, shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_classes, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_kernelMatrix, shark::QpMcSimplexDecomp< Matrix >::m_M, shark::QpMcSimplexDecomp< Matrix >::m_variables, SHARK_ASSERT, shark::QpMcSimplexDecomp< Matrix >::Example::var, shark::QpMcSimplexDecomp< Matrix >::Example::varsum, and shark::QpMcSimplexDecomp< Matrix >::Example::y.
Referenced by shark::QpMcSimplexDecomp< Matrix >::selectWorkingSet().
|
inlineprotected |
Returns the best variable pair (i,j) and gain for a given example.
For a given example all possible pairs of variables are checkd and the one giving the maximum gain is returned. This method has a special handling for the simplex case.
Definition at line 589 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::Example::active, shark::QpMcSimplexDecomp< Matrix >::Example::avar, shark::QpMcSimplexDecomp< Matrix >::m_activeVar, shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_C, shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_classes, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_M, shark::QpMcSimplexDecomp< Matrix >::m_variables, shark::QpMcSimplexDecomp< Matrix >::Example::var, shark::QpMcSimplexDecomp< Matrix >::Example::varsum, and shark::QpMcSimplexDecomp< Matrix >::Example::y.
Referenced by shark::QpMcSimplexDecomp< Matrix >::selectWorkingSet().
|
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 823 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_examples, and shark::QpMcSimplexDecomp< Matrix >::m_variables.
Referenced by shark::QpMcSimplexDecomp< Matrix >::addDeltaLinear(), shark::QpMcSimplexDecomp< Matrix >::solution(), and shark::QpMcSimplexDecomp< 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 406 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::getSimplexMVP(), shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_C, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_variables, shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), and shark::QpMcSimplexDecomp< Matrix >::Example::varsum.
|
inline |
enable/disable shrinking
Definition at line 131 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_useShrinking.
|
inline |
Shrink the problem.
Definition at line 284 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::Example::active, shark::QpMcSimplexDecomp< Matrix >::Example::avar, shark::QpMcSimplexDecomp< Matrix >::bUnshrinked, shark::QpMcSimplexDecomp< Matrix >::checkKKT(), shark::QpMcSimplexDecomp< Matrix >::deactivateVariable(), shark::QpMcSimplexDecomp< Matrix >::getSimplexMVP(), shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_C, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_useShrinking, shark::QpMcSimplexDecomp< Matrix >::unshrink(), and shark::QpMcSimplexDecomp< Matrix >::Example::varsum.
|
inline |
Returns the solution found.
Definition at line 137 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_numVariables, shark::QpMcSimplexDecomp< Matrix >::m_variables, and shark::QpMcSimplexDecomp< Matrix >::originalIndex().
|
inline |
Returns the gradient of the solution.
Definition at line 146 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_numVariables, shark::QpMcSimplexDecomp< Matrix >::m_variables, and shark::QpMcSimplexDecomp< Matrix >::originalIndex().
|
inline |
Activate all m_numVariables.
Definition at line 348 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::Example::active, shark::QpMcSimplexDecomp< Matrix >::Example::avar, shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_activeVar, shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_classes, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_kernelMatrix, shark::QpMcSimplexDecomp< Matrix >::m_linear, shark::QpMcSimplexDecomp< Matrix >::m_M, shark::QpMcSimplexDecomp< Matrix >::m_numExamples, shark::QpMcSimplexDecomp< Matrix >::m_numVariables, shark::QpMcSimplexDecomp< Matrix >::m_variables, SHARK_ASSERT, shark::QpMcSimplexDecomp< Matrix >::Example::var, and shark::QpMcSimplexDecomp< Matrix >::Example::y.
Referenced by shark::QpMcSimplexDecomp< Matrix >::shrink().
|
inline |
Definition at line 187 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::gradientUpdate(), shark::QpMcSimplexDecomp< Matrix >::m_activeEx, shark::QpMcSimplexDecomp< Matrix >::m_activeVar, shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_C, shark::QpMcSimplexDecomp< Matrix >::m_cardP, shark::QpMcSimplexDecomp< Matrix >::m_classes, shark::QpMcSimplexDecomp< Matrix >::m_examples, shark::QpMcSimplexDecomp< Matrix >::m_gradient, shark::QpMcSimplexDecomp< Matrix >::m_kernelMatrix, shark::QpMcSimplexDecomp< Matrix >::m_M, shark::QpMcSimplexDecomp< Matrix >::m_variables, SHARK_ASSERT, SIZE_CHECK, and shark::QpMcSimplexDecomp< Matrix >::updateVarsum().
|
inlineprotected |
Definition at line 718 of file QpMcSimplexDecomp.h.
References shark::QpMcSimplexDecomp< Matrix >::m_alpha, shark::QpMcSimplexDecomp< Matrix >::m_C, shark::QpMcSimplexDecomp< Matrix >::m_cardP, and shark::QpMcSimplexDecomp< Matrix >::m_examples.
Referenced by shark::QpMcSimplexDecomp< Matrix >::updateSMO().
|
protected |
true if the problem has already been unshrinked
Definition at line 881 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), and shark::QpMcSimplexDecomp< Matrix >::shrink().
|
protected |
number of currently active examples
Definition at line 872 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::checkKKT(), shark::QpMcSimplexDecomp< Matrix >::deactivateExample(), shark::QpMcSimplexDecomp< Matrix >::gradientUpdate(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::selectWorkingSet(), shark::QpMcSimplexDecomp< Matrix >::shrink(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), and shark::QpMcSimplexDecomp< Matrix >::updateSMO().
|
protected |
number of currently active variables
Definition at line 875 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::deactivateExample(), shark::QpMcSimplexDecomp< Matrix >::deactivateVariable(), shark::QpMcSimplexDecomp< Matrix >::getSimplexMVP(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), and shark::QpMcSimplexDecomp< Matrix >::updateSMO().
|
protected |
solution candidate
Definition at line 853 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::deactivateVariable(), shark::QpMcSimplexDecomp< Matrix >::functionValue(), shark::QpMcSimplexDecomp< Matrix >::getSimplexMVP(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::shrink(), shark::QpMcSimplexDecomp< Matrix >::solution(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), shark::QpMcSimplexDecomp< Matrix >::updateSMO(), and shark::QpMcSimplexDecomp< Matrix >::updateVarsum().
|
protected |
complexity constant; upper bound on all variabless
Definition at line 835 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::checkKKT(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::selectWorkingSet(), shark::QpMcSimplexDecomp< Matrix >::shrink(), shark::QpMcSimplexDecomp< Matrix >::updateSMO(), and shark::QpMcSimplexDecomp< Matrix >::updateVarsum().
|
protected |
number of dual variables per example
Definition at line 841 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::addDeltaLinear(), shark::QpMcSimplexDecomp< Matrix >::cardP(), shark::QpMcSimplexDecomp< Matrix >::deactivateExample(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::solution(), shark::QpMcSimplexDecomp< Matrix >::solutionGradient(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), shark::QpMcSimplexDecomp< Matrix >::updateSMO(), and shark::QpMcSimplexDecomp< Matrix >::updateVarsum().
|
protected |
number of classes in the problem
Definition at line 838 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::gradientUpdate(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), and shark::QpMcSimplexDecomp< Matrix >::updateSMO().
|
protected |
information about each training example
Definition at line 860 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::checkKKT(), shark::QpMcSimplexDecomp< Matrix >::deactivateExample(), shark::QpMcSimplexDecomp< Matrix >::deactivateVariable(), shark::QpMcSimplexDecomp< Matrix >::gradientUpdate(), shark::QpMcSimplexDecomp< Matrix >::label(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::originalIndex(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::selectWorkingSet(), shark::QpMcSimplexDecomp< Matrix >::shrink(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), shark::QpMcSimplexDecomp< Matrix >::updateSMO(), and shark::QpMcSimplexDecomp< Matrix >::updateVarsum().
|
protected |
gradient of the objective function The m_gradient array is of fixed size and not subject to shrinking.
Definition at line 857 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::addDeltaLinear(), shark::QpMcSimplexDecomp< Matrix >::deactivateVariable(), shark::QpMcSimplexDecomp< Matrix >::functionValue(), shark::QpMcSimplexDecomp< Matrix >::getSimplexMVP(), shark::QpMcSimplexDecomp< Matrix >::gradientUpdate(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::shrink(), shark::QpMcSimplexDecomp< Matrix >::solutionGradient(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), and shark::QpMcSimplexDecomp< Matrix >::updateSMO().
|
protected |
kernel matrix (precomputed matrix or matrix cache)
Definition at line 829 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::deactivateExample(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), and shark::QpMcSimplexDecomp< Matrix >::updateSMO().
|
protected |
linear part of the objective function
Definition at line 850 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::addDeltaLinear(), shark::QpMcSimplexDecomp< Matrix >::deactivateVariable(), shark::QpMcSimplexDecomp< Matrix >::functionValue(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), and shark::QpMcSimplexDecomp< Matrix >::unshrink().
|
protected |
kernel modifiers
Definition at line 832 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::gradientUpdate(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), and shark::QpMcSimplexDecomp< Matrix >::updateSMO().
|
protected |
number of examples in the problem (size of the kernel matrix)
Definition at line 844 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::addDeltaLinear(), shark::QpMcSimplexDecomp< Matrix >::getNumExamples(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), and shark::QpMcSimplexDecomp< Matrix >::unshrink().
|
protected |
number of variables in the problem = m_numExamples * m_cardP
Definition at line 847 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::addDeltaLinear(), shark::QpMcSimplexDecomp< Matrix >::dimensions(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::solution(), shark::QpMcSimplexDecomp< Matrix >::solutionGradient(), and shark::QpMcSimplexDecomp< Matrix >::unshrink().
|
protected |
space for the example[i].var pointers
Definition at line 866 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp().
|
protected |
space for the example[i].avar pointers
Definition at line 869 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp().
|
protected |
should the m_problem use the shrinking heuristics?
Definition at line 878 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::setShrinking(), and shark::QpMcSimplexDecomp< Matrix >::shrink().
|
protected |
information about each variable of the problem
Definition at line 863 of file QpMcSimplexDecomp.h.
Referenced by shark::QpMcSimplexDecomp< Matrix >::addDeltaLinear(), shark::QpMcSimplexDecomp< Matrix >::deactivateExample(), shark::QpMcSimplexDecomp< Matrix >::deactivateVariable(), shark::QpMcSimplexDecomp< Matrix >::maxGainBox(), shark::QpMcSimplexDecomp< Matrix >::maxGainSimplex(), shark::QpMcSimplexDecomp< Matrix >::originalIndex(), shark::QpMcSimplexDecomp< Matrix >::QpMcSimplexDecomp(), shark::QpMcSimplexDecomp< Matrix >::selectWorkingSet(), shark::QpMcSimplexDecomp< Matrix >::solution(), shark::QpMcSimplexDecomp< Matrix >::solutionGradient(), shark::QpMcSimplexDecomp< Matrix >::unshrink(), and shark::QpMcSimplexDecomp< Matrix >::updateSMO().