什么,7 句话就让 AI 给我生成了一个小游戏?还是“极简版”塞尔达这样的经典冒险游戏,不仅能捡金币、躲怪,地图也不重复的那种。
这是一位名叫 Andrew Mayne 的小哥的真实经历,整个过程中,他甚至一行代码都没写!把 AI 生成的游戏和游戏代码 po 到网上后,短短数小时就收获了上千热度:
赶来围观的网友试玩了他搞出来的游戏,直呼“Mind blowing”。
所以,Andrew Mayne 到底是怎么做到的?原来,他用来做游戏的 AI,是 OpenAI 最新版本的 Codex。
这个版本的 Codex,除了能直接生成、修改和编辑代码以外,连处理的文本长度也翻倍,从 2048 个 token 提升到了 4000 个,简直像是“解开一层封印”。
起初,Andrew Mayne 只是好奇这版 Codex 的创造力极限在哪里,想做个实验,看看它能否根据文本直接生成小游戏。没想到,这一试简直让他停不下来。
7 句话生成冒险游戏
第一次尝试便是被他命名为“极简塞尔达”的游戏。别看画面抽象,整个游戏包括随机生成地图、玩家用键盘控制角色移动、有敌人会攻击玩家、收集金币加分等游戏核心要素。走到地图边缘还能生成一张新地图,这样就能一直玩下去…… 总之是一个 2D 冒险游戏原型的样子。
所有这些规则只用英语写了七句话,AI 则用 Javascript 写出了 190 行代码。
由于小哥本人不是专业游戏设计师,描述用词不是很精确,但 AI 总是能产生自己的理解。比如描述怪物的部分,描述里只有“一个红色的怪物,玩家移动时它也移动,试图接近玩家,如果玩家被碰到就减一分”。AI 则根据上下文生生成了 50 多行完整的怪物生成、移动、判定分数的逻辑。
只需把色块替换成简单贴图,和真正的塞尔达原型是不是就很像了?
△被曝光的初代塞尔达原型程序
第二个小游戏,他打算考验 AI 对逻辑的理解,生成一个简化版猜词游戏 Wordle。
这次只用了 5 段话描述规则。谜底词从一个列表里随机选择,每次选择一个放到控制台。
描述字母输入框的样式,包括宽高、文字居中对齐、每个输入框有独立 ID;输入时自动大写;再加一个确认按钮。
分四种情况讨论如何判定输入结果。
后面他又进行了更多尝试,调用第三方库生成 3D 迷宫、能与玩家对战的井字棋,以及给照片加滤镜的小程序等,全都没手写一行代码。
其中比较有意思的是生成《黑客帝国》字符雨视觉特效,几乎是只告诉 AI“创建一个画布,加一个黑客帝国雨特效”,没有任何额外解释,AI 就做出来了:
最后他总结出几条经验,介绍如何写文字描述能让 AI 更容易理解需求:
先描述逻辑部分。然后创建 UI 元素时候调用前面生成的逻辑函数。
给描述编号。这样更容易看明白 AI 正在处理哪条描述。
多让 AI 创建函数。如果直接让 AI 生成 100 项的数组,AI 可能真的每一项每一项写出来,如果告诉 AI 创建一个生成数组的函数,AI 就会用循环语句来完成了。
如果一次不理想,多试几次。把 temperature 参数设为 0.5,有一定随机性可能会产生更好结果。
看起来有点产品经理总结如何与程序员沟通对接的味了。
背后的 Codex“再进化”
所以话说回来,这个最新版的 Codex 到底有多好用?除了 Andrew Mayne 最感兴趣的 token 上限翻倍以外,新增加的插入和编辑两大功能也挺有意思。
先来看看 Codex 的编辑功能,像优化代码性能就能用一句话搞定:
或是换个编程语言实现代码:
还有“单行代码编程”(One Liner),一句命令就能实现:
有了这一功能,调整代码的难度就会降低不少。使用 Codex 的时候,甚至可以像甲方一样,无需手动调整代码,只需要对着这位“AI 程序员”发号施令,就能让它生成你想要的东西。
再来看看 Codex 的插入功能。不仅能主动生成注释,提醒这段代码的作用:
还能根据上下文理解这段函数,主动帮你插入它的定义:
无论是开发框架、还是写小软件,都不需要再担心“一条路走到黑”,可以根据需求再从中间进行调整。
当然,这些功能放到 GPT-3 上也类似。无论是换人称、改格式这种小技巧:
还是随着上下文修改并插入语句,都不在话下。
除了这两个功能以外,还有一些细节上的更新,例如 UI 变得更加简洁等等。
事实上,这一系列新功能,都是为了让 Codex 和 GPT-3 变得更容易上手。据 OpenAI 的科学家表示,他们希望通过这次更新,让更多“非职业选手”也玩上 GPT-3 和 Codex。
这也确实吸引了不少感兴趣的网友动手尝试。像搞出“7 句话让 AI 给我做游戏”的 Andrew Mayne,原本只是一位惊悚小说家。
△还戴着顶 SpaceX 的帽子,要素过多
除了他以外,包括《连线》编辑 Clive Thompson 等人也在尝试用 Codex 给自己写代码。Clive 表示,Codex 掌握的知识量比他们这些“业余选手”丰富不少,能选出最合适的函数和库来完成需求。例如在接到与 PDF 有关的需求时,调用 PyPDF 库。
还有网友表示,自己拿 Codex 做了个《太空侵略者》(space invaders)小游戏,同样成功了。
看到这些成果,有网友感叹,当 AI 真的学会写代码后,留给人类做的可能就剩下两件事情:写更好的 AI,或是想想能用 AI 生成什么。
不过,更加谨慎的网友则认为,AI 生成代码容易让人对它产生依赖性,从而忽视代码本身的问题。例如这位作者用 Codex 写的图像处理代码,就存在一些不正确的地方:
还有网友预测,用 AI 写代码的话,最后还是要让工程师来调整它,本质上还是殊途同归。
你会用 AI 来写工具、或是做游戏吗?
参考链接:
[1]https://andrewmayneblog.wordpress.com/2022/03/17/building-games-and-apps-entirely-through-natural-language-using-openais-davinci-code-model/
[2]https://twitter.com/AndrewMayne/status/1504612428432125970
[3]https://beta.openai.com/docs/engines/codex-series-private-beta
[4]https://news.ycombinator.com/item?id=30717773
[5]https://www.wired.com/story/openai-copilot-autocomplete-for-code/
[6]https://www.facebook.com/andrewmayne?_rdr
广告声明:文内含有的对外跳转链接(包括不限于超链接、二维码、口令等形式),用于传递更多信息,节省甄选时间,结果仅供参考,IT之家所有文章均包含本声明。