python语言模型工具_语言模型kenlm的训练及使用

本文介绍了如何使用kenlm工具训练n-gram语言模型,详细讲解了arpa文件的内容及其在概率计算中的作用,包括一元、二元、三元组的概率计算,并探讨了困惑度作为衡量指标的应用。
摘要由CSDN通过智能技术生成

一、背景

近期研究了一下语言模型,同事推荐了一个比较好用的工具包kenlm,记录下使用过程。

二、使用kenlm训练 n-gram

1.工具介绍:http://kheafield.com/code/kenlm/

3.解压后运行,./bjam 进行编译

4.使用如下命令进行训练:bin/lmplz -o 5 --verbose_header --text data/chat_log.txt --arpa result/log.arpa --vocab_file result/log.vocab

备注:4.1 文件必须是分词以后的文件。

4.2 -o后面的5表示的是5-gram,一般取到3即可,但可以结合自己实际情况判断。

三、使用kenlm判断一句话概率

使用kenlm主要就是对arpa文件内容的运行,下面解析下该文件的内容。

1.arpa文件

\1-grams:

-6.55140920

0-2.9842114

-1.85864340

-2.88382!-2.38764

-2.94351world-0.514311

-2.94351hello-0.514311

-6.09691guys-0.15553

\2-grams:

-3.91009world !-0.351469

-3.91257hello world-0.24

-3.87582hello guys-0.0312

\3-grams:

-0.00108858hello world !

-0.000271867, hi hello !

\end\

1.1 介绍

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值