ml-distance
Version:
Distance and similarity functions to compare vectors
21 lines (20 loc) • 560 B
text/typescript
import { NumberArray } from 'cheminfo-types';
/**
*Returns the Jensen difference distance between vectors a and b
* @link [Jensen difference algorithm](https://www.naun.org/main/NAUN/ijmmas/mmmas-49.pdf)
* @param a - first vector
* @param b - second vector
*
*/
export default function jensenDifference(
a: NumberArray,
b: NumberArray,
): number {
let ans = 0;
for (let i = 0; i < a.length; i++) {
ans +=
(a[i] * Math.log(a[i]) + b[i] * Math.log(b[i])) / 2 -
((a[i] + b[i]) / 2) * Math.log((a[i] + b[i]) / 2);
}
return ans;
}