NLP模型也有“老师”了!装上这个开源库,1毫秒纠正语法错误

导读:杨净 发自 凹非寺 量子位 报道 | 公众号 QbitAI 当NLP模型产生了语法错误,怎么办? 比如,He wants that you send him an email. 没关系,现在可以像小时候的英语老师,改作文一样简单。 只要装上一个专门纠正语法错误的库就可以,还是毫秒钟就可揪出来的那...

杨净 发自 凹非寺

量子位 报道 | 公众号 QbitAI

当NLP模型产生了语法错误,怎么办?

比如,He wants that you send him an email.

没关系,现在可以像小时候的英语老师,改作文一样简单。

只要装上一个专门纠正语法错误的库就可以,还是毫秒钟就可揪出来的那种。

这不,把“that”改成“to”不就可以了吗~

纠正过来就是:

He wants you to send him an email.

(不会真有人看不出其中的语法错误吧)

再比如这句。

I can due his homework.

应该变成:I can do his homework.

好像这些语法错误,都有点太过明显了。那就来复杂一点的。

Thanks for your’s and Lucy’s help.

系统就会改成:

Thanks for yours and Lucy’s help.

这就是最近一位AI专业本科生Benjamin Minixhofer,利用假期时间开发出来的一款快速纠正语法错误的库NLPRule。

它是由Rust编写的一个基于LanguageTool语法规则的逆向工程。

LanguageTool是一款开放源代码校对软件,适用于英语,法语,德语,波兰语,俄语以及20多种其他语言,它可以发现许多拼写检查器无法检测到的错误。

一经发出,就在Reddit上获得了200+的热度。

如何实现?

NLPRule是将语法规则与ML模型结合起来,主要应用于NLP的预处理和NLG的后处理。

在作者看来,使用基于语法规则的方法有两大优势。

一是速度。作者使用第8代英特尔,纠正一个句子只需要不到1毫秒的时间。

二是语法错误的训练数据极度稀少,ML模型无法处理。

比如,就像这句“It is enough for all intensive purposes. ”

就包含了一个错误。除非特别说明,ML模型基本上不能纠正这个错误,因为它几乎不会出现在其训练数据当中。

而若是放在其他语言数据中,肯定会比英语更少。

比如,中文。

作者创建这个库的目的在于创建一个快速、轻量级的引擎来运行自然语言规则,无需依赖JVM(Java虚拟运行环境)速度、内存的影响。

目前,这个库支持英语和德语。

具体安装可分成如下四个步骤,详细可戳文末链接。

在GPT-2进行文本测试

接着,作者就尝试用GPT-2生成的文本来测试,结果产生了大量的改进建议。

比如语法错误。

Before: …t out, as a condition of its being operated. Each lock keeper should ensure >that all locks are operated and tha…

After: …t out, as a condition of its being operated. Each lockkeeper should ensure that all locks are operated and tha…

Message: This noun is normally spelled as one word.

Type: grammar

再比如拼写错误。

Before: …he Z-machine version (in the standardised format) is comprised of 32 (in total) >bytes, one per line. …

After: …he Z-machine version (in the standardised format) comprises 32 (in total) bytes, one per line. …

Message: Did you mean comprises or consists of or is composed of?

Type: misspelling

一经发出,不少网友直呼:Fantastic!

也有网友想到,如果跟BERT或者其他Transformer模型结合起来,会不会生成更好的句子呢?

想要了解更多细节,呐~传送门送上!

参考链接:

https://www.reddit.com/r/MachineLearning/comments/kzuaie/p_i_made_nlprule_a_lipary_for_fast_grammatical/

GitHub网址:https://github.com/bminixhofer/nlprule