condgausstrainobserved.m

来自「KPMstats is a directory of miscellaneous」· M 代码 · 共 28 行

M
28
字号
function [mu, Sigma] = mixgaussTrainObserved(obsData, hiddenData, nstates, varargin);
% mixgaussTrainObserved Max likelihood estimates of conditional Gaussian from raw data
% function [mu, Sigma] = mixgaussTrainObserved(obsData, hiddenData, nstates, ...);
%
% Input:
% obsData(:,i)
% hiddenData(i)  - this is the mixture component label for example i
% Optional arguments - same as mixgauss_Mstep
%
% Output:
% mu(:,q)
% Sigma(:,:,q) - same as mixgauss_Mstep

[D numex] = size(obsData);
Y = zeros(D, nstates);
YY = zeros(D,D,nstates);
YTY = zeros(nstates,1);
w = zeros(nstates, 1);
for q=1:nstates
  ndx = find(hiddenData==q);
  w(q) = length(ndx); % each data point has probability 1 of being in this cluster
  data = obsData(:,ndx);
  Y(:,q) = sum(data,2);
  YY(:,:,q) = data*data';
  YTY(q) = sum(diag(data'*data));
end
[mu, Sigma] = mixgauss_Mstep(w, Y, YY, YTY, varargin{:});

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?