长尾分布下的视网膜:关系子集学习、射击法、加权知识蒸馏
- 核心思想
- 问题:类别分布的不平衡问题
- 问题:共现标签
- 问题:特定区域和特征的类别关联
- 解法:划分子集解决样本不平衡问题
- 解法:射击法解决共现标签问题
- 解法:划分子集解决,特定解剖区域、特征的类别
- 效果
- 总结
- 子问题1:长尾分布问题
- 子问题2:标签共现问题
- 子问题3:特定区域和特征的类别关联
- 子问题4:模型性能平衡问题
论文:https://arxiv.org/pdf/2104.11057.pdf
核心思想
论文讨论 3 个关于医学影像分析的挑战,以及相应的解决方案。
问题:类别分布的不平衡问题
首先,论文提到的第一个问题是数据中类别分布的不平衡。
在很多情况下,一些类别的样本非常多,而其他类别的样本则很少。
为了解决这个问题,建议把数据按照一定的先验知识,比如区域或表型信息,分成几个小的类别子集。
这样一来,模型就能专注于学习每个子集的特点,从而更有效地处理数据不平衡的问题。
表中列出了每个数据集中拥有不同数量标签的图像数。
- 在Lesion-10数据集中,有5929个图像只包含一个病变标签,1569个图像包含两个病变标签,等等。
- 在Disease-48数据集中,包含两个及以上疾病标签的图像超过了22000张。
问题:共现标签
接下来,第二个问题,即共现标签。
在医学影像里,一个样本可能同时包含多个疾病的标签,这就使得分析变得复杂。
但共现标签(Co-occurring labels)和多标签(Multi-label)不完全相同。
多标签 指的是每个样本可以同时拥有多个标签。在多标签问题中,每个实例或数据点不是简单地被分配到单一的类别,而是可以关联到多个类别。
例如,在一个医学图像的多标签分类问题中,一个图像可能同时被标注为包含“黄斑变性”和“糖尿病视网膜病变”。
共现标签 是多标签数据集中的一个现象,其中某些标签组合经常一起出现在同一实例中。共现标签意味着数据集中某些标签组合比其他组合更常见。
例如,如果在很多图像中“高血压”和“心脏病”这两个标签经常同时出现,那么它们就是共现标签。
在多标签学习中,共现标签可能会对模型训练产生影响,因为模型可能会学习到这些标签间的依赖关系。
理解共现关系可以帮助改进分类器的性能,使其能够更准确地预测标签的这种组合。
处理共现标签的常见方法包括损失函数的设计,这可以帮助模型区分哪些标签组合是重要的,并学习如何正确地预测它们。
为此,提出了一种加权知识蒸馏的方法。
这个方法通过训练几个不同的“教师”模型,每个模型专注于不同的类别子集,然后再把这些模型的知识结合到一个“学生”模型中。
目的是在处理多标签问题时,让模型能够更好地区分不同的疾病标签。
问题:特定区域和特征的类别关联
最后,论文解决了第三个问题,即特定区域和特征的类别关联问题。
有些疾病与特定的解剖区域,比如视盘或黄斑,或者特定的病理特征,比如出血,有关。
建议根据这些关联,将疾病分到相关的类别子集中。
这种方法可以让模型更加专注于学习与特定区域或特征相关的疾病,提高分析的准确性。
视网膜疾病数据分布的情况,特别是它呈现出长尾分布的特点。
在长尾分布中,头部的类别(图中的“Head”区域)有大量的图像,而尾部的类别(图中的“Tail”区域)则图像数量急剧减少。
这种分布表明有一小部分疾病类别的样本数量很多,而大多数疾病类别的样本数量较少。
在图中的“Class Distribution”放大区域中,不同颜色的圆点代表不同的类别,并且它们之间的箭头表示标签之间的共现关系。
这意味着某些疾病类别的标签往往同时出现,表明存在某种关联。
例如,一个图像可能同时被标记为具有两种或多种疾病。
在长尾部分,也看到了一些具体的视网膜图像,可能用以说明数据集中那些较少见的类别。
整体来说,这张图旨在展示视网膜疾病在数据集中的不均匀分布,并且指出标签共现是在不同类别之间常见的现象。
标签共现导致的分类困难。
上图,展示数据集中不同类别之间的共现关系。
- 色块的深浅代表了不同类别共现的频率,深色表示共现较少,亮色表示共现较多。
标签共现(Label Co-occurrence)指的是在多标签数据集中,不同的标签(疾病类别)经常一起出现在同一个样本上。
例如,一个视网膜图像可能同时被标记有“出血”和“渗出物”的标签,这就是两个标签共现的情况。
在医学影像分析和其他多标签分类任务中,标签共现是一个常见现象。
反映了真实世界中的疾病关联,比如某些视网膜疾病可能会同时发生,或者一个疾病可能导致多种病理变化。
识别和理解这些共现关系对于建立准确的预测模型非常重要,因为它可以帮助模型学习不同疾病标签之间的关系,从而改善对每个独立疾病标签的识别能力。
作者提出一个框架,针对的是处理长尾分布样本的情况:
框架分为两个阶段:
- 第一阶段,原始的长尾样本根据关联类别约束被划分成多个子集。
这些子集按照样本数量的多少分为“Many”(多)、“Medium”(中等)和“Few”(少),或者按照解剖区域分为“Optic Disc”(视盘)、“Macula”(黄斑)和“Others”(其他),或者按照特征分为“Hemorrhages”(出血)、“Exudates”(渗出物)和“Others”(其他)。
这样的划分帮助模型更好地理解和学习那些不常见的类别。 - 第二阶段,训练一个统一的“学生”模型,该模型使用所训练的“教师”模型的参数,并应用加权知识蒸馏损失(Weighted Knowledge Distillation Loss)。
在这里,"教师"模型专注于特定的子集,并将学习到的知识通过知识蒸馏的方式传递给“学生”模型。
图中展示了不同的“教师”模型,它们各自处理不同的子集,并通过权重和标签的调整来影响“学生”模型的训练。
这张图也展示了损失函数的计算方式,其中包括交叉熵损失()和知识蒸馏损失()。
最终的损失(( L ))是这两部分损失的组合,用于优化统一模型的参数。
总的来说,这个框架旨在通过创建多个专注于特定子集的“教师”模型和一个统一的“学生”模型来解决长尾分布问题,同时考虑到疾病标签的共现和类别间的关系。
这种方法旨在提高模型对稀有类别的识别能力,并提高在多标签分类任务中的性能。
上图显示了不同医学征象(病变)在视网膜的特定区域中出现频率的热图。
这些热图帮助识别出某些医学征象,更倾向于在视网膜的哪个区域出现。
热图被分为四个部分,每个部分对应不同的视网膜区域:
- a) 全局基金地区(global fundus areas)
- b) 黄斑区(macula)
- c) 视盘区(optic disc)
- d) 血管区(vessels)
在每个部分中,列出了不同的医学征象,如出血(hemorrhage)、色素沉着(pigmentation)、硬渗出物(hard exudates)、软渗出物(soft exudates)、视网膜上膜(epiretinal membrane)、黄斑裂孔(macular hole)等。
通过这些热图可以观察到,例如出血和色素沉着在全局区域内出现得更为频繁,而特定的征象如黄斑裂孔主要出现在黄斑区。
表格提供了基于区域的子集和相应病变/疾病的列表。
例如,
- 视盘区经常与青光眼(Glaucoma)和视网膜髓样神经纤维(retinal myelinated nerve fiber)等病变相关联;
- 黄斑区则与视网膜上膜、硬渗出物和黄斑裂孔等相关;
- 血管区与动脉静脉交叉现象(arteriovenous crossing phenomenon)和血管周围鞘(perivascular sheathing)等相关。
这些数据和可视化有助于研究人员和算法开发者更好地理解特定病变在视网膜上的分布规律,并可以用于提高自动疾病诊断算法的准确性。
解法:划分子集解决样本不平衡问题
首先是样本不平衡的问题。
举个例子,如果咱们的数据集里有1000张糖尿病视网膜病变的图片,但只有100张青光眼的图片,这就是不平衡。
解决的办法是划分关系子集,比如把所有的视网膜病变图片分成几个小组,每个小组里的疾病类型和图片数量都差不多,这样每种疾病的重要性就能得到平等对待。
如果简单地把所有的糖尿病视网膜病变和青光眼图片分成若干组,那么糖尿病的数据依然会很多。
这里的关键在于如何划分这些子集,使得每个子集内部的数据分布更加平衡。
咱们可以这样做:
- 按疾病严重程度划分:如果这些糖尿病视网膜病变图片中,有严重的、中等的和轻微的变化,咱们可以将它们按照严重程度分成几个子集。
这样,即使糖尿病图片多,但每个严重程度的类别内部是平衡的。
同理,如果青光眼图片中也有不同程度的变化,也可以这样分。 - 按解剖区域划分:另一个方法是按照疾病影响的视网膜区域来分组。
比如,糖尿病视网膜病变可能主要集中在黄斑区,而青光眼影响的是视神经盘周围区域。
这样分组后,每个区域内部的数据量可能会更接近。 - 按病变特征划分:也可以根据病变的特征,如出血、渗出物等,将图片分组。
这样,不同疾病但有相似特征的图片就会被归为一类,这有助于学习病变特征,而不是单纯关注疾病标签。
目标是让模型能够从每个子集中学到有用的信息,而不是仅仅因为某个疾病的样本多就偏向于它。
- 轻度子集:300张糖尿病视网膜病变 + 100张青光眼 = 400张图片
- 中度子集:400张糖尿病视网膜病变 + 100张青光眼 = 500张图片
- 重度子集:300张糖尿病视网膜病变 + 100张青光眼 = 400张图片
平衡并不是指每个疾病的样本数量完全相同,而是说在每个严重程度的子集中,疾病之间的比例更加接近,使得模型能够对每种严重程度的特征进行学习,而不是由于某一疾病样本数量过多而导致的偏差。
通过这样的划分,每个疾病,无论其在数据集中的总数量如何,都能在至少一个子集中得到充分的代表,从而帮助模型更均衡地学习。
解法:射击法解决共现标签问题
第二个问题,多标签分类中标签共现的问题。
用射击法划分子集的好处就是,可以将相似数量的病变标签分在一起,避免因为某个标签特别多而影响模型对其他标签的学习。
如果糖尿病视网膜病变的图片有1000张,青光眼的图片有100张,同时有糖尿病和青光眼的图片有50张,我们可能会将它们分为三个子集:
- “多射击子集”:只包含糖尿病视网膜病变的图片
- “中射击子集”:只包含青光眼的图片
- “少射击子集”:同时包含糖尿病和青光眼的图片
为了让模型平等地学习每种疾病,我们可以进一步平衡这些子集。
例如,在“少射击子集”中,因为标签共现的图片数量少,我们可以通过数据增强等技术来增加样本数量,或者调整模型训练时的权重,以确保这部分数据对模型的影响与其他子集相当。
分别在这些子集上训练模型,这样每个模型就可以在没有其他类别干扰的情况下学习特定的标签信息。
最后,我们可以用知识蒸馏等技术,将这些单独训练的模型的知识结合起来,训练一个综合所有子集信息的“学生”模型。
让模型对每种疾病标签都有比较好的识别能力,即使某些疾病的图片数量比其他的少。
这样,模型的识别能力不会偏向于那些标签更多的类别。
解法:划分子集解决,特定解剖区域、特征的类别
第三个问题,疾病在特定解剖区域集中出现的问题。
不同疾病出现不同区域。
比如,糖尿病视网膜病变可能主要在黄斑区(视网膜中心)出现,而青光眼可能更多影响到视神经盘。
基于区域的子集划分就是根据这种解剖特征来分组,让模型能专注于特定区域的特征。
步骤1:识别和标记区域
- 我们首先需要对影像数据中的不同区域进行识别和标记。
- 由眼科医生完成,他们能够识别出黄斑区、视神经盘等解剖结构。
步骤2:创建子集
- 然后,我们按照这些区域划分数据集。
- 所有主要显示黄斑区变化的图像构成一个子集,所有主要显示视神经盘变化的图像构成另一个子集。
- 黄斑区子集:包含所有糖尿病视网膜病变的图像。
- 视神经盘子集:包含所有青光眼的图像。
步骤3:模型训练
对于每个子集,我们独立训练一个机器学习模型。
这样,每个模型都可以专注于学习影响特定区域的疾病特征。
- 黄斑区模型:只学习和识别黄斑区的病变,比如糖尿病视网膜病变的特征。
- 视神经盘模型:只学习和识别视神经盘的病变,比如青光眼的特征。
步骤4:综合和评估
在独立训练之后,我们评估每个模型的性能,确保它们各自能准确识别相应区域的病变。
包括在一个综合的测试集上测试,该测试集包含了影响不同视网膜区域的多种疾病。
通过这种方法,我们不仅提高了模型对特定区域病变的识别能力,而且还使得模型可以更精准地针对具体疾病进行诊断。
第四个问题是,很多疾病有相似的病理特征。
就像糖尿病视网膜病变和高血压视网膜病变,都可能有出血(出现血斑)和渗出物(视网膜上的小白点)特征。
基于特征的子集划分就是把这些有共同特征的疾病分在一起,这样模型就可以学习到哪些特征是这几种病共有的。
我们现在要构建一个能够识别这些特征的模型。
但是,如果我们把所有DR和HR的图片都混在一起训练模型,模型可能会学习到哪些特征与特定疾病相关,而不是哪些特征是两种疾病共有的。
步骤1:识别共同特征
首先,我们需要通过图像分析或专家知识来识别出DR和HR图片中共有的病理特征。
在这个例子中,我们已经确定出血和渗出物是两种疾病共有的特征。
步骤2:创建基于特征的子集
接下来,我们根据这些共同特征创建两个子集:
- 出血子集:包括所有显示出血特征的DR和HR图片。
- 渗出物子集:包括所有显示渗出物特征的DR和HR图片。
这样做的目的是集中在特定的病理特征上,而不是疾病标签。
步骤3:模型训练
然后,我们分别对这两个子集训练我们的模型:
- 在出血子集上训练的模型会专注于学习出血这一特征。
- 在渗出物子集上训练的模型则会专注于学习渗出物这一特征。
步骤4:评估和应用
最后,我们评估每个模型的性能,确保它们能够准确识别出对应的病理特征。
这些模型现在可以应用于新的影像数据,帮助医生识别和区分DR和HR,即使在新的数据中这些特征可能与其他病变特征共现。
通过这种基于特征的子集划分,我们能够更好地让模型学习到不同疾病共有的特征,而不是仅仅依赖于疾病的标签。
这可以显著提高模型在实际临床应用中的泛化能力和准确性。
最后,是知识整合的问题。
咱们已经有几个模型了,每个模型都学习了一部分疾病的信息,现在需要把这些知识合并起来。
多重加权知识蒸馏就是将每个模型学到的知识,根据它们的重要性给予不同的权重,然后传递给一个新的模型,这样这个新模型就能全面地理解所有类型的疾病了。
效果
在Lesion-10和Disease-48这两个数据集上,对于长尾分类问题的不同方法的性能结果,使用平均精度均值(mAP)作为评价指标。
表格中展示了各种方法在数据集不同部分(头部、中部、尾部)以及整体上的性能表现。
其中包括了基线的ERM模型、各种重采样(RS)和重加权(RW)方法、Focal Loss、OLTR、LDAM和DB Loss等方法,以及作者自己提出的基于射击(shot-based)、基于区域(region-based)和基于特征(feature-based)的方法。
- 此外,还展示了将作者的方法与其他当时最先进方法结合的结果。
在这个表中可以看到,作者提出的方法在处理长尾分布时,在尾部类别上取得了显著提高,特别是与Focal Loss相结合时,在Lesion-10数据集上的总体mAP提升了1.38%,表明了作者方法在提升模型性能方面的有效性。
在Disease-48数据集上,这个柱状图展示了在不同类别上的性能提升,在尾部类别上的性能提升更为显著,这与表3中的结果一致。
这个图表进一步证实了作者方法在改善尾部类别的诊断结果方面的有效性。
总结
假设我们有一个视网膜疾病图像的数据集,它受到长尾分布的影响,即某些疾病的图像非常多(如糖尿病视网膜病变),而其他疾病的图像非常少(如黄斑裂孔)。
子问题1:长尾分布问题
- 子解法1:关系子集知识蒸馏
- 首先,面对长尾分布,我们将数据按照疾病类型、解剖区域或病变特征划分成多个子集。这样做是为了在子集内部达到更平衡的数据分布,让模型可以专注于学习每个子集的特点,从而提高对稀有类别的识别能力。
子问题2:标签共现问题
- 子解法2:本地共现标签的关系子集学习
- 接着,针对标签共现问题,我们进一步优化子集的划分,确保共现标签的样本得到特别关注。这可以通过识别共现标签的模式,并据此调整子集的划分策略来实现。这种专门针对共现标签的训练有助于减少模型对这些共现标签的混淆。
子问题3:特定区域和特征的类别关联
- 子解法3:基于区域和特征的子集划分
- 随后,我们根据疾病与特定解剖区域或特征的关联,如黄斑区疾病与视盘区疾病,进一步细化子集划分。这种划分依据疾病在解剖结构上的分布和表现,使得模型能更精确地学习特定区域或特征相关的疾病特点。
子问题4:模型性能平衡问题
- 子解法4:加权知识蒸馏损失
- 最后,为了整合各个子模型的知识,并平衡模型在不同类别上的性能,我们采用加权知识蒸馏的方法。这意味着将各个子模型(教师模型)的知识以一定的权重蒸馏给一个综合模型(学生模型),权重的分配考虑了类别的重要性和稀有程度,以优化模型在所有类别上的整体性能。
从关系子集的划分开始,到针对共现标签的优化,再到基于特定区域和特征的细化子集,最后通过加权知识蒸馏整合知识,这
这种逐步深入、相互关联的策略,不仅平衡了模型在各类别上的性能,也提高了模型对稀有疾病的识别能力,体现了从数据预处理到模型训练再到知识整合的全面考虑。