使用HResults HTK Tool生成混淆矩阵,用于手写识别ICFHR的示例

时间:2015-04-01 07:26:11

标签: htk

我正在研究HTK Tools如何使用手写识别。在ICFHR–2010 TUTORIAL之后,我运行了“西班牙语 - 数字”语料库的示例并收到了生成的HMM(文件夹存储在文件夹hmm中并列在HMMsList中),res32.mlf收到了包含的识别结果HVite。我还有主标签文件SamplesRef.mlf。 现在我想查看识别结果统计数据,即研究HResults工具。

当我将HResults作为

运行时
 HResults -I SamplesRef.mlf HMMsList res32.mlf

我看到了

====================== HTK Results Analysis =======================
  Date: Tue Mar 31 15:21:11 2015
  Ref : SamplesRef.mlf
  Rec : res32.mlf
------------------------ Overall Results --------------------------
 SENT: %Correct=0.00 [H=0, S=2, N=2]
 WORD: %Corr=77.78, Acc=77.78 [H=7, D=0, S=2, I=0, N=9]
===================================================================

但是如果我添加选项-p以便有混淆矩阵,我会看到以下错误消息:

~/icfhr$ HResults -p -I SamplesRef.mlf HMMsList res32.mlf
 ERROR [+3331]  Index: Label millones not in list[0 of 19]
FATAL ERROR - Terminating program HResults

我理解该消息意味着没有名称为“millones”的HMM,我发现在我的res32.mlf样本中看起来像:

"’*’/210341.rec"
mil
seiscientos
cincuenta
y
siete
millones
.

如果我使用文字编辑器将res32.mlf更改为res33.mlf,内容如下:

"’*’/210341.rec"
m
i
l
s
e
i
s
c
i

......等等。

使用samples.mlf(而不是SamplesRef.mlf)里面的内容如下:

"*/210341.lab"
m
i
l
@
q
u
i
n
i
e
n
t
o
s
@
c

......等等。

我有理想的结果:

~/icfhr$ HResults -p -I samples.mlf HMMsList res33.mlf
====================== HTK Results Analysis =======================
  Date: Tue Mar 31 15:35:42 2015
  Ref : samples.mlf
  Rec : res33.mlf
------------------------ Overall Results --------------------------
SENT: %Correct=0.00 [H=0, S=2, N=2]
WORD: %Corr=79.63, Acc=77.78 [H=43, D=5, S=6, I=1, N=54]
------------------------ Confusion Matrix -------------------------
       a   c   d   e   i   l   m   n   o   s   t   u   v   y  Del [ %c / %e]
   @   0   0   0   0   0   1   1   0   0   0   0   0   0   0    5 [ 0.0/3.7]
   a   2   0   0   0   0   0   0   0   0   0   0   0   0   0    0
   c   0   2   0   0   0   0   0   0   0   0   0   0   0   0    0
   d   0   0   1   0   0   0   0   0   0   0   0   0   0   0    0
   e   0   0   0   6   0   0   0   0   0   0   0   0   0   0    0
   i   0   0   0   0   6   0   0   0   0   0   0   0   0   0    0
   l   0   0   0   0   0   3   0   0   0   0   0   0   0   0    0
   m   0   0   0   0   0   0   2   0   0   0   0   0   0   0    0
   n   0   1   0   0   0   0   0   6   0   0   0   0   0   0    0 [85.7/1.9]
   o   0   0   0   0   0   0   0   0   4   0   0   0   0   0    0
   q   0   0   0   0   0   0   0   0   0   1   0   0   0   0    0 [ 0.0/1.9]
   s   0   0   0   0   0   0   0   0   0   4   0   0   0   0    0
   t   0   0   0   0   0   0   0   0   0   0   4   0   0   0    0
   u   0   0   0   1   0   0   0   0   0   0   0   1   0   0    0 [50.0/1.9]
   v   0   0   0   0   0   0   0   0   0   0   0   0   1   0    0
   y   0   0   0   0   1   0   0   0   0   0   0   0   0   1    0 [50.0/1.9]
Ins    0   0   0   0   0   0   0   0   0   1   0   0   0   0
===================================================================

所以,主要问题是:

最简单的方法(没有文本编辑器)使mlf文件适合制作混淆矩阵?

(我想我错过了一些HTK工具的选项......但是哪个工具和哪个选项?)

任何有用的想法都将受到高度赞赏。

1 个答案:

答案 0 :(得分:0)

为了使用-p选项,您需要提供类别的标签列表而不是您的HMM,(例如,如果您尝试识别单词是,否,从不),那么您的&#34 ; HMMsList"文件应写为:

Yes
No
Never

无论真正构成单词的HMM如何。 你的" HMMsList"文件应该是" LabelsList"