view toolboxes/FullBNT-1.0.7/bnt/potentials/@cpot/cpot_to_mpot.m @ 0:e9a9cd732c1e tip

first hg version after svn
author wolffd
date Tue, 10 Feb 2015 15:05:51 +0000
parents
children
line wrap: on
line source
function mom = cpot_to_mpot(can)
% CPOT_TO_MPOT Convert a canonical potential to moment form.
% mom = cpot_to_mpot(can)

[logp, mu, Sigma] = canonical_to_moment(can.g, can.h, can.K);
mom = mpot(can.domain, can.sizes, logp, mu, Sigma);

%%%%%%%

function [logp, mu, Sigma] = canonical_to_moment(g, h, K)
% CANONICAL_TO_MOMENT Convert canonical characteristics to moment form.
% [logp, mu, Sigma] = canonical_to_moment(g, h, K)

n = length(K);
if isempty(K)
  logp = g - 0.5*(log(det(K)) - n*log(2*pi));
  Sigma = [];
  mu = [];
else
  if det(K)==0
    Sigma = inf*ones(n,n);
    mu = zeros(n,1); % if the precision is zero, the mean is arbitrary
    logp = g; % the scaling factor for the uniform distribution is 1
  else
    Sigma = inv(K);
    mu = Sigma*h;
    logp = g - 0.5*(log(det(K)) - n*log(2*pi) - mu'*K*mu);
  end
end