ATLAS + NumPy + SciPy + Theano的python科學(xué)計(jì)算環(huán)境的搭建

ATLAS + NumPy + SciPy + Theano的python科學(xué)計(jì)算環(huán)境的搭建

http://fhqdddddd.blog.163.com/blog/static/1869915420116642947209/

Theano是一個(gè)python庫(kù),提供了定義、優(yōu)化以及評(píng)估數(shù)學(xué)表達(dá)式的庫(kù),尤其適合處理高維數(shù)組。使用Theano能獲得和C差不多的處理速度,并且當(dāng)利用GPU進(jìn)行計(jì)算時(shí),效率要優(yōu)于CPU上運(yùn)行的C語(yǔ)言程序。利用Theano能快速驗(yàn)證各種算法模型。

但是在Linux上安裝theano是一件非常痛苦的事情,從theano的文檔中看到,其依賴條件非常多:

(1) 64-bit Linux(最佳)

(2) python 2.4以上

(3) g++ 4.2以上

(4) NumPy 1.5.0以上

(5) SciPy 0.8以上

(6) BLAS支持Level-3

事實(shí)上,在安裝過(guò)程中發(fā)現(xiàn),如果要安裝NumPy,還需要安裝ATLAS,而ATLAS則又依賴于lapack ……

這其中涉及到:

ATLAS是python下的一個(gè)線性代數(shù)庫(kù),是基于另外兩個(gè)線性代數(shù)庫(kù)BLAS和lapack的;

NumPy提供了一個(gè)在python中做科學(xué)計(jì)算的基礎(chǔ)庫(kù),它重在數(shù)值計(jì)算,甚至可以說(shuō)是用于多維數(shù)組處理的庫(kù);

SciPy是基于numpy,提供了一個(gè)在python中做科學(xué)計(jì)算的工具集,也就是說(shuō)它是更上一個(gè)層次的庫(kù);

Theano則是基于NumPy以及SciPy的一個(gè)更高級(jí)的用于科學(xué)計(jì)算的庫(kù)。

這里假設(shè)python和g++已經(jīng)按要求裝好,并且符合版本要求,以下根據(jù)安裝的步驟來(lái)進(jìn)行說(shuō)明:

首先介紹下環(huán)境,多核服務(wù)器,cpu時(shí)鐘頻率2668MHz,Linux-64bit,非root權(quán)限。所有源碼放在/data4/open_src中

各開發(fā)包的版本為:

開發(fā)包 ? ? 版本 ? ? ? 文件名 ? ? ? ? ? ? ? ? ? 下載地址

-----------------------------------------------------------------------------------------------

BLAS ? ? ? ? ? ? ? ? ?blas.tgz ? ? ? ? ? ? ? ? http://www.netlib.org/blas/

lapack ? ? 3.2.2 ? ? ?lapack.tgz ? ? ? ? ? ? ? http://www.netlib.org/lapack/#_previous_release

ATLAS ? ? ?3.8.4 ? ? ?atlas3.8.4.tar.bz2 ? ? ? http://sourceforge.net/projects/math-atlas/files/Stable/

NumPy ? ? ?1.7.1 ? ? ?numpy-1.7.1.tar.gz ? ? ? https://pypi.python.org/pypi/numpy

SciPy ? ? ?0.12.0 ? ? scipy-0.12.0.tar.gz ? ? ?https://pypi.python.org/pypi/scipy

Theano ? ? 0.6.0 ? ? ?Theano-0.6.0rc3.tar.gz ? http://deeplearning.net/software/theano/#download

以下是安裝步驟:

step 1. 編譯BLAS

(1) 解壓:tar -xvzf blas.tgz

(2) cd BLAS

(3) 修改 make.inc 中的編譯選項(xiàng):

PLAT = _LINUX

FORTRAN ?= gfortran

OPTS ? ? = -O2 -m64 -fPIC

NOOPT ? ?= -O0 -m64 -fPIC

LOADER ? = gfortran

(4) 編譯BLAS:make

