会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

萧箫 发自 凹非寺
量子位 | 公众号 QbitAI

Codex还会写C语言的AI代码生成模型,现在开源了!

这段时间,用AI写代码可以说是大火,其中最著名的要属OpenAI的Codex和DeepMind的AlphaCode。

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

△基于Codex的Copilot

然而,这两个AI模型,全都没有开源:

其中AlphaCode只给出了一些测试样例,而Codex只开放了API。

为此,来自CMU的几个研究人员,用GPT-2搞出了一个名叫PolyCoder的AI代码生成模型,而且还是开源的

据研究人员表示,虽然PolyCoder最大只有27亿参数(相比Codex有120亿参数),但它用C语言写出来的代码,比Codex的效果还要好。

这里面究竟有什么秘诀?

用12种编程语言代码集训练

首先来看训练用的数据集,这也是PolyCoder的最大特点之一。

此前,包括Codex、CodeParrot等AI代码生成模型,主要都是基于Python语言的代码来训练。

例如Codex的评估数据集之一HumanEval,评估的也是生成Python代码的效果。

相比之下,PolyCoder采用了多种编程语言代码集来训练,一共有12种:

C、C#、C 、Go、Java、JavaScript、PHP、Python、Ruby、Rust、ScalaTypeScript

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

其中,C语言的代码量是最多的,达到了221GB;而Python代码的数据量比Codex和CodeParrot用得都要少。

这里PolyCoder用的是GitHub上的公开代码,主要选取的是各种编程语言中比较受欢迎的库,每个库至少有50 Stars。

据研究人员表示,每种编程语言库的Stars总数加起来不超过25k,以避免模型生成的代码效果太过于倾斜最流行的编程语言(通常编程语言越流行,库的Stars就越多)

通过提取库中的文件、经过简单处理(包括消除重复代码)后,一共筛选出大约254GB的数据用于训练。

然后是预训练的方法。

语言模型的预训练方法通常有三种。

第一种是自左向右的语言模型,根据上文预测下文,比较适用于代码生成等;第二种是掩蔽语言模型,基于上下文预测屏蔽片段,比较适合代码分类等;第三种是编解码器模型,比较适用于代码注释等任务。

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

这里PolyCoder主要采用的是第一种预训练方法。

相比于同样采用GPT-2训练的CodeParrot和Codex,PolyCoder在超参数设置上也稍微有一些差异:

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

PolyCoder一共提供了三种不同的模型,分别有27亿参数、4亿参数和1.6亿参数,研究人员可以根据自身需求和不同的训练能力来选取合适的模型。

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

那么,最终训练出来的AI模型,代码生成效果如何?

C语言写得尤其好,但Python不行

研究人员将PolyCoder与已有的AI代码生成模型进行了对比。

由于AlphaCode不好比较(接口没开放),所以研究人员主要分析了下面这些模型,包括GPT-Neo、CodeParrot和Codex等。

其中蓝色的是开源的,橙色的是没开源的:

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

从参数量来看,PolyCoder并不是最顶尖的,最大的27亿参数模型也只有Codex的四分之一不到。

研究人员先是用语言模型评估常用的困惑度对一系列模型进行了比较。

困惑度(Perplexity),用于衡量语言模型(LM)的好坏。困惑度越低,语言模型面对代码感到困惑的程度就越低,模型生成效果越好。

从图中来看,PolyCoder在C语言中意外取得了最好的效果(困惑度最低)

用大量C语言训练PolyCoder的结果说明,即使模型整体原理不变(基于GPT-2),单纯改变训练用的代码集,也能训练出擅长不同语言风格的AI代码生成模型。

可惜的是,从其他语言来看,生成的效果就完全没办法和Codex相比了:

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

例如,在主要用于评估Python代码的HumanEval上,PolyCoder的能力远不如Codex好:

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

据论文分析,这可能是Python代码数据量、模型参数量不足等原因导致的。

此外,作者们也提到,做出PolyCoder的目的主要还是为了开源一个AI代码生成模型,让更多人参与研究和使用。

目前代码已经开源,无论是直接拿来用,还是试着在它的基础上开发新模型都可以。

感兴趣的小伙伴可以上手一试了~

作者介绍

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

一作许方正(Frank Xu),目前在CMU读博,研究方向是NLP、信息抽取等,发表过多篇顶会论文,包括ICLR、ACL和EMNLP等。本硕毕业于上海交通大学,师从朱其立教授。

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

