案例精析—2021语言与智能技术竞赛:多形态信息抽取任务

本文主要是介绍案例精析—2021语言与智能技术竞赛:多形态信息抽取任务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

总结

  • 文章来源:CSDN_LawsonAbs
  • LawsonAbs的认知与思考,望各位读者审慎阅读。
  • 本文可以看做是2021语言与智能技术竞赛:多形态信息抽取任务比赛过程的一个记录。

1 百度Baseline

百度baseline是使用paddle 写的,主要的思想是一个多层的指针网络。

1.1 关于 predicate2id.json 文件

这里针对 predicate = 配音这个就生成了如下两个 predicate 值:
配音_inwork配音_@value。 因为这是一个复杂的结构体,而不能简单的抽取配音就可以了。
在这里插入图片描述

1.2 在运行 run_duie.py 脚本时,出现如下的界面?是什么问题?

在这里插入图片描述

没找到是什么原因。惨!

2. 2020年的冠军解决方案

采用创新技术方案,把实体抽取任务分为主语抽取、宾语抽取和关系分类三个步骤,输出层采用机器阅读理解中的指针网络作为基本结构,有效解决了实体进行两两匹配带来的大量负样本问题,训练效果大大提升,最终取得了第一名的成绩。

3 Baseline 的错误样例分析

这些问题来源于 error case 分析

3.1 text 没有有效的分隔符(猜测)

在这里插入图片描述
预测结果:
在这里插入图片描述
这里预测结果较差,主要有两个原因:

  • 因为text 间没有有效的分隔符,
  • baseline 中的是 将subject 和 object 全部组合在一起,

2 噪音数据

在这里插入图片描述
在这里插入图片描述
模型能够预测出来,但是dev_train.json 中却没有给出正确的来。

在这里插入图片描述
上面这条数据是不是有点儿问题? 只是标注了一个西班牙语,怎么就变成了官方语言?
在这里插入图片描述
针对上面这条数据,我想采取一个分阶段训练的方法:

  • 第一阶段大致训练一个模型
  • 第二阶段开始精致调参,丢弃loss超过一定范围的数据。要保证每条数据都能被完全充分的利用

这种数据标注情况非常常见,所以一定要使用修改后的train数据来训练,否则会很影响训练效果

3.3 少字导致错误

如下面所示: 因为预测的是情人,而正确的是情人节,导致出现错误。
在这里插入图片描述

这个里面还有一个就是@xxx 竟然也被预测出来了。

3.4 遗漏数据

训练好的模型有很多遗漏,这里简单展示一下:
forget

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

观察这么多的数据,发现原因是无法预测潜在的关系

其实模型并不知道 的差别,它们的embedding 甚至都很相似,所以就会产生下面这种错误。
在这里插入图片描述

其它

在这里插入图片描述

在这里插入图片描述
这里的数字都预测错误了

在这里插入图片描述
隔这么远都能预测,但是预测的都是错误的,肯定是有某些数据导致产生这种问题。

遗漏的有1w条(recall很低),(即使除去官方数据中的错误标注)precision也不是很高。
在这里插入图片描述

3.4 我的想法

3.4.1 噪音数据处理(未实现)

将空格,替换成[sep],或者是其它特殊字符。

3.4.2 数据迭代(未实现)

当前的模型根本是理解不了语义的,所以我认为一切的问题都是数据的问题,如果能利用好所有的正确数据,而规避错误数据集,再采用迭代训练的方式来解决这个问题。

3.4.3 dropout(未实现)

能不能 dropout 掉所有无用的数据?

4 疑问

4.1 怎么根据生成的标签,匹配出一组?

将匹配出来的subject 和 object 循环匹配即可,所以这种匹配方式可能会导致出现冗余。冗余情形如下:
在这里插入图片描述

4.2 如何根据predicate 的label生成最后的结果?

这个是写在baseline utils.py 下 的decoding 函数中。

5 团队方案

基于之前的冠军方案,下面介绍一下我们的方案

5.1 模型结构

在这里插入图片描述
总体是一个 pipeline 的方式:

  • step 1. 先预测subject 【NER问题】
  • setp 2. 再预测上述subject 下的所有 object 【NER 问题】
  • step 3. 使用上述 subject 和 object 得到的元组,去预测二者的关系类别 【分类问题】

样例解释:在这里插入图片描述

  • 先预测出宇文娥英
  • 再在宇文娥英 的基础上,预测出杨丽华周宣帝
  • 再将宇文娥英+杨丽华 => 母亲宇文娥英+周宣帝 => 父亲

5.2 模型效果

在这里插入图片描述

precision 和 recall都很低 ,说明模型遗漏了基础要点。

5.3 模型预测结果错误样例分析

5.3.1 subject 预测的成功率不高(待解决)

单独运行 预测subject 的效果,发现其效果并不好
在这里插入图片描述

5.3.2 英文字符间的空格被分开了导致出错(待解决)

在这里插入图片描述

5.3.3 因为字不在vocab库导致出错(已解决)

在这里插入图片描述

5.4 改进方案

  • 使用subjectobject预测relation时,加O 类。(加一部分噪音数据构造O类) 【2021-4-11】
  • 模型加CRF 【2021-4-11】
  • 模型加入scheduler 参数 【2021-04-18】
  • pu learning 【2021-04-18】
  • 数据迭代【2021-04-25】
  • 梯度累积【2021-04-25】
  • 在训练模型时使用 Sampler 【2021-04-25】

5.5 其它优化方案

  • 降低batch中的数据集大小

这篇关于案例精析—2021语言与智能技术竞赛:多形态信息抽取任务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/525092

相关文章

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

SpringQuartz定时任务核心组件JobDetail与Trigger配置

《SpringQuartz定时任务核心组件JobDetail与Trigger配置》Spring框架与Quartz调度器的集成提供了强大而灵活的定时任务解决方案,本文主要介绍了SpringQuartz定... 目录引言一、Spring Quartz基础架构1.1 核心组件概述1.2 Spring集成优势二、J

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4