編譯完成后,會(huì)生成blas_LINUX.a文件

step 2. 配置ATLAS

在安裝ATLAS之前需要先編譯lapack,但是為了能使得編譯成功,需要保證lapack的編譯選項(xiàng)與ATLAS一致。因此首先配置ATLAS,然后將相關(guān)編譯配置拷貝到lapack中

(1) 解壓:tar -xvjf atlas3.8.4.tar.bz2

(2) cd ATLAS

(3) 創(chuàng)建一個(gè)build目錄,用于存放ATLAS的編譯配置:mkdir atlas_build

(4) cd atlas_build

(5) 執(zhí)行configure進(jìn)行配置:../configure -b 64 -D c -DPentiumCPS=2668 -Fa alg -fPIC --with-netlib-lapack=/data4/open_src/lapack-3.2.2/lapack_LINUX.a --prefix=~/.local

其中的參數(shù)說(shuō)明如下:

-b 指定編譯出庫(kù)的類型(32位庫(kù)還是64位庫(kù))

-D c -DPentiumCPS 是指定你的CPU的時(shí)鐘頻率,可以通過(guò) grep MHz /proc/cpuinfo 得到

-Fa alg -fPIC 得到與位置無(wú)關(guān)的代碼,生成動(dòng)態(tài)的共享庫(kù)

--prefix 為安裝路徑

--with-netlib-lapack 則是制定lapack庫(kù)文件(此時(shí)lapack庫(kù)文件還沒(méi)有生成,先隨便指定一個(gè))

../configure -b 64 -Fa alg -fPIC -Si cputhrchk 0 --prefix=$HOME/atlas3.8.4 --with-netlib-lapack==$HOME/lapack-3.5.0/liblapack.a

(6) 完成配置后,在Make.inc文件中找到F77和F77FLAGS的參數(shù)配置,這兩個(gè)配置將會(huì)賦給lapack的FORTRAN和OPTS

ps:對(duì)于ATLAS 3.10及以上版本,設(shè)置--with-netlib-lapack會(huì)出錯(cuò),需要直接指定lapack的壓縮包(--with-netlib- lapack-tarfile=),它在編譯過(guò)程中會(huì)自動(dòng)解壓和編譯lapack,最終生成的so文件也由之前的6個(gè)整合成兩個(gè)。ATLAS 3.10以上版本對(duì)后續(xù)安裝NumPy沒(méi)有影響,但是在使用的時(shí)候會(huì)造成有些庫(kù)文件找不到的現(xiàn)象。因此這里使用的是ATLAS 3.8.4版本。

step 3. 編譯lapack

(1) 解壓:tar -xvzf lapack.tgz

(2) cd lapack-3.2.2

(3) 拷貝生成make.inc: cp make.inc.example make.inc

(4) 修改make.inc:

將其中FORTRAN和OPTS的值設(shè)置得跟 ATLAS/atlas_build/Make.inc 中的F77和F77FLAGS一致

PLAT = _LINUX

BLASLIB = /data4/open_src/BLAS/blas$(PLAT).a

(5) 編譯:make

(6) 編譯成功后,會(huì)在根目錄生成兩個(gè)庫(kù)文件:lapack_LINUX.a 和 tmglib_LINUX.a

step 4 編譯并安裝ATLAS

(1) cd ATLAS

(2) 刪除原配置:rm -rf atlas_build

(3) 重新配置ATLAS:參考 step 2,并設(shè)置 --with-netlib-lapack=/data4/open_src/lapack-3.2.2/lapack_LINUX.a

(4) 在atlas_build中進(jìn)行編譯:make

ps:這個(gè)過(guò)程相當(dāng)漫長(zhǎng),耐心等待!!

(5) check編譯結(jié)果:

make check

make ptcheck (對(duì)于多核服務(wù)器)

make time

ps:如果check過(guò)程中沒(méi)有報(bào)錯(cuò),則可以放心進(jìn)行以后的步驟;如果出現(xiàn)報(bào)錯(cuò),也可以嘗試進(jìn)行后續(xù)步驟,是否成功就要靠人品了。

