! K# J% ]* Q2 ]2 N }, b " Y( m8 t: G) C+ x/ |" B 许多人都喜欢玩电脑游戏,而3D游戏里的每一帧画面都依赖于显卡的强大性能。显卡是现代PC里规模最庞大的核心组件,不仅能用于游戏和三维渲染,还在人工智能领域发挥着重要的作用。它有哪些结构,又如何生成游戏画面?本期我们将会带你从零开始认识显卡。我们在玩儿的电脑游戏,形态各异的建筑,细节丰富的车辆,一切都很真实,它们的本质其实是一个个不同位置的点,这些顶点在空间中相互连成线,形成无数个三角面,再经过贴图、光照、着色等复杂的渲染过程最终形成了我们看到的精美画面,从三角形的生成再到图像的输出,其中每一个步骤都需要显卡。作为电脑里进气管儿数量最多的核心组件,显卡有哪些结构,又是如何工作的?以这张ROG strix RTX4080猛禽为例,带你从零开始认识显卡。& f9 g. _ L6 n4 X, U: I; K
# f5 l2 P- h8 ?: s1 j: y 0 m& q& Z p' Q! Q' N. G# ~% b ; w& S# R. V! n* o# p3 I' Y3 T0 ~
3 F U- o% W/ [3 p# G* D7 v. F s: j
显卡的正面是散热风扇,底部的黄色长条是用于传输数据的PCIE接口 * @$ Q" c( y S8 m4 W. L A- a- w& t# K7 u& _- n6 B, j: Z
侧面是装饰用的logo和供电接口 + g' e4 e$ C- G4 h u" C9 P; _- t2 I2 M @' u# I6 o
而尾部则是用来连接显示器的视频接口。 * j# I. l" Y/ q2 K$ ?; A2 z y, }( V: D! @5 j6 c5 ?
显卡通常会以侧插的形式安装在主板接口上,此时风扇会朝向机箱底部,视频接口则会出现在机箱尾部,从机箱的侧面观察我们通常只会看到显卡的侧面和背板。 & |$ t1 u8 U4 L2 x1 I8 P: k; U! C
一.显卡的供电4 d7 q7 X; r6 j# {- Q8 M$ o8 \
* g9 t# W, C8 T/ r3 R1 ~! I% g
之前大部分显卡都使用8pin PCIE供电接口,能提供225W左右的供电,高功耗显卡则使用多个8pin才能满足需求。 / H% c% e* f w4 d* k+ @3 {0 J) s. V" t) O1 ^* @& _/ N
这张4080猛禽使用了最新的12V-2x6接口,体积十分小巧,单个接口可提供高达600W的供电。 8 g" [$ i* T, o5 n' S4 K$ X2 D& `( k
华硕也设计出了无需外接供电线的背插显卡,可以直接从主板取电,安装以后会更加的简洁美观,但要搭配特定的主板或转接头才能使用。 / I& [7 r ~7 h: L) K9 Z- o# G- S. j
二.显卡的散热 . ~6 n* y& n0 A: }$ ?: Z; V % c* A/ S, {; l' `$ I% g这张显卡在满载时的功耗可以达到360W,为了有效的排出热量,巨大的散热模组占据了整张显卡90%的体积。8 v6 J+ R. k" Y0 J# W9 X
7 F. R/ @ `+ Z( I7 x- q. c: R% e而最下面这张小小的电路板才是显卡的本体,也是热量的来源。% ~" {) E3 a4 k% A1 |4 S 4 o& ^- p1 K5 `0 a8 i7 y 5 r9 S" k0 ]/ k2 U9 B" ~7 { M' I, L) f9 b/ b6 D" J- k! [
散热模组由风扇,鳍片,热管与均热板构成,这里的核心是热管,热管的内壁是由粉末烧结成的多孔结构,在制造成型后,热管内部会填充少量的高纯水,并被抽成真空,以降低水的沸点和凝固点。 1 b! \# T% m9 o1 \ s! v5 t1 k3 a# K8 M9 _- W/ E. k, v7 h
散热原理:当热管一侧接触到热源,这一侧的水就会蒸发为水蒸气,往压强更低的另一侧飘荡,在温度更低的区域释放热量,重新凝结成液态水,而凝结的液滴,会在毛细作用下,沿着多孔的内壁回流,达成气液循环,通过气体液体的转化,实现热量的高效传导。 $ @ L0 @4 c1 Q3 Q0 M9 f3 | + X2 l4 j' R' p! L4 K 为了提高导热效果,大部分显卡会使用多根热管来传递热量,但热管直接接触核心不仅会有空隙,还会有热管无法接触到GPU芯片。所以现在高端显卡一般会使用大铜底包裹热管进行均热,一些高端显卡会使用到能力更强的均热板取代大铜底。均热板,你可以理解为面积非常大的板状热管,同样采用气液转换传递热量,导热能力是纯铜底的数倍。 9 C3 A# w/ Z, ?& h5 P$ H' i1 ~! k; h' \* \" d0 C' E
不过热管和均热板能提供的对流面积非常有限,因此还需要搭配大量的铝制散热鳍片,扩大散热面积,最后通过风扇加强空气对流,带走芯片上的热量。早期的显卡采用下压式风扇设计,从风扇面进风,从侧面出风。现在显卡为了提高散热效果,会采用贯穿式风道设计,热量可以直接从背板的隔栅处排出。4080猛禽的风扇还使用了特殊的设计,中间的风扇与左右两侧的风扇旋转方向不同,保证风扇之间的气流方向相同,从而更高效的排出热量并降低噪音。 8 E+ Q5 o j* y; q4 s( f+ H5 l- Z 4 q. b" B' k0 T/ E+ Z8 J/ e( d5 t! ]: R
三.显卡的主板, R( l: X, [7 r& z" J& {- g* Z
/ }8 D' q0 }# N( _5 k
我们可以把这块电路板从外往里划分成四个部分:接口,供电,显存以及GPU。; w: o4 A0 a `& ]6 u% I6 y
% v/ i0 [; N |/ v
) Z# [; H1 {; s) r" @
( M7 z+ a& e: a & ?$ h* ? U# b GPU相当于显卡的大脑,负责几乎所有的运算任务。要注意,GPU并不等于显卡,GPU通常指的是最中间的这块儿芯片,而显卡指的是包括芯片、显存、供电接口、电路板以及散热模块的整体。) c+ Q2 k9 Y9 Y
1 J! \7 A) }' R I5 L5 N GPU芯片主要由英特尔、AMD和Nvidia 三家厂商供应,而我们熟知的华硕等AIC厂商主要完成的是电路板与散热的设计和生产。+ @2 p+ `% u% z+ }: N D: X
, }- Y: g, k( M6 g
就像主板上所有的元器件都是为CPU服务一样,显卡电路板上的所有元器件也都是为GPU而服务的。视频接口让显卡可以直接把运算好的图像发送给显示器显示。这张4080猛禽搭载了两个HDMI2.1和三个DP1.4接口,不同版本的视频接口能承载的分辨率和刷新率不同。 4 C( u4 x3 f [, }- \- J5 O$ j0 M7 V
PCIE接口让显卡能够通过主板和CPU、内存等其他原器件交互数据,它的数据传输能力和版本以及规则有关。比如说这张4080猛禽用的就是PCE4.0 x16接口,在主板同样支持PCE4.0的情况下,单条4.0通道每秒可以传输2GB的数据,16条总共可以传输每秒32GB的数据。 $ m* o4 \, u* F4 r# _, K: a& a % x# e* i6 @& V0 d, m/ O- [/ Z: B ( k" [" ?; @0 z, u4 J+ l 供电模块保证了显卡有充足的电力分配,它们分布在GPU和显存的外围,由PWM芯片、电容、电感和。MOS管组成电源会从右上方的供电接口输入+12伏的供电,之后再用供电模块儿降压至1.1伏与1.35伏,输送给GPU与显存。这张RT4080猛禽采用直出供电的设计,一个MOS管和一个电感就是一个供电项,总共有18项70A的GPU供电和三项50A的显存供电,即使显卡满载运转,也能提供持续稳定的电能。 ! g" ?) j5 ^, g) x4 p) V1 L6 K2 A |1 b% v
CPU在计算时需要把数据临时存放在内存里,而高速运行的GPU同样需要把数据暂存在显存里,GPU周围黑色的小方块就是显存,这块4080猛禽使用的是最新的GDDR6X显存,频率1400兆赫兹,每颗显存都是2GB的容量,32bit的位宽,八颗一共16GB、256bit。图片 & E" x* A, N1 @# Z; \% U/ k ! j! ? M: i9 P: f 显存的总带宽是由频率、位宽还有显存类型共同决定的。显存的频率代表一秒钟可以传输多少个周期,位宽代表显存一次可以传输的数据量。GDDR6X显存每个周期内可以传输16倍的数据,把它们相乘,再把bit换算成Byte以后,就得到了716.8GB/s的总带宽,代表显存每秒能传输的数据量。 % `9 T; e0 t" }2 B$ e2 u; E, a1 T5 N' V- f8 E' i! d
一般来说,游戏的分辨率越高,贴图和模型越精致,对显存容量和带宽的要求就越高,但在显存够用的情况下,显卡的性能还是由显卡的核心GPU来决定。这张RTX4080显卡搭载的GPU芯片叫做AD 103-301。它使用的是Nvidia最新的ADA-Lovelace架构,面积只有379平方毫米,不过一个矿泉水瓶盖儿大小,但内部却集成了整整459亿颗晶体管。之所以能有这么高的晶体管密度,靠的是台积电先进的5nm光刻工艺。& H3 t3 U W$ Y: K# b
. H$ N: w- p+ u" r/ p' R 台积电会根据英伟达的设计方案,在一块儿12英寸的硅晶圆上,通过复杂的生产工艺刻制出复杂的电路图案。数量庞大的晶体管在GPU的内部组成了复杂的电路结构,就像一座微缩的城市,其中大部分的电路都可以用于图形运算。 , J( b* ?! L& K' p7 b ; ?( o$ S) g+ M6 g) Y 我们一般会用一张简化图来观察GPU结构:主要由SM流式多处理器、L2缓存、NENC视频编码器、NEC视频解码器、显存控制器和PCE控制器构成。 ! w6 j- m$ O' T9 f7 J" k6 a U% o( X5 t
SM流式多处理器占据了GPU的大部面积,他负责了几乎所有的图形运算。这颗AD103-301核心里一共有76组SM单元,每组SM单元里包含128个流处理器,总共9728个流处理器。英伟达把这些流处理器叫做CUDA核心。 & ^8 Q3 H! Z$ n7 z 8 N' |# ^ \* o& T) ^% L8 ~ 显卡的流处理器数量越多,频率越高,性能就会越强。* i' f) ^/ R7 S- ~. z# r/ v& z9 M+ m
$ V$ k; L9 n& s0 q# s6 m: L- U 如果把每组SM类比成一个CPU核心,那么这颗GPU就相当于一颗76核9728线程的处理器。不过,CPU核心就像经验丰富的数学家,能处理更加复杂的任务;而GPU核心更像是只会四则运算的小学生,适合做简单的并行计算。在AI模型的训练和推理、3D游戏里的图形渲染都是需要这样大量简单计算的场景。显卡核心的数量优势就比CPU核心的质量优势更加有效率。要理解为什么显卡更适合这样的运算,我们就需要了解一下游戏画面到底是如何渲染的?图片# H9 ^- c* f- A. V
# M( c& _( s7 W L2 Q' L+ ^
认识图形渲染的基本流程,只需要知道我们看到的世界是由无数个带坐标的模型世界构成,想要观察这个世界,我们还需要一个虚拟摄像机,只有位于摄像机视野范围内的模型才会被渲染出来,同时这些模型相对于摄像机的位置也会被重新计算,得到新的坐标值。 & V6 H8 n& y# O7 p# f * I J- Y2 v% P/ V, J/ q 摄像机所捕获到的这些画面实际上是一个二维平面。三维空间中的模型是要通过投影的方式映射到这个平面上,最后我们需要将这个二维画面显示在由像素点构成的屏幕上。为了获得最终的渲染效果,我们还需要对每个像素点的纹理、光照和颜色等属性进行单独计算。经过这一系列复杂的运算,才能最终生成一帧在屏幕上显示的图像。2 [* `- E$ z6 y2 ]5 m1 t, a
6 W1 h& T! O' c7 f% L( a
在这个计算的过程中,构成三角面的顶点坐标会精确到小数点后七位,转换成计算机能理解的二进制,就是32为0和1,我们管这个叫做FP32单精度浮点数。 4 Y/ p% M* \+ C) q; j L+ T2 A2 e8 d 流畅的画面需要每秒30帧甚至60帧以上的图像,而每一帧都需要大量精确的数据来计算,每秒钟能算的次数就是单精度浮点数算力,可以用来衡量图形渲染的性能。 3 O, A" M: F, s; k ) D; N1 B4 T5 V6 I: b RTX4080的GPU核心可以让9728个CUDA核心同时进行单精度浮点计算,在2800兆赫兹的频率下,可以提供大约54T pro4的单精度浮点算力,意味着每秒钟可以计算五十四万亿次。图片, d6 D: @6 b( M$ w0 h
0 m Z! T |! J' W/ O6 s* } 而像I9这样的高端CPU FT32的算力也只有2.5T Flops,对比之下你就会发现GPU比CPU更加适合图形渲染,单精度浮点主要影响的是游戏图像的渲染性能。! P- g1 y+ q* r" t2 z6 m
) o1 z* p1 Y# L4 o4 I! p 在这颗4080的GPU核心中,所有的CUDA都能计算单精度浮点数,除了能计算FP32之外,同时向下兼容精度更低的半精度浮点FP16和1/4精度浮点FP8,但只有一半的CUDA能支持整数计算。英伟达会把不同GPU支持的具体算力标注在官网上供大家查询。, T' Y/ E5 l `" Z3 j; h! g
8 o& `# @4 E+ N% {! |% f 这里要说明的是GPU的算力和架构有关,架构是GPU的设计方案,设计方案越先进,相同算力下的图形渲染效率就越高。比如GTX1660的GPU架构比GTX980更先进,虽然他们的FP32算力差不多,但1660的游戏性能却明显更强。所以Nvdia在官网标注算力的同时还会标注GPU的架构。 8 d P) N, q( A 0 @9 p% [, y0 X0 Z; r7 ^ 单精度浮点算力和架构共同决定了GPU的游戏性能。8 P b. W! j; t7 R. Y6 t, u# z) F
3 \; J/ x, @4 n I
但现在的GPU除了玩游戏和做渲染建模之外,还承担了许多AI相关的任务,在CUDA核心的右边是第四代Tensor Core张量核心,它非常适合做AI相关的深度学习计算,所有的Tensor Core一共可以提供780 AI TOPS算力。比如说现在的AI绘图软件就可以调用Tensor Core,生成图片的速度远比纯CUDA要快很多。. h" q3 I8 y/ Z2 E- c
/ S7 ~. h/ n$ m1 \* F$ x/ Z
游戏里的DLSS功能同样可以调用Tensor Core,用更低的分辨率渲染,再通过AI上采样到更高的分辨率,从而提升游戏的流畅度。! _* o7 w. N; U5 i; v
9 J# v$ I, \# Q; Y, u6 r 逼真的游戏画面还离不开真实的光照效果,而光线的反射和折射需要庞大的算力,这张4080的核心中,每组SM里都有一颗第三代RT Core光线追踪核心,专门用来加速光照和反射的计算,一共可以提供113 RT-TFLOPS光追算力,光线追踪可以明显提升画质,但也非常的吃性能,如果用的是低端显卡,开了光追以后就可能很卡顿,只有性能更强的高端显卡才适合开启光线追踪。 5 z0 d" \+ n. E. x( O0 I% r) n0 R0 _1 e
在SM单元之外,还有很多其他的单元,视频解码器让显卡能把0101的数据转换成连续播放的视频画面,解码器性能过弱,就可能在播放视频时出现卡顿掉帧。而视频编码器则可以让你把拍摄到的视频数据以新的编码方式压缩成期望的格式和大小。编码器性能过弱则会在剪辑视频导出时浪费过多的时间,显存控制器让GPU和显存得以顺利交互数据。PCIE控制器则让显卡能和主板上的CPU、内存、硬盘等其他元器件交互数据。 D+ |7 E; t5 R, Z1 e- R
- y7 q! ~4 V8 A7 `. P 除开上述内容,显卡的电路板上还有很多其他的附属芯片和接口,他们共同协作让显卡得以顺利运行。 ! i. A% @ S5 v3 X6 j # p5 c$ `, s. |9 a 现在你对显卡的硬件已经有一定的了解了。最后我们来讲讲该如何选择适合自己的显卡?9 N# [( t" }- A
8 ?( J2 Y" ^3 K8 g) p) d- q
四.如何选择适合自己的显卡? 3 l, x* S P% G' b1 W J' ]8 w& _, ^
挑选一张显卡的顺序大概可以按照:性能需求、GPU型号、AIC品牌、实际产品 这四个步骤来考虑,性能需求可以借助Time SPY天梯图做参考。: I( n# Q9 x# O- ]
6 E. U/ y1 h! I$ c3 s6 q0 i
在各个网站里你都可以搜到,它这个显卡的跑分,从高到低依次排列,虽然跑分和实际的游戏性能会略有差异,但是一个非常值得参考的数据,在天梯图里随便盲选一张显卡,然后搜索它的评测类节目,大概就可以知晓这张显卡在不同游戏中可以看到什么样的画质,达到什么样的流畅度,也可以看到它在专业软件中和其它显卡之间的性能差异。 8 S/ V" @( l0 E% x/ L 6 X- A# h: _( e: S, B 最后去查询这张显卡的价格,京东与官方旗舰店还有天猫旗舰店是存在一定的溢价的,建议使用淘宝第三方店作为价格参考,这样你就知道了多少钱可以买到一张跑分多少性能如何的显卡。: _: u! W; X0 R* I9 E7 w