当前位置:   article > 正文

【论文翻译】小样本学习(Few-Shot Learning)背景和主要方向简介_小样本学习研究背景

小样本学习研究背景

【论文翻译】小样本学习(Few-Shot Learning)背景和主要方向简介

本文主要翻译自论文Generalizing from a Few Examples: A Survey on Few-Shot Learning的前两部分,这两部分对于小样本学习有了简要的介绍,并给出了形式上的定义,同时对于小样本学习在机器学习领域中的地位做出了梳理,并阐述了与机器学习相关问题的区别和联系。

文章将小样本学习的工作分为三个方向,后面几个部分主要是对于各个方向的工作进行了系统性总结,受时间和能力所限,具体算法罗列的部分本文并没有翻译,只是列出作者在文章中总结的几个表格,感兴趣的读者可根据前面对于分类的介绍以及自己的问题按需查找原文中的相应部分。

原文链接:https://arxiv.org/pdf/1904.05046.pdf

摘要

机器学习在数据挖掘和应用上取得了巨大的成功,但当数据集比较小时,其效果往往会大打折扣。近来人们提出小样本学习(Few-Shot Learning FSL)来解决这一问题。通过使用先验知识,FSL可以迅速适应新的任务,即便此时我们只有一小部分有监督的样本。在本文中,我们对于这一领域展开了一次全面的归纳总结。首先我们给FSL问题一个定义,将其明确为机器学习领域中一个独立的问题。接着我们指出,FSL的核心问题是基于经验给出的判断可能是不可靠的。根据先验知识在这个问题上不同的应用方式,我们可以将FSL方法分成三个流派:(i)通过数据,这种方法通过先验知识对我们手中有标签的小样本进行扩充和增强;(ii)通过模型,可以通过先验知识缩小我们未知的假设范围;(iii)通过算法,这种方法利用先验知识帮助我们在一个问题未知的解空间中更好地搜索出较优的结果。我们讨论了各类方法的优缺点,以及问题定义/解决方式和理论研究中一些可能的方向。

介绍

“机器可以思考吗?:1950年Alan Turing在其著名论文Computing Machinery and Intelligence中提出了这个问题。他说:”电子计算机发展的思路可以解释为让机器去完成人类可以完成的任何事情“。换句话说,计算机发展的终极目标是和人类一样智能,近年来随着计算技术(GPU和分布式平台),大规模数据集,前沿算法模型(卷积神经网络(CNN)和长短时神经网络(LSTM))的兴起,人工智能大步向前发展,在很多方面都超过了人类。比如AlphaGo在围棋这项人类古老的运动中打败了人类的冠军;残差神经网络(ResNet)在图像分类的问题上也取得了比人类更好的成绩。人工智能同样在日常生活中被广泛应用,比如语音助手/搜索引擎/自动假设和工业机器人。
虽然人工智能行业一派欣欣向荣,但是现阶段的人工智能还缺乏从小样本数据集进行学习的能力。前述的大部分成果都是建立在大规模数据集之上的。相反,人类则可以迅速利用之前的知识来处理新的问题。比如一个儿童可以通过学习加法轻松理解乘法,一个人只需要几张照片就可以从人群中准确找到目标。
打通人工智能和人类的这一壁垒是一个很重要的方向,机器学习便是用来解决这一问题的,它可以构建根据经验自动改善性能的电脑程序。为了从有限的样本中进行学习,机器学习中的一种新的问题和范式被定义,即小样本学习(FSL)。一个典型的例子时字符串生成,给定一些例子,计算机程序被要求去解析并生成新的手写字符。为了解决这一问题,一种方法是把字符分解成可以在不同字符之间通用的部分,然后将这些部分组合在一起成为新的字符,就像人类的学习过程一样。小样本学习可以促进机器人的发展,让其更好地模拟人类的行为。包括单样本模仿,多重武装视觉导航和连续控制。
另一个经典的小样本学习应用场景是当出于隐私/安全或伦理原因,有监督的信息极难获取时。典型的例子时药品研发,我们希望发现药品中对于疾病治疗有用的分子结构。因为可能存在的毒性,低活性和低溶解度,新的药物分子可能只有很少的临床记录。因此,高效利用这宝贵的样本就变得十分重要。相似的例子还包括FSL翻译,冷启动推荐系统等。通过小样本学习,利用这些稀有样本得到良好的模型成为了可能。
FSL还使得人们不用去寻找大量的数据。比如尽管ResNet可以在分类性能上胜过人类,但是每个类别都需要足够多的样本,这本身有需要很多人类的劳动。FSL可以降低此类数据驱动型任务所需要的数据量,这会使得包括图像分类,图像检索,目标跟踪,姿态识别,视觉问答,图像标注,视频信息检测,语言建模和神经元架构搜索。
因为学术研究和实际的双重需要,小样本学习时下是一个热门的话题,包括元学习,嵌入式学习和生成模型等方式纷纷被提出。然而现在还没有一个工作总结和分类这些研究,探究其作用效果和优缺点。因此在本文我们进行了一次全面的总结和归纳。
本文的贡献可以简要总结如下:

  • 我们给出了FSL问题的定义,这个定义与传统的机器学习问题相互联系。这个定义不仅可以概括已有的FSL工作,还可以阐明FSL的目标以及解决方法。这样一个定义对于未来的研究规范化是很有帮助的。
  • 通过给出足够详实的例子,我们列出了FSL的相关问题,以及他们与FSL的联系和区别。这样的研究帮助我们明确了FSL在机器学习领域中的位置。
  • 我们指出了FSL问题中的核心问题:即基于经验和实验进行错误风险最小化过程中存在的不稳定性,错误风险最小化问题在机器学习中通过误差分解进行研究。这为推进FSL的发展提供了更具有系统化和结构化的思路指导。
  • 我们广泛地调研了大量文献,并将其按照数据驱动/模型驱动和算法驱动进行了分类,我们也总结了各个类别的优缺点和研究思想,这些都可以帮助我们更好地理解FSL模型。
  • 我们提出了FSL问题未来的发展方向,包括问题设定/方法/应用和理论。这些思想基于FSL当下发展中的一些不足,希望可以得到一些可能的解决方案。