(6) 編譯動(dòng)態(tài)庫(kù):

cd lib

make shared

make ptshared (對(duì)于多核服務(wù)器)

如果在 lib 下面出現(xiàn)libatlas.so, libcblas.so, libf77blas.so, liblapack.so, libptcblas.so, libptf77blas.so 這6個(gè)動(dòng)態(tài)庫(kù)文件,則表示編譯成功

(7) 安裝ATLAS:make install

由于之前設(shè)置了--prefix=~/.local 因此ATLAS將被安裝到 ~/.local/lib 中

(8) cp ./lib/*.so ~/.local/lib

(9) 設(shè)置環(huán)境變量:在~/.bashrc中添加 export LD_LIBRARY_PATH=~/.local/lib:$LD_LIBRARY_PATH 并執(zhí)行 source ~/.bashrc

step 5. 安裝nose

tar -xzvf nose-1.0.0

cd nose-1.0.0

python setup.py build

python setup.py install

step 6. 安裝NumPy

(1) 解壓 tar -xvzf numpy-1.7.1.tar.gz

(2) cd numpy-1.7.1

(3) 拷貝生成sit.cfg: cp site.cfg.example site.cfg

(4) 配置site.cfg:

1> 打開[DEFAULT],并設(shè)置 library_dirs 和 include_dirs ,使得在編譯的時(shí)候能夠找到atlas庫(kù)

library_dirs = ~/.local/lib

include_dirs = ~/.local/include

2> 打開[blas_opt],并設(shè)置 libraries

libraries = ptf77blas, ptcblas, atlas

3> 打開[lapack_opt],并設(shè)置 libraries

libraries = lapack, ptf77blas, ptcblas, atlas

ps:如果在ATLAS安裝過(guò)程中,沒(méi)有生成libptf77blas和libptcblas,則需要設(shè)置兩個(gè)libraries為

libraries = f77blas, cblas, atlas

libraries = lapack, f77blas, cblas, atlas

(5) 利用python構(gòu)建NumPy:python setup.py build

(6) 利用python安裝NumPy:python setup.py install --prefix=~/.local

(7) 安裝完成后,NumPy被安裝在 ~/.local/lib/python2.7/site-packages/numpy

(8) 設(shè)置環(huán)境變量:在~/.bashrc中添加 export PYTHONPATH=~/.local/lib/python2.7/site-packages:$PYTHONPATH 并執(zhí)行 source ~/.bashrc

step 7. 安裝SicPy

(1) 解壓: tar -xvzf scipy-0.12.0.tar.gz

(2) cd scipy-0.12.0

(3) 設(shè)置site.cfg: 可以直接將NumPy的site.cfg拷貝到當(dāng)前目錄中

(4) 利用python構(gòu)建SciPy:python setup.py build

(5) 利用python安裝SciPy:python setup.py install --prefix=~/.local

(6) 安裝完成后,SciPy被安裝在 ~/.local/lib/python2.7/site-packages/scipy

如果前面得到的Fortran編譯器是gfortran的話,執(zhí)行:

python setup.py build --fcompiler=gnu95

如果前面得到的Fortran編譯器是g77的話,執(zhí)行:

python setup.py build --fcompiler=gnu

環(huán)境變量設(shè)置:

我換成 gnu95 以后,和我以前 環(huán)境變量設(shè)置有沖突(動(dòng)態(tài)庫(kù)設(shè)置)

export HOME=/home/SCE/zhaolei

export PATH=$HOME/local/bin:$PATH

export LD_LIBRARY_PATH=$HOME/local/lib:$HOME/local/BerkeleyDB.4.5/lib:$LD_LIBRARY_PATH

export LIBRARY_PATH=$HOME/local/lib:$HOME/local/BerkeleyDB.4.5/lib:$LIBRARY_PATH

export LD_RUN_PATH=$LD_LIBRARY_PATH

export INCLUDE=$HOME/local/include:$INCLUDE

所以安裝時(shí),只好先注釋掉了。

或者下面的變量一般不用設(shè)置:

#export LDFLAGS="-L$HOME/local/lib -L$HOME/local/BerkeleyDB.4.5/lib"

#export CPPFLAGS="-I$HOME/local/include -I$HOME/local/BerkeleyDB.4.5/include"

#export CXXFLAGS=$CPPFLAGS

#export CFLAGS=$CPPFLAGS

step 8. 安裝Theano

有了以上的準(zhǔn)備后,安裝Theano就是一個(gè)非常簡(jiǎn)單的過(guò)程了。直接利用python就可以完成安裝:

(1) 解壓:tar -xvzf Theano-0.6.0rc3.tar.gz

(2) cd Theano-0.6.0rc3

(3) python setup.py install --prefiex=~/.local

(4) 安裝完成后,SciPy被安裝在 ~/.local/lib/python2.7/site-packages/Theano-0.6.0rc3-py2.7.egg

然后可以在python下執(zhí)行相應(yīng)的測(cè)試程序:

python

>>>import nose

>>>import numpy

>>>import scipy

>>>numpy.test('full')

等待。。。。

>>>scipy.test('full')

至此,完成了ATLAS + NumPy + SciPy + Theano的python科學(xué)計(jì)算環(huán)境的搭建

http://blog.sina.com.cn/s/blog_6cb8e53d0101keak.html

Theano是一個(gè)python庫(kù),提供了定義、優(yōu)化以及評(píng)估數(shù)學(xué)表達(dá)式的庫(kù),尤其適合處理高維數(shù)組。使用Theano能獲得和C差不多的處理速度,并且當(dāng)利用GPU進(jìn)行計(jì)算時(shí),效率要優(yōu)于CPU上運(yùn)行的C語(yǔ)言程序。利用Theano能快速驗(yàn)證各種算法模型。

但是在Linux上安裝theano是一件非常痛苦的事情,從theano的文檔中看到,其依賴條件非常多:

(1) 64-bit Linux(最佳)

(2) python 2.4以上

(3) g++ 4.2以上

(4) NumPy 1.5.0以上

(5) SciPy 0.8以上

(6) BLAS支持Level-3

事實(shí)上,在安裝過(guò)程中發(fā)現(xiàn),如果要安裝NumPy,還需要安裝ATLAS,而ATLAS則又依賴于lapack ……

這其中涉及到:

ATLAS是python下的一個(gè)線性代數(shù)庫(kù),是基于另外兩個(gè)線性代數(shù)庫(kù)BLAS和lapack的;

NumPy提供了一個(gè)在python中做科學(xué)計(jì)算的基礎(chǔ)庫(kù),它重在數(shù)值計(jì)算,甚至可以說(shuō)是用于多維數(shù)組處理的庫(kù);

SciPy是基于numpy,提供了一個(gè)在python中做科學(xué)計(jì)算的工具集,也就是說(shuō)它是更上一個(gè)層次的庫(kù);

Theano則是基于NumPy以及SciPy的一個(gè)更高級(jí)的用于科學(xué)計(jì)算的庫(kù)。

這里假設(shè)python和g++已經(jīng)按要求裝好,并且符合版本要求,以下根據(jù)安裝的步驟來(lái)進(jìn)行說(shuō)明:

首先介紹下環(huán)境,多核服務(wù)器,cpu時(shí)鐘頻率2668MHz,Linux-64bit,非root權(quán)限。所有源碼放在/data4/open_src中

各開發(fā)包的版本為:

開發(fā)包版本文件名下載地址

-----------------------------------------------------------------------------------------------

BLASblas.tgzhttp://www.netlib.org/blas/

lapack3.2.2lapack.tgzhttp://www.netlib.org/lapack/#_previous_release

ATLAS3.8.4atlas3.8.4.tar.bz2http://sourceforge.net/projects/math-atlas/files/Stable/

NumPy1.7.1numpy-1.7.1.tar.gzhttps://pypi.python.org/pypi/numpy

SciPy0.12.0scipy-0.12.0.tar.gzhttps://pypi.python.org/pypi/scipy

Theano0.6.0Theano-0.6.0rc3.tar.gzhttp://deeplearning.net/software/theano/#download

以下是安裝步驟:

step 1. 編譯BLAS

(1) 解壓:tar -xvzf blas.tgz

(2) cd BLAS

(3) 修改 make.inc 中的編譯選項(xiàng):

PLAT = _LINUX

FORTRAN= gfortran

OPTS= -O2 -m64 -fPIC

NOOPT= -O0 -m64 -fPIC

LOADER= gfortran

(4) 編譯BLAS:make

編譯完成后,會(huì)生成blas_LINUX.a文件

step 2. 配置ATLAS

在安裝ATLAS之前需要先編譯lapack,但是為了能使得編譯成功,需要保證lapack的編譯選項(xiàng)與ATLAS一致。因此首先配置ATLAS,然后將相關(guān)編譯配置拷貝到lapack中

(1) 解壓:tar -xvjf atlas3.8.4.tar.bz2

(2) cd ATLAS

(3) 創(chuàng)建一個(gè)build目錄,用于存放ATLAS的編譯配置:mkdir atlas_build

(4) cd atlas_build

(5) 執(zhí)行configure進(jìn)行配置:../configure -b 64 -D c -DPentiumCPS=2668 -Fa alg -fPIC --with-netlib-lapack=/data4/open_src/lapack-3.2.2/lapack_LINUX.a --prefix=~/.local

其中的參數(shù)說(shuō)明如下:

-b 指定編譯出庫(kù)的類型(32位庫(kù)還是64位庫(kù))

-D c -DPentiumCPS 是指定你的CPU的時(shí)鐘頻率,可以通過(guò) grep MHz /proc/cpuinfo 得到

-Fa alg -fPIC 得到與位置無(wú)關(guān)的代碼,生成動(dòng)態(tài)的共享庫(kù)

--prefix 為安裝路徑

--with-netlib-lapack 則是制定lapack庫(kù)文件(此時(shí)lapack庫(kù)文件還沒(méi)有生成,先隨便指定一個(gè))

(6) 完成配置后,在Make.inc文件中找到F77和F77FLAGS的參數(shù)配置,這兩個(gè)配置將會(huì)賦給lapack的FORTRAN和OPTS

ps:對(duì)于ATLAS 3.10及以上版本,設(shè)置--with-netlib-lapack會(huì)出錯(cuò),需要直接指定lapack的壓縮包(--with-netlib-lapack-tarfile=),它在編譯過(guò)程中會(huì)自動(dòng)解壓和編譯lapack,最終生成的so文件也由之前的6個(gè)整合成兩個(gè)。ATLAS 3.10以上版本對(duì)后續(xù)安裝NumPy沒(méi)有影響,但是在使用的時(shí)候會(huì)造成有些庫(kù)文件找不到的現(xiàn)象。因此這里使用的是ATLAS 3.8.4版本。

step 3. 編譯lapack

(1) 解壓:tar -xvzf lapack.tgz

(2) cd lapack-3.2.2

(3) 拷貝生成make.inc: cp make.inc.example make.inc

(4) 修改make.inc:

將其中FORTRAN和OPTS的值設(shè)置得跟 ATLAS/atlas_build/Make.inc 中的F77和F77FLAGS一致

同時(shí)設(shè)置

PLAT = _LINUX

BLASLIB = /data4/open_src/BLAS/blas$(PLAT).a

(5) 編譯:make build

(6) 編譯成功后,會(huì)在根目錄生成兩個(gè)庫(kù)文件:lapack_LINUX.a 和 tmglib_LINUX.a

step 4. 編譯并安裝ATLAS

(1) cd ATLAS

(2) 刪除原配置:rm -rf atlas_build

(3) 重新配置ATLAS:參考 step 2,并設(shè)置 --with-netlib-lapack=/data4/open_src/lapack-3.2.2/lapack_LINUX.a

(4) 在atlas_build中進(jìn)行編譯:make build

ps:這個(gè)過(guò)程相當(dāng)漫長(zhǎng),耐心等待!!

(5) check編譯結(jié)果:

make check

make ptcheck (對(duì)于多核服務(wù)器)

make time

ps:如果check過(guò)程中沒(méi)有報(bào)錯(cuò),則可以放心進(jìn)行以后的步驟;如果出現(xiàn)報(bào)錯(cuò),也可以嘗試進(jìn)行后續(xù)步驟,是否成功就要靠人品了。

(6) 編譯動(dòng)態(tài)庫(kù):

cd lib

make shared

make ptshared (對(duì)于多核服務(wù)器)

cd ..

如果在 lib 下面出現(xiàn)libatlas.so, libcblas.so, libf77blas.so, liblapack.so, libptcblas.so, libptf77blas.so 這6個(gè)動(dòng)態(tài)庫(kù)文件,則表示編譯成功

(7) 安裝ATLAS:make install

由于之前設(shè)置了--prefix=~/.local 因此ATLAS將被安裝到 ~/.local/lib 中

(8) cp ./lib/*.so ~/.local/lib

(9) 設(shè)置環(huán)境變量:在~/.bashrc中添加 export LD_LIBRARY_PATH=~/.local/lib:$LD_LIBRARY_PATH 并執(zhí)行 source ~/.bashrc

step 5. 安裝NumPy

(1) 解壓 tar -xvzf numpy-1.7.1.tar.gz

(2) cd numpy-1.7.1

(3) 拷貝生成sit.cfg: cp site.cfg.example site.cfg

(4) 配置site.cfg:

1> 打開[DEFAULT],并設(shè)置 library_dirs 和 include_dirs ,使得在編譯的時(shí)候能夠找到atlas庫(kù)

library_dirs = ~/.local/lib

include_dirs = ~/.local/include

2> 打開[blas_opt],并設(shè)置 libraries

libraries = ptf77blas, ptcblas, atlas

3> 打開[lapack_opt],并設(shè)置 libraries

libraries = lapack, ptf77blas, ptcblas, atlas

ps:如果在ATLAS安裝過(guò)程中,沒(méi)有生成libptf77blas和libptcblas,則需要設(shè)置兩個(gè)libraries為

libraries = f77blas, cblas, atlas

libraries = lapack, f77blas, cblas, atlas

(5) 利用python構(gòu)建NumPy:python setup.py build

(6) 利用python安裝NumPy:python setup.py install --prefix=~/.local

(7) 安裝完成后,NumPy被安裝在 ~/.local/lib/python2.7/site-packages/numpy

(8) 設(shè)置環(huán)境變量:在~/.bashrc中添加 export PYTHONPATH=~/.local/lib/python2.7/site-packages:$PYTHONPATH 并執(zhí)行 source ~/.bashrc

step 6. 安裝SicPy

(1) 解壓: tar -xvzf scipy-0.12.0.tar.gz

(2) cd scipy-0.12.0

(3) 設(shè)置site.cfg: 可以直接將NumPy的site.cfg拷貝到當(dāng)前目錄中

(4) 利用python構(gòu)建SciPy:python setup.py build

(5) 利用python安裝SciPy:python setup.py install --prefix=~/.local

(6) 安裝完成后,SciPy被安裝在 ~/.local/lib/python2.7/site-packages/scipy

step 7. 安裝Theano

有了以上的準(zhǔn)備后,安裝Theano就是一個(gè)非常簡(jiǎn)單的過(guò)程了。直接利用python就可以完成安裝:

(1) 解壓:tar -xvzf Theano-0.6.0rc3.tar.gz

(2) cd Theano-0.6.0rc3

(3) python setup.py install --prefiex=~/.local

(4) 安裝完成后,SciPy被安裝在 ~/.local/lib/python2.7/site-packages/Theano-0.6.0rc3-py2.7.egg

至此,完成了ATLAS + NumPy + SciPy + Theano的python科學(xué)計(jì)算環(huán)境的搭建

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容