Skip to content

Instantly share code, notes, and snippets.

@techedlaksh
Forked from larsmans/hellinger.py
Created December 10, 2016 12:04
Show Gist options
  • Save techedlaksh/088b770eb15e0887f06f55ec775529d1 to your computer and use it in GitHub Desktop.
Save techedlaksh/088b770eb15e0887f06f55ec775529d1 to your computer and use it in GitHub Desktop.
Hellinger distance for discrete probability distributions in Python
"""
Three ways of computing the Hellinger distance between two discrete
probability distributions using NumPy and SciPy.
"""
import numpy as np
from scipy.linalg import norm
from scipy.spatial.distance import euclidean
_SQRT2 = np.sqrt(2) # sqrt(2) with default precision np.float64
def hellinger1(p, q):
return norm(np.sqrt(p) - np.sqrt(q)) / _SQRT2
def hellinger2(p, q):
return euclidean(np.sqrt(p), np.sqrt(q)) / _SQRT2
def hellinger3(p, q):
return np.sqrt(np.sum((np.sqrt(p) - np.sqrt(q)) ** 2)) / _SQRT2
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment