当前位置: 代码迷 >> 综合 >> Sentence-BERT详解
  详细解决方案

Sentence-BERT详解

热度:22   发布时间:2024-02-28 01:57:10.0

简述

BERT和RoBERTa在文本语义相似度(Semantic Textual Similarity)等句子对的回归任务上,已经达到了SOTA的结果。但是,它们都需要把两个句子同时送入网络,这样会导致巨大的计算开销:从10000个句子中找出最相似的句子对,大概需要5000万(C100002=49,995,000C_{10000}^2=49,995,000C100002?=49,995,000)个推理计算,在V100GPU上耗时约65个小时。这种结构使得BERT不适合语义相似度搜索,同样也不适合无监督任务,例如聚类

解决聚类和语义搜索的一种常见方法是将每个句子映射到一个向量空间,使得语义相似的句子很接近。通常获得句子向量的方法有两种:

  1. 计算所有Token输出向量的平均值
  2. 使用[CLS]位置输出的向量

然而,UKP的研究员实验发现,在文本相似度(STS)任务上,使用上述两种方法得到的效果却差强人意,即使是Glove向量也明显优于朴素的BERT句子embeddings(见下图前三行)

Sentence-BERT(SBERT)的作者对预训练的BERT进行修改:使用Siamese and Triplet Network(孪生网络和三胞胎网络) 生成具有语义的句子Embedding向量。语义相近的句子,其Embedding向量距离就比较近,从而可以使用余弦相似度、曼哈顿距离、欧氏距离等找出语义相似的句子。SBERT在保证准确性的同时,可将上述提到BERT/RoBERTa的65小时降低到5秒(计算余弦相似度大概0.01秒)。这样SBERT可以完成某些新的特定任务,比如聚类、基于语义的信息检索等

模型介绍

Pooling策略

SBERT在BERT/RoBERTa的输出结果上增加了一个Pooling操作,从而生成一个固定维度的句子Embedding。实验中采取了三种Pooling策略做对比:

  1. CLS:直接用CLS位置的输出向量作为整个句子向量
  2. MEAN:计算所有Token输出向量的平均值作为整个句子向量
  3. MAX:

三种策略的实验对比效果如下

由结果可见,MEAN的效果是最好的,所以后面实验默认采用的也是MEAN策略

模型结构

为了能够fine-tune BERT/RoBERTa,文章采用了孪生网络和三胞胎网络来更新参数,以达到生成的句子向量更具语义信息。该网络结构取决于具体的训练数据,文中实验了下面几种机构和目标函数

Classification Objective Function

针对分类问题,作者将向量u,v,∣u?v∣u,v,|u-v|u,v,u?v三个向量拼接在一起,然后乘以一个权重参数Wt∈R3n×kW_t\in \mathbb{R}^{3n\times k}Wt?R3n×k,其中nnn表示向量的维度,kkk表示label的数量
o=softmax(Wt[u;v;∣u?v∣])o = softmax(W_t[u;v;|u-v|]) o=softmax(Wt?[u;v;u?v])
损失函数为CrossEntropyLoss

注:原文公式为softmax(Wt(u,v,∣u?v∣))softmax(W_t(u,v,|u-v|))softmax(Wt?(u,v,u?v)),我个人比较喜欢用[;;][;;][;;]表示向量拼接的意思

Regression Objective Function

两个句子embedding向量u,vu,vu,v的余弦相似度计算结构如下所示,损失函数为MAE(mean squared error)

Triplet Objective Function

更多关于Triplet Network的内容可以看我的这篇Siamese Network & Triplet NetWork。给定一个主句aaa,一个正面句子ppp和一个负面句子nnn,三元组损失调整网络,使得aaappp之间的距离尽可能小,aaannn之间的距离尽可能大。数学上,我们期望最小化以下损失函数:
max(∣∣sa?sp∣∣?∣∣sa?sn∣∣+?,0)max(||s_a-s_p||-||s_a-s_n||+\epsilon, 0) max(sa??sp??sa??sn?+?,0)
其中,sxs_xsx?表示句子xxx的embedding,∣∣?∣∣||·||?表示距离,边缘参数?\epsilon?表示sas_asa?sps_psp?的距离至少应比sas_asa?sns_nsn?的距离近?\epsilon?。在实验中,使用欧式距离作为距离度量,?\epsilon?设置为1

模型训练细节

作者训练时结合了SNLI(Stanford Natural Language Inference)和Multi-Genre NLI两种数据集。SNLI有570,000个人工标注的句子对,标签分别为矛盾,蕴含(eintailment),中立三种;MultiNLI是SNLI的升级版,格式和标签都一样,有430,000个句子对,主要是一系列口语和书面语文本

蕴含关系描述的是两个文本之间的推理关系,其中一个文本作为前提(Premise),另一个文本作为假设(Hypothesis),如果根据前提能够推理得出假设,那么就说前提蕴含假设。参考样例如下:

Sentence A (Premise) Sentence B (Hypothesis) Label
A soccer game with multiple males playing. Some men are playing a sport. entailment
An older and younger man smiling. Two men are smiling and laughing at the cats playing on the floor. neutral
A man inspects the uniform of a figure in some East Asian country. The man is sleeping. contradiction

实验时,作者使用类别为3的softmax分类目标函数对SBERT进行fine-tune,batch_size=16,Adam优化器,learning_rate=2e-5

消融研究

为了对SBERT的不同方面进行消融研究,以便更好地了解它们的相对重要性,我们在SNLI和Multi-NLI数据集上构建了分类模型,在STS benchmark数据集上构建了回归模型。在pooling策略上,对比了MEAN、MAX、CLS三种策略;在分类目标函数中,对比了不同的向量组合方式。结果如下


结果表明,Pooling策略影响较小,向量组合策略影响较大,并且[u;v;∣u?v∣][u;v;|u-v|][u;v;u?v]效果最好

Reference

  • 论文阅读 | Sentence-BERT: Sentence Embeddings using Siamese BERT-Networks
  • Richer Sentence Embeddings using Sentence-BERT — Part I
  • Sentence-BERT: Sentence Embeddings using Siamese BERT-Networks (EMNLP 2019)
  • Sentence-BERT: 一种能快速计算句子相似度的孪生网络
  相关解决方案