`

正确地猜测用户的意图

阅读更多

当我们在Collins词典中输入“voilent”的时候,会有如下提示:

当我们在Google中搜索“voilent”的时候,也会有如下提示:

Collins和Google是如何做到的呢?它是怎么知道我们把i和o的位置弄反了呢?

当我们输入一个词,而这个词不存在于Google的倒排索引或者Collins的词典中时,我们就可以假设用户输入可能有误,接着我们通过算法找出一个和用户的输入最相似的词推荐给用户,这个找出和用户输入最相似的词的算法有很多种,最常用的有编辑距离算法(Edit Distance),因为这个算法是俄罗斯科学家Vladimir Levenshtein在1965年提出的,所以编辑距离(Edit Distance)又叫做Levenshtein距离。

编辑距离算法是指两个字串之间,由一个转成另一个所需的最少编辑操作次数,允许的编辑操作包括将一个字符替换成另一个字符,增加一个字符,删除一个字符。

例如将kitten转成sitting: 

sitten (k→s)将一个字符k替换成另一个字符s

sittin  (e→i) 将一个字符e替换成另一个字符i

sitting (→g) 增加一个字符g

所以编辑距离为3,word分词提供了编辑距离算法的Java代码实现,同时superword项目也演示了编辑距离算法对于单词记忆的辅助作用

 

下面我们看看中文的情况,当我们在Google搜索“热挨”的时候,Google在倒排索引中找不到“热挨”这个词,于是它猜测我们真正想搜索的是“热爱”,那么Google是怎么猜测到我们的意图的呢?

工作原理和上面介绍的英文词比较相似,只是算法不一样,如果把编辑距离算法应用到这里,效果会很差,那么怎么办呢?

解决方法是利用汉语的同音词原理,先把“热挨”转换为拼音“reai”,然后找出所有拼音为“reai”的双字词,在按照词的出现频率取频率最大者“热爱”。

 

更多资料:

How to Write a Spelling Corrector

Using the Web for Language Independent Spellchecking and Autocorrection

How Difficult is it to Develop a Perfect Spell-checker A Cross-linguistic Analysis through Complex Network Approach

 

 

 

 

 

1
0
分享到:
评论

相关推荐

    ChatGPT技术对于意图识别与槽位填充的支持程度分析.docx

    当用户输入一个问题或者请求时,ChatGPT 可以根据其预训练模型中的知识进行推理和判断,猜测用户的意图。 其次,ChatGPT 还可以通过上下文信息来帮助意图识别。在对话过程中,ChatGPT 可以根据上一轮对话内容进行...

    ChatGPT 对非流畅输入的响应行为研究.docx

    当模型无法理解用户意图时,它可能会尝试猜测用户的意图并给出一个不确定的回答。 3. 完全错误的回答。在面对非流畅输入时,ChatGPT 可能生成与用户问题完全无关的回复。 为了解决 ChatGPT 对于非流畅输入的挑战,...

    ChatGPT技术如何应对用户的错误输入与打字错误.docx

    例如,当用户输入含义不清晰或者存在歧义的句子时,ChatGPT 可以通过之前的对话内容来进行推断和猜测,从而给出更合理的响应。 3. 通过追问和确认来解决用户输入错误带来的问题:ChatGPT 可以主动向用户询问更多...

    XP全拼输入法

    - **拼音纠错**:即使输入错误的拼音,输入法也能尝试猜测用户意图并提供正确的候选词。 4. 更新与优化: 随着时间的发展,虽然Windows XP系统已经逐渐被淘汰,但XP全拼输入法仍有一定的用户群体。开发者可能对...

    很简易的密码查看器密码查看器

    然而,在某些情况下,用户可能会遇到忘记自己密码的情况,或者需要确认自己输入的密码是否正确。为了应对这种需求,一种名为“很简易的密码查看器”的工具应运而生。正如其名称所暗示的,这款工具的出现是为了帮助...

    猜数字功能、

    在这个循环中,程序会不断接收用户的猜测并进行比较。根据猜测结果,我们可以给出提示,如“猜大了”、“猜小了”或者“恭喜,你猜对了”。C++的`while`或`do-while`循环可以很好地实现这一功能: ```cpp while ...

    蓝桥杯EV3竞赛试题“猜数字”

    3. **逻辑控制**:程序需要包含一系列的逻辑判断,比如判断用户猜测的数字是否正确,或者与目标数字的大小关系,这些都需要通过if-else语句来实现。 4. **数据处理**:参赛者需要学会如何存储和处理用户输入的数字...

    T9输入法源码,够详细

    这种输入法的核心在于其智能预测和自动完成功能,它允许用户只需按每个字母一次,即使这些字母在同一个数字键上,系统也能根据上下文猜测并显示最有可能的词汇。 T9输入法的源码分析是一个深入理解计算机科学、算法...

    Launchy使用说明

    它通过智能搜索功能来猜测用户想要启动的程序或文件,并在按下回车键后立即启动。 #### 二、Launchy 的由来与背景 **Launchy**最初是由Josh Karlin为其个人使用而开发的。随着他和他的朋友们越来越依赖这款软件,...

    python猜数字游戏-09-函数的说明文档.ev4.rar

    3. **条件语句**:`if`和`else`语句用于检查用户输入是否正确,以及给出相应的反馈。 4. **用户输入处理**:使用`input()`函数获取用户的猜测,并进行类型转换(如`int()`),确保数据类型匹配。 5. **错误处理**:...

    q-behave:Arduino 机器学习库

    以传统方式,系统不能被编程来猜测用户对显示哪种颜色的意图。 当我们将 Q-Behave 作为交互(按下按钮)和状态(使二极管闪烁)之间的处理器时,设备将根据从用户交互中获得的先前经验选择一种可能的状态。 因此,...

    Web-Information-Management-Projects:该存储库包含在UCLA CS246课程中完成的项目

    在拼写检查器的帮助下,搜索引擎将尝试猜测用户的意图,并建议用户键入的任何内容都可能是正确的拼写。 在该项目中,探索了实现基本拼写检查器的不同方法。 项目4:该项目的主要目标是学习如何使用通用软件工具...

    cpp-didyoumean你是什么意思根据属性提供良好的错误提示

    "did you mean" 这个概念来源于很多现代编程环境,当用户输入的命令或者函数名有拼写错误时,它们会尝试猜测用户的意图并给出更正建议。例如,如果你尝试调用一个不存在的函数 "functoin()",编译器可能会提示 "did ...

    如何编写高质量“软件需求说明书”

    1. **正确性**:每个需求必须准确反映客户的真实意图,与系统的高级需求保持一致。需求的正确性通常由用户代表或其代理人来确认。在审查需求时,用户参与是至关重要的,避免开发人员的主观猜测。 2. **可行性**:...

    PowerSurfacing教程.pdf

    用户可以使用这些命令来生成3D模型的各个部分,并确保它们正确地连接和融合。 5. Sub-D细分级别 提到的SubD45、SubDOverrideSampleDensity等词汇涉及的是Sub-D模型的细分级别,这是Sub-D技术的核心概念。细分级别...

    CurrentlyLiving

    在压缩包文件"354"中,虽然没有具体的文件名,但我们可以猜测这可能包含了一些字体文件、设计示例、源代码或者是关于"CurrentlyLiving"项目的文档。为了深入理解这个项目,我们需要解压文件并检查其内容,了解设计...

    简单的android闹钟源代码.zip

    通过这个名字,我们可以猜测应用可能结合了定时器和传统闹钟功能,帮助用户提高工作效率。 总之,这个简单的Android闹钟源代码项目涵盖了Android应用开发的基础,包括组件通信、系统服务交互、用户界面设计和事件...

    Drivecon变频器说明书VF61说明书(英文).pdf

    ”、“(cid:26)#”、“(cid:26)%”、“(cid:26)’”、“(cid:26)(cid:3)”、“(cid:26)+(cid:26)”这些符号和乱码可能是扫描错误的结果,需要用户根据上下文来合理猜测和解读。同时,“(cid:18)(cid:7)(cid:15)(cid:...

    单元19我在哪里.pdf

    - 阅读和理解这类技术文档时,需要对专业知识有一定了解,才能确保正确理解文档意图传达的信息。 综合上述信息,文件内容很可能涉及GPS定位系统以及如何利用该系统来确定特定位置的教程或说明文档。考虑到OCR技术...

    动软Mysql注释生成的插件.dll.zip

    它们能够详细说明数据库对象如表、字段等的设计意图和用途,有助于避免代码随时间推移而变得难以理解。因此,这类工具对于数据库开发者和数据库管理员来说是非常有价值的。 结合描述信息中的“覆盖根目录”这一指令...

Global site tag (gtag.js) - Google Analytics