ACL-BioNLP 2020 | 耶鲁大学实践成果:生物医药知识图谱嵌入模型基准测试

简介: ACL-BioNLP 2020 | 耶鲁大学实践成果:生物医药知识图谱嵌入模型基准测试

image.png

今天给大家介绍的是耶鲁大学医学信息学中心主任Brandt教授实验室和爱丁堡大学的博士生联合发表在ACL-BioNLP 2020发表的文章“Benchmark and Best Practices for Biomedical Knowledge Graph Embeddings”。作者将五个KGE模型应用到SNOMED-CT知识图谱中,提供了与现有方法的比较基准并深入讨论目前的最佳实践应用,并说明了利用知识图谱的多关系特性来学习生物医学知识表示的重要性。


1


介绍


大量的生物医学领域知识存储在知识库和本体中。例如,SNOMED Clinical Terms(SNOMED-CT),世界上使用最广泛的医疗保健文献和报告的临床术语,包含数十万个医学术语及其关系并拥有多层次组织结构。我们可以将SNOMED-CT看作一个知识图谱,此外,它提供了一个词库,该词库在一个通用的本体论框架下结合了数百万种生物医学概念和关系。


自然语言处理中临床和生物医学领域的主要障碍之一是如何更有效地表示和整合领域知识。尽管自然语言处理领域的最新进展极大地改善了文本表示,但迄今为止,在术语或知识图谱中学习生物医学概念的类似密集概念嵌入的尝试限制了其可用性以及无法广泛使用。此外,当前仍未出现用于训练和比较这种嵌入的最佳实践或基准。


作者探索了知识图谱嵌入模型作为现有方法的替代方法并做出以下贡献:


在SNOMED-CT上训练了五个最新的KGE模型,并展示了它们相对于先前方法的优势,从而证明了利用知识图谱的多关系性质进行生物医学知识表示的重要性;


建立了一套基准任务,以实现各种方法之间的公平比较;


通过提供与现实世界相关的新数据集的基准来服务于整个KGE社区;


将嵌入,代码和其他资料开源,并概述了未来工作的几种方向,以促进该领域的进步。


2


实验设置


由于在通用的可扩展平台下实现,作者将实验限制在五个模型中:TransE, ComplEx, DistMult, SimplE和RotatE。


2.1数据


考虑到UMLS的复杂性,作者详细介绍了生成最终数据集的预处理步骤。将得到的三元组列表构成了最终的知识图谱数据集。另外作者还排除了不必要的特定语义类型。表1显示了最终数据集的描述性统计信息。

image.png

表1 最终SNOMED数据集的统计信息


2.2实现


考虑到SNOMED-CT的巨大规模以及可扩展性和一致的实施对于运行实验的重要性,作者将GraphVite用于KGE模型。虽然目前的工作仅限于这些模型,但未来的工作应该考虑其他最先进的模型,例如TuckER和MuRP,尤其是因为MuRP被证明对具有层次结构的图特别有效。


所有实验都在3个GTX-1080ti GPU上运行,最后的运行在单个GPU上花费了大约6个小时。可以根据每种模型的验证集调整超参数。


2.3评估和基准


2.3.1KGE链接预测


KGE文献中的标准评估任务是链接预测。但是,NE方法也将链接预测用作标准评估任务。当两者都预测是否连接了两个节点时,NE链接预测会基于该图是完整的假设,在一组平衡的正负边缘上执行二进制分类。相反,知识图谱通常被假定为不完整,这使得KGE的链接预测成为基于排名的任务,在该任务中,模型的评分函数被用于对候选样本进行排名,而不依赖于基本事实否定。在本文中,链接预测是指后一种基于排名的KGE方法。


典型的链接预测指标包括MR,MRR和Hits@k。MR被认为对异常值敏感,并且不可靠。Guu等人提出使用平均分位数(MQ)作为MR和MRR的更强大的替代方案。作者使用MQ100作为MQ的更具挑战性的版本,它在排名前100的位置引入了一个临界值,适用于大量可能的实体。


2.3.2嵌入评估


作者通过采用所有模型中涵盖的概念的交集来生成用于实体分类的数据集,包括39k个具有32个唯一语义类型和4个语义组的概念。并且以9:1的比率将数据分成训练集和测试集,训练一个dropout比率为0.1且没有进一步的超参数调整的简单线性层。用于分类的单一线性层评估每个模型的实体嵌入空间中语义信息的线性可分性。


3


可视化


