forked from luxiaoxun/KMeans-GMM-HMM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCHMM.h
67 lines (53 loc) · 1.82 KB
/
CHMM.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/***************************************************************************
Module Name:
Continuous Observation Hidden Markov Model with Gaussian Mixture
History:
2003/12/13 Fei Wang
2013 luxiaoxun
***************************************************************************/
#pragma once
#include <vector>
#include "GMM.h"
class CHMM
{
public:
CHMM(int stateNum = 1, int dimNum = 1, int mixNum = 1);
~CHMM();
int GetStateNum() { return m_stateNum; }
int GetMaxIterNum() { return m_maxIterNum; }
double GetEndError() { return m_endError; }
void SetMaxIterNum(int n) { m_maxIterNum = n; }
void SetEndError(double e) { m_endError = e; }
GMM* GetStateModel(int i);
double GetStateInit(int i);
double GetStateFinal(int i);
double GetStateTrans(int i, int j);
void Zero();
void Norm();
double GetProbability(std::vector<double*>& seq);
//Viterbi Decode
double Decode(std::vector<double*>& seq, std::vector<int>& state);
/* SampleFile: <size><dim><seq_size><seq_data>...<seq_size><seq_data>...
size: number of samples
dim: dimension of feature
seq_size: number of each sample's feature
*/
void Train(const char* sampleFileName);
void Init(const char* sampleFileName);
double getTransProb(int i,int j);
friend std::ostream& operator<<(std::ostream& out, CHMM& hmm);
friend std::istream& operator>>(std::istream& in, CHMM& hmm);
//将特征数据文本文件转化为二进制文件
void TextTransform(const char* InputText, const char * OutputBinaryText);
private:
int m_stateNum; //状态数
GMM** m_stateModel; //高斯混合模型
double* m_stateInit; //状态初始概率
double** m_stateTran; //状态转移概率
int m_maxIterNum; // 最大迭代次数
double m_endError;
void Allocate(int state, int dim = 1, int mix = 1);
void Dispose();
double LogProb(double p);
void DumpSampleFile(const char* fileName);
};