用“模型想象出来的target”来训练可以提高分类的效果

LearnFromPapers系列——用“模型想象出来的target”来训练可以提高分类的效果

<center>作者:郭必扬</center>
<center>时间:2020年最后一天</center>

前言:今天是2020年最后一天,这篇文章也是我的SimpleAI公众号2020年的最后一篇推文,感谢大家一直以来的陪伴和支持,希望SimpleAI曾带给各位可爱的读者们一点点的收获吧~这么特殊的一天,我也来介绍一篇特殊的论文,那就是今年我和组里几位老师合作的一篇AAAI论文:“Label Confusion Learning to Enhance Text Classification Models”。这篇文章的主要思想是通过构造一个“标签混淆模型”来实时地“想象”一个比one-hot更好的标签分布,从而使得各种深度学习模型(LSTM、CNN、BERT)在分类问题上都能得到更好的效果。个人感觉,还是有、意思的。

  • 论文标题:Label Confusion Learning to Enhance Text Classification Models
  • 会议/期刊:AAAI-21
  • 团队:上海财经大学 信息管理与工程学院 AI Lab

一、主要贡献

本文的主要贡献有这么几点:

  • 构造了一个插件--"Label Confusion Model(LCM)",可以在模型训练的时候实时计算样本和标签间的关系,从而生成一个标签分布,作为训练的target,实验证明,这个新的target比one-hot标签更好;
  • 这个插件不需要任何外部的知识,也仅仅在训练的时候才需要,不会增加模型预测时的时间,不改变原模型的结构。所以LCM的应用范围很广;
  • 实验发现LCM还具有出色的抗噪性和抗干扰能力,对于有错标的数据集,或者标签间相似度很高的数据集,有更好的表现。

二、问题背景、相关工作

1. 用one-hot来训练不够好

本文主要是从文本分类的角度出发的,但文本分类和图像分类实际上在训练模式上是类似的,基本都遵循这样的一个流程:

step 1. 一个深度网络(DNN,诸如LSTM、CNN、BERT等)来得到向量表示
step 2. 一个softmax分类器来输出预测的标签概率分布p
step 3. 使用Cross-entropy来计算真实标签(one-hot表示)与p之间的损失,从而优化

这里使用cross-entropy loss(简称CE-loss)基本上成了大家训练模型的默认方法,但它实际上存在一些问题。下面我举个例子:

比如有一个六个类别的分类任务,CE-loss是如何计算当前某个预测概率p相对于y的损失呢:


可以看出,根据CE-loss的公式,只有y中为1的那一维度参与了loss的计算,其他的都忽略了。这样就会造成一些后果

  • 真实标签跟其他标签之间的关系被忽略了,很多有用的知识无法学到;比如:“鸟”和“飞机”本来也比较像,因此如果模型预测觉得二者更接近,那么应该给予更小的loss
  • 倾向于让模型更加“武断”,成为一个“非黑即白”的模型,导致泛化性能差;
  • 面对易混淆的分类任务、有噪音(误打标)的数据集时,更容易受影响

总之,这都是由one-hot的不合理表示造成的,因为one-hot只是对真实情况的一种简化。

2. 一些可能的解决办法

LDL
既然one-hot不合理,那我们就使用更合理的标签分布来训练嘛。比如下图所示:


如果我们能获取真实的标签分布来训练,那该多好啊。

这种使用标签的分布来学习模型的方法,称为LDL(Label Distribution Learning),东南大学耿新团队专门研究这个方面,大家可以去了解一下。

但是,真实的标签分布,往往很难获取,甚至不可获取,只能模拟。比如找很多人来投票,或者通过观察进行统计。比如在耿新他们最初的LDL论文中,提出了很多生物数据集,是通过实验观察来得到的标签分布。然而,大多数的现有的数据集,尤其是文本、图像分类,几乎都是one-hot的,所以LDL并无法直接使用。

Label Enhancement
Label Enhancement,机标签增强技术,则是一类从通过样本特征空间来生成标签分布的方法,我在前面的论文解读中有介绍,这些方法都很有趣。

然而,使用这些方法来训练模型,都比较麻烦,因为我们需要通过“两步走”来训练,第一步使用LE的方法来构造标签分布,第二步再使用标签分布来训练。

Loss Correction
面对one-hot可能带来的容易过拟合的问题,有研究提出了Label Smoothing方法:

label smoothing就是把原来的one-hot表示,在每一维上都添加了一个随机噪音。这是一种简单粗暴,但又十分有效的方法,目前已经使用在很多的图像分类模型中了。

这种方法,一定程度上,可以缓解模型过于武断的问题,也有一定的抗噪能力。但是单纯地添加随机噪音,也无法反映标签之间的关系,因此对模型的提升有限,甚至有欠拟合的风险。

