7155|7

6423

帖子

16

TA的资源

版主

楼主
 

爱上OpenCL的十个理由(转) [复制链接]

 

作为OpenCL CodeBench的开发者,Amdahl软件公司始终坚信OpenCL能够带来巨大的利益,也从未怀疑过OpenCL标准的成功性。现在人们对计算性能的要求越来越高,在不超过发热量和功耗的限制范围,我们相信多核和多核系统提供了一个可行的解决方法。对于OpenCL用户来说,OpenCL标准的优点和利益是很明显的。我们认为在未来的几十年甚至超过几十年里,OpenCL将会引领计算机软件行业。

下面是我们为什么觉得OpenCL强大的最重要的10个理由。

1-OpenCL可以为代码加速10倍甚至更多

现在许多的嵌入式或者桌面计算平台在主板上都有GPU。但是,大部分时间GPU都是闲置的,除非该计算平台正在运行图形敏感的工作。通过利用空闲的GPU的计算能力,你可以加速代码的运行。假如你的算法本身就是并行的,那么利用GPU可以加速的更多。对于分子动力学模拟,甚至电子电路,实时视频处理,图像处理,图像增强,移动侦测,财务分析和自动交易等方面的应用特别适合利用GPU来进行加速。

GPU并不是唯一可以利用OpenCL加速的设备。如果你的主机平台有多个CPU核——而且现在越来越多的台式电脑拥有四个核或者更多的核——在这种情况下你同样可以使用OpenCL进行CPU的多核编程。利用OpenCL进行CPU多核编程可能达不到利用GPU加速的效果,但这取决于加速的算法,不过随着CPU核数的增加性能也会随之提高。

2-OpenCL是一个开放标准

OpenCL是一个开放的标准意味着该标准对于所有使用OpenCL的人来说都是免费的,开放的。OpenCL有一系列高品质的文档,包括在线教程、编程指南和参考手册。除此之外,我们还可以找到很多关于的OpenCL的开源工具和出版的书籍,而且我们还可以利用互联网找到很多的使用案例和设计实例。

3-OpenCL可以降低功耗

现在存在很多的工业例子证明对加速器的使用可以降低系统能耗。Amdahl软件公司在不久的将来会出版一本白皮书,该书使用直接的定量分析的方式表明使用简单的CPU+GPU模型来降低功耗的机会。与此同时,Imagination Technologies公司提供的OpenCL视频例子很好的展示了这一点。

4-OpenCL可以节省你的硬件成本

对于数字信号处理(DSP),OpenCL提供了一种宽松的浮点实现。如果你的算法不需要绝对的精确,你可以在系统中取消DSP,使用已有的GPGPU代替。

5-OpenCL正在快速的普及

这对于桌面和嵌入式世界都是正确的。半导体和IP供应商,像Altera, Apple, AMD, ARM, Freescale, IBM, Imagination, Intel, NVidia, Samsung, STMicroelectronics, Texas Instruments, Vivante, Qualcomm等已经宣布了他们的OpenCL兼容设备。在Khronos的OpenCL兼容产品资料库可以找到完整的兼容设备和驱动清单。随着其他设备兼容性的测试,这个清单会迅速扩大。通过使用OpenCL,现在越来越多的库和最终用户应用正在被移植到OpenCL平台,以利用GPGPU的加速能力。OpenCL的使用提高了应用的性能,为最终用户的体验和期望设定了新的标准。

6-OpenCL可以被用作产生自定义硬件的基础

OpenCL编程模型在本质上是通过对内核,工作组和工作项的定义来实现并行。在内核中,甚至可以通过使用有着固定的众所周知长度的小型矢量数据类型进行更细粒度的并行度划分。在高效数据访问过程中,OpenCL另外一个重要的组成特性是内核能够通过barrier和memory fence进行同步的能力。所有这些特性使得OpenCL不仅仅适合编程以用来进行软件加速,也适合对自定义硬件加速器实现的定义。Altera公司已经意识到了这一点,它最近发布了一个程序,该程序提供了从OpenCL移植到FPGA的实现方式。

开发人员的应用程序不再受限于存在的设备。相反,他们可以通过OpenCL定义特定的“co-processor”来进行系统优化,以满足他们的特殊要求(性能,功耗,大小)。设计人员可以在一个已知的并易于调试的环境下开发一个功能全面并已通过测试的的并行应用。一旦完成了代码的编写,影响性能的关键代码部分可以通过FPGA image来进行完美的加速,该FPGA image是程序涉及到的内核直接产生的,这是OpenCL的一个很重要的好处。这促进了一种紧密的集成硬件/软件协同设计方法的行成,在该方法中,同一个基准程序和测试贯穿整个开发过程,这样就加快了应用进入市场的时间。

7-OpenCL C99语言是基于C语言的

这是一个不应该被忽略的特性。创建一种全新的编程语言会减慢对OpenCL的采纳速度——尽管它可能会带来巨大的利益。C语言是一种工业标准语言,它是OpenCL的基础。OpenCL kernel定义语言是对C99的扩展,简单易于接受。对于会使用C编程的工程师来说,能够很快的掌握OpenCL。这样,程序员就可以集中精力在他们想要加速的算法上,而不是OpenCL的语法上。

8-OpenCL可以被用于各种各样的宿主语言

