C++ AMP

C++ AMP是微软公司基于DirectX 11技术实现的一个并行计算库。它建立在C++的语言规范上,使得程序员可以相对容易地在数据并行硬件(如显卡)上编写并执行并行计算程序。

特性

[编辑]
  • 支持CPU/GPU共享内存
  • 代码可在GPU上调试,亦可在CPU上模拟及调试GPU代码

系统要求

[编辑]
  • 操作系统:Windows 7, Windows 8, Windows Server 2008 R2, 或者Windows Server 2012
  • 支持DirectX 11或更新的硬件

示范程序

[编辑]
#include <amp.h> // C++ AMP 头文件 #include <iostream> using namespace concurrency; //C++ AMP 命名空间  const int size = 5; // 定义数组大小  void TestCPPAMP() {     int aCPU[] = {1, 1, 1, 1, 1};     int bCPU[] = {3, 3, 3, 3, 3};     int cCPU[size];          // 定义C++ AMP封装对象     array_view<const int, 1> a(size, aCPU); //a是aCPU在并行计算硬件(显卡)上的拷贝     array_view<const int, 1> b(size, bCPU);     array_view<int, 1> c(size, cCPU);      parallel_for_each( // C++ AMP 并行代码         c.extent, // 定义并行计算的大小         [=](index<1> idx) // [=]是lambda函数中的捕捉从句,index是数组下标         restrict(amp) // 通知编译器此处为C++ AMP代码     {         c[idx] = a[idx] + b[idx];     }     );      // 打印结果     for (int i = 0; i < size; i++) {         std::cout << c[i] << "\n"; // 结果应为 4, 4, 4, 4, 4     } } 

历史

[编辑]

C++ AMP的初始版本于2012年发布[1]。2013年,微软在添加了一些特性后发布了C++ AMP的Microsoft Visual Studio 2013版本[2]

竞争对手

[编辑]

在并行计算领域,C++ AMP的对手有NVidia公司的CUDA技术和开放标准的OpenCL技术。

资料来源

[编辑]
  1. ^ 存档副本. [2014-04-24]. (原始内容存档于2014-04-03). 
  2. ^ 存档副本. [2014-04-24]. (原始内容存档于2019-09-24).