dus*_*ard 5 double gpu gpgpu opencl
我正在尝试在 OpenCL 内核中获得double精确的工作精度,但在启用cl_khr_fp64. 如果我把它放在#pragma OPENCL EXTENSION cl_khr_fp64 : enable内核文件的顶部并定义一个变量,double u = 5.0;那么它就会定义它并允许我+-*/打开u. 但是,如果我尝试执行任何数学函数,例如double u = exp(5.0);它会抛出错误,指出找不到exptype 的重载函数double。我发现奇怪的是,如果我检查是否cl_khr_fp64是通过定义的
#ifdef cl_khr_fp64
#pragma OPENCL EXTENSION cl_khr_fp64 : enable
#elif defined(cl_amd_fp64)
#pragma OPENCL EXTENSION cl_amd_fp64 : enable
#else
#error "Double precision floating point not supported by OpenCL implementation."
#endif
Run Code Online (Sandbox Code Playgroud)
然后它会抛出不支持双精度的错误。如果我只是说启用它,那么它就会启用,但如果我检查它是否能够启用,那么它就会说不能。
我已经检查了卡上的扩展并cl_khr_fp64已列出,我还检查了CL_DEVICE_DOUBLE_FP_CONFIG使用clGetDeviceInfo,它返回 63。我在 Yosemite 上使用 MacPro 和 AMD FirePro D700。我想知道我是否cl_khr_fp64在错误的地方启用了或者是什么。我的文件的内容mykernel.cl如下。它只是 Apple 'hello_world' OpenCL Xcode 项目的修改。编写的代码工作得很好,但是如果我将行从 更改为double u = (5.0);则double u = exp(5.0);它不起作用。最终我想对double变量使用数学函数。任何帮助将不胜感激!
#pragma OPENCL EXTENSION cl_khr_fp64 : enable
__kernel void square5(global double* input, global double* output, double mul,int nv)
{
size_t i = get_global_id(0);
double u = (5.0);
float left = u/1.2;
if(i==0) {
output[i] = mul*pow((float)u,left)*input[i]*input[i];
} else if (i==nv-1) {
output[i] = mul*u*input[i]*input[i];
} else {
output[i] = 0.25*mul*u*(input[i-1] + input[i+1])*(input[i-1] + input[i+1]);
}
}
Run Code Online (Sandbox Code Playgroud)
双精度在 OpenCL 1.2 中成为核心可选功能(这应该是您的设备在 OS X 下支持的版本)。这意味着如果设备支持该扩展,您不需要启用该扩展即可使用它。然而,启用扩展不应产生任何负面影响。
您没有做错任何事情,因此这可能是 Apple 的 OpenCL 实现中的一个错误。exp()对于支持双精度的设备,相同的代码(带有该函数)在我的 Macbook 上编译得很好。因此,如果您的设备明确报告它支持双精度,那么您应该在Apple 的错误报告系统中提交错误。
| 归档时间: |
|
| 查看次数: |
8858 次 |
| 最近记录: |