forked from TheAlgorithms/Python
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Adds hinge loss function algorithm (TheAlgorithms#10628)
* Adds exponential moving average algorithm * code clean up * spell correction * Modifies I/O types of function * Replaces generator function * Resolved mypy type error * readibility of code and documentation * Update exponential_moving_average.py * Adds hinge loss function * suggested doc and refactoring changes * refactoring --------- Co-authored-by: Christian Clauss <cclauss@me.com>
- Loading branch information
1 parent
788e4ed
commit 361f64c
Showing
1 changed file
with
64 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
""" | ||
Hinge Loss | ||
Description: | ||
Compute the Hinge loss used for training SVM (Support Vector Machine). | ||
Formula: | ||
loss = max(0, 1 - true * pred) | ||
Reference: https://en.wikipedia.org/wiki/Hinge_loss | ||
Author: Poojan Smart | ||
Email: smrtpoojan@gmail.com | ||
""" | ||
|
||
import numpy as np | ||
|
||
|
||
def hinge_loss(y_true: np.ndarray, y_pred: np.ndarray) -> float: | ||
""" | ||
Calculate the mean hinge loss for y_true and y_pred for binary classification. | ||
Args: | ||
y_true: Array of actual values (ground truth) encoded as -1 and 1. | ||
y_pred: Array of predicted values. | ||
Returns: | ||
The hinge loss between y_true and y_pred. | ||
Examples: | ||
>>> y_true = np.array([-1, 1, 1, -1, 1]) | ||
>>> pred = np.array([-4, -0.3, 0.7, 5, 10]) | ||
>>> hinge_loss(y_true, pred) | ||
1.52 | ||
>>> y_true = np.array([-1, 1, 1, -1, 1, 1]) | ||
>>> pred = np.array([-4, -0.3, 0.7, 5, 10]) | ||
>>> hinge_loss(y_true, pred) | ||
Traceback (most recent call last): | ||
... | ||
ValueError: Length of predicted and actual array must be same. | ||
>>> y_true = np.array([-1, 1, 10, -1, 1]) | ||
>>> pred = np.array([-4, -0.3, 0.7, 5, 10]) | ||
>>> hinge_loss(y_true, pred) | ||
Traceback (most recent call last): | ||
... | ||
ValueError: y_true can have values -1 or 1 only. | ||
""" | ||
|
||
if len(y_true) != len(y_pred): | ||
raise ValueError("Length of predicted and actual array must be same.") | ||
|
||
# Raise value error when y_true (encoded labels) have any other values | ||
# than -1 and 1 | ||
if np.any((y_true != -1) & (y_true != 1)): | ||
raise ValueError("y_true can have values -1 or 1 only.") | ||
|
||
hinge_losses = np.maximum(0, 1.0 - (y_true * y_pred)) | ||
return np.mean(hinge_losses) | ||
|
||
|
||
if __name__ == "__main__": | ||
import doctest | ||
|
||
doctest.testmod() |