2016-08-17 21 views
6

w systemie Ubuntu MATE 16.04 Próbuję uruchomić przykłady głębokiego uczenia Pythona tutaj za pomocą GPU:OSTRZEŻENIE (theano.sandbox.cuda): CUDA jest zainstalowana, ale urządzenie gpu nie jest dostępne (błąd: cuda jest niedostępna)

testing Theano with GPU

ja nie uruchamiać kod przykładowy,

THEANO_FLAGS=mode=FAST_RUN,device=gpu,floatX=float32 python check1.py 

ale wydaje się, że jest ona wykorzystywana CPU i GPU nie. Oto ostatnia część produkcji końcowej:

WARNING (theano.sandbox.cuda): CUDA is installed, but device gpu0 is not available (error: cuda unavailable) 
... 
Used the cpu 

Próbowałem uruchomić ten kod TOO:

THEANO_FLAGS=device=cuda0 python check1.py 

ale wyjście jest:

ERROR (theano.sandbox.gpuarray): pygpu was configured but could not be imported 
Traceback (most recent call last): 
    File "/usr/local/lib/python2.7/dist-packages/theano/sandbox/gpuarray/__init__.py", line 20, in <module> 
    import pygpu 
ImportError: No module named pygpu 
... 
used cpu 

Po zainstalowaniu zestawu narzędzi cuda z apt . Tutaj istnieje (mam nadzieję) przydatne dane:

python --version 
Python 2.7.12 

g++ -v 
gcc version 5.4.0 

nvcc --version 
Cuda compilation tools, release 7.5, V7.5.17 

lspci 
NVIDIA Corporation GM107 [GeForce GTX 750 Ti] (rev a2) 

nvidia-smi 

+------------------------------------------------------+      
| NVIDIA-SMI 361.42  Driver Version: 361.42   |      
|-------------------------------+----------------------+----------------------+ 
| GPU Name  Persistence-M| Bus-Id  Disp.A | Volatile Uncorr. ECC | 
| Fan Temp Perf Pwr:Usage/Cap|   Memory-Usage | GPU-Util Compute M. | 
|===============================+======================+======================| 
| 0 GeForce GTX 750 Ti Off | 0000:01:00.0  On |     N/A | 
| 29% 35C P8  1W/38W | 100MiB/2044MiB |  0%  Default | 
+-------------------------------+----------------------+----------------------+ 

+-----------------------------------------------------------------------------+ 
| Processes:              GPU Memory | 
| GPU  PID Type Process name        Usage  | 
|=============================================================================| 
| 0  2861 G /usr/lib/xorg/Xorg        90MiB | 
+-----------------------------------------------------------------------------+ 

Odpowiedz

6

końcu rozwiązany! Ten post Ubuntu 16.04, Theano and Cuda

sugeruje, aby dodać flagę

nvcc.flags=-D_FORCE_INLINES 

do wiersza poleceń, więc linia poleceń staje:

THEANO_FLAGS=floatX=float32,device=gpu,nvcc.flags=-D_FORCE_INLINES python check1.py 

Wydaje się naprawić błąd w użyciu glibc 2.23

fix for glibc 2.23

Teraz program prawidłowo korzysta z GPU, jest to poprawne wyjście:

THEANO_FLAGS=floatX=float32,device=gpu,nvcc.flags=-D_FORCE_INLINES python check1.py 
Using gpu device 0: GeForce GTX 750 Ti (CNMeM is disabled, cuDNN not available) 
[GpuElemwise{exp,no_inplace}(<CudaNdarrayType(float32, vector)>), HostFromGpu(GpuElemwise{exp,no_inplace}.0)] 
Looping 1000 times took 0.317012 seconds 
Result is [ 1.23178029 1.61879349 1.52278066 ..., 2.20771813 2.29967761 
    1.62323296] 
Used the gpu 

Należy pamiętać, że przed skorzystaniem z tego rozwiązania, usunąłem nvidia-CUDA Toolkit i zainstalowane CUDA ze strony Nvidia po części instrukcji znaleźć tutaj :

CUDA with Ubuntu 16.04

to jest dokładnie to, co zrobiłem:

1) Pobrałem CUDA stąd CUDA 7.5 download wybierając LINUX, x86_64, Ubuntu 15.04, deb lokalny

2) Po zainstalowaniu deb file

dpkg -i cuda_repo-ubuntu1504-7-5-local_7.5-18_amd64.deb 

3) Następnie uruchom

apt-get update 

To daje pewne błędy! Naprawiłem go nadpisanie plików kin w \ var \ CUDA repo-7,5-miejscowy z następujących linii:

Origin: NVIDIA 
Label: NVIDIA CUDA 
Architecture: repogenstagetemp 
MD5Sum: 
51483bc34577facd49f0fbc8c396aea0   75379 Packages 
4ef963dfa4276be01db8e7bf7d8a4f12   21448 Packages.gz 
SHA256: 
532b1bb3b392b9083de4445dab2639b36865d7df1f610aeef8961a3c6f304d8a   75379 Packages 
2e48cc13b6cc5856c9c6f628c6fe8088ef62ed664e9e0046fc72819269f7432c   21448 Packages.gz 

(przepraszam, nie pamiętam gdzie czytałem to rozwiązanie).

4), że z powodzeniem działać

apt-get-update 
apt-get install cuda 

5) wszystko było insatlled w \ usr \ Local \ CUDA-7,5

6) I komentuje linię N: 115 w pliku \ usr \ lokalne \ CUDA -7,5 \ include \ gospodarzowi config.h

#if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ > 9) 

//#error -- unsupported GNU version! gcc versions later than 4.9 are not supported! 

#endif /* __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ > 9) */ 

co wydaje się zapobiegać CUDA używania gcc 5.4 Po tych wszystkich operacjach, I uaktualniony plik .theanorc, dodając korzeń cuda

[cuda] 
root = /usr/local/cuda-7.5 

To wszystko :)

PS: Nie wiem, czy to działa, nawet z NVIDIA CUDA Toolkit!

0

W moim systemie problem został rozwiązany tylko po ponownym uruchomieniu systemu. Może możesz spróbować.

0

naprawiłem ten problem, dodając ścieżkę cuda do ~/.bashrc, jak następuje,

export LD_LIBRARY_PATH=/usr/lib64:$LD_LIBRARY_PATH 
export LD_LIBRARY_PATH=/usr/local/cuda/lib64:$LD_LIBRARY_PATH 
export LD_LIBRARY_PATH=/usr/local/cuda-8.0/lib64:$LD_LIBRARY_PATH 
Powiązane problemy