案例精析—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中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

在Golang中实现定时任务的几种高效方法

《在Golang中实现定时任务的几种高效方法》本文将详细介绍在Golang中实现定时任务的几种高效方法,包括time包中的Ticker和Timer、第三方库cron的使用,以及基于channel和go... 目录背景介绍目的和范围预期读者文档结构概述术语表核心概念与联系故事引入核心概念解释核心概念之间的关系

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(