annotate toolboxes/FullBNT-1.0.7/bnt/examples/static/Zoubin/mfa_cl.m @ 0:cc4b1211e677 tip

initial commit to HG from Changeset: 646 (e263d8a21543) added further path and more save "camirversion.m"
author Daniel Wolff
date Fri, 19 Aug 2016 13:07:06 +0200
parents
children
rev   line source
Daniel@0 1 % function [lik, likv]=mfa_cl(X,Lh,Ph,Mu,Pi);
Daniel@0 2 %
Daniel@0 3 % Calculates log likelihoods of a data set under a mixture of factor
Daniel@0 4 % analysis model.
Daniel@0 5 %
Daniel@0 6 % X - data matrix
Daniel@0 7 % Lh - factor loadings
Daniel@0 8 % Ph - diagonal uniquenesses matrix
Daniel@0 9 % Mu - mean vectors
Daniel@0 10 % Pi - priors
Daniel@0 11 %
Daniel@0 12 % lik - log likelihood of X
Daniel@0 13 % likv - vector of log likelihoods
Daniel@0 14 %
Daniel@0 15 % If 0 or 1 output arguments requested, lik is returned. If 2 output
Daniel@0 16 % arguments requested, [lik likv] is returned.
Daniel@0 17
Daniel@0 18 function [lik, likv]=mfa_cl(X,Lh,Ph,Mu,Pi);
Daniel@0 19
Daniel@0 20 N=length(X(:,1));
Daniel@0 21 D=length(X(1,:));
Daniel@0 22 K=length(Lh(1,:));
Daniel@0 23 M=length(Pi);
Daniel@0 24
Daniel@0 25 if (abs(sum(Pi)-1) > 1e-6)
Daniel@0 26 disp('ERROR: Pi should sum to 1');
Daniel@0 27 return;
Daniel@0 28 elseif ((size(Lh) ~= [D*M K]) | (size(Ph) ~= [D 1]) | (size(Mu) ~= [M D]) ...
Daniel@0 29 | (size(Pi) ~= [M 1] & size(Pi) ~= [1 M]))
Daniel@0 30 disp('ERROR in input matrix sizes');
Daniel@0 31 return;
Daniel@0 32 end;
Daniel@0 33
Daniel@0 34 tiny=exp(-744);
Daniel@0 35 const=(2*pi)^(-D/2);
Daniel@0 36
Daniel@0 37 I=eye(K);
Daniel@0 38 Phi=1./Ph;
Daniel@0 39 Phid=diag(Phi);
Daniel@0 40 for k=1:M
Daniel@0 41 Lht=Lh((k-1)*D+1:k*D,:);
Daniel@0 42 LP=Phid*Lht;
Daniel@0 43 MM=Phid-LP*inv(I+Lht'*LP)*LP';
Daniel@0 44 dM=sqrt(det(MM));
Daniel@0 45 Xk=(X-ones(N,1)*Mu(k,:));
Daniel@0 46 XM=Xk*MM;
Daniel@0 47 H(:,k)=const*Pi(k)*dM*exp(-0.5*sum((XM.*Xk)'))';
Daniel@0 48 end;
Daniel@0 49
Daniel@0 50 Hsum=rsum(H);
Daniel@0 51
Daniel@0 52 likv=log(Hsum+(Hsum==0)*tiny);
Daniel@0 53 lik=sum(likv);
Daniel@0 54