本文的结构

第二部分对FSL进行概览性的介绍,包括形式化的定义,相关的问题,核心问题,以及已有工作的分类。第三部分是解决FSL问题的数据增强方法;第四部分是缩减未知空间的方法;第5部分包括了通过调整搜索算法来处理FSL问题的方法;第6部分我们提出了FSL问题的发展方向;最后第7部分包含了对本文的总结。

术语和标注

考虑一个学习任务 T T T,一般情况下我们都会有一个测试集和一个训练集,二者共同组成了该问题 T T T的数据集 D D D D = { D t r a i n , D t e s t } D=\{D_{train},D_{test}\} D={Dtrain,Dtest},其中的训练集 D t r a i n D_{train} Dtrain包含了若干样本点 D t r a i n = { ( x i , y i ) } i = 1 I D_{train}=\{(x_i,y_i)\}_{i=1}^{I} Dtrain={(xi,yi)}i=1I,但样本点的个数 I I I在FSL问题中是很少的。我们用 p ( x , y ) p(x,y) p(x,y)代表真实数据样本 x x x y y y的联合概率密度,而映射 h ^ \hat{h} h^代表着从 x x x y y y的最佳预测,机器学习的任务本质上就是根据训练集 D t r a i n D_{train} Dtrain在许多个可能的预测假设 h h h中找到最佳的 h ^ \hat{h} h^,而“最佳”则是由测试集 D t e s t D_{test} Dtest上的表现决定的。为了近似最佳的 h ^ \hat{h} h^,我们需要在一个包含很多预测映射的空间 H \mathcal{H} H中搜索,这个空间不妨定义为“模型假设空间”或者说“模型搜索空间”。空间中的每一个点 h ( ⋅ ; θ ) h(·;\theta) h(;θ)都代表一个预测映射,其中 θ \theta θ代表这个映射中的全部参数。我们认为模型假设是与参数高度相关的,非参数的模型假设往往需要大量数据,这对于FSL问题是不现实的。一个FSL算法即为一种最优化的搜索策略,目的是从模型搜索空间 H \mathcal{H} H中找到能够最好拟合 h ^ \hat{h} h^的参数 θ \theta θ。对于参数模型 h ( ⋅ ; θ ) h(·;\theta) h(;θ),我们可以得到预测值 y ^ \hat{y} y^,FSL的性能就通过这个预测值和真值之间的二元损失函数 l o s s ( y ^ , y ) loss(\hat{y},y) loss(y^,y)来定义。

概览

