我正在研究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工具的选项......但是哪个工具和哪个选项?)
任何有用的想法都将受到高度赞赏。
答案 0 :(得分:0)
为了使用-p选项,您需要提供类别的标签列表而不是您的HMM,(例如,如果您尝试识别单词是,否,从不),那么您的&#34 ; HMMsList"文件应写为:
Yes
No
Never
无论真正构成单词的HMM如何。 你的" HMMsList"文件应该是" LabelsList"