论文地址:Language-Agnostic Representation Learning of Source Code from Structure and Context
CodeTransformer:只使用AST语言无关特征做多语言训练
Abstract
原代码(context)和语法结构树(AST)是程序的两种互补表示,本文模型只使用了语言无关的特征,即原代码和特征可以直接从AST中计算得到。除了在五种编程语言单语言代码摘要SOTA外,也是第一个提出了多语言代码摘要模型,对来自多种编程语言的非并行数据进行联合训练可以提高所有单个语言的结果,特别是在低资源的语言上。只在context多语言训练不能得到同样的提升,所以结果肯定是结构和上下文组合得到的
Introduction
研究人员和从业者在机器学习模型中主要利用结构或上下文,作者证明了上下文和结构的联合学习改进了源代码的表示学习
data:image/s3,"s3://crabby-images/13021/13021988e2379f939e92fcd41533142fa6a88138" alt="avatar"
作者提出了CodeTransformer结合了在自注意操作在结构和上下文上计算的距离,与通过边进行的局部处理相比,计算AST上的成对距离,如最短路径长度,使每一层的模型都可以访问完整的结构。此外在注意力计算时使用了相对距离替代绝对位置,这些都是语言无关的特征可以直接使用
Integrating Structure and Context in the Code Transformer
Integrating Source Code and AST Representations of Programs
data:image/s3,"s3://crabby-images/41e73/41e73b32033c50f047659eb884381bc88f542bc5" alt="avatar"
PPR是Personalized PageRank
data:image/s3,"s3://crabby-images/b0357/b03576cea1566c8c83c63655336a6064c8765e42" alt="avatar"
Efficient Relative Attention Computation
data:image/s3,"s3://crabby-images/54b70/54b70b91556a23734b4a352f8fc41f915a609610" alt="avatar"
这里用的解耦注意力和相对位置距离
Experiment
data:image/s3,"s3://crabby-images/cb392/cb392c9f89435a4809a4848cb5094a67d8744699" alt="avatar"
data:image/s3,"s3://crabby-images/10e7e/10e7ed423be292553b7d1021a9784faf77309dcb" alt="avatar"
data:image/s3,"s3://crabby-images/894aa/894aa3bb43892b1b6cac29c7c85873263a51d0f6" alt="avatar"