CN112346737B - 编程语言翻译模型的训练方法、装置、设备及存储介质 - Google Patents

编程语言翻译模型的训练方法、装置、设备及存储介质 Download PDF

Info

Publication number
CN112346737B
CN112346737B CN202110021389.8A CN202110021389A CN112346737B CN 112346737 B CN112346737 B CN 112346737B CN 202110021389 A CN202110021389 A CN 202110021389A CN 112346737 B CN112346737 B CN 112346737B
Authority
CN
China
Prior art keywords
code
solution code
solution
programming language
word
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN202110021389.8A
Other languages
English (en)
Other versions
CN112346737A (zh
Inventor
刘玉
徐国强
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
OneConnect Financial Technology Co Ltd Shanghai
Original Assignee
OneConnect Financial Technology Co Ltd Shanghai
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by OneConnect Financial Technology Co Ltd Shanghai filed Critical OneConnect Financial Technology Co Ltd Shanghai
Priority to CN202110021389.8A priority Critical patent/CN112346737B/zh
Publication of CN112346737A publication Critical patent/CN112346737A/zh
Application granted granted Critical
Publication of CN112346737B publication Critical patent/CN112346737B/zh
Priority to PCT/CN2021/124418 priority patent/WO2022148087A1/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/51Source to source

Landscapes

  • Engineering & Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Machine Translation (AREA)

Abstract

本申请涉及模型构建技术领域,公开了一种编程语言翻译模型的训练方法、装置、设备及存储介质,该方法包括:通过第一编码层对第一解答代码中的每个单词进行编码,得到第一解答代码中每个单词对应的第一特征向量;通过第二编码层对第二解答代码中的每个单词进行编码,得到第二解答代码中每个单词对应的第二特征向量;将第一解答代码中每个单词对应的第一特征向量和第二解答代码中对应单词的第二特征向量输入解码层,以预测第一解答代码对应的代码翻译结果;根据第一解答代码对应的代码翻译结果,调整编程语言翻译模型的模型参数,以对编程语言翻译模型进行训练。实施本申请实施例,提高了模型的构建效率。

Description

编程语言翻译模型的训练方法、装置、设备及存储介质
技术领域
本申请涉及人工智能(Artificial Intelligence,AI)领域,尤其涉及编程语言翻译模型的训练方法、装置、设备及存储介质。
背景技术
目前编程语言层出不穷,从最初的机器语言到如今2500种以上的高级语言。然而学习一门新的编程语言并不简单,需要花费大量的时间。而且有些编程语言语法十分复杂,运用方式也十分灵活。因此,亟需一种可以将一种编程语言翻译为另一种编程语言的技术手段。
一般来说,在现有的模型中,需要由人工构建启发式的规则,以实现将一种编程语言翻译为另一种编程语言。具体的,假设需要将采用C语言编写的代码翻译为采用Python语言编写的代码,那么就需要人工构建C语言以及Python语言涉及到的各种规则。这种模型的构建效率低,不适用于未来更多应用场景。
发明内容
本申请实施例提供了编程语言翻译模型的训练方法、装置、设备及存储介质,可以提高模型的构建效率。
本申请第一方面提供了一种编程语言翻译模型的训练方法,所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言,所述方法包括:
针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量;
针对所述第二解答代码集中每个第二解答代码,将所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述第二解答代码中的每个单词进行编码,得到所述第二解答代码中每个单词对应的第二特征向量;
将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果;
根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
本申请第二方面提供了一种编程语言翻译模型的训练装置,所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言,所述训练装置包括第一输入模块,第二输入模块、第三输入模块和处理模块,
所述第一输入模块,用于针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量;
所述第二输入模块,用于针对所述第二解答代码集中每个第二解答代码,将所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述第二解答代码中的每个单词进行编码,得到所述第二解答代码中每个单词对应的第二特征向量;
所述第三输入模块,用于将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果;
所述处理模块,用于根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
本申请第三方面提供了一种电子设备,包括处理器、存储器、通信接口以及一个或多个程序,其中,所述一个或多个程序被存储在所述存储器中,并且被生成由所述处理器执行,以执行一种编程语言翻译模型的训练方法任一项方法中的步骤的指令。
本申请第四方面提供了一种计算机可读存储介质,所述计算机可读存储介质用于存储计算机程序,所述存储计算机程序被所述处理器执行,以实现一种编程语言翻译模型的训练方法任一项所述的方法。
可以看出,上述技术方案中,通过利用两个编码层分别对两种编程语言编写的代码进行编码,从而将编码后的特征向量输入解码层,以实现对编程语言翻译模型的训练,从而避免了现有方案中需要人工构建规则导致的模型构建效率低的问题。同时,通过采用两个编码层同时对不同的代码集进行处理,提高了编码效率,进而也提高了模型构建效率。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
其中:
图1是本申请实施例提供的一种编程语言翻译模型的示意图;
图2是本申请实施例提供的一种编程语言翻译模型的训练方法的流程示意图;
图3是本申请实施例提供的又一种编程语言翻译模型的训练方法的流程示意图;
图4为本申请实施例提供的一种解码层进行预测的流程示意图;
图5为本申请实施例提供的一种编程语言翻译模型的训练装置的示意图;
图6为本申请的实施例涉及的硬件运行环境的电子设备结构示意图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
以下分别进行详细说明。
本申请的说明书和权利要求书及上述附图中的术语“第一”、“第二”是用于区别不同对象,而不是用于描述特定顺序。此外,术语“包括”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或单元的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可选地还包括没有列出的步骤或单元,或可选地还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。
应理解的,本申请实施例提供的一种编程语言翻译模型的训练方法可以适用于电子设备,该电子设备可以包括各种具有无线通信功能的手持设备、车载设备、可穿戴设备、计算设备或连接到无线调制解调器的其他处理设备,以及各种形式的用户设备(UserEquipment,UE),移动台(Mobile Station,MS),终端设备(terminal device)等,在此不做限制。
参见图1,图1是本申请实施例提供的一种编程语言翻译模型的示意图。其中,如图1所示,该编程语言翻译模型100包括编码层110和解码层120,编码层110包括第一编码层1101和第二编码层1102。其中,第一编码层1101和第二编码层1102可以为TransCoder模型的编码层。解码层120可以为TransCoder模型的解码层。
另外,该编程语言翻译模型100还可以包括注意力层130。
参见图2,图2是本申请实施例提供的一种编程语言翻译模型的训练方法的流程示意图。所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言。
示例性的,若第一编程语言为C语言,第二编程语言为C++语言;若第一编程语言为C语言,第二编程语言为Java语言;若第一编程语言为C语言,第二编程语言为Python语言;若第一编程语言为C语言,第二编程语言为PHP语言;若第一编程语言为Python语言,第二编程语言为Java语言。
其中,如图2所示,所述方法包括:
201、针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量。
需要说明,在本申请中,第一解答代码中的每个单词可以理解为第一解答代码中的一个英文单词、一个数字、一个汉字等,在此不做限制。
可选的,步骤201可以包括:针对所述第一解答代码集中每个第一解答代码,在所述第一解答代码的起始位置插入开始符号[CLS]以及结束位置插入结束符号[SEP],得到新的所述第一解答代码;将所述新的所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述新的所述第一解答代码中的每个单词进行编码,得到所述新的所述第一解答代码中每个单词对应的第一特征向量。
其中,所述新的所述第一解答代码还包括开始符号[CLS]和结束符号[SEP]。
可以理解的,开始符号[CLS]和结束符号[SEP]可以作为所述第一解答代码进行编码的开始信号和结束信号。
202、针对所述第二解答代码集中每个第二解答代码,将所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述第二解答代码中的每个单词进行编码,得到所述第二解答代码中每个单词对应的第二特征向量。
需要说明,在本申请中,第二解答代码中的每个单词可以理解为第二解答代码中的一个英文单词、一个数字、一个汉字等,在此不做限制。
可选的,步骤202可以包括:针对所述第二解答代码集中每个第二解答代码,在所述第二解答代码的起始位置插入开始符号[CLS],得到新的所述第二解答代码;将所述新的所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述新的所述第二解答代码中的每个单词进行编码,得到所述新的所述第二解答代码中每个单词对应的第二特征向量。
其中,所述新的所述第二解答代码还包括开始符号[CLS]。
可以理解的,开始符号[CLS]可以作为所述第二解答代码进行编码的开始信号。
需要说明的,在本申请中,所述第一解答代码集中每个第一解答代码包括的单词数量和所述第二解答代码集中对应第二解答代码包括的单词数量相同。因此,当第一解答代码插入开始符号[CLS]和结束符号[SEP]时,第二解答代码集中对应第二解答代码只需要插入开始符号[CLS],而无需插入结束符号[SEP]。
203、将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果。
可选的,步骤203可以包括:将所述新的所述第一解答代码中每个单词对应的第一特征向量和所述新的所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果。
204、根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
可以看出,上述技术方案中,通过利用两个编码层分别对两种编程语言编写的代码进行编码,从而将编码后的特征向量输入解码层,以实现对编程语言翻译模型的训练,从而避免了现有方案中需要人工构建规则导致的模型构建效率低的问题。同时,通过采用两个编码层同时对不同的代码集进行处理,提高了编码效率,进而也提高了模型构建效率。
参见图3,图3是本申请实施例提供的又一种编程语言翻译模型的训练方法的流程示意图。所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言。
示例性的,若第一编程语言为C语言,第二编程语言为C++语言;若第一编程语言为C语言,第二编程语言为Java语言;若第一编程语言为C语言,第二编程语言为Python语言;若第一编程语言为C语言,第二编程语言为PHP语言;若第一编程语言为Python语言,第二编程语言为Java语言。
其中,如图3所示,所述方法包括:
301、通过网络爬虫从互联网中获取N个编程题中每个编程题对应的M个解答代码以及M个标签,所述N和所述M均为大于0的整数,所述M个解答代码和所述M个标签一一对应,所述M个标签中的每个标签用于指示所述M个解答代码中每个解答代码所采用的编程语言。
其中,网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本。
可选的,网络爬虫可以包括:通用网络爬虫(General Purpose Web Crawler)、聚焦网络爬虫(Focused Web Crawler)、增量式网络爬虫(Incremental Web Crawler)、深层网络爬虫(Deep Web Crawler)等,在此不做限制。
其中,所述M个标签中的不同标签用于指示所述M个解答代码中不同解答代码所采用的编程语言不同。
示例性的,若第二编程题为N个编程题中任意一个编程题,第二编程题对应3个标签。其中,标签1用于指示第二编程题对应的解答代码1所采用的编程语言为第一编程语言;标签2用于指示第二编程题对应的解答代码2所采用的编程语言为第二编程语言;标签3用于指示第二编程题对应的解答代码3所采用的编程语言为不同于第一编程语言和第二编程语言的编程语言。那么,可以根据第二编程题对应的3个标签,确定编程语言为第一编程语言的解答代码1和编程语言为第二编程语言的解答代码2。
可选的,在本申请中,标签可以用不同的比特来表示。示例性的,M个标签包括第一标签和第二标签,第一标签用于指示所述M个解答代码中编程语言为第一编程语言的解答代码,第二标签用于指示所述M个解答代码中编程语言为第二编程语言的解答代码。若第一标签为“0”比特,第二标签可以为“1”比特;或,若第一标签为“1”比特,第二标签可以为“0”比特。
302、根据所述N个编程题中每个编程题对应的所述M个标签,从所述N个编程题中每个编程题对应的所述M个解答代码中,确定编程语言为所述第一编程语言的第一解答代码集和编程语言为所述第二编程语言的第二解答代码集。
其中,第一解答代码集可以包括N个编程题中不同编程题目对应的第一编程语言编写的解答代码,第二解答代码集包括N个编程题中不同编程题目对应的第二编程语言编写的解答代码,在此不做限制。
可选的,所述N个编程题中的一个编程题为第一编程题,步骤302可以包括:根据所述第一编程题对应的M个标签,从所述第一编程题对应的所述M个解答代码中,选择第三解答代码,所述第三解答代码为所述第一解答代码集中任意一个代码;根据所述第一编程题对应的M-1个标签,从所述第一编程题对应的M-1个解答代码中,选择第四解答代码,所述第一编程题对应的M-1个标签为所述第一编程题对应的所述M个标签中除所述第三解答代码对应的标签之外的其他标签,所述第一编程题对应的所述M-1个解答代码为所述第一编程题对应的所述M个解答代码中除所述第三解答代码之外的其他解答代码,所述第四解答代码为所述第二解答代码集中与所述第三解答代码对应的解答代码。
其中,所述第三解答代码和所述第四解答代码为同一编程题不同编程语言编写的解答代码。
可以看出,上述技术方案中,通过基于标签来确定不同编程语言编写的解答代码,从而实现了高效确定不同编程语言编写的解答代码。
303-306、与图2中步骤201-204相同,在此不加赘述。
可以看出,上述技术方案中,通过网络爬虫获取大量编程题对应的不同解答代码,以确定不同编程语言的解答代码集,从而可以利用两个编码层分别对两种编程语言编写的代码进行编码,并将编码后的特征向量输入解码层,以实现对编程语言翻译模型的训练,从而避免了现有方案中需要人工构建规则导致的模型构建效率低的问题。同时,通过采用两个编码层同时对不同的代码集进行处理,提高了编码效率,进而也提高了模型构建效率。
可选的,所述第一解答代码包括K个单词,所述K为大于0的整数,所述将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果,包括:
S1:设置i的初始值为1;
S2:若所述i小于或等于所述K,则执行步骤S3;若所述i大于所述K,则执行步骤S6;
S3:将所述第一解答代码中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第i个单词对应的代码翻译结果,其中,所述解码层包括第一隐向量和第二隐向量,所述第一隐向量是根据所述第一解答代码中所有单词的上下文信息确定的,所述第二隐向量是根据所述第二解答代码中所有单词的上下文信息确定的;
S4:将所述第i个单词对应的代码翻译结果保存在代码翻译结果库中;
S5:令i=i+1,返回执行步骤S2;
S6:从所述代码翻译结果库中,获取所述第一解答代码中每个单词对应的代码翻译结果,将所述第一解答代码中每个单词对应的代码翻译结果进行映射,以得到所述第一解答代码对应的代码翻译结果;
S7:结束预测所述第一解答代码对应的代码翻译结果。
其中,所述第一隐向量是从所述第一解码层获取的,所述第二隐向量是从所述第二解码层获取的。
其中,代码翻译结果库例如可以为数据库或区块链,在此不做限定。
可以理解的,区块链是一种按照时间顺序将数据区块相连的一种链式数据结构,并以密码学方式保证的不可篡改和不可伪造的分布式账本。该区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
进一步的,区块链的特性有开放、共识、去中心、去信任、透明、双方匿名、不可篡改以及可追溯等。其中,开放与透明意为任何人都可以参与到区块链网络,每一台设备都能作为一个节点,每个节点都允许获得一份完整的数据库拷贝。节点基于一套共识机制,通过竞争计算共同维护整个区块链。任一节点失效,其余节点仍能正常工作。其中,去中心化与去信任意为区块链由众多节点共同组成一个端到端的网络,不存在中心化的设备和管理机构。节点之间数据交换通过数字签名技术进行验证,无需互相信任,只要按照系统既定的规则进行,节点之间不能也无法欺骗其他节点。其中,透明与双方匿名意为区块链的运行规则是公开的,所有的数据信息也是公开的,因此每一笔交易都对所有节点可见。由于节点与节点之间是去信任的,因此节点之间无需公开身份,每个参与的节点都是匿名的。其中,不可篡改和可追溯意为每个甚至多个节点对数据库的修改无法影响其他节点的数据库,除非能控制整个网络中超过51%的节点同时修改,这是几乎不可能发生的。区块链中的,每一笔交易都通过密码学方法与相邻两个区块串联,因此可以追溯到任何一笔交易记录。
具体的,区块链可以利用块链式数据结构来验证与存储数据、利用分布式节点共识算法来生成和更新数据、利用密码学的方式保证数据传输和访问的安全、利用由自动化脚本代码组成的智能合约来编程和操作数据的一种全新的分布式基础架构与计算方式。因此,区块链技术不可篡改的特性从根本上改变了中心化的信用创建方式,有效提高了数据的不可更改性以及安全性。其中,由于智能合约使得所有的条款编写为程序,这些条款可在区块链上自动执行,保证了当存在触发智能合约的条件时,区块链能强制根据智能合约中的内容执行,且不受任何外力阻挡,从而保证了合约的有效性和执行力,不仅能够大大降低成本,也能提高效率。区块链上的各个节点都有相同的账本,能够确保账本记录过程是公开透明的。区块链技术可以实现了一种点对点的、公开透明的直接交互,使得高效率、大规模、无中心化代理的信息交互方式成为了现实。
示例性的,若第一解答代码包括[s1]、[s2]和[s3],其中,[s1]、[s2]和[s3]表示3个不同的单词。参见图4,图4为本申请实施例提供的一种解码层进行预测的流程示意图。如图4所示,先将[s1]对应的第一特征向量和第二解答代码中对应单词的第二特征向量输入该解码层,以预测[s1]对应的代码翻译结果;然后再将[s2]对应的第一特征向量和第二解答代码中对应单词的第二特征向量输入该解码层,以预测[s2]对应的代码翻译结果;最后将[s3]对应的第一特征向量和第二解答代码中对应单词的第二特征向量输入该解码层,以预测[s3]对应的代码翻译结果。
可以看出,上述技术方案中,通过第一解答代码中第i个单词对应的第一特征向量和第二解答代码中对应单词的第二特征向量输入解码层,从而实现了将不同编程语言编写的解答代码同时输入解码层,进而使得训练后的编程语言翻译模型能够更好的进行编程语言的翻译,提高了代码翻译的精准性,也提高了训练后的编程语言翻译模型的泛化能力。
可选的,所述编程语言翻译模型还包括注意力层,所述方法还包括:
将所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量输入所述注意力层,以通过所述注意力层确定所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量之间的相似度;
根据所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量之间的相似度从高到低的顺序,对所述K个单词进行排序,得到排序后的所述K个单词。
其中,该方法还可以包括:将开始符号和结束符号分别对应的第一特征向量和所述第一隐向量输入所述注意力层,以通过所述注意力层确定开始符号和结束符号分别对应的第一特征向量和所述第一隐向量之间的相似度。可以理解的,针对第一解答代码集中每个第一解答代码,其开始符号和结束符号分别对应的第一特征向量和所述第一隐向量之间的相似度均相同。
其中,该方法还可以包括:将开始符号对应的第二特征向量和所述第二隐向量输入所述注意力层,以通过所述注意力层确定开始符号对应的第二特征向量和所述第二隐向量之间的相似度。可以理解的,针对第二解答代码集中每个第二解答代码,其开始符号对应的第二特征向量和所述第二隐向量之间的相似度均相同。
可以看出,上述技术方案中,通过在注意力层确定相似度,从而可以按照相似度从高到低的顺序对第一解答代码中的单词进行排序,以重新调整第一解答代码中的单词的顺序。
可选的,所述将所述第一解答代码中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第一解答代码中第i个单词对应的代码翻译结果,包括:
将所述排序后的所述K个单词中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第i个单词对应的代码翻译结果。
可以看出,上述技术方案中,通过重新调整第一解答代码中的单词的顺序,从而在利用解码层进行预测时避免语序颠倒的问题。
可选的,所述根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练,包括:
根据预设损失函数、所述第一解答代码中每个单词对应的代码翻译结果以及所述第二解答代码中对应单词,确定所述第一解答代码中每个单词对应的损失值;
根据所述第一解答代码中每个单词对应的损失值的平均值,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
其中,预设损失函数例如可以为交叉熵损失函数,在此不做限制。
需要说明的,当编程语言翻译模型收敛时,停止训练。
参见图5,图5为本申请实施例提供的一种编程语言翻译模型的训练装置的示意图。其中,如图5所示,该编程语言翻译模型的训练装置500可以包括第一输入模块501,第二输入模块502、第三输入模块503和处理模块504。
其中,所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言。
其中,所述第一输入模块501,用于针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量;
所述第二输入模块502,用于针对所述第二解答代码集中每个第二解答代码,将所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述第二解答代码中的每个单词进行编码,得到所述第二解答代码中每个单词对应的第二特征向量;
所述第三输入模块503,用于将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果;
所述处理模块504,用于根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
可以看出,上述技术方案中,通过利用两个编码层分别对两种编程语言编写的代码进行编码,从而将编码后的特征向量输入解码层,以实现对编程语言翻译模型的训练,从而避免了现有方案中需要人工构建规则导致的模型构建效率低的问题。同时,通过采用两个编码层同时对不同的代码集进行处理,提高了编码效率,进而也提高了模型构建效率。
可选的,在针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量之前,所述训练装置还包括获取模块505和确定模块506,所述获取模块505,用于通过网络爬虫从互联网中获取N个编程题中每个编程题对应的M个解答代码以及M个标签,所述N和所述M均为大于0的整数,所述M个解答代码和所述M个标签一一对应,所述M个标签中的每个标签用于指示所述M个解答代码中每个解答代码所采用的编程语言;所述确定模块506,用于根据所述N个编程题中每个编程题对应的所述M个标签,从所述N个编程题中每个编程题对应的所述M个解答代码中,确定编程语言为所述第一编程语言的第一解答代码集和编程语言为所述第二编程语言的第二解答代码集。
可以看出,上述技术方案中,通过网络爬虫获取大量编程题对应的不同解答代码,以确定不同编程语言的解答代码集。
可选的,第一编程题为所述N个编程题中的一个编程题,所述根据所述N个编程题中每个编程题对应的所述M个标签,从所述N个编程题中每个编程题对应的所述M个解答代码中,确定编程语言为所述第一编程语言的第一解答代码集和编程语言为所述第二编程语言的第二解答代码集方面,所述确定模块506,具体用于根据所述第一编程题对应的M个标签,从所述第一编程题对应的所述M个解答代码中,选择第三解答代码,所述第三解答代码为所述第一解答代码集中任意一个代码;根据所述第一编程题对应的M-1个标签,从所述第一编程题对应的M-1个解答代码中,选择第四解答代码,所述第一编程题对应的M-1个标签为所述第一编程题对应的所述M个标签中除所述第三解答代码对应的标签之外的其他标签,所述第一编程题对应的所述M-1个解答代码为所述第一编程题对应的所述M个解答代码中除所述第三解答代码之外的其他解答代码,所述第四解答代码为所述第二解答代码集中与所述第三解答代码对应的解答代码。
可以看出,上述技术方案中,通过基于标签来确定不同编程语言编写的解答代码,从而实现了高效确定不同编程语言编写的解答代码。
可选的,所述第一解答代码包括K个单词,所述K为大于0的整数,所述将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果方面,所述第三输入模块503,具体用于S1:设置i的初始值为1;S2:若所述i小于或等于所述K,则执行步骤S3;若所述i大于所述K,则执行步骤S6;S3:将所述第一解答代码中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第i个单词对应的代码翻译结果,其中,所述解码层包括第一隐向量和第二隐向量,所述第一隐向量是根据所述第一解答代码中所有单词的上下文信息确定的,所述第二隐向量是根据所述第二解答代码中所有单词的上下文信息确定的;S4:将所述第i个单词对应的代码翻译结果保存在代码翻译结果库中;S5:令i=i+1,返回执行步骤S2;S6:从所述代码翻译结果库中,获取所述第一解答代码中每个单词对应的代码翻译结果,将所述第一解答代码中每个单词对应的代码翻译结果进行映射,以得到所述第一解答代码对应的代码翻译结果;S7:结束预测所述第一解答代码对应的代码翻译结果。
可以看出,上述技术方案中,通过第一解答代码中第i个单词对应的第一特征向量和第二解答代码中对应单词的第二特征向量输入解码层,从而实现了将不同编程语言编写的解答代码同时输入解码层,进而使得训练后的编程语言翻译模型能够更好的进行编程语言的翻译,提高了代码翻译的精准性,也提高了训练后的编程语言翻译模型的泛化能力。
可选的,所述编程语言翻译模型还包括注意力层,所述处理模块504,还用于将所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量输入所述注意力层,以通过所述注意力层确定所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量之间的相似度;根据所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量之间的相似度从高到低的顺序,对所述K个单词进行排序,得到排序后的所述K个单词。
可以看出,上述技术方案中,通过在注意力层确定相似度,从而可以按照相似度从高到低的顺序对第一解答代码中的单词进行排序,以重新调整第一解答代码中的单词的顺序,从而在利用解码层进行预测时避免语序颠倒的问题。
可选的,所述将所述第一解答代码中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第一解答代码中第i个单词对应的代码翻译结果方面,所述第三输入模块503,具体用于将所述排序后的所述K个单词中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第i个单词对应的代码翻译结果。
可以看出,上述技术方案中,通过重新调整第一解答代码中的单词的顺序,从而在利用解码层进行预测时避免语序颠倒的问题。
可选的,所述根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练方面,所述处理模块504,具体用于根据预设损失函数、所述第一解答代码中每个单词对应的代码翻译结果以及所述第二解答代码中对应单词,确定所述第一解答代码中每个单词对应的损失值;根据所述第一解答代码中每个单词对应的损失值的平均值,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
参见图6,图6为本申请的实施例涉及的硬件运行环境的电子设备结构示意图。
本申请实施例提供了一种电子设备,包括处理器、存储器、通信接口以及一个或多个程序,其中,所述一个或多个程序被存储在所述存储器中,并且被配置由所述处理器执行,以执行包括任一项编程语言翻译模型的训练方法中的步骤的指令。其中,如图6所示,本申请的实施例涉及的硬件运行环境的电子设备可以包括:
处理器601,例如CPU。
存储器602,可选的,存储器可以为高速RAM存储器,也可以是稳定的存储器,例如磁盘存储器。
通信接口603,用于实现处理器601和存储器602之间的连接通信。
本领域技术人员可以理解,图6中示出的电子设备的结构并不构成对其的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
如图6所示,存储器602中可以包括操作系统、网络通信模块以及一个或多个程序。操作系统是管理和控制服务器硬件和软件资源的程序,支持一个或多个程序的运行。网络通信模块用于实现存储器602内部各组件之间的通信,以及与电子设备内部其他硬件和软件之间通信。
其中,所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言,在图6所示的电子设备中,处理器601用于执行存储器602中一个或多个程序,实现以下步骤:
针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量;
针对所述第二解答代码集中每个第二解答代码,将所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述第二解答代码中的每个单词进行编码,得到所述第二解答代码中每个单词对应的第二特征向量;
将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果;
根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
本申请涉及的电子设备的具体实施可参见上述编程语言翻译模型的训练方法的各实施例,在此不做赘述。
本申请还提供了一种计算机可读存储介质,其中,所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言,所述计算机可读存储介质用于存储计算机程序,所述存储计算机程序被所述处理器执行,以实现以下步骤:
针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量;
针对所述第二解答代码集中每个第二解答代码,将所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述第二解答代码中的每个单词进行编码,得到所述第二解答代码中每个单词对应的第二特征向量;
将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果;
根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
本申请涉及的计算机可读存储介质的具体实施可参见上述编程语言翻译模型的训练方法的各实施例,在此不做赘述。
需要说明的是,对于前述的各方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应所述知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应所述知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作和模块并不一定是本申请所必须的。
以上所述,以上实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的范围。

Claims (9)

1.一种编程语言翻译模型的训练方法,其特征在于,所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言,所述方法包括:
针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量;
针对所述第二解答代码集中每个第二解答代码,将所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述第二解答代码中的每个单词进行编码,得到所述第二解答代码中每个单词对应的第二特征向量;
将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果;
根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练;
在针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量之前,所述方法还包括:
通过网络爬虫从互联网中获取N个编程题中每个编程题对应的M个解答代码以及M个标签,所述N和所述M均为大于0的整数,所述M个解答代码和所述M个标签一一对应,所述M个标签中的每个标签用于指示所述M个解答代码中每个解答代码所采用的编程语言;
根据所述N个编程题中每个编程题对应的所述M个标签,从所述N个编程题中每个编程题对应的所述M个解答代码中,确定编程语言为所述第一编程语言的第一解答代码集和编程语言为所述第二编程语言的第二解答代码集。
2.根据权利要求1所述的方法,其特征在于,所述N个编程题中的一个编程题为第一编程题,所述根据所述N个编程题中每个编程题对应的所述M个标签,从所述N个编程题中每个编程题对应的所述M个解答代码中,确定编程语言为所述第一编程语言的第一解答代码集和编程语言为所述第二编程语言的第二解答代码集,包括:
根据所述第一编程题对应的M个标签,从所述第一编程题对应的所述M个解答代码中,选择第三解答代码,所述第三解答代码为所述第一解答代码集中任意一个代码;
根据所述第一编程题对应的M-1个标签,从所述第一编程题对应的M-1个解答代码中,选择第四解答代码,所述第一编程题对应的M-1个标签为所述第一编程题对应的所述M个标签中除所述第三解答代码对应的标签之外的其他标签,所述第一编程题对应的所述M-1个解答代码为所述第一编程题对应的所述M个解答代码中除所述第三解答代码之外的其他解答代码,所述第四解答代码为所述第二解答代码集中与所述第三解答代码对应的解答代码。
3.根据权利要求1所述的方法,其特征在于,所述第一解答代码包括K个单词,所述K为大于0的整数,所述将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果,包括:
S1:设置i的初始值为1;
S2:若所述i小于或等于所述K,则执行步骤S3;若所述i大于所述K,则执行步骤S6;
S3:将所述第一解答代码中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第i个单词对应的代码翻译结果,其中,所述解码层包括第一隐向量和第二隐向量,所述第一隐向量是根据所述第一解答代码中所有单词的上下文信息确定的,所述第二隐向量是根据所述第二解答代码中所有单词的上下文信息确定的;
S4:将所述第i个单词对应的代码翻译结果保存在代码翻译结果库中;
S5:令i=i+1,返回执行步骤S2;
S6:从所述代码翻译结果库中,获取所述第一解答代码中每个单词对应的代码翻译结果,将所述第一解答代码中每个单词对应的代码翻译结果进行映射,以得到所述第一解答代码对应的代码翻译结果;
S7:结束预测所述第一解答代码对应的代码翻译结果。
4.根据权利要求3所述的方法,其特征在于,所述编程语言翻译模型还包括注意力层,所述方法还包括:
将所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量输入所述注意力层,以通过所述注意力层确定所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量之间的相似度;
根据所述第一解答代码中每个单词对应的第一特征向量和所述第一隐向量之间的相似度从高到低的顺序,对所述K个单词进行排序,得到排序后的所述K个单词。
5.根据权利要求4所述的方法,其特征在于,所述将所述第一解答代码中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第一解答代码中第i个单词对应的代码翻译结果,包括:
将所述排序后的所述K个单词中第i个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层中,以预测所述第i个单词对应的代码翻译结果。
6.根据权利要求1-5任意一项所述的方法,其特征在于,所述根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练,包括:
根据预设损失函数、所述第一解答代码中每个单词对应的代码翻译结果以及所述第二解答代码中对应单词,确定所述第一解答代码中每个单词对应的损失值;
根据所述第一解答代码中每个单词对应的损失值的平均值,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练。
7.一种编程语言翻译模型的训练装置,其特征在于,所述编程语言翻译模型包括编码层和解码层,所述编码层包括第一编码层和第二编码层,所述编程语言翻译模型通过第一解答代码集和第二解答代码集训练得到,所述第一解答代码集和所述第二解答代码集一一对应,所述第一解答代码集中每个第一解答代码的编程语言为第一编程语言,所述第二解答代码集中每个第二解答代码的编程语言为第二编程语言,所述第一编程语言不同于所述第二编程语言,所述训练装置包括第一输入模块,第二输入模块、第三输入模块和处理模块,
所述第一输入模块,用于针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量;
所述第二输入模块,用于针对所述第二解答代码集中每个第二解答代码,将所述第二解答代码输入所述第二编码层,以通过所述第二编码层对所述第二解答代码中的每个单词进行编码,得到所述第二解答代码中每个单词对应的第二特征向量;
所述第三输入模块,用于将所述第一解答代码中每个单词对应的第一特征向量和所述第二解答代码中对应单词的第二特征向量输入所述解码层,以预测所述第一解答代码对应的代码翻译结果;
所述处理模块,用于根据所述第一解答代码对应的代码翻译结果,调整所述编程语言翻译模型的模型参数,以对所述编程语言翻译模型进行训练;
在针对所述第一解答代码集中每个第一解答代码,将所述第一解答代码输入所述第一编码层,以通过所述第一编码层对所述第一解答代码中的每个单词进行编码,得到所述第一解答代码中每个单词对应的第一特征向量之前,所述训练装置还包括获取模块和确定模块,
所述获取模块,用于通过网络爬虫从互联网中获取N个编程题中每个编程题对应的M个解答代码以及M个标签,所述N和所述M均为大于0的整数,所述M个解答代码和所述M个标签一一对应,所述M个标签中的每个标签用于指示所述M个解答代码中每个解答代码所采用的编程语言;
所述确定模块,用于根据所述N个编程题中每个编程题对应的所述M个标签,从所述N个编程题中每个编程题对应的所述M个解答代码中,确定编程语言为所述第一编程语言的第一解答代码集和编程语言为所述第二编程语言的第二解答代码集。
8.一种电子设备,其特征在于,包括处理器、存储器、通信接口以及一个或多个程序,其中,所述一个或多个程序被存储在所述存储器中,并且被生成由所述处理器执行,以执行权利要求1-6任一项方法中的步骤的指令。
9.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质用于存储计算机程序,所述存储计算机程序被处理器执行,以实现权利要求1-6任一项所述的方法。
CN202110021389.8A 2021-01-08 2021-01-08 编程语言翻译模型的训练方法、装置、设备及存储介质 Active CN112346737B (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN202110021389.8A CN112346737B (zh) 2021-01-08 2021-01-08 编程语言翻译模型的训练方法、装置、设备及存储介质
PCT/CN2021/124418 WO2022148087A1 (zh) 2021-01-08 2021-10-18 编程语言翻译模型的训练方法、装置、设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110021389.8A CN112346737B (zh) 2021-01-08 2021-01-08 编程语言翻译模型的训练方法、装置、设备及存储介质

Publications (2)

Publication Number Publication Date
CN112346737A CN112346737A (zh) 2021-02-09
CN112346737B true CN112346737B (zh) 2021-04-13

Family

ID=74427961

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110021389.8A Active CN112346737B (zh) 2021-01-08 2021-01-08 编程语言翻译模型的训练方法、装置、设备及存储介质

Country Status (2)

Country Link
CN (1) CN112346737B (zh)
WO (1) WO2022148087A1 (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112346737B (zh) * 2021-01-08 2021-04-13 深圳壹账通智能科技有限公司 编程语言翻译模型的训练方法、装置、设备及存储介质

Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103052943A (zh) * 2010-09-09 2013-04-17 株式会社日立制作所 源代码转换方法和源代码转换程序
CN108595185A (zh) * 2018-04-11 2018-09-28 暨南大学 一种将以太坊智能合约转换成超级账本智能合约的方法
CN109614111A (zh) * 2018-12-28 2019-04-12 北京百度网讯科技有限公司 用于生成代码的方法和装置
CN109739483A (zh) * 2018-12-28 2019-05-10 北京百度网讯科技有限公司 用于生成语句的方法和装置
CN109857459A (zh) * 2018-12-27 2019-06-07 中国海洋大学 一种e级超算海洋模式自动移植优化方法及系统
CN110263348A (zh) * 2019-03-06 2019-09-20 腾讯科技(深圳)有限公司 翻译方法、装置、计算机设备和存储介质
CN110488755A (zh) * 2019-08-21 2019-11-22 江麓机电集团有限公司 一种数控g代码的转换方法
CN110598224A (zh) * 2019-09-23 2019-12-20 腾讯科技(深圳)有限公司 翻译模型的训练方法、文本处理方法、装置及存储介质
CN110851142A (zh) * 2019-10-18 2020-02-28 浙江大学 一种将Transact-SQL程序转换为Java程序的方法
CN110879710A (zh) * 2019-07-24 2020-03-13 中信银行股份有限公司 一种rpg程序自动转成java程序的方法
US10599460B2 (en) * 2017-08-07 2020-03-24 Modelop, Inc. Analytic model execution engine with instrumentation for granular performance analysis for metrics and diagnostics for troubleshooting

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106295343B (zh) * 2016-08-24 2019-03-12 北京奇虎测腾安全技术有限公司 一种基于序列化中间表示的源代码分布式检测系统及方法
US10572607B1 (en) * 2018-09-27 2020-02-25 Intuit Inc. Translating transaction descriptions using machine learning
CN111931518A (zh) * 2020-10-15 2020-11-13 北京金山数字娱乐科技有限公司 一种翻译模型的训练方法及装置
CN112346737B (zh) * 2021-01-08 2021-04-13 深圳壹账通智能科技有限公司 编程语言翻译模型的训练方法、装置、设备及存储介质

Patent Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103052943A (zh) * 2010-09-09 2013-04-17 株式会社日立制作所 源代码转换方法和源代码转换程序
US10599460B2 (en) * 2017-08-07 2020-03-24 Modelop, Inc. Analytic model execution engine with instrumentation for granular performance analysis for metrics and diagnostics for troubleshooting
CN108595185A (zh) * 2018-04-11 2018-09-28 暨南大学 一种将以太坊智能合约转换成超级账本智能合约的方法
CN109857459A (zh) * 2018-12-27 2019-06-07 中国海洋大学 一种e级超算海洋模式自动移植优化方法及系统
CN109614111A (zh) * 2018-12-28 2019-04-12 北京百度网讯科技有限公司 用于生成代码的方法和装置
CN109739483A (zh) * 2018-12-28 2019-05-10 北京百度网讯科技有限公司 用于生成语句的方法和装置
CN110263348A (zh) * 2019-03-06 2019-09-20 腾讯科技(深圳)有限公司 翻译方法、装置、计算机设备和存储介质
CN110879710A (zh) * 2019-07-24 2020-03-13 中信银行股份有限公司 一种rpg程序自动转成java程序的方法
CN110488755A (zh) * 2019-08-21 2019-11-22 江麓机电集团有限公司 一种数控g代码的转换方法
CN110598224A (zh) * 2019-09-23 2019-12-20 腾讯科技(深圳)有限公司 翻译模型的训练方法、文本处理方法、装置及存储介质
CN110851142A (zh) * 2019-10-18 2020-02-28 浙江大学 一种将Transact-SQL程序转换为Java程序的方法

Also Published As

Publication number Publication date
WO2022148087A1 (zh) 2022-07-14
CN112346737A (zh) 2021-02-09

Similar Documents

Publication Publication Date Title
CN112084383B (zh) 基于知识图谱的信息推荐方法、装置、设备及存储介质
CN111222317B (zh) 序列标注方法、系统和计算机设备
CN111104512B (zh) 游戏评论的处理方法及相关设备
CN113836866B (zh) 文本编码方法、装置、计算机可读介质及电子设备
EP4145273A1 (en) Natural solution language
CN112232524A (zh) 多标签信息的识别方法、装置、电子设备和可读存储介质
CN114511038A (zh) 虚假新闻检测方法、装置、电子设备及可读存储介质
CN112949758A (zh) 应答模型的训练方法、应答方法、装置、设备及存储介质
CN112232052A (zh) 文本拼接方法、装置、计算机设备及存储介质
CN113704393A (zh) 关键词提取方法、装置、设备及介质
CN115544560A (zh) 一种敏感信息的脱敏方法、装置、计算机设备及存储介质
CN116069931A (zh) 层级标签文本分类方法、系统、设备及存储介质
CN114358023B (zh) 智能问答召回方法、装置、计算机设备及存储介质
CN112084779A (zh) 用于语义识别的实体获取方法、装置、设备及存储介质
CN112346737B (zh) 编程语言翻译模型的训练方法、装置、设备及存储介质
CN117787226A (zh) 标签生成模型训练方法、装置、电子设备及存储介质
CN113609866A (zh) 文本标记方法、装置、设备及存储介质
CN116186295B (zh) 基于注意力的知识图谱链接预测方法、装置、设备及介质
CN116630712A (zh) 基于模态组合的信息分类方法、装置、电子设备及介质
CN112528674B (zh) 文本处理方法、模型的训练方法、装置、设备及存储介质
CN115328753A (zh) 一种故障预测方法及装置、电子设备、存储介质
CN113486180A (zh) 一种基于关系层级交互的远程监督关系抽取方法及系统
CN111882416A (zh) 一种风险预测模型的训练方法和相关装置
CN111949867A (zh) 跨app的用户行为分析模型训练方法、分析方法及相关设备
CN111611498A (zh) 一种基于领域内部语义的网络表示学习方法及系统

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant