OpenCl 内核代码

OpenCl kernel code

我是 OpenCL 的新手(今天开始)。我很难实现以下列方式添加数组数字的内核代码: 如果A[]=[1,2,3,4,5,6,7,8,9,10],那么求和应该是sum[]=[4,10,16];

i.e, sum[i]=A[i]+A[i+2]; 
     i=i+3;

我已经尝试了以下代码,但它似乎不起作用。

std::string kernel_code =
        "   void kernel simple_add(global const int* A, global const int* B, global int* C){ "
        "   int x =0;"
        "   int i =get_global_id(0);"
        "   SUM[x]=A[i]+A[i+2];"
        "   i=i+3;
        "   x++;"
        "   }  ";

我敢肯定这不是解决问题的方法。在这方面的建议将不胜感激。

您应该计算 i,就好像该工作项是集合中的唯一一个一样。 gid 是工作项的全局 ID,我需要是它的三倍。您也不需要在使用后修改 gid 或 i。这不是最优的,但它会给你正确的答案。

void kernel simple_add(global const int* A, global const int* SUM){
    int gid = get_global_id(0);
    int i = gid * 3;
    SUM[gid]=A[i]+A[i+2];
}