芯片中的上百亿个晶体管是如何设计的?

news2024/7/4 4:42:57

2021年4月21日,在芯片界的顶级会议Hot Chips大会上,Cerebras Systems公司发布了一款晶圆级引擎芯片——Wafer Scale Engine 2。

这款芯片采用台积电7纳米工艺制程,拥有85万个AI核心,包含2.6万亿个晶体管,面积为46225平方毫米,基于一整张12英寸的晶圆制造,这是迄今为止包含晶体管数量最多的芯片。

除了这款“巨无霸”,市面上主流的用在智能手机或者个人电脑中的芯片,其晶体管规模都在百亿级。那么数量如天文数字般的晶体管,是如何被设计出来的呢?

“上百亿个晶体管,总不能用手来画吧?”相信很多非业内人士会有类似的困惑。

其实在集成电路发展早期,内部的晶体管都是通过手画设计的,彼时芯片的规模较小,只有几十个或者几百个晶体管。但随着芯片的发展和演进,其逻辑功能变得越来越复杂且全面,晶体管的数目也呈指数级增长,此时再徒手画电路,显然是不现实的。随后,计算机辅助设计开始应用于芯片领域。在直接促成百亿级规模的芯片设计这一方面,有三种秘密武器必不可少。

秘密武器之一——使用编程语言来设计芯片的思想

这个思想来自卡沃·米德和林恩·康威的著作《超大规模集成电路系统导论》,它的提出是芯片设计历史上一个非常重要的里程碑。

假设我们要设计一个数据比较器,当输入值a和b相等时,equal的返回值为1;当a和b不相等时,返回值为0。使用Verilog语言,一行代码即可实现。

assign equal = (a==b)? 1 : 0;

但如果徒手画晶体管电路,通过分析以上数据比较器的功能可知,逻辑功能和同或门一致,因此可以用异或门后接一个反相器实现该数据比较器的功能。搭建一个异或门最少需要6个晶体管,一个反相器需要2个晶体管,所以我们用一行代码就完成了8个晶体管的设计,这大幅提高了工程师设计芯片的效率!

这是数字芯片设计中最简单的一个例子,在实际工作中,工程师可以在比较抽象的层次上描述设计电路的结构和逻辑功能,用简洁明确的源代码描述复杂的逻辑功能,并且支持模块化设计和层次化设计。往往由简单的几十行代码设计出来的电路,即可包含成千上万个晶体管。因此,通过编程可以让设计具有百亿级数量晶体管的芯片成为可能。

秘密武器之二——EDA

在 RTL 设计完成后,即可采用逻辑综合工具把RTL 转换成门级网表,也就是与、或、非等逻辑门及其之间的连接关系。

将RTL 转换成门级网表的过程主要有三个步骤:翻译、优化和映射。就像自动化流水线一样,只要把原材料放进去,就可以得到成品。

这些纷繁复杂的工作都交给EDA来做,可以明显缩短设计的时间,加快将芯片推向市场的速度。

秘密武器之三——重复调用已有的成熟设计模块

在芯片中,很多单元或模块的数目不止用到一次,比如算术逻辑单元,我们只需设计一次,即可重复调用。

这好比建筑师在设计住宅楼时,只需设计几种标准户型,并不要求每间房屋的户型都是独一无二的设计。

或者从更高层次的角度看,目前的中央处理器都是8核、16核等,这些核心在设计上也几乎是一致的。

尽管芯片设计工程师被认为是硬件工程师,但编程是芯片设计工程师必不可少的技能之一,也正是编程思想赋予了芯片设计无限的可能。

本文节选自《了不起的芯片》一书,欢迎阅读此书了解更多相关内容。

在这里插入图片描述在这里插入图片描述

限时五折优惠,扫码了解本书详情!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/699980.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux8.进程(中)(状态)

