非侵入式Self-attention多维信息融合

非侵入式Self-attention多维信息融合

Bert模型自2018年提出至今依旧辉煌热度不减,其在自然语言领域取得的成绩非常注目。一些研究已经将Bert应用在了序列数据的处理上,比如序列推荐场景下。然而在推荐场景下除了item序列之外,还有存在与序列item相关的额外信息(如用户在item的驻留时长、item类型等),又因为Bert模型只使用一种token序列作为输入,所以如何将与token相关的额外信息融合到模型,以及融合模型是否能提升模型性能成为一个新的研究方向。

Bert的强大是不能缺少的self-attention机制的贡献的。正是由于Self-attention机制可以解决RNN无法处理的长依赖问题和Self-attention优秀的并行能力,成就了Bert的声名鹊起。当然应用Self-attention机制的另一个明星模型就是地表最强模型——GPT了,目前OpenAI已经将GPT演进到了GPT-3了。

论文地址:https://arxiv.org/pdf/2103.03578.pdf

从Self-attention说起

self-attention机制可以理解为对输入序列的加权和,而其中的加权系数也就是所谓的Attention了,那么self主要表达了这些加权系数是由输入序列计算而来并且作用于输入的token,这与传统的attention机制有所不同。当然这里主要是针对Transformer模型中的encoder进行说明。其计算过程可以由下图来说明


SA.png

self-attention计算过程示例

其中由x^1,x^2,x^3,x^4组成长度为4的序列,经过embedding之后得到a^ia^i在分别经过W^Q,W^K,W^V三个线性变换得到q^i,k^i,v^i. 之后分别计算attenton权重\hat{a}_{i,j}经过加权和得到x_i对序列所有token的综合向量b^i, 即完成了x_i的self-attention过程。

SA(Q,K,V)=\sigma (\frac{QK^T}{\sqrt d_k})V

从上述过程中可以看出,原始self-attention计算过程中仅仅将token经过上述计算过程,与token相关的其他相信并未经过该流程。此外,序列中token本身的position信息经过编码(Transformer是由余弦函数编码,Bert则由随机Embedding编码)与向量a^i对应相加。若认为position信息是一种token的额外信息的话,那么论文作者认为这种直接相加的方式属于侵入式信息融合。当采用同样的侵入方式处理其他额外相关信息的话,其效果不明显甚至有反效果。

为什么侵入式融合的效果差?

作者在一些先导性试验上验证了侵入式的信息融合并不能取得一个明显的提升效果,甚至会导致效果变差。其中可能的原因有两个:

  1. 直接在item表征上加入额外相关信息后,会造成item信息淹没;
  2. 一般情况下,模型利用self-attention层堆叠进行自动编码,融合额外信息后的映射空间会形成一个混合空间映射,在对item表征进行解码时带来混乱或困难。

这里的直接相加是一种融合方式,此外如拼接、有门控制的相加等融合方式同样无法解决这两种问题。

解决方案

如何解决信息淹没和混合映射空间带来的问题呢?作者提出了一种新的解决方案,首先我们定义用户序列:

S_u=[v^{(1)}_u, v^{(2)}_u, ..., v^{(n)}_u]

其中v^{(j)}_u表示用户在第j次产生的交互实体,v^{(j)}_u \in I, I= \{ID^{(1)}, ID^{(2)}, ..., ID^{(m)}\}I是交互实体item的集合,也就是vocabulary。

额外相关信息可以分为两种:一种是和用户行为相关的信息b_{u,j},一种是和交互实体item相关的信息f_k。加入额外信息后,交互序列的实体表示为:

v_u^{(j)}=(I^{(k)}, b_{u,j}^{(1)}, b_{u,j}^{(2)},...,b_{u,j}^{(q)})

I^{(k)}=(ID^{(k)},f_k^{(1)},f_k^{(2)},...,f_k^{(p)})

将实体item和额外信息综合表征得到

\begin{aligned} E_{u,j}=\mathcal{F}(&\mathcal{E}_{id}(ID),\\ &\mathcal{E}_{f1}(f^{(1)}), \mathcal{E}_{f2}(f^{(2)}), ..., \mathcal{E}_{fp}(f^{(p)}), \\ &\mathcal{E}_{b1}(b_{u,j}^{(1)}), \mathcal{E}_{b2}(b_{u,j}^{(2)}), ...,\mathcal{E}_{bq}(b_{u,j}^{(q)})) \end{aligned}

其中E_{u,j}表示对用户第j次交互的综合表示,\mathcal{F}表示融合函数,\mathcal{E}表示对应的embedding层。其中融合函数主要有直接相加融合、逐点乘积融合和门函数融合等方式。

定义仅有实体ID得到的表示为

E_{u,j}^{(ID)}=\mathcal{E}_{id}(ID)

于是,用户序列的表征可以分为两种,仅由ID得到的表征和包含额外信息的综合表征:

\begin{aligned} &R_u^{(ID)}=(E_{u,1}^{(ID)}, E_{u,2}^{(ID)}, ..., E_{u,n}^{(ID)})\\ &R_u=(E_{u,1},E_{u,2},...,E_{u,n}) \end{aligned}

则新的注意力计算为:

NOVA(R,R^{(ID)})=\sigma(\frac{QK^T}{\sqrt d_k})V

其中Q=RW_Q, K=RW_k, V=R^{(ID)}W_v,即Q,K由包含额外信息的综合表征经过线性变换求得,V由仅包含ID信息的表征经过线性变换求得。

2021-06-07_162929.png

上图表达了侵入式融合和非侵入式融合的两种方式。

实施方案

作者的具体实施方案如下图所示:

nova.png
non-invasive.png

左图是作者在原始Bert架构上做了调整,将额外信息作为辅助融合到模型中,具体融合方式由右图说明。其中作为辅助的额外信息在Bert layer迭代过程中始终不变,而id信息则随着迭代不断进行更新。作者认证尽管id表征信息不断在更新,但是其始终处于同一映射空间中,所以在该映射空间中解码会获得更加准确的编解码。

实验结果

作者使用新的融合方案后得到的attention在多个数据集上均取得了最好的性能表现。

sota.png
  • NOVA-Bert的效果比其他的都要好
  • 与Bert4Rec仅利用位置ID相比,侵入式融合使用了很多额外信息,但是改进非常有限甚至有负面效果。相反,NOVA-Bert方法能有效利用额外信息,性能稳定,优于其他方法
  • 对于越大越稠密的数据集,模型提升的幅度会下降。作者认为在语料更丰富的情况下,这些模型可以从序列上下文中学习到足够好的embedding,而留给辅助信息的补充空间更小。
  • NOVA-BERT模型的鲁棒性非常好;不管使用什么融合函数,NOVA-Bert的效果都比baseline好
  • 最佳融合函数可能取决于数据集。一般情况下,gating融合方法具有很强的性能,这可能是因为gating方式的可训练机制
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容