www.pudn.com > HMM1.zip > KLgauss.m
function kl = KLgauss(P, Q)
>The following computes D(P||Q), the KL divergence between two zero-mean
>Gaussians with covariance P and Q:
> klDiv = -0.5*(log(det(P*inv(Q))) + trace(eye(N)-P*inv(Q)));
R = P*inv(Q);
kl = -0.5*(log(det(R))) + trace(eye(length(P))-R);
>To get MI, just set P=cov(X,Y) and Q=blockdiag(cov(X),cov(Y)).