[发明专利]一种高级编程语言间代码自动转换方法在审

专利信息
申请号: 202011617567.5 申请日: 2020-12-30
公开(公告)号: CN112732264A 公开(公告)日: 2021-04-30
发明(设计)人: 刘毅;李家勋;李旭;肖彬 申请(专利权)人: 中国船舶重工集团公司第七0九研究所
主分类号: G06F8/40 分类号: G06F8/40;G06F8/30
代理公司: 武汉河山金堂专利事务所(普通合伙) 42212 代理人: 胡清堂
地址: 430205 湖北省武汉市*** 国省代码: 湖北;42
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 高级 编程 语言 代码 自动 转换 方法
【说明书】:

发明公开了一种高级编程语言间代码自动转换方法,包括如下步骤:S1、搜集各种编程语言大量的源代码,作为神经模型训练的语料库;S2、采用自然语言翻译中使用的跨语言的seq2seq模型进行训练,该模型采用transformer架构。本发明采用人工智能技术,将自然语言机器翻译中的神经模型借鉴到编程语言转换中,经过模型训练,实现高级编程语言间代码自动转换的目的,可以广泛应用于计算机编程语言领域。

技术领域

本发明涉及计算机编程语言和人工智能领域,特别是涉及一种高级编程语言间代码自动转换方法。

背景技术

将高级编程语言写成的源代码转自动换成另一种语言(如将C++转换成JAVA),能够提高代码的复用性、减少软件开发的工作量、缩短项目周期,具有重要的现实意义。目前主要采用源到源编译器技术实现该功能,它通常依赖于手动编写的重写规则,并应用于源代码抽象语法树。但是,源到源编译器存在一些缺陷,如转换结果通常缺乏可读性,无法遵循目标编程语言的规范,需要程序员进行手动修改才能准确运行。整个转换过程不仅耗时,还需要程序员能够同时掌握源语言和目标语言的专业知识,因此使用该方法进行代码转换项目的工作量很大,实际应用较困难。

发明内容

本发明的目的是为了克服上述背景技术的不足,提供一种高级编程语言间代码自动转换方法,使其针对目前高级编程语言间代码自动转换问题没有好的解决办法、自动化程度低的问题,采用人工智能技术,将自然语言机器翻译中的神经模型借鉴到编程语言转换中,经过模型训练,实现高级编程语言间代码自动转换的目的。

本发明提供的一种高级编程语言间代码自动转换方法,包括如下步骤:S1、搜集各种编程语言大量的源代码,作为神经模型训练的语料库;S2、采用自然语言翻译中使用的跨语言的seq2seq模型进行训练,该模型采用transformer架构。

在上述技术方案中,所述步骤S1中,编程语言包括C++和JAVA。

在上述技术方案中,所述步骤S2的具体步骤如下:S21、预训练编码器和解码器,产生跨语言的句子表征;S22、语言建模,训练同语种翻译,利用去噪自编码,训练解码器生成有效的序列;S23、利用回译训练跨语种翻译。

在上述技术方案中,所述步骤S21的具体步骤如下:S211、采用XLM来分别预训练编码和解码器,把各种编程语言语料库放在一起,每次batch选择一种语言;S212、使用MLM模型和TLM模型进行训练和交互。

在上述技术方案中,所述步骤S22的具体步骤如下:S221、给输入加上干扰,然后把它传给机器翻译模型;S222、解码器重新把正确的代码恢复,即自己翻译自己。

在上述技术方案中,所述步骤S23的具体步骤如下:S231、利用步骤S22产生的模型进行两次翻译,从A语言翻译到B语言,再从B语言到A语言,构建有监督的数据集;S232、将有监督的数据集当做信号回传给翻译模型进行训练。

在上述技术方案中,还包括步骤S3、使用测试集进行对比测试,验证模型训练后自动转换不同编程语言间代码的转换对齐质量。

在上述技术方案中,所述步骤S3的具体过程为:测试使用三个评估度量指标:BLEU值、参考匹配和计算准确率。

在上述技术方案中,所述步骤S3中,所述BLEU值用于评估生成函数的质量;参考匹配用于评估转换结果完美匹配真值参考的比例;计算准确率用于评估当输入相同时,假设函数是否生成与参考相同的输出。

本发明高级编程语言间代码自动转换方法,具有以下有益效果:

1)仅需单语源代码即可实现编程语言转换,无需任何源语言或目标语言的专业知识;

2)能够成功掌握每种语言的特定复杂模式,并将其迁移至其他高级语言;

3)代码转换效率和质量大幅超过利用规则的源到源编译器方法;

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国船舶重工集团公司第七0九研究所,未经中国船舶重工集团公司第七0九研究所许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/202011617567.5/2.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top