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技術。

資料來源[編輯]

<references>

  1. ^ http://blogs.msdn.com/b/somasegar/archive/2012/02/03/c-amp-open-specification.aspx
  2. ^ http://blogs.msdn.com/b/nativeconcurrency/archive/2013/06/28/what-s-new-for-c-amp-in-visual-studio-2013.aspx?Redirected=true