Skip to content
  • Sponsor TheAlgorithms/Python

  • Notifications You must be signed in to change notification settings
  • Fork 46.9k

Update support_vector_machines.py to add the polynomial kernel #12748

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
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
41 changes: 41 additions & 0 deletions machine_learning/support_vector_machines.py
Original file line number Diff line number Diff line change
@@ -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__(
@@ -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":
@@ -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)
@@ -98,6 +123,22 @@ 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.