本文整理自网络,主要是对自然语言处理能发展和落地的方向进行总结,也算是对自然语言处理常见任务的总结。
NLP的四大任务如下:
- 序列标注任务
- 分类任务
- 句子关系判断
- 生成式任务
1. 序列标注任务
序列标注(Sequence labeling)是我们在解决NLP问题时经常遇到的基本问题之一。在序列标注中,我们想对一个序列的每一个元素标注一个标签。一般来说,一个序列指的是一个句子,而一个元素指的是句子中的一个词。比如信息提取问题可以认为是一个序列标注问题,如提取出会议时间、地点等。
序列标注一般可以分为两类:
- 原始标注(Raw labeling):每个元素都需要被标注为一个标签。
- 联合标注(Joint segmentation and labeling):所有的分段被标注为同样的标签。
命名实体识别(Named entity recognition, NER)是信息提取问题的一个子任务,需要将元素进行定位和分类,如人名、组织名、地点、时间、质量等。
举个NER和联合标注的例子。一个句子为:Yesterday , George Bush gave a speech. 其中包括一个命名实体:George Bush。我们希望将标签“人名”标注到整个短语“George Bush”中,而不是将两个词分别标注。这就是联合标注。
1.1 BIO标注
解决联合标注问题最简单的方法,就是将其转化为原始标注问题。标准做法就是使用BIO标注。
BIO标注:将每个元素标注为“B-X”、“I-X”或者“O”。其中,“B-X”表示此元素所在的片段属于X类型并且此元素在此片段的开头,“I-X”表示此元素所在的片段属于X类型并且此元素在此片段的中间位置,“O”表示不属于任何类型。
比如,我们将 X 表示为名词短语(Noun Phrase, NP),则BIO的三个标记为:
- B-NP:名词短语的开头;
- I-NP:名词短语的中间;
- O:不是名词短语;
因此可以将一段话划分为如下结果:
image我们可以进一步将BIO应用到NER中,来定义所有的命名实体(人名、组织名、地点、时间等),那么我们会有许多 B 和 I 的类别,如 B-PERS、I-PERS、B-ORG、I-ORG等。然后可以得到以下结果:
[图片上传失败...(image-b1cfb3-1609330627120)]
1.2 序列标注常用模型
- Bi-LSTM
选择双向LSTM的原因是:当前词的tag和前后文都有关。
1.3 序列标注具体任务
(1)分词
- 输入:word + tag(I:in word;E:end of word);
- 输出:tag of word,标签是E的后面加空格,就达到了分词的目的;
(2)词性标注(Part-of-Speech tagging ,POS tagging)
- 输入:word + tag (词性:动词、名词、形容词等);
- 输出:词性;
- 模型:HMM也可以做
(3)命名实体标注(name entity recognition, NER)
- 输入:word + tag(B: begin of entity,I : inside of entity,o: outside of entity);
- 输出:实体标注;
(4)词义角色标注 (semantic role labeling, SRL) :
- 输入: word + 是不是谓语(B-Argo,I-Argo,BV );
- 输出:语义角色;
2. 分类任务
2.1 分类的具体任务
(1)文本分类、情感分类
- 模型:LSTM,属于 many- to - one 的问题,最后使用 Softmax输出分类结果;
3. 句子关系判断
3.1 具体任务
(1)句法分析、蕴含关系判断(entailment)
- 模型:语法分析树,LSTM 来对每个edges 算得分,选择得分高的edges,限制是这些edges 必须组成一个树;
- 模型:RNNGs 也可以做
4. 生成式任务
这类任务一般直接面向普通用户,提供自然语言处理产品服务的系统级任务,会用到多个层面的自然语言处理技术。
4.1 具体任务
(1)机器翻译(Machine Translation,MT)
Encoder-Decoder的最经典应用,事实上这一结构就是在机器翻译领域最先提出的。
(2)文本摘要、总结(Text summarization/Simplication)
输入是一段文本序列,输出是这段文本序列的摘要序列。
(3)阅读理解(Reading Comprehension)
将输入的文章和问题分别编码,再对其进行解码得到问题的答案。
(4)语音识别
输入是语音信号序列,输出是文字序列。
(5)对话系统(Dialogue Systerm)
输入的是一句话,输出是对这句话的回答。
(6)问答系统(Question-Answering Systerm)
针对用户提出的问题,系统给出相应的答案。
(7)自动文章分级(Automatic Essay Grading)
给定一篇文章,对文章的质量进行打分或分级。
NLP基本任务:
1. 词法分析(Lexical Analysis):对自然语言进行词汇层面的分析,是NLP基础性工作
- 分词(Word Segmentation/Tokenization):对没有明显边界的文本进行切分,得到词序列
- 新词发现(New Words Identification):找出文本中具有新形势、新意义或是新用法的词
- 形态分析(Morphological Analysis):分析单词的形态组成,包括词干(Sterms)、词根(Roots)、词缀(Prefixes and Suffixes)等
- 词性标注(Part-of-speech Tagging):确定文本中每个词的词性。词性包括动词(Verb)、名词(Noun)、代词(pronoun)等
- 拼写校正(Spelling Correction):找出拼写错误的词并进行纠正
2. 句子分析(Sentence Analysis):对自然语言进行句子层面的分析,包括句法分析和其他句子级别的分析任务
- 组块分析(Chunking):标出句子中的短语块,例如名词短语(NP),动词短语(VP)等
- 超级标签标注(Super Tagging):给每个句子中的每个词标注上超级标签,超级标签是句法树中与该词相关的树形结构
- 成分句法分析(Constituency Parsing):分析句子的成分,给出一棵树由终结符和非终结符构成的句法树
- 依存句法分析(Dependency Parsing):分析句子中词与词之间的依存关系,给一棵由词语依存关系构成的依存句法树
- 语言模型(Language Modeling):对给定的一个句子进行打分,该分数代表句子合理性(流畅度)的程度
- 语种识别(Language Identification):给定一段文本,确定该文本属于哪个语种
- 句子边界检测(Sentence Boundary Detection):给没有明显句子边界的文本加边界
3. 语义分析(Semantic Analysis):对给定文本进行分析和理解,形成能勾够表达语义的形式化表示或分布式表示
- 词义消歧(Word Sense Disambiguation):对有歧义的词,确定其准确的词义
- 语义角色标注(Semantic Role Labeling):标注句子中的语义角色类标,语义角色,语义角色包括施事、受事、影响等
- 抽象语义表示分析(Abstract Meaning Representation Parsing):AMR是一种抽象语义表示形式,AMR parser把句子解析成AMR结构
- 一阶谓词逻辑演算(First Order Predicate Calculus):使用一阶谓词逻辑系统表达语义
- 框架语义分析(Frame Semantic Parsing):根据框架语义学的观点,对句子进行语义分析
- 词汇/句子/段落的向量化表示(Word/Sentence/Paragraph Vector):研究词汇、句子、段落的向量化方法,向量的性质和应用
4. 信息抽取(Information Extraction):从无结构文本中抽取结构化的信息
- 命名实体识别(Named Entity Recognition):从文本中识别出命名实体,实体一般包括人名、地名、机构名、时间、日期、货币、百分比等
- 实体消歧(Entity Disambiguation):确定实体指代的现实世界中的对象
- 术语抽取(Terminology/Giossary Extraction):从文本中确定术语
- 共指消解(Coreference Resolution):确定不同实体的等价描述,包括代词消解和名词消解
- 关系抽取(Relationship Extraction):确定文本中两个实体之间的关系类型
- 事件抽取(Event Extraction):从无结构的文本中抽取结构化事件
- 情感分析(Sentiment Analysis):对文本的主观性情绪进行提取
- 意图识别(Intent Detection):对话系统中的一个重要模块,对用户给定的对话内容进行分析,识别用户意图
- 槽位填充(Slot Filling):对话系统中的一个重要模块,从对话内容中分析出于用户意图相关的有效信息
5. 顶层任务(High-level Tasks):直接面向普通用户,提供自然语言处理产品服务的系统级任务,会用到多个层面的自然语言处理技术
- 机器翻译(Machine Translation):通过计算机自动化的把一种语言翻译成另外一种语言
- 文本摘要(Text summarization/Simplication):对较长文本进行内容梗概的提取
- 问答系统(Question-Answering Systerm):针对用户提出的问题,系统给出相应的答案
- 对话系统(Dialogue Systerm):能够与用户进行聊天对话,从对话中捕获用户的意图,并分析执行
- 阅读理解(Reading Comprehension):机器阅读完一篇文章后,给定一些文章相关问题,机器能够回答
- 自动文章分级(Automatic Essay Grading):给定一篇文章,对文章的质量进行打分或分级
Reference:
【1】序列标注中的BIO标注介绍,地址:https://blog.csdn.net/HappyRocking/article/details/79716212
【2】http://nlpers.blogspot.com.au/2006/11/getting-started-in-sequence-labeling.html
【3】NLP 四大任务,地址:https://www.dazhuanlan.com/2019/08/21/5d5ca1e2826b9/
【4】NLP基本任务,地址:https://blog.csdn.net/lz_peter/article/details/81588430
【5】微信研究员解析深度学习在NLP中的发展和应用,地址:https://edu.csdn.net/course/play/8673
【6】从Word Embedding到Bert模型—自然语言处理中的预训练技术发展史 - 张俊林的文章 - 知乎 https://zhuanlan.zhihu.com/p/49271699
网友评论