⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hmminit.m

📁 HMMBOX, version 3.2, William Penny, Imperial College, Feb 1999 Matlab toolbox for Hidden Markov Mod
💻 M
字号:
function [hmm] = hmminit (X,hmm,covtype,gamma)% function [hmm] = hmminit (X,hmm,covtype,gamma)%% Initialise Gaussian observation HMM model % using a static Gaussian Mixture Model (using NetLab routines)%% X		N x p data matrix% hmm		hmm data structure% covtype	'full' or 'diag' covariance matrices% gamma		weighting of each of N data points %		(default is 1 for each data point)N=size(X,1);if nargin < 4 | isempty(gamma), gamma=ones(N,1); endp=size(X,2);mix=gmm(p,hmm.K,covtype);options=foptions;options(14) = 5; % Just use 5 iterations of k-means initialisationmix = gmminit(mix, X, options);options = zeros(1, 18);options(1)  = 0;                % Prints out error values.% Termination criteriaoptions(3) = 0.000001;          % tolerance in likelihoodoptions(14) = 100;              % Max. Number of iterations.% Reset cov matrix if singular values become too smalloptions(5)=1;              [mix, options, errlog] = wgmmem(mix, X, gamma,options);hmm.gmmll=options(8);     % Log likelihood of gmm modelfor k=1:mix.ncentres;  hmm.state(k).Mu=mix.centres(k,:);  hmm.state(k).covtype=covtype;  switch covtype   case 'full',    hmm.state(k).Cov=squeeze(mix.covars(:,:,k));    hmm.init_val(k).Cov = hmm.state(k).Cov; % In case we need to re-init   case 'diag',    hmm.state(k).Cov=diag(mix.covars(k,:));    hmm.init_val(k).Cov = hmm.state(k).Cov; % In case we need to re-init   otherwise,          disp('Unknown type of covariance matrix');  endendhmm.train.init='gmm';hmm.mix=mix;

⌨️ 快捷键说明

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