博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CPU和GPU的差别
阅读量:6689 次
发布时间:2019-06-25

本文共 981 字,大约阅读时间需要 3 分钟。

详见:

   首先需要解释CPU和GPU这两个缩写分别代表什么。CPU即中央处理器,GPU即图形处理器。其次,要解释两者的区别,要先明白两者的相同之处:两者都有总线和外界联系,有自己的缓存体系,以及数字和逻辑运算单元。一句话,两者都为了完成计算任务而设计。

   两者的区别在于存在于片内的缓存体系和数字逻辑运算单元的结构差异:CPU虽然有多核,但总数没有超过两位数,每个核都有足够大的缓存和足够多的数字和逻辑运算单元,并辅助有很多加速分支判断甚至更复杂的逻辑判断的硬件;GPU的核数远超CPU,被称为众核(NVIDIA Fermi有512个核)。每个核拥有的缓存大小相对小,数字逻辑运算单元也少而简单(GPU初始时在浮点计算上一直弱于CPU)。

   从结果上导致CPU擅长处理具有复杂计算步骤和复杂数据依赖的计算任务,如分布式计算,数据压缩,人工智能,物理模拟,以及其他很多很多计算任务等。GPU由于历史原因,是为了视频游戏而产生的(至今其主要驱动力还是不断增长的视频游戏市场),在三维游戏中常常出现的一类操作是对海量数据进行相同的操作,如:对每一个顶点进行同样的坐标变换,对每一个顶点按照同样的光照模型计算颜色值。GPU的众核架构非常适合把同样的指令流并行发送到众核上,采用不同的输入数据执行。在2003-2004年左右,图形学之外的领域专家开始注意到GPU与众不同的计算能力,开始尝试把GPU用于通用计算(即GPGPU)。之后NVIDIA发布了CUDA,AMD和Apple等公司也发布了OpenCL,GPU开始在通用计算领域得到广泛应用,包括:数值分析,海量数据处理(排序,Map-Reduce等),金融分析等等。

   简而言之,当程序员为CPU编写程序时,他们倾向于利用复杂的逻辑结构优化算法从而减少计算任务的运行时间,即Latency。当程序员为GPU编写程序时,则利用其处理海量数据的优势,通过提高总的数据吞吐量(Throughput)来掩盖Lantency。目前,CPU和GPU的区别正在逐渐缩小,因为GPU也在处理不规则任务和线程间通信方面有了长足的进步。另外,功耗问题对于GPU比CPU更严重。

总的来讲,GPU和CPU的区别是个很大的话题,甚至可以花一个学期用32个学时十几次讲座来讲,所以如果提问者有更具体的问题,可以进一步提出。我会在我的知识范围内尝试回答。

转载地址:http://jykoo.baihongyu.com/

你可能感兴趣的文章
java中的枚举类 enum使用与分析
查看>>
JAVA 四大域对象总结
查看>>
GIT 常用命令
查看>>
企业级落地容器与DevOps,选用K8S都有哪些“姿势”
查看>>
Bugtags,产品经理的瑞士军刀
查看>>
p2v之 clonezilla(2)将物理机win7备份为clonezilla镜像文件
查看>>
JMeter-PerfMon插件(服务器cpu、内存等信息收集)
查看>>
2016年底学习前端的姿势
查看>>
spring boot session 拦截
查看>>
Bound Service
查看>>
解决twisted 的socket长连接问题
查看>>
JS错误类型的学习
查看>>
JOIN关联表中ON,WHERE后面跟条件的区别
查看>>
Could not find result map java.lang.String
查看>>
Spring读取Properties配置文件
查看>>
android 获得根视图 和获得根actionbar
查看>>
jquery实现hover图片半透明效果
查看>>
(在线文库系统)centos+nginx+mysql+php+openoffice+pdf2swf+pdf2image
查看>>
linux挂载/卸载U盘
查看>>
MAP-Diameter IWF Introduction
查看>>