作者首先讨论通过LargeVis获得的嵌入可视化效果,这是一种有效的大规模降维技术,可用作GraphVite中的应用。图1显示了RotatE,ComplEx,Snomed2Vec和Cui2Vec的概念嵌入,其颜色对应于广泛的语义组。


有趣的是,针对5个KGE模型的嵌入可视化分为两种类型:RotatE和TransE产生分离良好的簇,而ComplEx,DistMult和SimplE围绕原点产生球状簇。作者将两种模型类型之间的特征差异归因于其评分函数的性质:RotatE和TransE具有加法成分,而ComplEx,DistMult和SimplE具有乘法成分。

image.png

图1按语义组的概念嵌入可视化

通过在“Procedures”语义组下为5种选定的语义类型着色并将其余的部分灰显,显示了更细粒度的语义结构。图2中将具有2,000多个实体的语义类型抽样到1,200个以提高可见性。

image.png

图2 Procedures语义组下选定语义类型的可视化


4


结论


4.1链接预测


由于没有以前的结果可比较,作者将TransE和RotatE在两个标准KGE基准数据集上的性能作为参考:FB15k-237(14,541个实体,237个关系和310,116个三元组)和WN18RR(40,943个实体,11个关系和93,003个三元组)。鉴于SNOMED-CT比两个数据集更大,并且可以说是一个更复杂的知识图谱,因此链接预测结果表明KGE模型学习了SNOMED-CT的合理表示。表2显示了SNOMED-CT上5个KGE模型的链接预测任务的结果,其中表的上部针对SNOMED-CT上的5个KGE模型,下部针对两个标准KGE数据集上的TransE和RotatE。


表2 链接预测结果

image.png

4.2 嵌入评估和关系预测


根据语义簇的可视化效果(图1和2),KGE和NE方法的性能明显优于语料库-基于方法(Cui2Vec)。值得注意的是,对于更广泛的语义组分类(4类),TransE和RotatE达到了近乎完美的准确性。ComplEx,DistMult和SimplE的性能稍差一些,Snomed2Vec略低于它们,而Cui2Vec则落后很多。表3显示了实体语义类型(STY)和语义组(SG)分类的测试集准确性。


表3 语义类型和组的分类结果

image.png

为了与相关工作进行比较,作者还研究了由Beam等人提出的基于统计能力和余弦相似性自举的基准任务,以评估医学概念的嵌入。相比之下,KGE方法显式地建立关系模型,并且可以更好地推断知识图谱嵌入的关系结构。表3的最后3列报告了5个KGE模型的关系预测指标。尤其是RotatE和SimplE表现良好,达到了约0.8 Hits @ 1和大约0.85 MRR。


作者根据源语义组和目标语义组的基数和同质性将关系类型分为6个组,从而进行错误分析,以进一步了解问题。表4显示了RotatE和ComplEx的6组关系类型的每一个的关系预测指标,最后两行与因果关系类型相关。


表4 按关系类型分类的RotatE和ComplEx的关系预测结果

image.png

每个模型下的最后两行显示了前面提到的因果关系的每个关系结果:cause_of和causative_agent_of。与ComplEx相比,RotatE再次显示出明显更好的结果,这与其理论上优越的表示能力一致。


5


展望


未来可以从几种途径直接入手,作者致力于GraphVite中实现的SNOMED-CT数据集和KGE模型,但也可以扩展到其他生物医学术语(如基因本体论和RxNorm),并应用更近期的KGE模型(如TuckER和MuRP);还可以纳入其他信息来源,如实体和关系的文本描述。最后,可以在生物医学NLP的下游应用中研究生物医学知识图谱嵌入的有用性,例如信息提取,概念归一化和实体链接等。总体而言,用于学习和合并特定领域知识表示的方法仍处于早期阶段,需要进一步讨论。


