TJU自然语言处理(5):词义消岐

2023-10-31 15:11

本文主要是介绍TJU自然语言处理(5):词义消岐,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

TJU自然语言处理(5):词义消岐

  • 定义
  • 预备知识
    • 有监督学习
    • 无监督学习
    • 现实情况
    • 伪词
    • 算法的上界和下界
  • 基于贝叶斯分类的词义消歧
  • 基于互信息的WSD方法
      • flip-flop算法
  • 贝叶斯和互信息算法的比较
  • 基于词典的消岐
  • 基于义类词典的消岐
  • 语义消岐的两个约束
  • 有监督词义消岐小结

定义

语义歧义:很多词语具有几个意思或语义,如果将这样的词从上下文中独立出来,就会产生语义歧义。就是必须通过其语境来确定其含义的词汇。

比如:生意清淡和口味清淡。
语义消岐(WSD):确定一个歧义词的哪一种语义在一个特殊的使用环境中被调用。
WSD需要解决的三个问题:

  1. 如何判断一个词是不是多义词
  2. 对每个需要进行义项标注处理的多义词,预先得有关于它的各个不同义项的清晰的区分标准,也即如何表示一个多义词的不同意思
  3. 对出现在具体语境中的每个多义词,给它确定一个合适的义项

我们通过一个词周围的搭配词,即上下文语境来了解意义。

预备知识

有监督和无监督学习
算法性能的上界和下界

有监督学习

  1. 训练数据已知(语义标注)
  2. 分类任务
  3. 函数拟合(function-fitting):基于一些数据点推断出函数的形态

无监督学习

  1. 训练数据的分类未知
  2. 聚类任务(clustering task)

现实情况

  1. 从未标注数据中学习
  2. 使用多种知识源
  3. 建立种子集→从未标注数据中学习→扩大种子集→获取大规模标注语料

伪词

在测试数据难以获得的情况下,可方便地产生一些人工数据,用来比较和提高算法性能。在语义消歧的情况下,这些人工数据称为伪词。

  • 例如,合并两个或多个自然词汇,
    创建伪词banana-door,代替语料库中出现的所有banana和door

这样做的意义在于:既回避了手工标注的困难,又可以为消歧问题轻松创建大规模的训练和测试数据。即带有伪词的文本作为歧义文本,最初的文本作为消歧后的文本。

算法的上界和下界

上界通常指人工效能。
下界通常指可能的最简单算法的效能。

基于贝叶斯分类的词义消歧

基本思想:
在这里插入图片描述
在这里插入图片描述

基于互信息的WSD方法

要判断多义词在具体语境下的意义,关键是找到能够指示该多义词意义的示意特征(indicator)。
例如:
在这里插入图片描述

flip-flop算法

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

贝叶斯和互信息算法的比较

  • 相同之处:都需要事先进行义项标注的语料库进行训练。
  • 不同之处1:对语境的理解不同,贝叶斯是大语境下,而互信息是小语境
  • 不同之处2:对训练语料库的要求不同,贝叶斯不需要标注结构信息,而根据训练目标,需要标注更多信息。

基于词典的消岐

算法描述:在这里插入图片描述
简单的说就是一个多义词中都多个释义,每个释义都会有一个解释。而特征词也会有释义,就比较一下,特征词释义解释和多义词释义解释中相同的多少来找出得分最大的就是义项了。下面是一个典型的例子。在这里插入图片描述
方法总结:
用词典资源进行词义排歧,是利用词典中对多义词的各个义项的描写,而这些描写是在语言学家观察了多义词的不同使用情况后概括归纳,抽象总结的结果。只不过跟实际语料不同的是,它是以一种概括的方式在描写词义,而语料库是以具体可感知的大量重复的实例本身在描写词义。
由于词典释义的概括性,这种方法应用于实际语料中多义词的排歧,效果不理想。

基于义类词典的消岐

原理:上下文中词汇的语义范畴大体上确定了此上下文的语义范畴,且上下文的语义范畴可以反过来确定词汇的哪一个语义被使用。

英语词“crane”有两个意思,一是指“吊车”,一是指“鹤”。前者属于“工具/机械”这个义类;后者属于“动物”这个义类。如果能够确定“crane”出现在具体语境中时属于哪个义类,实际上也就知道了“crane”的义项。

  • 收集数据:对Roget词典中每个义类(共1041个类)中所有的词,收集包含这些词的上下文C(每个词的上下文长度为前后100个词)作为训练数据。
  • 在这里插入图片描述
  • 在这里插入图片描述
    总结:是对一个多义词所处语境的“主题领域”的猜测,假定如果当前主题领域猜对了,该多义词的义项也能判定正确
    对训练语料库不需要事先标注
    对义项区别依赖大语境的多义词效果较好(比如名词);对那些不依靠大语境提示词义的多义词效果较差(比如动词和形容词)

