西风 发自 凹非寺
量子位 | 公众号 QbitAI
和ChatGPT聊聊天 , 就可解决CPU开发过程中的一大难题?
纽约州立大学(NYU)研究人员完成了一件看似不可能的事情:
无需专业的 硬件描述语言(HDL) , 仅靠说人话就能设计芯片!
文章插图
在ChatGPT的帮助下 , 他们不仅设计出CPU上的一个组件 , 甚至还通过了有效性验证环节 。
这个组件主要负责创造出一种基于八位累加器的微处理器架构的逻辑 。而累加器本质上是寄存器(存储器) , 是专门存放算术或逻辑运算的一个操作数和存储运算结果的 。而这是CPU运作中不可或缺的一部分 。
所以 , 还有什么是大语言模型不能做的?
有网友表示:
芯片设计的部分流程实现自动化无疑是个好消息 。也有网友表现出对在芯片设计中使用AI编写HDL的担忧:
ChatGPT对芯片设计干了啥?
通常 , 设计和制造芯片的过程中会经历几个阶段 。
其中一个阶段是用 硬件描述语言(HDL)(例如Verilog)描述芯片内不同部件的实际几何形状、密度和整体布局 。
在此前 , 作为一个极其专业化和复杂的领域 , HDL编写一直是一项相对罕见且非常难以掌握的工作 。
研究团队成员之一、也是研究助理教授的Hammond Pearce博士更是认为:
硬件描述语言的最大挑战就是没有多少人知道如何编写它们 , 很难成为这方面的专家 。这也就意味着 , 即使是最好的工程师也还是经常需要用这种语言做一些琐碎的事情 。
文章插图
△使用 LLM 创建 IC(集成电路)的设计流程 。
在这项研究中 , 研究人员分别使用LLM对八个具有代表性的硬件设计示例进行了研究 。工程师与LLM之间实时来回交互 , 将纯英文文本逐步转化为Verilog(HDL)的等效代码 。
其中一位硬件工程师与LLMs共同设计了一种新颖的基于八位累加器的微处理器体系结构 。他们将这些基准测试和处理器发送到Skywater 130纳米Shuttle进行流片(tapeout) 。
这个过程中 , 研究人员评估了ChatGPT-4、ChatGPT-3.5、Bard、HuggingChat四个不同LLM创建硬件设计的Verilog能力:
此外 , 研究人员还针对8位移位寄存器进行了基准测试 。告诉大模型正在尝试为一个「测试名称」创建一个Verilog模型 。然后提供规范说明 , 定义输入和输出端口以及其他所需的具体信息 。最后询问他该如何编写一个满足这些规范的设计 。
文章插图
△8位移位寄存器的设计提示
下面是不同大模型给出的设计方案:
文章插图
△左图是ChatGPT-4的八位移位寄存器设计 , 右图是ChatGPT-3.5
文章插图
△左图是Bard(第4行的「红色」输入过宽) , 右图是HuggingChat(截断 , 格式化)
如上图所示 , 虽然ChatGPT都能够满足规格要求并开始进行设计流程 , 但Bard和HuggingChat都未能满足规格要求的初始标准 。
研究人员又基于Bard和HuggingChat的初始提示 , 让它们重新生成了五次回答 , 但两者还是都失败了 。Bard一直无法满足给定的设计规格要求 , 而HuggingChat的Verilog输出在模块定义之后就不符合语法规范 。
鉴于Bard和HuggingChat在初始的挑战基准测试中表现不佳 , 研究人员决定后续完整测试仅对ChatGPT-4和ChatGPT-3.5进行 。
与此同时 , 顺便让大模型进行了Testbench(测试台)的设计:
你能为这个设计编写一个Verilog测试台吗?测试台应该具备自检功能 , 并且能够与iverilog一起用于仿真和验证 。如果测试用例失败 , 测试台应该能够提供足够的信息 , 以便找到并解决错误 。
最终结果表明ChatGPT-4的表现较为出色 。大多数基准测试都通过了 , 并且大部分只需要工具反馈即可 。
【ChatGPT强势加入芯片设计!不用学专业硬件描述语言了,说人话就行】与创建可运行设计相比 , ChatGPT-4在创建可运行的测试台上遇到了更多困难 , 往往还是需要人类的反馈意见 。
推荐阅读
- AI之下没有秘密:网友诱骗ChatGPT激活 Windows 11,ChatGPT落入陷阱!
- OpenAI 创始人最新演讲:ChatGPT 炸裂新功能,分享怎样教 AI 使用工具
- 饿了么店家怎么加入
- 《王牌8》嘉宾曝光,贾玲华晨宇退出,两位年轻流量艺人加入
- |《鱿鱼游戏》第2季演员阵容,李政宰孔刘回归,任时完姜河那加入
- 肖战|肖战首部大男主剧开启,携手李沁领衔主演,刘学义、宣璐强势加盟
- 怎么加入淘宝社区团购平台账号
- excel怎么建立表格
- 郭富城|曝郭富城拒娶熊黛林原因:女方性格强势,不满被蹭人气,选择多
- 我的前半生2|《我的前半生2》开启,三大主演强势回归,新女主人选意外