gpt4 book ai didi

java - Peter Norvig 的多词匹配拼写检查器

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:05:31 26 4
gpt4 key购买 nike

Peter Norvig 的著名作品 spellchecker (Java 8 版本 here )能够纠正单个单词,如果训练数据中出现与该单词接近的内容。但是我该如何调整它来处理整个短语。例如,如果我有一个文件,其中每个短语都用换行符分隔:

Plastic box
Pencils and sketch
Romeo and Juliet
.
.
.

如果我告诉算法更正 'Platic',它应该返回 'Plastic box'。同样,如果我告诉它更正 'Pencils',它应该返回 'Pencils and sketch'

我尝试更改上面代码的以下几行(Java 版本):

Stream.of(new String(Files.readAllBytes( dictionaryFile )).toLowerCase().replaceAll("[^a-z ]","").split(" ")).forEach( (word) ->{
dict.compute( word, (k,v) -> v == null ? 1 : v + 1 );
});

 Stream.of(new String(Files.readAllBytes( dictionaryFile )).toLowerCase().split("\n")).forEach( (word) ->{
dict.compute( word, (k,v) -> v == null ? 1 : v + 1 );
});

但似乎没有用。

最佳答案

如果你仔细查看 Norvig 的拼写检查器,你会发现作为错误模型,他使用了 edit distance 1 和 2 处的单词拼错的单词因此,如果您想使用文件 big.text 作为字典来更正 Platic,它可以找到编辑距离为 2 的单词 Elastic作为候选正确词。

现在,使用您修改后的代码,短语 Plastic box 与单词 Platic 的编辑距离不在 2 以内,它甚至不会被视为候选词错误模型,这就是它不起作用的原因。

例如,它们之间的编辑距离为 5,那么您必须实现函数 edit3edit4edit5 才能使其工作,这将需要考虑数百万个单词并且效率很低。

相反,我认为你可以考虑 bigram language model 并且尽管为拼错的单词返回一个可能的候选词,你可以返回最有可能的 bigram短语,取决于字典中的出现概率,使用语言模型 P(塑料盒)=P(Plastic)*P(box|Plastic) 和候选短语的概率a P(Plastic box)*P( Platic|Plastic Box)Bayes公式,如果您有一个错误模型`到位(或者您有数据可以学习)。

关于java - Peter Norvig 的多词匹配拼写检查器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41987840/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com