当然还有一些其他的Loss Correction方法,可以参考我前面的一个介绍。

三、我们的思想&模型设计

我们最终的目标,是能够使用更加合理的标签分布来代替one-hot分布训练模型,最好这个过程能够和模型的训练同步进行。

首先我们思考,一个合理的标签分布,应该有什么样的性质。

① 很自然地,标签分布应该可以反映标签之间的相似性。
比方下面这个例子:


② 标签间的相似性是相对的,要根据具体的样本内容来看。
比方下面这个例子,同样的标签,对于不同的句子,标签之间的相似度也是不一样的:


③ 构造得到的标签分布,在01化之后应该跟原one-hot表示相同。
啥意思呢,就是我们不能构造出了一个标签分布,最大值对应的标签跟原本的one-hot标签还不一致,我们最终的标签分布,还是要以one-hot为标杆来构造。

根据上面的思考,我们这样来设计模型:

使用一个Label Encoder来学习各个label的表示,与input sample的向量表示计算相似度,从而得到一个反映标签之间的混淆/相似程度的分布。最后,使用该混淆分布来调整原来的one-hot分布,从而得到一个更好的标签分布。

设计出来的模型结构如图:


这个结构分两部分,左边是一个Basic Predictor,就是各种我们常用的分类模型。右边的则是LCM的模型。注意LCM是一个插件,所以左侧可以更换成任何深度学习模型。

Basic Predictor的过程可以用如下公式表达:
\begin{aligned} v^{(i)} &=f^{I}(x)=f^{I}\left(\left[x_{1}, x_{2}, \ldots, x_{n}\right]\right) \\ &=\left[v_{1}^{(i)}, v_{2}^{(i)}, \ldots, v_{n}^{(i)}\right] \\ y^{(p)} &=\operatorname{softmax}\left(v^{(i)}\right) \end{aligned}
其中v^i就是输入的文本的通过Input Decoder得到的表示。y^p则是predicted label distribution(PLD)。

LCM的过程可以表达为:
\begin{aligned} V^{(l)} &=f^{L}(l)=f^{L}\left(\left[l_{1}, l_{2}, \ldots, l_{C}\right]\right) \\ &=\left[v_{1}^{(l)}, v_{2}^{(l)}, \ldots, v_{C}^{(l)}\right] \\ y^{(c)} &=\operatorname{softmax}\left(v^{(i)^{\top}} V^{(l)} W+b\right) \\ y^{(s)} &=\operatorname{softmax}\left(\alpha y^{(t)}+y^{(c)}\right) \end{aligned}
其中V^l代表label通过Label Encoder得到的标签表示矩阵,y^c是标签和输入文本的相似度得到的标签混淆分布,y^t是真实的one-hot表示,二者通过一个超参数结合再归一化,得到最终的y^s,即模拟标签分布,simulated label distribution(SLD)。

最后,我们使用KL散度来计算loss:
\begin{aligned} \text {loss} &=K L \text {-divergence}\left(y^{(s)}, y^{(p)}\right) \\ &=\sum_{c}^{C} y_{c}^{(s)} \log \left(\frac{y_{c}^{(s)}}{y_{c}^{(p)}}\right) \end{aligned}

总体来说还是比较简单的,很好复现,其实也存在更优的模型结构,我们还在探究。

四、实验&结果分析

1. Benchmark数据集上的测试

我们使用了2个中文数据集和3个英文数据集,在LSTM、CNN、BERT三种模型架构上进行测试,实验表明LCM可以在绝大多数情况下,提升主流模型的分类效果。


下面这个图展示了不同水平的α超参数对模型的影响:



从图中可以看出,不管α水平如何,LCM加成的模型,都可以显著提高收敛速度,最终的准确率也更高。针对不同的数据集特征,我们可以使用不同的α(比如数据集混淆程度大,可以使用较小的α),另外,论文中我们还介绍了在使用较小α的时候,可以使用early-stop策略来防止过拟合。

而下面这个图则展示了LCM确实可以学习到label之间的一些相似性关系,而且是从完全随机的初始状态开始学到的:


2. 难以区分的数据集(标签易混淆)

我们构造了几个“简单的”和“困难的”数据集,通过实验标签,LCM更适合那些容易混淆的数据集:


3. 有噪音的数据集

我们还测试了在不同噪音水平下的数据集上的效果,并跟Label Smoothing方法做了对比,发现是显著好于LS方法的。


下面这个图展示了另外一组更细致的实验结果:


4. 在图像分类上也有效果

最后,我们在图像任务上也简单测试了一下,发现也有效果:


总结:

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,761评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,953评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,998评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,248评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,130评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,145评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,550评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,236评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,510评论 1 291
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,601评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,376评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,247评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,613评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,911评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,191评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,532评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,739评论 2 335

推荐阅读更多精彩内容