-
Notifications
You must be signed in to change notification settings - Fork 3.2k
/
Copy pathkernel_ridge.py
90 lines (71 loc) · 2.55 KB
/
kernel_ridge.py
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
import scipy as sp
from numpy.linalg import inv
import numpy as np
from scipy import linalg
class KernelRidge():
"""
Simple implementation of a Kernel Ridge Regression using the
closed form for training.
Doc: https://www.ics.uci.edu/~welling/classnotes/papers_class/Kernel-Ridge.pdf
"""
def __init__(self, kernel_type='linear', C=1.0, gamma=5.0):
"""
:param kernel_type: Kernel type to use in training.
'linear' use linear kernel function.
'quadratic' use quadratic kernel function.
'gaussian' use gaussian kernel function
:param C: Value of regularization parameter C
:param gamma: parameter for gaussian kernel or Polynomial kernel
"""
self.kernels = {
'linear': self.kernel_linear,
'quadratic': self.kernel_quadratic,
'gaussian': self.kernel_gaussian
}
self.kernel_type = kernel_type
self.kernel = self.kernels[self.kernel_type]
self.C = C
self.gamma = gamma
# Define kernels
def kernel_linear(self, x1, x2):
return np.dot(x1, x2.T)
def kernel_quadratic(self, x1, x2):
return (np.dot(x1, x2.T) ** 2)
def kernel_gaussian(self, x1, x2, gamma=5.0):
gamma = self.gamma
return np.exp(-linalg.norm(x1 - x2) ** 2 / (2 * (gamma ** 2)))
def compute_kernel_matrix(self, X1, X2):
"""
compute kernel matrix (gram matrix) give two input matrix
"""
# sample size
n1 = X1.shape[0]
n2 = X2.shape[0]
# Gram matrix
K = np.zeros((n1, n2))
for i in range(n1):
for j in range(n2):
K[i, j] = self.kernel(X1[i], X2[j])
return K
def fit(self, X, y):
"""
training KRR
:param X: training X
:param y: training y
:return: alpha vector, see document TODO
"""
K = self.compute_kernel_matrix(X, X)
self.alphas = sp.dot(inv(K + self.C * np.eye(np.shape(K)[0])),
y.transpose())
return self.alphas
def predict(self, x_train, x_test):
"""
:param x_train: DxNtr array of Ntr train data points
with D features
:param x_test: DxNte array of Nte test data points
with D features
:return: y_test, D2xNte array
"""
k = self.compute_kernel_matrix(x_test, x_train)
y_test = sp.dot(k, self.alphas)
return y_test.transpose()