OpenCL,我看行

不是每个程序员都关心并行计算,也难怪,这个世界充斥着大量不可并行的01,这苦了HPC的程序员,如果你的公司很忧伤的裁了你,你会像我这样很忧伤的学Java么?

 

说Cell B.E死了这句话不知道对不对,最起码IBM裁了这个部门,人们纷纷跑去做L2 support或者有幸去做pNext去了。一直不太明白IBM为什么把Cell B.E死死的焊在blade上,而不是像Mercury那样做成PCIe的板子,实现一种廉价的加速方案,就像ClearSpeed干的那样。我更愿意相信,在程序员没有为并行计算做好准备的时候,在并行计算百花齐放的时候,IBM是不会为这种没有高利润的东西花一分钱的。

 

并行计算的问题,首先在于体系结构的多样化和标准的缺失。集群,MPP,CUDA,Brook+,Cell B.E,ClearSpeed,每个人都说自己多牛,每个人都摆出巨高的加速比,但你能让程序员为每个平台都porting自己的程序么?MPP的消失,Beowulf的流行显然迎合了并行计算体系结构归一化的趋势。随着MPI和OpenMP成为集群系统事实上的标准,人们乐意把自己写好的程序放在更新一遍再一遍的集群硬件上,去继续享受免费的午餐。

 

Cell B.E显然断了这些程序员的念头,程序员需要去重新认识什么是PPE,什么是SPE,谁乐意这么干呢?IBM试图标准化一些自己的编程模型,ALF?可惜,没人捧场。Intel也在试图干类似的事情,TBB?不知道捧场的人有几个。Mercury做了自己的平台,好的地方是,这是个抽象硬件的平台,支持多种设备等等,捧场的人会比较多吧,但Mercury显然不能靠自己一力而标准化自己的平台,IBM不可能让他这么干,Intel不会,谁都不会。

 

于是Apple跳出来,推出了OpenCL,诸侯群家争相追捧。为什么是Apple,可能是他从没有自己的并行相关的东西出来吧。

 

OpenCL显然不仅仅面向GPGPU。它的更主要的目的是单节点(共享内存)中的异构并行环境。不可否认,MPI+OpenMP是现有Beowulf的流行方式,但这种模式对现有节点的加速技术显然准备不够。OpenCL首先能够瞄准GPGPU,推出标准化的接口,然后再屏蔽其他加速器,例如Cell B.E,例如ClearSpeed的技术细节,完成Mercury想做但做不了的事情。最后,MPI+OpenCL指日可待。

 

在单节点环境中并行的标准化是任何人都希望看到的事情。尤其对于我们程序员,掌握了OpenCL意味着掌握了所有异构并行环境,何乐而不为?有点时间大家看看孩子不比coding强啊。而所有硬件厂商如果能够在设计之初考虑到OpenCL spec,这显然又是一个大同世界。程序员的素质可能由此得以培养,这个时候IBM再推类Cell B.E的产品,估计就没那么多人被裁了吧,呵呵。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值