在这部分,我们首先通过足够详实的例子给出FSL的形式化定义。为了将其与其他学习问题区别开来,我们还讨论了其与其他问题的联系和区别。接下来我们讨论了使得FSL变得棘手的核心问题。本部分的最后一节展示了为了解决FSL核心问题而产生的已有工作的分类。

问题定义

因为FSL是机器学习领域的一个子问题,所以让我们首先回忆机器学习在文献中的定义。

定义:机器学习,是指一个计算机程序 T T T,它可以从解决任务的经验 E E E中学习,并且得到更良好的性能,这个性能可以用P来表示。

比如我们可以考虑一个图像分类的问题,一个机器学习的程序可以通过从大量训练图片中获取的经验提升在这个问题上的表现,这个表现用准确度衡量。另一个例子是AlphaGo,它通过学习大量人类对局记录和自我对局的记录来提升在围棋运动中的胜率。
像上面提出的这些典型的机器学习应用,都需要大量的有监督的样本,但正像我们之前提到的,者在很多情况下往往是很难的。FSL就是机器学习的这样一种特殊情况,它希望在一个很有限的训练集(包含少数有监督的样本)上提升学习的性能。用规范化的形式定义就是:

定义:小样本学习,属于机器学习的一种,但其经验只能从一个有限的数据集中获得。

已经出现的FSL问题主要是有监督的问题,具体来说,小样本分类就是每个类只有一小部分标注的数据,应用场景包括图像分类,情感分析和模式识别。小样本分类器学习出一个分类器,可以从每一个输入预测输出。典型的场景是N-way-K-shot classification 对于N个类,每个类由K个样本组成。FSL还可以用于回归问题,用于估计两个变量的联系。除了有监督的FSL学习以外,FSL的另一个分支是强化学习,目标是在只有一些状态-行动样本的情况下寻找到一个策略。
我们总结了FSL的三种典型应用场景:

  • 作为模仿人类学习的试验台:解决FSL问题是迈向人类智能的关键问题,比如根据少量样本学习生成新字符。像人类那样,计算机程序通过有监督的样本和预先训练的先验知识,我们通过人类视觉来辨别字符是人类生成的还是机器生成的,这样的方法也能用来辨别/解析和生成手写字符。
  • 从小样本中学习:有些时候学习样本是很难获得的,比如对于药品分子结构的实验,我们对于药品毒性的实验本身是很少的,但是可以用相似分子的情况作为先验知识来改善毒性分类的准确率。
  • 用以减小所需要的数据量和计算成本:考虑图像分类问题,FSL技术可以用更少的标注图片和其他训练的先验知识改善分类准确率,这种方法往往可以获取更高的泛化能力,也适用于其他样本更多的问题。
    表2增加了先验知识作为 E E E的一部分,如果仅有与任务直接相关的一小部分数据,那么用传统的学习策略肯定是很难得到想要的结果,所以必须加上在我们得到数据之前就已经通过一些方式获得的先验知识。一个典型的例子是贝叶斯学习,它在学习时加入了一个与样本集合无关的先验分布。
    注:根据样本数目的多少,FSL还分为单样本学习和零样本学习。因为不包括有监督的信息,零样本学习需要其他类似学习任务的一些信息。

相关的学习问题

在这一部分,我们讨论一些相关的机器学习问题以及与FSL问题的联系和区别。

  • 弱监督学习:弱监督学习的样本集合是不完整/不精确/不确切或者是有噪声的,其中不完整样本集合与FSL最为类似。根据是否存在人工介入,弱监督学习可以被分为以下几类。
    • 半监督学习:半监督学习是从一小部分有标签的样本和大部分无标签的样本中进行学习,比如文本和网页分类。非负样本学习(Positive-unlabeled learning)是其中一个特例,在这里我们只知道正样本和无标签样本而没有负样本,比如社交网络中的好友推荐,我们只知道一部分用户的好友,而对剩下的用户是不是好友一无所知,因此无法确定谁不是好友。
    • 主动学习:主动学习选择一部分信息量较高的无标签数据去人工标注,加入了人工选择并人工对数据集进行主动补充,这往往被应用在标注数据代价很高的场景下。
      从定义上说,弱监督学习只包括分类和回归两类问题,而FSL包括强化学习。而且不完整样本集合的弱监督学习通常只用未被标注的数据作为数据源E,而FSL利用了其他先验知识。也就是说,只有针对先验知识仅包含未标注数据的回归和分类问题,FSL和弱监督学习才是等价的。
  • 不平衡学习(倾斜学习):不平衡学习是指样本中某一类的样本很少出现,比如劣质品检验和自然灾害预测,它从所有可能的 y y y中进行学习。FSL则仅仅利用了部分样本,只是将其他的样本作为先验知识。
  • 迁移学习:将源任务/领域问题的知识传递给目标任务/领域,应用领域有跨领域推荐,跨时期空间和设备的WIFI定位。领域迁移(Domain adaptation)是一种任务相同但是应用领域不同的迁移学习,比如通过用户对电影的评价分析其对商品的评价。迁移学习在FSL问题中是经常使用的方法。
  • 元学习(Meta-learning)通过元学习器在不同任务上学习的元知识和数据集来解决全新的问题。元学习器从不同的学习任务中概括共性的信息,并在具体的新问题上进行推广。在学习优化/冷启动问题自然语言指导策略等问题上有广泛应用。元学习可以用来处理FSL问题,在之后会提到,元学习器会被用作先验知识来指导FSL任务,附录A中有详细的介绍。