1.grep -v 关键字a :不显示关键字a匹配的信息。 2.进程状态 :新建,就绪,阻塞,挂起,执行,终止。 运行 : task_struct结构体在运行队列中排队,这就叫做运行态。 阻塞 :等待非CPU资源(磁盘,网卡…

科技云报道:公有云内卷时代,青云的新想象力在哪?

科技云报道原创。 2023年接踵而至的价格战,将国内公有云的竞争力度再次拉满。阿里云、腾讯云、京东云、移动云带头降价,也将寒意传导给了更多腰部云服务商。毫无疑问,这是一场对云服务商的残酷考验。 在公有云高度内卷的阶段,以…

kaggle新赛:肾脏血管分割大赛赛题解析(CV)

用AI为医疗贡献一份力量,从加入本次竞赛开始! 赛题名称:HuBMAP - Hacking the Human Vasculature 从人肾组织切片中分割微血管结构 赛题链接:https://www.kaggle.com/competitions/hubmap-hacking-the-human-vasculature 赛题背…

java 正则表达式总结

目录 一、简介 二、源码分析 1.简单实例 : 2.底层实现 : 1 fund()方法 2 group(0/1)方法 (1)group(0): (2)group(1): 三、 基本语法 1.元字符介绍 : 2.元字符—字符匹配符 : Δ代码演示 3.关于字母大小写问题 : Δ代码演示 4.元字符—定位符 : 1 定义 2 常用定位符 3…

图简介-数据结构和算法教程

介绍 图是由顶点和边组成的非线性数据结构。顶点有时也被称为节点,并且边是连接图中的任何两个节点的线或弧。更正式地说,一个图是由一组顶点(V)和一组边(E)组成的。该图表示为G(V,…

Win11的两个实用技巧系列之亮度条消的解决办法

Win11更新后无法调节亮度怎么办 Win11亮度条消的解决办法 Win11更新后无法调节亮度怎么办?win11系统升级以后,发现屏幕亮度不能调节,没有亮度调节按钮了,下面我们就来看看Win11亮度条消的解决办法 电脑更新后,亮度条消…

如何设计可以动态扩容缩容的分库分表方案?

对于分库分表来说,主要是面对以下问题: 选择一个数据库中间件,调研、学习、测试;设计你的分库分表的一个方案,你要分成多少个库,每个库分成多少个表,比如 3 个库, 每个库 4 个表&am…

SpringSecurity(五):前后端分离认证总结案例。

前后端分离认证总结案例 前言难点分析Controller层eneity层RoleUser dao层service层config层LoginFilterSecurityConfig resourcesmapper propertiespom.xml结尾 前言 和上一篇一样,从上倒下复制粘贴,所有代码贴完再运行,代码没有问题&#…

初步学习使用SpringBoot框架(手动插入数据模拟访问数据库)

对于SpringBoot框架介绍大家可以看看这个这篇文章,SpringBoot优缺点以及如何安装使用 以下我是按照老师给的安装方法进行安装使用SpringBoot框架: 大家安装SpringBoot框架时候,最好安装3.0以下的,不然需要对应较高版本的JDK版本&…

【Axure教程】拖动调整行高列宽的表格

表格是在系统软件中非常常用的工具。表格通常由行和列组成,用于以结构化的方式显示和组织数据。它们在各种场景中都有广泛的应用,包括数据分析、数据录入、报表生成、项目管理和数据可视化等领域。 今天作者就教大家如何在Axure里制作一个能通过鼠标拖动…

阿里巴巴最新 SpringCloudAlibaba 学习笔记,全程通俗易懂,一套搞懂!

Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,依托 Spring Cloud Alibaba,只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里…

Visual C++中函数的覆盖和函数的隐藏

我是荔园微风,作为一名在IT界整整25年的老兵,今天来聊聊Visual C中函数的覆盖和函数的隐藏。 Visual C中函数的覆盖和函数的隐藏与JAVA有很大不同,有些容易搞错的点和概念,我们要特别注意。 首先,先满足一下急性子的…

【刷题笔记——链表专栏】牛客网:合并两个排序链表

【刷题笔记——链表专栏】牛客网:合并两个排序链表 一、题目描述 二、思路分析 1、创建新的头节点newHead(注意这一步) 2、循环遍历pHead1和pHead2并进行链表并进行合并,直到pHead1和pHead2其中有一个为null时结束循环 3、合并完…

Win10,Win11玩游戏找不到d3dx9怎么解决

相信有些朋友遇到了d3dx9_42.dll丢失的情况不知道怎么解决,而今日小编带来的这篇文章就是讲解关于d3dx9_42.dll丢失进行修复的操作内容,d3dx9_42.dll丢失怎么解决?(修复方法)d3dx9 42.dll文件是DirectX中必备文件,许多…

【期末不挂科 学习数据结构】

期末不挂科 学习数据结构 第一章绪论1.1数据结构的基本概念1.1.1基本概念和术语1.数据2.数据元素3.数据对象4.数据类型5.数据结构 1.1.2数据结构三要素1.数据的逻辑结构2.数据的存储结构3.数据的运算 第一章绪论 1.1数据结构的基本概念 1.1.1基本概念和术语 1.数据 数据是信…

Redis7【⑧ Redis集群(cluster)】

Redis集群 Redis 集群是 Redis 数据库的分布式解决方案,它可以将数据分散存储在多个节点上,以支持大规模数据存储和高并发访问。 Redis 集群使用的是基于槽的分区策略,即将数据分成固定数量的槽,每个槽由一个主节点和多个从节点组…

Python基础教程: 入门简介

Python 最初由 Guido van Rossum 在 1991 年开发,当时他在执行其他项目的时候需要编写一个简单的解释器。Python 最初只是一种简单的脚本语言,但在后来的发展中,它迅速成为一种流行的编程语言。 Python 不仅在大型科技企业中应用广泛&#x…

spring cloud 之 gateway

网关介绍 在微服务架构体系中,一个系统会被拆分为很多个微服务,那么作为客户端要如何去调用这么多的微服务呢?如果没有网关的存在,我们只能在客户端记录每个微服务的地址,然后分别调用,当然这样是不现实的…

Mysql事务原理

一、概述 事务:一组操作要么全部成功,要么全部失败,目的是为了保证数据最终的一致性。 数据库一般都会并发执行多个事务,多个事务可能会并发的对相同的一批数据进行增删改查操作,可能就会导致我们说的脏写、脏读、不可…

水站桶装水订水系统桶装水小程序,改变了桶装水行业传统的送水模式;

水站桶装水订水系统桶装水小程序,改变了桶装水行业传统的送水模式,客户通过线上下单,送水工实时接单配送,空桶更好的记录管理,财务数据在后台清晰明了,提高了水站的工作效率。 除此之外,还有很多…