polynomial_kernel.hpp
Go to the documentation of this file.
1 
12 #ifndef MLPACK_CORE_KERNELS_POLYNOMIAL_KERNEL_HPP
13 #define MLPACK_CORE_KERNELS_POLYNOMIAL_KERNEL_HPP
14 
15 #include <mlpack/prereqs.hpp>
16 
17 namespace mlpack {
18 namespace kernel {
19 
29 {
30  public:
38  PolynomialKernel(const double degree = 2.0, const double offset = 0.0) :
39  degree(degree),
40  offset(offset)
41  { }
42 
54  template<typename VecTypeA, typename VecTypeB>
55  double Evaluate(const VecTypeA& a, const VecTypeB& b) const
56  {
57  return pow((arma::dot(a, b) + offset), degree);
58  }
59 
61  const double& Degree() const { return degree; }
63  double& Degree() { return degree; }
64 
66  const double& Offset() const { return offset; }
68  double& Offset() { return offset; }
69 
71  template<typename Archive>
72  void serialize(Archive& ar, const uint32_t /* version */)
73  {
74  ar(CEREAL_NVP(degree));
75  ar(CEREAL_NVP(offset));
76  }
77 
78  private:
80  double degree;
82  double offset;
83 };
84 
85 } // namespace kernel
86 } // namespace mlpack
87 
88 #endif
const double & Degree() const
Get the degree of the polynomial.
Linear algebra utility functions, generally performed on matrices or vectors.
const double & Offset() const
Get the offset of the dot product of the arguments.
The core includes that mlpack expects; standard C++ includes and Armadillo.
double & Offset()
Modify the offset of the dot product of the arguments.
void serialize(Archive &ar, const uint32_t)
Serialize the kernel.
The simple polynomial kernel.
double Evaluate(const VecTypeA &a, const VecTypeB &b) const
Simple evaluation of the dot product.
double & Degree()
Modify the degree of the polynomial.
PolynomialKernel(const double degree=2.0, const double offset=0.0)
Construct the Polynomial Kernel with the given offset and degree.