我運行的是Mac OS X 10.6.8,並且使用Enthought Python Distribution。我想讓numpy功能利用我的兩個核心。我有一個類似於這個職位的問題:multithreaded blas in python/numpy但通過該海報的步驟後,我仍然有同樣的問題。這裏是我的numpy.show_config():假設自動線程scipy和numpy函數不使用多個核心
lapack_opt_info:
libraries = ['mkl_lapack95_lp64', 'mkl_intel_lp64', 'mkl_intel_thread', 'mkl_core', 'mkl_mc', 'mkl_mc3', 'pthread']
library_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/lib']
define_macros = [('SCIPY_MKL_H', None)]
include_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/include']
blas_opt_info:
libraries = ['mkl_intel_lp64', 'mkl_intel_thread', 'mkl_core', 'mkl_mc', 'mkl_mc3', 'pthread']
library_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/lib']
define_macros = [('SCIPY_MKL_H', None)]
include_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/include']
lapack_mkl_info:
libraries = ['mkl_lapack95_lp64', 'mkl_intel_lp64', 'mkl_intel_thread', 'mkl_core', 'mkl_mc', 'mkl_mc3', 'pthread']
library_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/lib']
define_macros = [('SCIPY_MKL_H', None)]
include_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/include']
blas_mkl_info:
libraries = ['mkl_intel_lp64', 'mkl_intel_thread', 'mkl_core', 'mkl_mc', 'mkl_mc3', 'pthread']
library_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/lib']
define_macros = [('SCIPY_MKL_H', None)]
include_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/include']
mkl_info:
libraries = ['mkl_intel_lp64', 'mkl_intel_thread', 'mkl_core', 'mkl_mc', 'mkl_mc3', 'pthread']
library_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/lib']
define_macros = [('SCIPY_MKL_H', None)]
include_dirs = ['/Library/Frameworks/EPD64.framework/Versions/1.4.2/include']
正如原文章的評論,我刪除了設置的變量MKL_NUM_THREADS=1
行。但即使如此,應該利用多線程的numpy和scipy函數也只能使用我的一個內核。還有什麼我應該改變?
編輯:爲了澄清,我試圖讓單個計算例如numpy.dot()根據MKL實現自行使用多線程,我不想利用numpy計算釋放GIL控制權,從而使其他函數的多線程更容易。
這裏是一個小的腳本,應利用多線程,但沒有我的機器上:
import numpy as np
a = np.random.randn(1000, 10000)
b = np.random.randn(10000, 1000)
np.dot(a, b) #this line should be multi-threaded
我剛剛試過:'python -mtimeit -s'import numpy as np; a = np.random.randn(1e3,1e3)''np.dot(a,a)''它使用多個核心。所以至少在某些配置中它可以做到這一點。 – jfs 2012-08-03 05:28:34
@ J.F.Sebastian我知道它可以,但我試圖找出我失蹤的東西。 – Nino 2012-08-03 19:23:44
@ J.F.Sebastian我只是試着做你所做的事情,並充分利用我的核心。原因是numpy計算放棄了GIL,因此以for循環的形式運行多個不同的計算(如timeit所做的),每個計算都在不同的線程中完成。然而,我遇到的問題是一個計算本身的多線程。如果我只是在不使用timeit的情況下運行類似於您的腳本(因此不需要迭代),則一次只能使用一個內核。 – Nino 2012-08-07 00:33:47