NLP(十九)首次使用BERT的可视化指导
本文(部分内容)翻译自文章A Visual Guide to Using BERT for the First Time,其作者为Jay Alammar,访问网址为:http://jalammar.github.io/a-visual-guide-to-using-bert-for-the-first-time/ ,可以作为那些不熟悉BERT的读者首次阅读。文章中如有翻译不当之处,还请批评指正。
本文是关于如何使用BERT的变异版本来进行句子分类的简单教程。该例子足够简单,因此可以作为首次使用BERT的介绍,当然,它也包含了一些关键性的概念。
数据集:SST2
本文中使用的数据集为SST2,它包含了电影评论的句子,每一句带有一个标签,或者标注为正面情感
(取值为1),或者标注为负面情感
(取值为0)。
模型:句子情感分类
我们的目标是创建一个模型,它能够处理一个句子(就行我们数据集中的句子那样)并且输出1(表明该句子具有正面情感)或者0(表明该句子具有负面情感)。我们设想它长这样:
事实上,该模型包含两个模型:
DistillBERT
会处理句子并把它提取后的信息传递给下一个模型。DistillBERT
是BERT
的变异版本,由HuggingFace
小组开发和开源。它是BERT
的更轻量、更快速的版本,同时它的表现基本与BERT
相近。- 下一个模型,从scikit learn中导入的一个基本的
逻辑回归模型
(Logistic Regression model),它会利用DistillBERT
的处理结果,然后将句子进行分类成正面情感
或者负面情感
(分别为1或者0)。
在两个模型之间传递的数据为1个768维的向量。我们可以把这个向量理解为这个句子的嵌入向量(Embedding Vector),用于分类。
模型训练
尽管我们用了两个模型,但是我们只会训练逻辑回归模型
。对于DistillBERT
,我们会使用已经预训练好的英语模型。该模型,既不会被训练也不会做微调(fine-tuned)
,直接进行句子分类。这是因为,我们可以从BERT
中获得句子分类的能力。这尤其适合BERT
输出的第一个位置(跟[CLS]标志相关)。我相信这是由于BERT
的第二个训练模型——下一句分类(Next sentence classification)
。该模型的目标在于封装句子级别的语料进行训练,并输出第一个位置。transformers
库已经提供了DistillBERT
的操作,作为其预训练模型版本。
教程总览
以下是该教程的计划安排。首先我们会使用DistillBERT
来产生2000个句子的句子向量。
这一步之后我们不会接触DistillBERT
。接下去只是Scikit Learn的操作。我们将数据集分为训练集和测试集。
接下来我们在训练集上使用逻辑回归模型
进行训练。
单次预测如何计算
在我们讲解代码和解释如何训练模型之前,让我们看一下已预训练好的模型如何进行预测。
我们尝试着预测句子“a visually stunning rumination on love”。第一步是使用BERT tokenizer 将句子划分成tokens。然后加上句子分类的特殊tokens([CLS]在开始位置,[SEP]在句子结尾)。
第三步是通过已预训练好的模型的嵌入表(embedding table)将每一个tokens映射成各自的id。这一步可以参考word embedding
,参考阅读文章The Illustrated Word2vec。
我们注意到,tokenizer仅需要一行代码就能完成以上步骤。
tokenizer.encode("a visually stunning rumination on love", add_special_tokens=True)
我们的输入句子现在已经处理成DistilBERT
可以处理的格式了。
如果你已经读过Illustrated BERT,那么这一步的可视化如下:
DistilBERT处理流程
DistilBERT
处理输入向量的流程类似于BERT
。输出是每一个token对应一个向量。每个向量由768个浮点型数字组成。
因为这是一个句子分类任务,故我们忽略其他向量而只取第一个向量(跟[CLS]相关的那个)。这个向量我们会作为逻辑回归模型
的输入。
从这里开始,就是逻辑回归模型
的事儿了,它负责将输入的向量进行分类。我们设想一个预测的流程长这样:
代码
文章中用到的数据集下载网址为:https://github.com/clairett/pytorch-sentiment-classification/raw/master/data/SST2/train.tsv。下载DistillBERT
模型文件,网址为:https://www.kaggle.com/abhishek/distilbertbaseuncased 。
原文中这部分的代码讲解比较多,我这边忽略过去了,笔者想按自己的思路来处理,因此这部分内容会有调整。完整的思路如下:
下载数据集和模型文件,与代码放在同一目录下。建立jupyter脚本,先载入必要的模块:
接着我们利用pandas读取训练集数据,并统计标签值的频数:
读取DistillBERT
模型文件并创建tokenizer:
通过tokenizer完成句子切分成tokens,并映射到id:
由于每个句子的长度可能会不同,因此需要对句子进行填充(Padding),保持每个句子的输入维度一致,句子填充的长度为该数据集中句子长度的最大值。
对句子进行填充后,然后再进行Masking。这是因为如果我们直接将padded传入BERT
,这会造成一定的困扰。我们需要创建另一个变量,来告诉模型去mask之前的填充结果。这就是attention_mask的作用:
我们的输入已经准备完毕,接下来我们尝试着用DistillBERT
来获取向量,也就是之前说的第一步。这一步的处理结果会返回last_hidden_states
,而我们的分类模型只需要获取[CLS]
这个token对应的输出向量。
可视化的操作说明如下图:
这样,我们就把之前的每一个句子映射成了1个768维的句子向量,然后就利用逻辑回归模型
直接进行训练就可以了。
最后,我们来看一下这个模型在测试集上的效果:
总结
本文主要介绍了如何利用DistillBERT
和已经封装好的transformers
模块,结合逻辑回归模型
对英文句子进行文本二分类。后续笔者还会研究在中文上的文本分类以及如何进行微调(Fine_tuning)。
本项目的Gitlab地址为:https://gitlab.com/jclian91/sentence_classify_using_distillBERT_LR,原文章作者的Github地址为https://github.com/jalammar/jalammar.github.io/blob/master/notebooks/bert/A_Visual_Notebook_to_Using_BERT_for_the_First_Time.ipynb 。
感谢大家阅读~
NLP(十九)首次使用BERT的可视化指导的更多相关文章
- NLP(二十)利用BERT实现文本二分类
在我们进行事件抽取的时候,我们需要触发词来确定是否属于某个特定的事件类型,比如我们以政治上的出访类事件为例,这类事件往往会出现"访问"这个词语,但是仅仅通过"访问&q ...
- WPF,Silverlight与XAML读书笔记第三十九 - 可视化效果之3D图形
原文:WPF,Silverlight与XAML读书笔记第三十九 - 可视化效果之3D图形 说明:本系列基本上是<WPF揭秘>的读书笔记.在结构安排与文章内容上参照<WPF揭秘> ...
- NLP十大里程碑
NLP十大里程碑 2.1 里程碑一:1985复杂特征集 复杂特征集(complex feature set)又叫做多重属性(multiple features)描写.语言学里,这种描写方法最早出现在语 ...
- Web 开发人员和设计师必读文章推荐【系列二十九】
<Web 前端开发精华文章推荐>2014年第8期(总第29期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各类能够提升网站用户体验的优秀 jQuery 插件,展示前沿的 HTML5 ...
- Gradle 1.12翻译——第十九章. Gradle 守护进程
有关其他已翻译的章节请关注Github上的项目:https://github.com/msdx/gradledoc/tree/1.12,或访问:http://gradledoc.qiniudn.com ...
- 第三百五十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)介绍以及安装
第三百五十九节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)介绍以及安装 elasticsearch(搜索引擎)介绍 ElasticSearch是一个基于 ...
- 无废话ExtJs 入门教程十九[API的使用]
无废话ExtJs 入门教程十九[API的使用] extjs技术交流,欢迎加群(201926085) 首先解释什么是 API 来自百度百科的官方解释:API(Application Programmin ...
- Python之路【第十九章】:Django进阶
Django路由规则 1.基于正则的URL 在templates目录下创建index.html.detail.html文件 <!DOCTYPE html> <html lang=&q ...
- Bootstrap <基础二十九>面板(Panels)
Bootstrap 面板(Panels).面板组件用于把 DOM 组件插入到一个盒子中.创建一个基本的面板,只需要向 <div> 元素添加 class .panel 和 class .pa ...
随机推荐
- $tarjan$简要学习笔记
$QwQ$因为$gql$的$tarjan$一直很差所以一直想着要写个学习笔记,,,咕了$inf$天之后终于还是写了嘻嘻. 首先说下几个重要数组的基本定义. $dfn$太简单了不说$QwQ$ 但是因为有 ...
- C# 添加文本、图片到PDF文档(基于Spire.Cloud.PDF.SDK)
Spire.Cloud.PDF.SDK提供了接口PdfTextApi及PdfImagesApi用于添加文本和图片到PDF文档,添加文本时,可格式化文本样式,包括文本字体类型.字号.字体样式.文本颜色. ...
- POJ1144 Network 题解 点双连通分量(求割点数量)
题目链接:http://poj.org/problem?id=1144 题目大意:给以一个无向图,求割点数量. 这道题目的输入和我们一般见到的不太一样. 它首先输入 \(N\)(\(\lt 100\) ...
- Linux 学习笔记 6 搭建nginx 实现二级域名访问
前言 在前一节的内容里面,我们学习了如何使用yum 包管理工具来安装我们需要的软件,这节内容,通过搭建Nginx 反向代理服务器,以及学习服务的配置等内容. NGINX Nginx是一款轻量级的Web ...
- iOS的项目目录结构
一.一般面试官都会问这样的一个问题,你怎样划分你项目的目录结构,就能测试出这个人是否有经验? 目前,比较常规的两种结构: 1.主目录按照业务分类,内目录按照模块分类(主目录按照MVC架构分类,内部根据 ...
- render()到底渲染的什么?
1.格式 render(request,"xx.html",{"xx": xx}) 2.本质 通过模板语言动态渲染字符串(HTML文件) 注意: 1.HTML文 ...
- 影响K8S Pod分配和调度策略的两大关键特性
在Kubernetes中有一个最复杂的调度器可以处理pod的分配策略.基于在pod规范中所提及的资源需求,Kubernetes调度器会自动选择最合适的节点来运行pod. 但在许多实际场景下,我们必须干 ...
- 【5min+】帮我排个队,谢谢。await Task.Yield()
系列介绍 [五分钟的dotnet]是一个利用您的碎片化时间来学习和丰富.net知识的博文系列.它所包含了.net体系中可能会涉及到的方方面面,比如C#的小细节,AspnetCore,微服务中的.net ...
- Drupal SA-CORE-2019-010 .开头文件名(如.htaccess) 文件上传
目录 drupal .开头文件名 文件上传 原生模块分析 第三方模块分析 补丁 参考 drupal .开头文件名 文件上传 通过diff 8.8.1的补丁,很容易发现修复点,位于core\module ...
- Qt Installer Framework翻译(7-1)
配置文件 配置文件可自定义安装程序的用户界面和行为.该文件通常称为config.xml,位于config文件夹中. 最小配置文件由一个<Installer>根元素组成,<Name&g ...