Уведомления

Группа в Telegram: @pythonsu

#1 Дек. 24, 2010 12:29:18

daemvil
От:
Зарегистрирован: 2010-12-24
Сообщения: 17
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

из стандартных примеров использования 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
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’
кусок кода из compiler.py, в котором как я понял ошибка вылезает:

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()
для куды ставил следующее:

Python 2.7.1
NVIDIA GPU Computing Toolkit 3.2
numpy-1.5.1.win32-py2.7
pytools-11
decorator-3.2.1
pycuda-0.94.2.win32-py2.7

операционка Windows 7 64x. Если важно: стоит Visual Studio 2010 и Delphi 7.
Посоветуйте, как заставить проект работать? я “в питоне” совсем недавно, буквально недели 2 только.



Отредактировано (Дек. 24, 2010 12:32:30)

Офлайн

#2 Дек. 25, 2010 10:18:22

daemvil
От:
Зарегистрирован: 2010-12-24
Сообщения: 17
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

нагуглил кой чего, пока не у компа, завтра буду пробовать: похоже, что вместо HOME надо написать PYTHONHOME…



Офлайн

#3 Дек. 26, 2010 11:15:15

guranvir
От:
Зарегистрирован: 2010-03-16
Сообщения: 186
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

обратите внимание, что возможно вам нужен PYTHONPATH



Офлайн

#4 Дек. 26, 2010 12:03:51

daemvil
От:
Зарегистрирован: 2010-12-24
Сообщения: 17
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

guranvir
обратите внимание, что возможно вам нужен PYTHONPATH
вместо PYTHONHOME PYTHONPATH? учту, сегодня поковыряю )



Офлайн

#5 Дек. 26, 2010 13:06:08

guranvir
От:
Зарегистрирован: 2010-03-16
Сообщения: 186
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

Просто насколько я понимаю в PYTHONHOME хранится путь до интерпретатора. Но обычно для этих целей устанавливают переменую PYTHONPATH. НО возможно я ошибаюсь, то же это учтите))



Офлайн

#6 Дек. 26, 2010 19:23:51

daemvil
От:
Зарегистрирован: 2010-12-24
Сообщения: 17
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

guranvir
Просто насколько я понимаю в PYTHONHOME хранится путь до интерпретатора. Но обычно для этих целей устанавливают переменую PYTHONPATH. НО возможно я ошибаюсь, то же это учтите))
не выходит ничего :( в переменных (переменные среды и системные переменные) нет такого. После того как добавил такую переменную(и в системные и в “переменные среды”) - все равно вылезает та же ошибка (



Офлайн

#7 Дек. 26, 2010 19:57:37

daemvil
От:
Зарегистрирован: 2010-12-24
Сообщения: 17
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

записал переменную командой environ = ‘C:\Python27’
выдает теперь другую ошибку:

C:\Python27>hello_gpu.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 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 должен лежать?



Офлайн

#8 Дек. 27, 2010 09:25:57

guranvir
От:
Зарегистрирован: 2010-03-16
Сообщения: 186
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

cl.exe входит в состав MS Visual Studio и является компилятором управляемым через командную строку, бесплатно доступна Visual Studio Express. А так вобще этот вопрос гуглится неплохо))



Офлайн

#9 Дек. 28, 2010 13:55:20

daemvil
От:
Зарегистрирован: 2010-12-24
Сообщения: 17
Репутация: +  0  -
Профиль   Отправить e-mail  

pyCUDA как заставить работать пример hello_gpu.py

guranvir
cl.exe входит в состав MS Visual Studio и является компилятором управляемым через командную строку, бесплатно доступна Visual Studio Express. А так вобще этот вопрос гуглится неплохо))
Поставил Visual Studio Express 2008 с сайта мелкософта, но он почему-то походу поставил только какой-то “удаленный отладчик Visual Studio2008”. (у меня уже стоит 2010 студия, но когда я прописал путь к cl.exe - стала выводиться другая ошибка, о том, что ему не нравится компилятор cl.exe, потому что он не от VS2008 :(

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 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
]
Может где-то можно взять просто компилятор отдельно? Гуглю сейчас, никак не могу нагуглить пока :mad:



Отредактировано (Дек. 28, 2010 14:08:23)

Офлайн

#10 Дек. 28, 2010 14:19:44

Андрей Светлов
От:
Зарегистрирован: 2007-05-15
Сообщения: 3137
Репутация: +  14  -
Профиль   Адрес электронной почты  

pyCUDA как заставить работать пример hello_gpu.py

не нужно править PATH вручную.
Следует запустить vcvars32.bat из недр Visual Studio - он правильно настраивает все переменные окружения.



Офлайн

Board footer

Модераторировать

Powered by DjangoBB

Lo-Fi Version