Uri Alon,在CMU进行博士后工作,研究方向是编程语言处理PLP、NLP和深度学习。

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

Graham Neubig,CMU助理教授,研究方向是NLP、机器翻译和基于机器学习的自然语言理解。

会写代码的AI开源!C语言比Codex写得好,掌握12种编程语言丨CMU(c语言写代码的软件)

Vincent J. Hellendoorn,CMU计算机助理教授,主要研究方向是软件工程和机器学习,致力于利用智能方法帮助软件开发人员减少代码调试、程序优化等繁琐工作的时间。

不知道作者们是否已经在用这个AI撸代码了(手动狗头)

项目地址:
https://github.com/VHellendoorn/Code-LMs

论文地址:
https://arxiv.org/abs/2202.13169

— 完 —

量子位 QbitAI · 头条号签约

关注我们,第一时间获知前沿科技动态

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023年12月29日 上午8:05
下一篇 2023年12月29日 上午8:17

相关推荐

  • 铁山港区:以高质量党建推动交通运输事业高质量发展

    来源:人民网-广西频道 原创稿 2021年以来,北海市铁山港区交通运输局党组充分发挥党建引领作用,建设让党中央放心、让人民满意的模范机关。 落实组织保障,为建设模范机关夯实基础。该…

    科研百科 2023年6月13日
    213
  • 基金项目管理

    基金项目管理 基金项目管理是一个重要的商业活动,涉及到投资、运营和管理投资组合。它是金融和投资领域中的关键角色,对于确保投资组合的稳健和成功至关重要。本文将探讨基金项目管理的各个方…

    科研百科 2024年5月26日
    59
  • 辽宁省今年扶持200个养殖场实施标准化建设

      9月25日,从省政府获悉,《辽宁省畜禽养殖废弃物资源化利用工作方案(2017—2020年)》(以下简称《工作方案》)已于近日出台并印发,全面推进我省畜禽养殖废弃物资…

    科研百科 2022年5月17日
    300
  • 工装装修的施工流程有哪些装完后如何进行收?(装修收工步骤)

    工装装修设计流程 1、拆改工程 拆改工程是装修过程中最基础的步骤,包括拆除和隔墙(也就是建墙),根据场地布局需要和设计师方案需要对场地进行拆除改建。 2、水电工程 水电工程是装修中…

    2022年6月28日
    345
  • 成本项目管理

    成本项目管理:实现项目成功的关键在于掌控成本 成本项目管理是项目管理的重要组成部分。在项目执行过程中,成本管理可以帮助项目团队有效地控制和管理项目的成本,从而实现项目的成功。本文将…

    科研百科 2024年7月16日
    49
  • 研究课题名称

    研究课题名称: 社交化网络对青少年心理健康的影响 摘要: 社交化网络已经成为人们生活中不可或缺的一部分,它给人们的生活带来了许多便利,但同时也对青少年心理健康产生了负面影响。本研究…

    科研百科 2024年10月9日
    15
  • 医院管理系统项目源码

    医院管理系统项目源码:探索医院运营流程的优化与改进 医院作为医疗行业的核心机构,其运营流程的优化与改进对于提高医疗服务质量和效率具有重要的意义。随着信息技术的不断发展,医院管理系统…

    科研百科 2024年12月12日
    0
  • 样品管理规定——工厂管理作业文件6(样品的管理规范)

    1.目的 1.1 合适的管理,规范样品的接受、制作、保管、借用等活动。 2.适用范围 2.1 顾客提供的样品、公司制作的样品和供应商提供的样品。 3.职责 3.1 本文由品保部编写…

    2022年7月20日
    983
  • 太绝了!从没见过这么全的财务一体化管理系统(财务业务一体化系统)

    整个系统有采购管理、销售管理、出纳管理、报表管理、应收应付、维护管理6个大板块 可谓是一个系统在手,财务问题都可以解决了,不仅可以管理合同,还可以管理应收应付,连最麻烦的进销存表格…

    科研百科 2022年11月13日
    264
  • 投融资项目管理系统

    投融资项目管理系统 随着社会经济的不断发展,企业融资和投资的需求日益增加。传统的项目管理系统已经无法满足这种需求,因此,我们需要一款新的系统来支持企业融资和投资的顺利进行。 投融资…

    科研百科 2024年8月13日
    53