FSL的核心问题

在任何机器学习的问题中,误差都是必然存在的。这一部分我们通过监督学习中的残差分解来说明FSL的核心问题。我们的讨论适用于有监督的分类和回归问题,对强化学习问题也提出了一些启发性的思想和探讨。

经验误差风险的最小化

给定loss function,我们希望我们给出的预测策略得到的loss在平均意义下最小。因此我们将loss的期望称为期望风险(expected risk)。但是因为真实数据的分布往往未知,因此我们只能将数据集中的所有样本的loss求平均,称之为实际风险(empirical risk)。我们真正的目标是最小化期望风险,假设这个使得期望风险最小化的为 h ^ \hat{h} h^,显然我们不可能知道 h ^ \hat{h} h^,机器学习所做的一切是在一个可能的空间内想尽一些办法逼近 h ^ \hat{h} h^,假设逼近的结果为 h ∗ h^* h,这是理论中的第一重近似。但当我们想要用种种方法求 h ∗ h^* h的时候,发现这对我们来说仍然是不可能的,因为我们无法准确知道期望风险,只得退而求其次,用实际风险去估计期望风险,这又是一重近似。两重近似之后,我们实际得到的模型的损失和真正最小化的损失之间就存在一些差距。这种差距决定了我们可能永远也无法获得最佳的模型,而差距来源于两次近似,换句话说我们模型估计的缺陷是因为无法真正达到 h ^ \hat{h} h^以及无法真正知道期望损失。因此我们可以将模型与最优解的差距分成两个部分,因近似最优解带来的误差和因为估计期望损失带来的误差,其中与数据有关的是第二部分,因为我们是通过数据集的分布来估计期望损失。
因此,减小模型误差就有了三个方向:1.调整数据;2.调整模型以改变搜索空间;3.算法层面,更好同时适应搜索空间和数据集。

不可靠的实际误差最小化

回忆误差的来源,估计误差的来源是因为我们用于估计平均损失的数据集和数据的真实分布有差距,通常情况下这可以通过扩大数据量得到解决。但在FSL中,数据集的大小是有限的,对于实际误差的估计偏差可能会更大,实际误差本身不再可靠,那么对于其最小化的尝试本身也就更难,所以FSL的核心问题就在于实际误差的最小化不再可靠。可用数据集和真实数据分布相差越大,那么估计缺陷也会越大。

FSL的分类

为了解决上述问题,关键是要使用一些其他信息(先验知识)来减小估计缺陷。相关的工作大致可以分为三个方向。

  • 数据:这些方法使用先验知识来扩充和增强数据集,在扩充之后的数据集上使用标准的机器学习方法可以得到更精确的结果。
  • 模型:这种方法利用先验知识将假设空间缩小,这样h在优化时的搜索空间也就更小,估计缺陷也会因此降低,此时尽管数据仍然不多,但是模型的性能也会有很大改观。
  • 算法:这种方法使用先验知识去搜索假设空间中模型的最优参数。一方面这种被先验知识修正的搜索策略可以提供一个更好的初始点,另一方面会影响搜索策略,使得搜索时不光参考实际误差最小化,还考虑先验的搜索策略。
    接下来给出了已有工作按照上述划分标准的分类树状图。

数据层面的FSL

数据层面的主要研究方向

模型层面的FSL

模型层面的主要研究方向

算法层面的FSL

算法层面的主要研究方向

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/神奇cpp/article/detail/877620
推荐阅读
相关标签
  

闽ICP备14008679号