语义消岐的两个约束

  • 每篇文本一个语义:在任意给定的文本中目标词语义有很强的一致性。可以抵消信息不足和误导信息带来的影响。
  • 每个搭配一个语义:根据和目标词之间的相对距离、次序和句法关系,相邻词提供了可用于判断目标词语义的很多线索信息。

有监督词义消岐小结

在这里插入图片描述
在这里插入图片描述

这篇关于TJU自然语言处理(5):词义消岐的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/zero_taeyeon/article/details/121066848
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/316239

相关文章

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

Python处理大量Excel文件的十个技巧分享

《Python处理大量Excel文件的十个技巧分享》每天被大量Excel文件折磨的你看过来!这是一份Python程序员整理的实用技巧,不说废话,直接上干货,文章通过代码示例讲解的非常详细,需要的朋友可... 目录一、批量读取多个Excel文件二、选择性读取工作表和列三、自动调整格式和样式四、智能数据清洗五、

SpringBoot如何对密码等敏感信息进行脱敏处理

《SpringBoot如何对密码等敏感信息进行脱敏处理》这篇文章主要为大家详细介绍了SpringBoot对密码等敏感信息进行脱敏处理的几个常用方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录​1. 配置文件敏感信息脱敏​​2. 日志脱敏​​3. API响应脱敏​​4. 其他注意事项​​总结

Python使用python-docx实现自动化处理Word文档

《Python使用python-docx实现自动化处理Word文档》这篇文章主要为大家展示了Python如何通过代码实现段落样式复制,HTML表格转Word表格以及动态生成可定制化模板的功能,感兴趣的... 目录一、引言二、核心功能模块解析1. 段落样式与图片复制2. html表格转Word表格3. 模板生

Python Pandas高效处理Excel数据完整指南

《PythonPandas高效处理Excel数据完整指南》在数据驱动的时代,Excel仍是大量企业存储核心数据的工具,Python的Pandas库凭借其向量化计算、内存优化和丰富的数据处理接口,成为... 目录一、环境搭建与数据读取1.1 基础环境配置1.2 数据高效载入技巧二、数据清洗核心战术2.1 缺失

SpringBoot项目中Redis存储Session对象序列化处理

《SpringBoot项目中Redis存储Session对象序列化处理》在SpringBoot项目中使用Redis存储Session时,对象的序列化和反序列化是关键步骤,下面我们就来讲讲如何在Spri... 目录一、为什么需要序列化处理二、Spring Boot 集成 Redis 存储 Session2.1

Python处理超大规模数据的4大方法详解

《Python处理超大规模数据的4大方法详解》在数据的奇妙世界里,数据量就像滚雪球一样,越变越大,从最初的GB级别的小数据堆,逐渐演变成TB级别的数据大山,所以本文我们就来看看Python处理... 目录1. Mars:数据处理界的 “变形金刚”2. Dask:分布式计算的 “指挥家”3. CuPy:GPU

Python中CSV文件处理全攻略

《Python中CSV文件处理全攻略》在数据处理和存储领域,CSV格式凭借其简单高效的特性,成为了电子表格和数据库中常用的文件格式,Python的csv模块为操作CSV文件提供了强大的支持,本文将深入... 目录一、CSV 格式简介二、csv模块核心内容(一)模块函数(二)模块类(三)模块常量(四)模块异常

详解如何在SpringBoot控制器中处理用户数据

《详解如何在SpringBoot控制器中处理用户数据》在SpringBoot应用开发中,控制器(Controller)扮演着至关重要的角色,它负责接收用户请求、处理数据并返回响应,本文将深入浅出地讲解... 目录一、获取请求参数1.1 获取查询参数1.2 获取路径参数二、处理表单提交2.1 处理表单数据三、

Spring Boot Controller处理HTTP请求体的方法

《SpringBootController处理HTTP请求体的方法》SpringBoot提供了强大的机制来处理不同Content-Type​的HTTP请求体,这主要依赖于HttpMessageCo... 目录一、核心机制:HttpMessageConverter​二、按Content-Type​处理详解1.