FYI,我使用的是Python 2.7的64位版本,并按照pycuda安装指南进行了安装。
我运行以下脚本没有任何问题。
但是,在执行这个语句之后,
我收到了错误信息:
我运行以下脚本没有任何问题。
import pycuda.driver as cuda
import pycuda.autoinit
from pycuda.compiler import SourceModule
import numpy
a = numpy.random.randn(4,4)
a = a.astype(numpy.float32)
a_gpu = cuda.mem_alloc(a.nbytes)
cuda.memcpy_htod(a_gpu,a)
但是,在执行这个语句之后,
mod = SourceModule("""
__global__ void doublify(float *a)
{
int idx = threadIdx.x + threadIdx.y * 4;
a[idx] *= 2;
}
""")
我收到了错误信息:
但我已经在计算机上安装了 VS 2008 和 VS 2010,并按照指示设置了路径和 nvcc 配置文件。有人能告诉我发生了什么事情吗? 更新1: 正如 cgohike 指出的那样,在出错语句之前运行以下语句将解决该问题。CompileError: nvcc 编译 c:\users\xxxx\appdata\local\temp\tmpaoxt97\kernel.cu 失败 [command: nvcc --cubin -arch sm_21 -m64 -Ic:\python27\lib\site-packages\pycuda\cuda kernel.cu] [stderr: nvcc : fatal error : nvcc cannot find a supported version of Microsoft Visual Studio. Only the versions 2008, 2010, and 2012 are supported
import os
os.system("vcvarsamd64.bat")