本帖最后由 fishshuke 于 2017-7-31 02:49 编辑
最近看了一个帖子使用Python写CUDA程序 ,刚好我的显卡是N卡,支持cuda。就想来试试看。结果,就是安装了numba后,显示报错了。错误信息是:“OSError: [WinError 193] %1 不是有效的Win32应用程序。”
百度google搜了好多,我看的头都大了。还是想不明白,我安装的使64位python,而且库函数都是64位的。此前从来没有出过这样的错误。为什么这次会出现这个错误呢?
代码如下:import numpy as np
from timeit import default_timer as timer
from numba import vectorize
@vectorize(["float32(float32, float32)"], target='cuda')
def vectorAdd(a, b):
return a + b
def main():
N = 320000000
A = np.ones(N, dtype=np.float32 )
B = np.ones(N, dtype=np.float32 )
C = np.zeros(N, dtype=np.float32 )
start = timer()
C = vectorAdd(A, B)
vectorAdd_time = timer() - start
print("c[:5] = " + str(C[:5]))
print("c[-5:] = " + str(C[-5:]))
print("vectorAdd took %f seconds " % vectorAdd_time)
if __name__ == '__main__':
main()
这是正常执行的另一个矩阵运算程序的截图(图一)。
这是安装"numba"成功的截图(图二)。
这是python3执行“import numba”的报错信息(图三)。
求论坛的朋友们看看我这个问题怎么解决?
PS:搜到一个帖子解释我这个报错原因(不知道对不对)
我在win7x64的机器上装了64位的python,不能有效load32位的dll,换成32位的python就好了。
|