PyCuda: может импортировать модуль, тогда я не могу ... (Примеры PyCUDA) - PullRequest
1 голос
/ 08 апреля 2011

Пример кода:

import pycuda.autoinit
import pycuda.driver as drv
import numpy

from pycuda.compiler import SourceModule
mod = SourceModule("""
__global__ void multiply_them(float *dest, float *a, float *b)
{
  const int i = threadIdx.x;
  dest[i] = a[i] * b[i];
}
""")

multiply_them = mod.get_function("multiply_them")

a = numpy.random.randn(400).astype(numpy.float32)
b = numpy.random.randn(400).astype(numpy.float32)

dest = numpy.zeros_like(a)
multiply_them(
        drv.Out(dest), drv.In(a), drv.In(b),
        block=(400,1,1), grid=(1,1))

print dest-a*b

Результаты:

Traceback (most recent call last):
  File "test.py", line 12, in <module>
    """)
  File "build/bdist.linux-x86_64/egg/pycuda/compiler.py", line 238, in __init__
  File "build/bdist.linux-x86_64/egg/pycuda/compiler.py", line 223, in compile
  File "build/bdist.linux-x86_64/egg/pycuda/compiler.py", line 149, in _find_pycuda_include_path
ImportError: No module named pycuda

Звучит достаточно просто, поэтому давайте проверим это.

Python 2.7.1 (r271:86832, Feb 17 2011, 14:13:40) 
[GCC 4.3.4] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import pycuda
>>> pycuda
<module 'pycuda' from '/home/abolster/lib/python2.7/site-packages/pycuda-0.94.2-py2.7-linux-x86_64.egg/pycuda/__init__.pyc'>
>>> 

Хорошо, это странно ...

Короче говоря, даже шаг за шагом проходя через файл в консоль python, ничего не происходит неправильно до фактического выполнения строки mod = SourceModule ().

(Финальная обратная связь, я обещаю)

/home/abolster/lib/python2.7/site-packages/pycuda-0.94.2-py2.7-linux-x86_64.egg/pycuda/compiler.pyc in _find_pycuda_include_path()
    147 def _find_pycuda_include_path():
    148     from imp import find_module
--> 149     file, pathname, descr = find_module("pycuda")
    150 
    151     # Who knew Python installation is so uniform and predictable?

ImportError: No module named pycuda

Так что похоже, что Pycuda становится другим, включая DIR, чем Python во время выполнения, что не должно происходить (насколько я понимаю)

Есть идеи? (Извините за длинный вопрос)

Talonmies подняли вопрос о том, что nvcc не найден; если питон не получает свои envars откуда-то, о котором я не могу думать, нет причины, по которой он не должен:

[bolster@dellgpu src]$ which nvcc
~/cuda/bin/nvcc

Ответы [ 3 ]

3 голосов
/ 07 сентября 2012

Переход на Python 2.6 и переустановка соответствующих модулей устранили проблему для OP.

1 голос
/ 09 апреля 2011

В коде, который вы пытаетесь запустить, нет ничего плохого - он должен работать. Я думаю, что nvcc не может быть найден. Убедитесь, что в вашей среде задан путь к исполняемому файлу nvcc, прежде чем пытаться использовать pycuda.compiler.

0 голосов
/ 09 апреля 2011

Я думаю, вы не установили инструментарий CUDA из nvidia и добавили

/ usr / local / cuda / lib /

в

LD_LIBRARY_PATH

найдите .so модуля pycuda и дайте нам вывод:

>lld pycuda.so 
...