Skip to content
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
42 changes: 42 additions & 0 deletions machine_learning/support_vector_machines.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,19 @@ class SVC:
Traceback (most recent call last):
...
ValueError: gamma must be > 0

>>> SVC(kernel="polynomial")
Traceback (most recent call last):
...
ValueError: polynomial kernel requires degree
>>> SVC(kernel="polynomial",degree=None)
Traceback (most recent call last):
...
ValueError: degree must be float or int
>>> SVC(kernel="polynomial",degree=-1.0)
Traceback (most recent call last):
...
ValueError: degree must be > 0
"""

def __init__(
Expand All @@ -57,9 +70,13 @@ def __init__(
regularization: float = np.inf,
kernel: str = "linear",
gamma: float = 0.0,
degree: float=0.0,
coef0: float = 0.0,
) -> None:
self.regularization = regularization
self.gamma = gamma
self.degree = degree
self.coef0 = coef0
if kernel == "linear":
self.kernel = self.__linear
elif kernel == "rbf":
Expand All @@ -73,6 +90,14 @@ def __init__(
# in the future, there could be a default value like in sklearn
# sklear: def_gamma = 1/(n_features * X.var()) (wiki)
# previously it was 1/(n_features)
elif kernel == "polynomial":
if self.degree == 0:
raise ValueError("polynomial kernel requires degree")
if not isinstance(self.degree, (float, int)) :
raise ValueError("degree must be float or int")
if not self.degree > 0:
raise ValueError("degree must be > 0")
self.kernel = self.__polynomial
else:
msg = f"Unknown kernel: {kernel}"
raise ValueError(msg)
Expand All @@ -98,6 +123,23 @@ def __rbf(self, vector1: ndarray, vector2: ndarray) -> float:
"""
return np.exp(-(self.gamma * norm_squared(vector1 - vector2)))


def __polynomial(self, vector1: ndarray, vector2: ndarray) -> float:
"""
Polynomial kernel: (x . y + coef0)^degree

Note: for more information see:
https://en.wikipedia.org/wiki/Polynomial_kernel

Args:
vector1 (ndarray): first vector
vector2 (ndarray): second vector

Returns:
float: (vector1 . vector2 + coef0)^degree
"""
return (np.dot(vector1, vector2) + self.coef0) ** self.degree

def fit(self, observations: list[ndarray], classes: ndarray) -> None:
"""
Fits the SVC with a set of observations.
Expand Down