Форум сайта python.su
из стандартных примеров использования CUDA пробовал запустить данный пример, но почему-то при исполнении выводится непонятная мне ошибка. Вот код и лог:
import pycuda.driver as drv
import pycuda.tools
import pycuda.autoinit
import numpy
import numpy.linalg as la
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))
print dest-a*b
C:\Python27>hello_gpu.pyкусок кода из compiler.py, в котором как я понял ошибка вылезает:
Traceback (most recent call last):
File “C:\Python27\hello_gpu.py”, line 14, in <module>
“”“)
File ”C:\Python27\lib\site-packages\pycuda\compiler.py“, line 235, in __init__
arch, code, cache_dir, include_dirs)
File ”C:\Python27\lib\site-packages\pycuda\compiler.py“, line 201, in compile
”pycuda-compiler-cache-v1-%s“ % _get_per_user_string())
File ”C:\Python27\lib\site-packages\pycuda\compiler.py", line 139, in _get_per_user_string
checksum.update(environ)
File “C:\Python27\lib\os.py”, line 423, in __getitem__
return self.data
KeyError: ‘HOME’
def _get_per_user_string():
try:
from os import getuid
except ImportError:
checksum = _new_md5()
from os import environ
checksum.update(environ["HOME"])
return checksum.hexdigest()
else:
return "uid%d" % getuid()
Отредактировано (Дек. 24, 2010 12:32:30)
Офлайн
нагуглил кой чего, пока не у компа, завтра буду пробовать: похоже, что вместо HOME надо написать PYTHONHOME…
Офлайн
обратите внимание, что возможно вам нужен PYTHONPATH
Офлайн
guranvirвместо PYTHONHOME PYTHONPATH? учту, сегодня поковыряю )
обратите внимание, что возможно вам нужен PYTHONPATH
Офлайн
Просто насколько я понимаю в PYTHONHOME хранится путь до интерпретатора. Но обычно для этих целей устанавливают переменую PYTHONPATH. НО возможно я ошибаюсь, то же это учтите))
Офлайн
guranvirне выходит ничего :( в переменных (переменные среды и системные переменные) нет такого. После того как добавил такую переменную(и в системные и в “переменные среды”) - все равно вылезает та же ошибка (
Просто насколько я понимаю в PYTHONHOME хранится путь до интерпретатора. Но обычно для этих целей устанавливают переменую PYTHONPATH. НО возможно я ошибаюсь, то же это учтите))
Офлайн
записал переменную командой environ = ‘C:\Python27’
выдает теперь другую ошибку:
C:\Python27>hello_gpu.pyгде этот компиллятор cl.exe должен лежать?
Traceback (most recent call last):
File “C:\Python27\hello_gpu.py”, line 14, in <module>
“”“)
File ”C:\Python27\lib\site-packages\pycuda\compiler.py“, line 236, in __init__
arch, code, cache_dir, include_dirs)
File ”C:\Python27\lib\site-packages\pycuda\compiler.py“, line 226, in compile
return compile_plain(source, options, keep, nvcc, cache_dir)
File ”C:\Python27\lib\site-packages\pycuda\compiler.py", line 107, in compile_plain
cmdline, stdout=stdout, stderr=stderr)
pycuda.driver.CompileError: nvcc compilation of c:\users\aace~1\appdata\local\temp\tmp_dyt87\kernel.cu failed
[stderr:
nvcc fatal : Cannot find compiler ‘cl.exe’ in PATH
]
Офлайн
cl.exe входит в состав MS Visual Studio и является компилятором управляемым через командную строку, бесплатно доступна Visual Studio Express. А так вобще этот вопрос гуглится неплохо))
Офлайн
guranvirПоставил Visual Studio Express 2008 с сайта мелкософта, но он почему-то походу поставил только какой-то “удаленный отладчик Visual Studio2008”. (у меня уже стоит 2010 студия, но когда я прописал путь к cl.exe - стала выводиться другая ошибка, о том, что ему не нравится компилятор cl.exe, потому что он не от VS2008 :(
cl.exe входит в состав MS Visual Studio и является компилятором управляемым через командную строку, бесплатно доступна Visual Studio Express. А так вобще этот вопрос гуглится неплохо))
Traceback (most recent call last):Может где-то можно взять просто компилятор отдельно? Гуглю сейчас, никак не могу нагуглить пока :mad:
File “C:\Python27\hello_gpu.py”, line 14, in <module>
“”“)
File ”C:\Python27\lib\site-packages\pycuda\compiler.py“, line 235, in __init__
arch, code, cache_dir, include_dirs)
File ”C:\Python27\lib\site-packages\pycuda\compiler.py“, line 225, in compile
return compile_plain(source, options, keep, nvcc, cache_dir)
File ”C:\Python27\lib\site-packages\pycuda\compiler.py", line 107, in compile_plain
cmdline, stdout=stdout, stderr=stderr)
pycuda.driver.CompileError: nvcc compilation of c:\users\3d47~1\appdata\local\temp\tmpnmw0vl\kernel.cu failed
[stderr:
nvcc fatal : nvcc cannot find a supported cl version. Only MSVC 8.0 and MSVC 9.0 are supported
]
Отредактировано (Дек. 28, 2010 14:08:23)
Офлайн
не нужно править PATH вручную.
Следует запустить vcvars32.bat из недр Visual Studio - он правильно настраивает все переменные окружения.
Офлайн