会写代码的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

相关推荐

  • 农行吉林洮南市支行“四个加强”提升党建工作水平(银行加强党建工作的思路措施)

    农行吉林洮南市支行党委切实履行党建工作“第一责任人”职责,采取“四个加强”等措施,不断夯实基层党建根基,全面提升党建水平。 加强队伍建设。牢记党建工作“第一责任人”职责,不断强化党…

    科研百科 2023年6月17日
    145
  • 低代码开发是程序员的福还是祸

    低代码开发是程序员的福还是祸 低代码开发是近年来快速发展的一种软件开发方法,它通过使用图形化界面和可视化工具,使得开发人员能够以更快的速度创建应用程序。然而,对于程序员来说,低代码…

    科研百科 2024年2月24日
    82
  • 微软项目管理工具

    微软项目管理工具:让项目管理水平更上一层楼 随着信息技术的不断发展,项目管理工具也逐渐得到了广泛的应用。微软作为业界领先的公司之一,其项目管理工具更是受到了广泛的关注和认可。本文将…

    科研百科 2024年7月22日
    61
  • 韩国肉牛存栏量持续萎缩牛肉价格坚挺

       受到肉牛存栏量减少影响,韩国牛肉价格和牛肉进口量双双走高,牛肉自给率下降。韩国农村经济研究院近日发布《牛肉自给率动向与展望》报告,指出目前韩国牛肉的批发价格已经达到…

    科研百科 2022年5月27日
    312
  • 科研项目小组组成方案设计科研项目小组组成方案设计

    科研项目小组组成方案设计 科研项目小组是进行科学研究的重要组织形式之一。一个高效的科研项目小组需要由具有相关学科背景和科研经验的专业人员组成,以确保项目的顺利进行和高质量成果的获得…

    科研百科 2024年6月12日
    69
  • 低代码平台服务模式

    低代码平台服务模式是一种新兴的软件开发模式,它通过提供可视化的开发工具和预定义的组件,使开发人员能够快速构建和部署应用程序。这种模式的出现,极大地简化了传统软件开发的复杂性,提高了…

    科研百科 2024年3月1日
    86
  • erp 软件开发

    ERP(Enterprise Resource Planning)是一种集成管理软件,用于协调和管理企业内部各个部门的资源和业务流程。随着信息技术的发展,ERP软件开发成为企业提高…

    科研百科 2023年7月20日
    152
  • 办公室项目管理

    办公室项目管理:一个高效团队的指南 在现代社会,办公室项目管理已经成为了一个至关重要的环节。一个高效的团队需要能够有效地管理项目进度,确保项目按时完成,并交付高质量的成果。本文将介…

    科研百科 2024年5月25日
    77
  • 中学学校党建工作汇报

    中学学校党建工作汇报中学学校党建工作汇报1、贯彻落实习近平总书记关于《致党赴荆门挑战》的演讲辞。新华社记者 屈新志 摄在浙江宁波,未成年人网游成瘾高发,仅16周岁的未成年人每天玩1…

    科研百科 2024年11月21日
    1
  • 法院传真 – 德州两级法院 创新实践“一三五”党建模式

    文 | 杜桂清 为进一步提升党建工作能力,今年7月,山东省德州市中级人民法院开展“支部书记大比武”活动。本次活动共设置理论测试、实地评价、现场竞赛三个环节,通过专业考核,促使各党支…

    科研百科 2023年1月18日
    363