SHOGUN  v3.2.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules
MKLMulticlassGradient.h
Go to the documentation of this file.
1 /*
2  * This program is free software; you can redistribute it and/or modify
3  * it under the terms of the GNU General Public License as published by
4  * the Free Software Foundation; either version 3 of the License, or
5  * (at your option) any later version.
6  *
7  * Written (W) 2009 Alexander Binder
8  * Copyright (C) 2009 Fraunhofer Institute FIRST and Max-Planck-Society
9  *
10  * Update to patch 0.10.0 - thanks to Eric aka Yoo (thereisnoknife@gmail.com)
11  *
12  */
13 
14 #ifndef MKLMulticlassGRADIENT_H_
15 #define MKLMulticlassGRADIENT_H_
16 
17 #include <vector>
18 #include <cmath>
19 #include <cassert>
20 #include <shogun/base/SGObject.h>
22 
23 
24 namespace shogun
25 {
32 {
33 public:
41  virtual ~MKLMulticlassGradient();
42 
47 
52 
59  virtual void setup(const int32_t numkernels2);
60 
69  virtual void addconstraint(const ::std::vector<float64_t> & normw2,
70  const float64_t sumofpositivealphas);
71 
77  virtual void computeweights(std::vector<float64_t> & weights2);
78 
80  virtual const char* get_name() const { return "MKLMulticlassGradient"; }
81 
85  virtual void set_mkl_norm(float64_t norm);
86 
87 protected:
94  void linesearch2(std::vector<float64_t> & finalbeta,const std::vector<float64_t> & oldweights);
95 
102  void genbetas( ::std::vector<float64_t> & weights ,const ::std::vector<float64_t> & gammas);
103 
111  void gengammagradient( ::std::vector<float64_t> & gammagradient ,const ::std::vector<float64_t> & gammas,const int32_t dim);
112 
119  float64_t objectives(const ::std::vector<float64_t> & weights, const int32_t index);
120 
127  void linesearch(std::vector<float64_t> & finalbeta,const std::vector<float64_t> & oldweights);
128 
129 protected:
131  int32_t numkernels;
132 
133 
135  ::std::vector< ::std::vector<float64_t> > normsofsubkernels;
137  ::std::vector< float64_t > sumsofalphas ;
140 };
141 }
142 
143 #endif
virtual void addconstraint(const ::std::vector< float64_t > &normw2, const float64_t sumofpositivealphas)
double norm(double *v, double p, int n)
Definition: epph.cpp:452
void linesearch(std::vector< float64_t > &finalbeta, const std::vector< float64_t > &oldweights)
::std::vector< ::std::vector< float64_t > > normsofsubkernels
virtual void computeweights(std::vector< float64_t > &weights2)
void genbetas(::std::vector< float64_t > &weights, const ::std::vector< float64_t > &gammas)
double float64_t
Definition: common.h:48
MKLMulticlassOptimizationBase is a helper class for MKLMulticlass.
void gengammagradient(::std::vector< float64_t > &gammagradient, const ::std::vector< float64_t > &gammas, const int32_t dim)
virtual void set_mkl_norm(float64_t norm)
virtual void setup(const int32_t numkernels2)
float64_t objectives(const ::std::vector< float64_t > &weights, const int32_t index)
virtual const char * get_name() const
all of classes and functions are contained in the shogun namespace
Definition: class_list.h:16
MKLMulticlassGradient operator=(MKLMulticlassGradient &gl)
::std::vector< float64_t > sumsofalphas
void linesearch2(std::vector< float64_t > &finalbeta, const std::vector< float64_t > &oldweights)
MKLMulticlassGradient is a helper class for MKLMulticlass.

SHOGUN Machine Learning Toolbox - Documentation