微软发布C++ AMP规范,旨在降低数据并行门槛

微软在他们的GoingNative 2012大会上为其C++ AMP(C++加速大规模并行处理)发布了开放规范(PDF)。C++ AMP被描述成“一种能够在数据并行硬件上加速C++代码的编程模型”。而这类硬件中最常见的例子要属独立显卡上能够使用多核或SSE CPU作为替代选择的GPU了。

\

微软声明的C++ AMP编程模型如下:

\
\

……给你上面几个方面的显式控制,包括:在CPU和加速器之间进行数据拷贝,以及在GPU上执行计算。你可以显式地管理CPU和加速器间的所有通信。这类通信既可以是同步的也可以是异步的。加速器中的数据并行计算,可以通过使用多维数组、高层次数组操作函数、多维索引操作以及其他高层次抽象进行表示。所有这些表示都是基于C++编程语言的一个大型子集。该编程模型包含了多个层次,以便你可以在易用性和最大性能之间进行权衡。

\
\

微软对此标准的实现适用于任何运行DirectX 11的系统,而如果系统没有DirectX 11,那么会有一段非C++的代码被执行。

\

微软并不打算把C++ AMP只面向Windows,因为它“支持并鼓励任何人任何平台上实现C++ AMP开放规范……”(摘自原文)。迄今为止,该项目折射出的贡献者来自于Nvidia和AMD。为了鼓励外部实现,微软在其“微软社区承诺协议”下发布了整个C++ AMP规范。

\

虽然微软的实现支持C++ AMP和Direct 3D之间的互操作性,但是正式规范中并没有要求这点。另外,目前C++ AMP还不支持与OpenGL的互操作,开发人员Daniel Month最近在论坛一个贴子中指出,这项支持并不会即刻到来,因为“(C++ AMP团队)中没有人有OpenGL的经验”。

\

对于想要尝试新的C++ AMP编程模型的开发人员,可以先下载Visual Studio 11开发者预览版,然后查看这篇MSDN博客文章中给出的样例代码。(代码中的例子还包含了.NET开发人员如何从C#中使用C++ AMP。)

\

查看英文原文:http://www.infoq.com/news/2012/02/CPP_AMP_Published

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值