马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 fishshuke 于 2017-7-27 15:51 编辑
网上看到一个帖子(使用Python写CUDA程序)。我就来运行一下,运行后报错。错误信息是:“WindowsError: [Error 193] %1 不是有效的 Win32”。搜了一下报错信息,有人回复是因为“你用的是64位的python调用的32位的dll,换成32位的python试试”
让我感到奇怪的是我的python2.7从软件到库使用的都是64位,我不知道为什么我会调用到32位的dll文件呢?
请大家帮忙分析一些我的问题,我找到这个原因,对不对?如果对的话,改怎么解决(我不想用32位python呀 )?
代码如下: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()
|