首页 > 技术 > 内容

顶级FPGA和GPU的PK

时间:2025-11-29  作者:Diven  阅读:0

本部分,我们就跟随作者一起看看Intel Stratix10 NX和Nvidia在这个领域的利器T4以及V100之间的对比,过程分为芯片级对比以及系统级对比。

本部分一起先来看看芯片级对比

首先来看下我们的GPU对手——Nvidia T4和V100分别有320个和640个张量核(专门用于AI工作负载的矩阵乘法引擎)

Nvidia Tesla T4

Nvidia Tesla V100

下面表格了与Stratix10 NX和这些同代工艺GPU的关键指标对比。 就Die尺寸来说,V100是Nvidia最大的12nm GPU,几乎比T4大50%,而Stratix10 NX比两种GPU都小。

文章使用GPU最擅长处理的工作负载:通用矩阵乘(GEMM)来跑GPU的benchmark(什么是GEMM请移步https://spatial-lang.org/gemm),为了测量最佳的GPU性能,对每个器件使用最新的library,这些库不会出错,并且分别在使用和不使用张量核的情况下测试性能。对于fp32和fp16实验,分别使用CUDA10.0和10.2的CuBLAS库进行V100和T4。对于int8,我们使用CUDA10.2中的cuBLASLt库,这样可以比cuBLAS库获得更高的int8性能。文章使用Nvidia的官方(高度优化)的cuDNN kernel来处理DL工作负载,并且分别对V100和T4使用了从cuDNN7.6.2和7.6.5。 (cuBLAS API,从cuda6.0开始;cuBLASLt API,从cuda10.1开始)

cuDNN库不支持int8计算kernel,但支持将所有模型权重保存在片上内存中。对于每个工作负载、问题大小和序列长度,文章在两种GPU上运行了所有可能的配置组合,如精度{fp32、fp16、int8}、计算样式{persistent、non-persistent}、张量核心设置{enable、disable}。然后,选择最佳的性能,来和Stratix10 NX的NPU进行比较。 这里因为是芯片级对比,所以只考虑了芯核的计算效率,不包括任何初始化、芯核启动或主机-GPU数据传输开销。

下图给出了T4和V100 GPU上fp32、fp16和int8精度的GEMM benchmark测试结果。结果表明,相对于张量核禁用情况(蓝线),启用张量核(红线) 可以显著提高GPU在GEMM上的性能。

一个普遍的趋势是,张量核虽然是为GEMM设计的,但在矩阵大小为2048或以下情况时的利用效率明显不如峰值情况(红色虚线)。因此要实现高利用率,除非工作负载中的矩阵大小非常大,而这在实际DL工作负载中并不常见。T4和V100上的张量核都不支持fp32的精度,而是在执行乘法运算之前,将fp32数据转换为fp16。相对于纯fp16 GEMM,这种数据转换开销降低了张量核性能。另一个有趣的情况是,当T4张量核在int8模式下工作时,需要将输入矩阵从标准的行/列主要格式转换为特定于张量核的布局。即使在处理非常大的8192×8192矩阵时,在张量核(没有标记的红线)上实现的int8性能还不到峰值性能的45%。

为了更好地理解这种数据转换的开销,文章还进行了一个额外的实验,在这个实验中,对张量核进行了特殊布局(带有标记的红线)。即使不算矩阵布局变化的开销,对于4096×4096及以下的矩阵大小,张量核利用率也小于40%,在6144×6144矩阵中利用率达到最高为72%。

下面来看看FPGA上的情况,上图(Fig.6)的右上角那张图比较了Stratix10 NX上的NPU性能与具有int8张量核的T4 GPU的性能。为了公平地比较,文章禁用了NPU两个输入矩阵其中一个的矩阵布局变换,只保留了对另一个输入以及输出矩阵的布局变换(因为NPU以标准格式使用和生成这些矩阵)。

虽然NPU是为矩阵向量运算而设计的,但在GEMM工作负载上仍然实现了与T4相似的性能,其矩阵大小从512到3072不等(最大的矩阵可以fit进片上BRAM)。 

一起看看顶级FPGA和GPU的PK结果。下图(Fig.7)将文章在Stratix10 NX上增强型NPU的性能与T4和V100的最佳性能进行比较。对于比较小的batch-3和batch-6情况,FPGA性能总是显著高于两个GPU。FPGA在batch-6(其设计为:双核batch-3)中表现最好,平均性能分别是T4和V100的24.2x和11.7x。

与batch-6相比,FPGA在batch-3上的性能较低,因为两个核中的一个完全空闲。仍然比T4和V100分别平均快了22.3x和9.3x。在batch size高于6时,如果batch size不能被6整除,则NPU可能不能被充分利用。例如,在batch size为8、32和256的情况下,NPU最多可以达到其batch-6性能的67%、89%和99%,而batch size为12、36和258(上图中的虚线所示)可以达到100%的效率。在32输入的中等batch size情况下,NX仍然比T4具有更好的性能,并且与V100性能相当。

即使在比较大的batch size情况下,NX的性能也比T4高58%,只比Die size更大(大将近一倍)的V100低30%。这些结果表明,人工智能优化的FPGA在低batch实时推理中不仅可以实现比GPU好一个数量级的性能,而且可以在放宽延迟约束下的高batch推理中和GPU匹敌。上图(Fig.7)中的右下角图了不同batch size情况下NX相对于CPU的平均加速情况。

上图(Fig.7)中的右上角图显示了与不同batch大小下的两个GPU相比,NX的平均利用率。NX在batch-6中的平均利用率为37.1%,而T4和V100分别仅为1.5%和3%。GPU张量核并非直接互连,只能接收来自本地核内寄存器文件的输入。每个GPU张量核都必须发送partial result到全局内存中,并与其张量核同步,以结合这些partial result。然后GPU从全局内存中读取组合好的矢量来执行进一步的操作,如激活函数(activation functions)。

较高的batch size可以摊销这种同步延迟,但即使在batch-256情况下,T4和V100的利用率分别只有13.3%和17.8%。 另一方面,FPGA在架构上也更具优势,其在张量块之间有专用的用来做减法的互连, FPGA的可编程布线资源还允许将MVU tile和矢量单元级引擎级联起来进行直接通信,减少了像GPU中那样必须通过内存通信的情况。

综上可以看到,FPGA依靠架构优势和超高的资源利用率,在AI性能PK上对GPU形成了强劲挑战。下一篇,我们再来一起看看从系统角度,FPGA和GPU的对比情况以及功耗方面的分析。

审核编辑 :李倩

 

猜您喜欢


金属膜电阻作为电子元件中的重要组成部分,其性能和品牌选择成为工程师和采购人员关注的焦点。LIZ(丽智)作为知名的金属膜电阻制造商,其产品在市场上拥有较高的认可度...
2013-01-04 06:15:09
SD卡和存储卡连接器的规格尺寸是影响设备兼容性和性能的重要因素。标准SD卡的尺寸为32mm x 24mm x 2.1mm,而microSD卡则更小,仅为15mm...
2013-12-07 00:00:00
频谱分析仪是用于分析信号频率成分的仪器,应用于电子工程、通信、音频处理等领域。能够将复杂的信号转化为频率域的图形,帮助工程师识别和测量信号中的不同频率成分及其强...
2014-02-28 00:00:00
随着电子设备的不断发展,贴片电阻作为电子电路中重要的元件,其性能的稳定性直接影响整个电路的工作效果。贴片电阻在使用过程中可能会出现击穿损坏现象,导致电路故障。准...
2025-11-09 06:00:37
位置传感器是用于检测物体位置、方向和运动状态的设备,应用于工业自动化、机器人、汽车、航空航天等领域。根据工作原理的不同,位置传感器可以分为几种类型,包括电感式、...
2008-08-18 00:00:00
采样电阻作为电流检测和控制的重要元件,受到了越来越多电子工程师和技术人员的关注。宏达电子作为国内知名的电子元件制造商,其采样电阻产品因性能稳定、参数精准而受到青...
2016-05-02 02:23:30
贴片电阻6800本身并不能决定电流大小。6800代表的是电阻值,单位是欧姆,也就是6.8kΩ。电流大小取决于电路中的电压和电阻,根据欧姆定律:电流 (I) = ...
2024-11-29 10:26:17
SP1602 是一款高集成度的电源管理芯片,应用于各种电子设备中。为了帮助用户更好地理解和使用 SP1602,本文将详细介绍其各个引脚的功能。1. 电源输入引脚...
2024-05-22 00:00:00
电阻作为基础电子元件的重要性日益凸显。防硫化电阻因其优异的抗硫化性能,应用于汽车电子、电力设备及工业控制等领域。三环集团(CCTC)作为中国领先的电阻制造商,其...
2014-09-17 16:31:30
贴片电阻0.5欧姆,作为电子电路中很重要的基础元件,以其小巧的体积和稳定的性能,应用于各种电子设备和产品中。别看身材迷你,却在电路中是很重要的配件,例如限流、分...
2024-11-29 10:25:54