OpenCL kernel可以在C , C++, Java, Python, JavaScript, Haskell, Perl, Ruby等宿主语言中调用,而且能够调用OpenCL的语言还在增多。这就使得在不同的开发环境下可以进行OpenCL kernel和结果的移植和复用,使得对GPGPU计算的支持更加灵活。

9-很容易开始OpenCL

大部分的PC机都有兼容OpenCL的显卡。如果你的计算系统没有GPU(不太可能的情况),只要你找到相应可用的驱动,你同样可以在CPU上直接运行OpenCL程序。在嵌入式世界中,存在很多支持OpenCL的开发板。许多的GPU供应商除了提供了OpenCL的培训视频和教程,还提供了很多关于OpenCL的应用笔记和示例程序。所以要想开始OpenCL编程是很便宜,很简单的事情。

10-OpenCL是平台独立的

OpenCL的编程模型是平台独立的,它能够用来进行异构的多核的软件开发。不同的内存空间定义了一个内存一致的模型。在OpenCL代码运行时,从用户的角度看,低层级的任务例如队列和执行内核是被屏蔽的,是不可见的。在OpenCL中,events,barrier和fences提供了同步的能力。

OpenCL平台的独立性意味着在不修改代码的前提下就能够让代码在不同的兼容的OpenCL平台上运行。因此,即使在不同的平台运行同一OpenCL代码性能可能会有所不同,但是从一个平台将OpenCL代码移植到另一个平台是很简单的。OpenCL在基于共有系统模型的基础上提供了一个功能性的起点。

结论

我们坚信OpenCL潜在的能力。OpenCL使得软件工程师可以有效的利用(易购的)多核计算的能力。不管在什么编程环境下,用来进行开发的工具越好,开发效率就越高,代码的质量就越好。在多核的时代下,我们使用OpenCL CodeBench的目的就是简化OpenCL的开发。OpenCL CodeBench提供了全面的主机代码生成功能,还提供了基于Eclipse的智能便捷的OpenCL kernel编辑器。不要一味的相信我们的话,你可以自己去试试用OpenCL CodeBench进行编程,你将会发现要加速你的应用是件多么简单多么快捷的事情。


此帖出自Altera SoC论坛

最新回复

好文章,谢谢分享!!!!!!!!!!!!!!!!!  详情 回复 发表于 2015-1-23 14:25
点赞 关注
个人签名training
 
 

回复
举报

107

帖子

0

TA的资源

一粒金砂(中级)

沙发
 
在HPC领域被CUDA虐好几条街。。。OpenCL的日子不好混啊
此帖出自Altera SoC论坛

点评

给介绍介绍CUDA呗  详情 回复 发表于 2015-1-15 23:09
个人签名Caffe please.
 
 
 

回复

5979

帖子

8

TA的资源

版主

板凳
 
还有爱上它,也不知道这是什么玩意
继续关注
此帖出自Altera SoC论坛

点评

我也不知道这是什么玩意,从来没用过,又被你们鄙视了  详情 回复 发表于 2015-1-15 23:10
个人签名生活就是油盐酱醋再加一点糖,快活就是一天到晚乐呵呵的忙
===================================
做一个简单的人,踏实而务实,不沉溺幻想,不庸人自扰
 
 
 

回复

6423

帖子

16

TA的资源

版主

4
 
zhaoyongke 发表于 2015-1-15 22:01
在HPC领域被CUDA虐好几条街。。。OpenCL的日子不好混啊


给介绍介绍CUDA呗

此帖出自Altera SoC论坛
个人签名training
 
 
 

回复

6423

帖子

16

TA的资源

版主

5
 
chenzhufly 发表于 2015-1-15 22:23
还有爱上它,也不知道这是什么玩意
继续关注

我也不知道这是什么玩意,从来没用过,又被你们鄙视了


此帖出自Altera SoC论坛
个人签名training
 
 
 

回复

7608

帖子

18

TA的资源

五彩晶圆(高级)

6
 
个人比CUDA有前途,通用性强的多。异构,可以在一个平台中利用统一的编程模型统一利用DSP,FPGA,GPU,CPU的并行运算能力。缺点是目前针对高性能的算法库支持没有CUDA多。然CUDA毕竟只有一家玩在自家的显卡上。
此帖出自Altera SoC论坛
个人签名

默认摸鱼,再摸鱼。2022、9、28

 
 
 

回复

1025

帖子

1

TA的资源

纯净的硅(高级)

7
 
FPGA上的opencl个人觉得离普及,或者说大规模应用,还有比较长的路要走

目前来看,用C来描述任务,然后转化为硬件,实际上远远不像宣传说的那么easy可以获得很好的资源利用率和性能提升,如果想做的好,还是需要对硬件资源比较熟,才能选择相对好的优化方式

现在的状况,貌似就一些研究机构和大公司在这方面投入比较多,比如HW、ZTE,小公司很少有搞这个的,因为做产品的话,对开发人员的知识深度要求还是相对很高,并不是像单片机、或者操作系统上写C程序那么easy
此帖出自Altera SoC论坛
 
 
 

回复

16

帖子

0

TA的资源

一粒金砂(初级)

8
 
好文章,谢谢分享!!!!!!!!!!!!!!!!!
此帖出自Altera SoC论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/8 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表