目录
相关文章
|
22天前
|
Java 测试技术 开发者
初学者入门:掌握单元测试的基础与实践
【10月更文挑战第14天】单元测试是一种软件测试方法,它验证软件中的最小可测试单元——通常是单独的函数或类——是否按预期工作。单元测试的目标是确保每个模块在其自身范围内正确无误地运行。这些测试应该独立于其他模块,并且应该能够反复执行而不受外部环境的影响。
45 2
|
30天前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
27天前
|
测试技术 UED
软件测试的艺术与实践
【10月更文挑战第9天】 在数字时代的浪潮中,软件成为了我们生活和工作不可或缺的一部分。然而,高质量的软件背后,是无数测试工程师的默默付出。本文将通过深入浅出的方式,探讨如何进行高效的软件测试,确保软件产品的质量与稳定性。我们将一起揭开软件测试的神秘面纱,从基础理论到实际操作,一步步走进这个充满挑战与创造的世界。
|
2天前
|
测试技术 API Android开发
探索软件测试中的自动化框架选择与实践####
本文深入探讨了软件测试领域内,面对众多自动化测试框架时,如何依据项目特性和团队需求做出明智选择,并分享了实践中的有效策略与技巧。不同于传统摘要的概述方式,本文将直接以一段实践指南的形式,简述在选择自动化测试框架时应考虑的核心要素及推荐路径,旨在为读者提供即时可用的参考。 ####
|
13天前
|
机器学习/深度学习 人工智能 自然语言处理
探索软件测试的边界:从基础到高级的实践之旅
【10月更文挑战第21天】 在当今数字化时代,软件已成为我们生活和工作中不可或缺的一部分。随着技术的快速发展,对软件质量的要求也日益提高。本文旨在通过深入浅出的方式,带领读者踏上一场从基础到高级的软件测试实践之旅。我们将探讨软件测试的基本概念、重要性以及如何有效地进行测试规划和执行。通过具体案例分析,揭示常见错误及其解决方案,同时展望未来软件测试领域的发展趋势。无论你是软件开发新手还是经验丰富的测试工程师,这篇文章都将为你提供宝贵的见解和启发。
33 8
|
12天前
|
编解码 人工智能 自然语言处理
迈向多语言医疗大模型:大规模预训练语料、开源模型与全面基准测试
【10月更文挑战第23天】Oryx 是一种新型多模态架构,能够灵活处理各种分辨率的图像和视频数据,无需标准化。其核心创新包括任意分辨率编码和动态压缩器模块,适用于从微小图标到长时间视频的多种应用场景。Oryx 在长上下文检索和空间感知数据方面表现出色,并且已开源,为多模态研究提供了强大工具。然而,选择合适的分辨率和压缩率仍需谨慎,以平衡处理效率和识别精度。论文地址:https://www.nature.com/articles/s41467-024-52417-z
37 2
|
12天前
|
监控 安全 jenkins
探索软件测试的奥秘:自动化测试框架的搭建与实践
【10月更文挑战第24天】在软件开发的海洋里,测试是确保航行安全的灯塔。本文将带领读者揭开软件测试的神秘面纱,深入探讨如何从零开始搭建一个自动化测试框架,并配以代码示例。我们将一起航行在自动化测试的浪潮之上,体验从理论到实践的转变,最终达到提高测试效率和质量的彼岸。
|
15天前
|
测试技术 C# 数据库
C# 一分钟浅谈:测试驱动开发 (TDD) 实践
【10月更文挑战第18天】测试驱动开发(TDD)是一种软件开发方法论,强调先编写测试代码再编写功能代码,以确保代码质量和可维护性。本文从 TDD 的基本概念入手,详细介绍了其核心步骤——编写测试、运行测试并失败、编写代码使测试通过,以及“红绿重构”循环。文章还探讨了 TDD 的优势,包括提高代码质量、促进设计思考、减少调试时间和文档化。此外,文中分析了常见问题及解决方案,如测试覆盖率不足、测试代码过于复杂、忽视重构和测试依赖过多,并通过一个简单的计算器类的代码案例,展示了 TDD 的实际应用过程。
32 1
|
22天前
|
机器学习/深度学习 人工智能 自然语言处理
探索AI在软件测试中的创新应用与实践###
本文旨在探讨人工智能(AI)技术如何革新软件测试领域,提升测试效率、质量与覆盖范围。通过深入分析AI驱动的自动化测试工具、智能化缺陷预测模型及持续集成/持续部署(CI/CD)流程优化等关键方面,本研究揭示了AI技术在解决传统软件测试痛点中的潜力与价值。文章首先概述了软件测试的重要性和当前面临的挑战,随后详细介绍了AI技术在测试用例生成、执行、结果分析及维护中的应用实例,并展望了未来AI与软件测试深度融合的趋势,强调了技术伦理与质量控制的重要性。本文为软件开发与测试团队提供了关于如何有效利用AI技术提升测试效能的实践指南。 ###
|
1月前
|
测试技术
软件测试中的探索性测试(ET)实践
【10月更文挑战第5天】本文将深入探讨一种与传统脚本化测试不同的测试方法——探索性测试(Exploratory Testing,简称ET)。我们将通过一个实际案例来展示ET的有效性,并分享如何将ET融入日常的软件测试流程中。文章旨在为测试人员提供一种灵活、高效的测试策略,帮助他们更好地发现软件中的缺陷。
下一篇
无影云桌面