SHOGUN  v3.0.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
DiagKernel.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) 1999-2009 Soeren Sonnenburg
8  * Copyright (C) 1999-2009 Fraunhofer Institute FIRST and Max-Planck-Society
9  */
10 
11 #ifndef _DIAGKERNEL_H___
12 #define _DIAGKERNEL_H___
13 
14 #include <shogun/lib/common.h>
15 #include <shogun/kernel/Kernel.h>
16 
17 namespace shogun
18 {
26 class CDiagKernel: public CKernel
27 {
28  public:
30  CDiagKernel();
31 
37  CDiagKernel(int32_t size, float64_t diag=1.0);
38 
46 
47  virtual ~CDiagKernel();
48 
55  virtual bool init(CFeatures* l, CFeatures* r);
56 
62  {
63  return F_ANY;
64  }
65 
71  {
72  return C_ANY;
73  }
74 
79  virtual EKernelType get_kernel_type() { return K_DIAG; }
80 
85  virtual const char* get_name() const { return "DiagKernel"; }
86 
87  protected:
96  virtual float64_t compute(int32_t idx_a, int32_t idx_b)
97  {
98  if (idx_a==idx_b)
99  return diag;
100  else
101  return 0;
102  }
103  private:
104  void init();
105 
106  protected:
109 };
110 }
111 #endif /* _DIAGKERNEL_H__ */

SHOGUN Machine Learning Toolbox - Documentation