AI 编程神器 Copilot 治好了我的精神内耗
http://pic2.zhimg.com/v2-970fa821814c708e924c64a39b46300d_r.jpg转眼间,AI 编程神器 Copilot 已经发布一年有余,这一年,Copilot 改变了什么?真的给开发者带来辅佐了吗?
2021 年 6 月 30 日,微软旗下代码托管平台 GitHub 推出了名为 Copilot 的 AI 结对编程东西,Copilot 的主要定位是提供代码补全与建议功能,可按照当前文件的内容和光标位置自动生成代码。
据了解,Copilot 由 OpenAI 的 Codex 系统提供撑持。据 Copilot 网站称,Codex 模型由“互联网上的公共代码和文本”训练,“既能理解编程,也能理解人类语言”。作为 Visual Studio Code 的扩展,Copilot “将你的评论和代码发送到 GitHub Copilot 处事,然后它会使用 OpenAI Codex 来合成并建议个别行和整个函数”。
作为一款 AI 编程神器,Copilot 从诞生之初就争议不竭。
拥护者认为它确实可以提高出产力,否决者认为它写的代码错误率高,开发者还需要花费额外的时间做代码审查。有的争议焦点集中在 Copilot 是否涉及侵权上——毕竟 Copilot 传布鼓吹的基于公开代码训练,其实是在未遵循开源许可证的情况下,肆意“抄袭”开源代码。
在 Copilot 正式发布一年之际,GitHub 对 2000 多名开发者展开了查询拜访,以期了解 Copilot 到底改变了什么?
Copilot 大调研
结合查询拜访与尝试,GitHub 整理出一份 Copilot 在开发者群体中实际影响力的结论性资料。
GitHub 研究员 Eirini Kalliamvakou 在一篇博文中提到:由于 AI 辅助开发还是个相对较新的范围,作为研究人员,我们几乎找不到可供借鉴的早期成果。我们但愿衡量 GitHub Copilot 的实际效果如何,而且在早期不雅察看和用户采访之后,我们决定对 2000 多名开发者进行大规模查询拜访,了解他们的使用体验和感到感染。
在设计研究方式时,我们主要考虑到以下三大重点:
[*]安身整体存眷出产力。在 GitHub,我们喜欢广泛且可持续地考量开发者的出产力及相关影响因素。我们使用 SPACE 出产力框架选择需要查询拜访的具体标的目的。
[*]考量来自开发者的第一手不雅概念。我们开展了多轮研究,包罗定性(认知)与定量(不雅察看)数据,但愿拼凑出可靠的底细。我们但愿验证:(1)用户的实际体验,能否证实我们揣度出的结论?(2)我们的定性反馈,是否同样适合更泛博的用户群体?
[*]评估 GitHub Copilot 在日常开发场景中的效果。在设计研究方式时,我们出格注意覆盖专业开发人员,并围绕他们在工作日内面对的典型任务进行测试设计。最终的查询拜访成果,既有意料之中的发现,也有不测惊喜。
开发者出产力确有提升
除了加快开发速度之外,Copilot 还能给法式员带来哪些额外辅佐?
查询拜访发现:
[*]开发者对劲度有所提升。60% 至 75% 的用户暗示,他们对此刻的工作体验更对劲,编码时的精神压力更小,而且 Copilot 能辅佐他们更专注地达成令人对劲的工作成效。
[*]缓解精神内耗。开发者们陈述称,Copilot 能辅佐他们稳步推进开发流程(73%),并在措置反复性任务期间降低精力消耗(87%)。
http://pic2.zhimg.com/v2-191da17a468b94c73560e260bcfa7e6d_r.jpg
速度也很重要
有近 90% 的开发者们暗示,在使用 Copilot 时,他们完成任务,出格是反复性任务的速度更快了。这也符合 GitHub 在产物设计时做出的基本预期。
为了在实践中不雅察看并量化这种提升效果,GitHub 组织了一场对照尝试。两个受试小组(此中一组使用 Copilot)需要接受计时,核算用 JavaScript 编写 HTTP 处事器的平均用时。
尝试发现:
[*]使用 Copilot 的小组完成任务的比例更高,为 78%,未使用 Copilot 的小组完成任务比例为 70%。
[*]更显著的区别在于,使用 Copilot 的开发者完成任务的速度明显更快,要比未使用 Copilot 的开发者快 55%。具体来看,使用 Copilot 的开发者完成此项任务的平均用时为 1 小时 11 分钟,而未使用 Copilot 的开发者平均用时达 2 小时 41 分钟。综上,该项查询拜访和尝试最终得出的结论是,“Copilot 有助于加快工作完成速度,辅佐开发者减少精神内耗,以更加丰满的精神状态专注于工作内容,最终在本身的编码过程中找到更多乐趣。”
http://pic4.zhimg.com/v2-88c7f9077ae0a1da6b00548e8832bf77_r.jpg
对于这一查询拜访成果,有开发者留言暗示撑持: “使用 Copilot,我能尽量少把精力浪费在枯燥反复的工作身上。它点燃的灵感火花,让我感到编码过程更有趣、更高效了。”
GitHub 研究员 Eirini Kalliamvakou 暗示,“随着 Copilot 的呈现,我们在 AI 驱动型代码补全东西的探索道路上不再是孤军奋战。在实际出产范围,我们比来看到一项针对 24 名学生的评估,谷歌也在内部评估操作机器学习增强代码补全的可能性。
着眼于整个行业,研究社区正当真分析 GitHub Copilot 在各类场景下的实际影响,包罗教育、安全、劳动力市场,乃至开发者的实践与行为。我们目前正在各类环境下不雅察看 Copilot 的实际效果。这是个不竭成长的范围,我们对研究社区和自身查询拜访中的发现感到振奋,也将未来几个月内为大师揭晓更多动静。”
为什么 Copilot 会编写出糟糕的代码?
GitHub 的调研成果展现了 Copilot 在开发者群里中起到积极感化的一面,但任何事物都有其两面性,Copilot 本身带有的争议也不容忽视。开发者在决定是否采用 Copilot 前,需要对其有充实的了解。
此中,Copilot 斗劲大的一个争议点在于代码错误率高。
Copilot 由名为 Codex 的深度神经网络语言模型提供撑持,该模型在 GitHub 上的公共代码存储库长进行了训练。它读取了 GitHub 的整个公共代码档案,此中包含数千万个存储库,汇聚了来自许多世界上最优秀法式员的代码。
那么,为什么 Copilot 还是会编写出糟糕的代码呢?
按照 OpenAI 的论文,Codex 只有 29% 的时间会给出正确答案。而且它编写的代码往往重构得很差,无法充实操作现有的解决方案(即使这些方案就在 Python 的尺度库中)。
Copilot 编写出糟糕的代码,原因在于语言模型的工作机制。它们反映的是大大都人的平均写作程度。它们不知道什么是正确的,什么是好的写法。GitHub 上的大大都代码(按照软件尺度)相当陈旧,而且(按照定义)是由程度一般的法式员编写的。
Copilot 尽力猜测的是,如果这些法式员正在编写的是你面对的这些文件,他们可能会写什么代码。OpenAI 在他们的 Codex 论文中讨论了这一点:
“与其他训练方针是预测下一个词符的大型语言模型一样,Codex 会生成与其训练分布尽可能相似的代码。这样做的一个后果是,这种模型可能会做一些对用户无益的事情”
Copilot 之所以比那些程度一般的法式员更糟糕,一个关键问题在于,它甚至没有测验考试编译代码或查抄代码是否有效,也没有考虑过本身是否真的遵循了文档的指示。此外,Codex 没有接受过去一两年内创建代码的训练,因此它完全没学过最新版本、库和语言特性。例如,提示它创建 fastai 代码后,它只会给出使用 v1 API 的建议,而不是大约一年前发布的 v2 版本。
值得一提的是,本年 4 月,微软推出了 AI 代码审查东西 Jigsaw,以期进一步提升 AI 编码的准确率。
在研究论文《Jigsaw:当大型语言模型牵手法式综合》(Jigsaw: Large Language Models meet Program Synthesis,文章已被国际软件工程会议 ICSE 2022 接收)中,微软介绍了一种可以提高这类大型语言模型性能的新东西。Jigsaw 中包含可以理解法式语法及语义的后措置技术,可操感化户的反馈不竭提升修正能力。配合多模输入,Jigsaw 即可为 Python Pandas API 合成代码。
随着 Jigsaw 逐步在提高系统准确性方面阐扬重要感化,Copilot 这类 AI 编程东西准确率或将获得提升。
页:
[1]