将 std::vector 传递给 openCL 内核C++绑定



我是OpenCL的新手。我想使用 C++ 绑定将矢量传递给 OpenCL 内核。

目前我在主机程序中:

std::vector<cl_float4> toKernel;
std::vector<cl_float3> output;
int n = 50;
//init some value in toKernel vector
//make kernel, program, command queue, etc...
cl::Buffer bufferX = cl::Buffer(
      context,
      CL_MEM_READ_ONLY,
      vectorSize * sizeof(cl_float4)
    );
cl::Buffer bufferNumber = cl::Buffer(
      context,
      CL_MEM_READ_ONLY,
      sizeof(int)
    );
cl::Buffer bufferOutput = cl::Buffer(
      context,
      CL_MEM_WRITE_ONLY,
      vectorSize * sizeof(cl_float3)
    );

queue.enqueueWriteBuffer(
      bufferX,
      CL_TRUE,
      0,
      vectorSize * sizeof(cl_float4),
      toKernel.data()
    );
queue.enqueueWriteBuffer(
      bufferNumber,
      CL_TRUE,
      0,
      sizeof(int),
      &n
    );
kernel.setArg(0, bufferX);
kernel.setArg(1, bufferNumber);
kernel.setArg(2, bufferOutput);
cl::NDRange global(vectorSize);
    cl::NDRange local(1);
    queue.enqueueNDRangeKernel(
      kernel,
      cl::NullRange,
      global,
      local
    );
queue.enqueueReadBuffer(
      bufferOutput,
      CL_TRUE,
      0,
      vectorSize * sizeof(cl_float3),
      &output
    );

在我的内核程序中,我像这样访问每个向量值:

__kernel void calculate(__global const float4 *x, __global const int *n, __global float3 *out){
    int i = get_global_id(0);
    for (int j=0; j<n; j++) {
         //do some calculation using x[i] and x[j]....
    }
    out[i] = calc_result;
}

这是正确的方法吗?我不确定如何在 OpenCL 中输出调试消息。当我尝试从内核读取输出时,我得到clEnqueueReadBuffer(-5(。你如何从OpenCL读回std::vector?

-5的意思是"资源不足"。不能将output作为指向enqueueReadBuffer的指针传递。你需要通过output.data()

最新更新