SHOGUN  v3.0.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
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

SHOGUN Machine Learning Toolbox - Documentation