/usr/include/shogun/structure/PrimalMosekSOSVM.h is in libshogun-dev 3.1.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 | /*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* Written (W) 2012 Fernando José Iglesias García
* Copyright (C) 2012 Fernando José Iglesias García
*/
#ifndef _PRIMAL_MOSEK_SOSVM__H__
#define _PRIMAL_MOSEK_SOSVM__H__
#ifdef USE_MOSEK
#include <shogun/machine/LinearStructuredOutputMachine.h>
#include <shogun/mathematics/Mosek.h>
namespace shogun
{
/**
* @brief Class PrimalMosekSOSVM that implements the optimization
* algorithm for structured output (SO) problems presented in [1] for SVM
* learning. The optimization problem is solved using a cutting plane algorithm.
*
* [1] Tsochantaridis, I., Hofmann, T., Joachims, T., Altun, Y.
* Support Vector Machine Learning for Interdependent and Structured Ouput
* Spaces.
* http://www.cs.cornell.edu/People/tj/publications/tsochantaridis_etal_04a.pdf
*/
class CPrimalMosekSOSVM : public CLinearStructuredOutputMachine
{
public:
/** default constructor */
CPrimalMosekSOSVM();
/** standard constructor
*
* @param model structured model with application specific functions
* @param labs structured labels
*/
CPrimalMosekSOSVM(CStructuredModel* model, CStructuredLabels* labs);
/** destructor */
~CPrimalMosekSOSVM();
/** get slacks
*
* @return slacks
*/
inline SGVector< float64_t > get_slacks() const { return m_slacks; }
/** compute the primal objective value
*
* @return primal objective value.
*/
virtual float64_t compute_primal_objective() const;
/** @return name of SGSerializable */
virtual const char* get_name() const { return "PrimalMosekSOSVM"; }
/** get classifier type
*
* @return classifier type CT_PRIMALMOSEKSOSVM
*/
virtual EMachineType get_classifier_type();
/** set regularization constant C
*
* @param C regularization constant
*/
void set_regularization(float64_t C);
/** set epsilon
*
* @param epsilon if slack_i > max_slack_i + epsilon, add to cutting plane set
*/
void set_epsilon(float64_t epsilon);
protected:
/** train primal SO-SVM
*
* @param data training data
* @return whether the training was successful
*/
virtual bool train_machine(CFeatures* data = NULL);
private:
void init();
/** computes the result of TODO equation
*
* @param result CResultSet structure with any argmax output
* @return result of the operation
*/
float64_t compute_loss_arg(CResultSet* result) const;
/** insert element in the list of argmax results
*
* @param result_list list of CResultSet
* @param result element to insert in the list
*/
bool insert_result(CList* result_list, CResultSet* result) const;
/** introduces a new constraint of type Ax <= b in the
* optimization problem. Remember that each row i in A takes the
* form
*
* \f[
* \Psi(\vec{x}_i,{\hat{y}_i}) - \Psi(\vec{x}_i,y_i) ~|~-\delta_{ji}
*\f]
*
* and the corresponding element in b is
*
* \f[
* -\Delta(y, \hat{y}_i)
*\f]
*
* @param mosek MOSEK optimization problem instance
* @param result structure with numerical information of the
* constraint
* @param con_idx row index in A for this new constraint
* @param train_idx training example associated to this
* constraint
*
* @return whether the new constraint has been succesfully added
*/
bool add_constraint(CMosek* mosek, CResultSet* result, index_t con_idx, index_t train_idx) const;
private:
/** slack variables associated to each training example */
SGVector< float64_t > m_slacks;
/** primal objective value */
float64_t po_value;
/** regularization constant */
float64_t m_regularization;
/** epsilon */
float64_t m_epsilon;
}; /* class CPrimalMosekSOSVM */
} /* namespace shogun */
#endif /* USE_MOSEK */
#endif /* _PRIMAL_MOSEK_SOSVM__H__ */
|