| 5 | 1/1 | 返回列表 |
| 查看: 3510 | 回復(fù): 18 | ||||
| 【獎(jiǎng)勵(lì)】 本帖被評價(jià)8次,作者liangab_234620增加金幣 7.5 個(gè) | ||||
| 當(dāng)前主題已經(jīng)存檔。 | ||||
| 當(dāng)前只顯示滿足指定條件的回帖,點(diǎn)擊這里查看本話題的所有回帖 | ||||
[資源]
【原創(chuàng)】并行編譯SIESTA
|
||||
|
最近閑的無聊,在曙光集群上并行編譯了SIESTA,把其中的過程和教訓(xùn)跟大家分享一下. 1.獲得SIESTA SIESTA對科研人員是可以免費(fèi)使用的,因此可以在http://www.icmab.es/siesta/主頁上注冊,大概兩個(gè)星期后管理員會通過審核,通知您可以使用SIESTA.然后就可以從上面下載到源文件,贗勢文件等。 2.編譯器安裝 我這里使用的FORTRAN編譯器是PGI7.0,并行使用MPI-1.2.7. PGI的安裝很友好,因此不做介紹。 接著使用PGI編譯MPICH,先進(jìn)行配置生成MAKEFILE文件具體是: ./configure -prefix=/your/mpich/directory -fc="pgf77 -Mx,119,0x200000" \ -f90="pgf90 -Mx,119,0x200000" \ -without-romio --without-mpe -opt=-O -rsh=ssh 然后進(jìn)入你的安裝目錄,使用make完成安裝,最好是測試下例子確認(rèn)安裝成功。 安裝完之后將MPICH的BIN加入環(huán)境變量中。 3.安裝數(shù)學(xué)庫 并行編譯SIESTA需要以下4個(gè)數(shù)學(xué)庫BLAS,LAPACK,BLACS以及SCALAPACK,這些都可以從http://www.netlib.org/免費(fèi)獲得。對于BLAS和LAPACK可以使用優(yōu)化過的MKL(INTEL處理器),ACML(AMD處理器),同樣后者也可以從網(wǎng)上免費(fèi)獲得。SIESTA也能使用NETCDF數(shù)學(xué)庫(這里沒有使用)。 在這里我使用的ACML,BLACS以及SCALAPACK數(shù)學(xué)庫,ACML的安裝很友好,不過要下載對應(yīng)好編譯器的版本。這里主要介紹下BLACS和SCALAPCK的編譯。 3.1BLACS的安裝 從http://www.netlib.org/獲得mpiblacs.gz,使用tar -zxvf mpiblacs.gz解壓縮后進(jìn)入BLACS目錄,從BMAKES目錄下拷貝出你對應(yīng)系統(tǒng)系統(tǒng)的Bmake.X-X文件到上一目錄的Bmake.inc對于我的系統(tǒng)使用的是 cp Bmake.MPI-LINUX ../Bmake.inc 然后修改Bmake.inc文件中相關(guān)內(nèi)容 先修改安裝目錄 BTOPdir =/your/BLACS/directory 接著修改MPI目錄MPIdir = /your/MPICH/directory 最重要的是將 INTFACE = -DAdd_ 這里設(shè)置成-DAdd_ 然后設(shè)置 TRANSCOMM = -DUseMpich 最后將系統(tǒng)默認(rèn)編譯器改成PGI編譯 F77 = pgf77 F77NO_OPTFLAGS = F77FLAGS = $(F77NO_OPTFLAGS) -O F77LOADER = $(F77) F77LOADFLAGS = CC = pgcc CCFLAGS = -O4 CCLOADER = $(CC) CCLOADFLAGS = 完成修改之后使用make mpi進(jìn)行安裝,安裝成功后就會在LIB目錄下生成三個(gè)BLACS庫文件。 (這里注意的是如果不使用-DAdd_以及PGI編譯器,系統(tǒng)會在編譯到最后一部(生成可執(zhí)行文件是對數(shù)學(xué)庫文件報(bào)錯(cuò)))。 3.2SCALAPACK安裝 裝好BLACS后就可以進(jìn)行SCALAPACK的安裝了 如同安裝BLACS,下載SCALAPACK后解壓縮,從子目錄下拷貝出相應(yīng)系統(tǒng)的SLmake.inc然后對里面制定MPICH,BLACS,BLAS,LAPACK數(shù)學(xué)庫的相應(yīng)位置的地方進(jìn)行修改,指定到你所安裝的MPICH,BLACS,BLAS,LAPACK數(shù)學(xué)庫位置,如果BLAS,LAPACK使用的是MKL或者ACML的則指定相應(yīng)文件夾下的相應(yīng)文件,如我的是制定到/libacml.a。 同樣最重要是的設(shè)置CDEFS = -DAdd_ -DNO_IEEE $(USEMPI) (這里主要要指定好BLACS庫函數(shù)的位置,對于BLAS和LAPACK影響不大) 編譯使用MPI進(jìn)行 F77 = mpif77 CC = mpicc NOOPT = F77FLAGS = -O3 $(NOOPT) CCFLAGS = -O4 SRCFLAG = F77LOADER = $(F77) CCLOADER = $(CC) F77LOADFLAGS = CCLOADFLAGS = 4.編譯SIESTA SIESTA編譯同樣先解壓縮,然后進(jìn)入Src目錄,將/Src/Sys目錄下對應(yīng)的X-X.make拷貝到Src,并更改名字為arch.make,然后根據(jù)你具體的數(shù)學(xué)庫地址和編譯器名字修改arch.make. 由于時(shí)間關(guān)系這里我直接給出我自己的arch.make.給大家做個(gè)參考 更改完成后,make即可生成SIESTA文件,然后可以去TESTS目錄下進(jìn)行測試。 PS: arch.make文件 # # This file is part of the SIESTA package. # # Copyright (c) Fundacion General Universidad Autonoma de Madrid: # E.Artacho, J.Gale, A.Garcia, J.Junquera, P.Ordejon, D.Sanchez-Portal # and J.M.Soler, 1996-2006. # # Use of this software constitutes agreement with the full conditions # given in the SIESTA license, as signed by all legitimate users. # SIESTA_ARCH=pgf90-mpich # FC=mpif90 FC_ASIS=$(FC) # FFLAGS= -O3 -fastsse -Mx,119,0x200000 -tp k8-64e FFLAGS_DEBUG= -g -O0 RANLIB=echo COMP_LIBS=dc_lapack.a # NETCDF_LIBS= # /public/home/liang/libs/netcdf-4.0.1/lib/libnetcdf.a NETCDF_INTERFACE= # libnetcdf_f90.a DEFS_CDF= # -DCDF # MPI_INTERFACE=libmpi_f90.a MPI_INCLUDE=/your/MPICH/directory/include DEFS_MPI=-DMPI -DFC_HAVE_FLUSH -DFC_HAVE_ABORT # # There are (were?) some problems with command-line processing compatibility # that forced the extraction of "pgi.aux" and "pgiarg" as independent # libraries (details unfortunately lost) # BLAS_LIBS=/your/BLAS/directory/libblas.a LAPACK_LIBS=/your/LAPACK/diretory/liblapack.a BLACS_LIBS=/your/BLACS/LIB/blacsF77init_MPI-LINUX-0.a /your/BLACS/LIB/blacs_MPI-LINUX-0.a /your/BLACS/LIB/blacsF77init_MPI-LINUX-0.a SCALAPACK_LIBS=/your/scalapack-1.8.0/libscalapack.a LIBS=$(SCALAPACK_LIBS) $(BLACS_LIBS) $(LAPACK_LIBS) $(BLAS_LIBS) $(NETCDF_LIBS) $(PGI_LIBS) $(PGI_LIBS) SYS=cpu_time DEFS= $(DEFS_CDF) $(DEFS_MPI) # # # Important (at least for V5.0-1 of the pgf90 compiler...) # Compile atom.f and electrostatic.f without optimization. # atom.o: $(FC) -c $(FFLAGS_DEBUG) atom.f # electrostatic.o: $(FC) -c $(FFLAGS_DEBUG) electrostatic.f # .F.o: $(FC) -c $(FFLAGS) $(INCFLAGS) $(DEFS) $< .f.o: $(FC) -c $(FFLAGS) $(INCFLAGS) $< .F90.o: $(FC) -c $(FFLAGS) $(INCFLAGS) $(DEFS) $< .f90.o: $(FC) -c $(FFLAGS) $(INCFLAGS) $< # |
siesta問題 | ATK和電子輸運(yùn) |
榮譽(yù)版主 (職業(yè)作家)
| 最具人氣熱帖推薦 [查看全部] | 作者 | 回/看 | 最后發(fā)表 | |
|---|---|---|---|---|
|
[考研] 343求調(diào)劑 +4 | 愛羈絆 2026-03-28 | 4/200 |
|
|---|---|---|---|---|
|
[考研] 332求調(diào)劑 +3 | @MZB382400 2026-03-28 | 3/150 |
|
|
[考研] 一志愿中南大學(xué)化學(xué)0703總分337求調(diào)劑 +5 | niko- 2026-03-27 | 5/250 |
|
|
[考研] 346求調(diào)劑 一志愿070303有機(jī)化學(xué) +3 | 蘿卜燉青菜 2026-03-28 | 3/150 |
|
|
[考研] 299求調(diào)劑 +7 | 嗯嗯嗯嗯2 2026-03-27 | 7/350 |
|
|
[考研] 328求調(diào)劑 +7 | 嗯滴的基本都 2026-03-27 | 7/350 |
|
|
[考研] 材料與化工085600,總分304,本科有兩篇sci參與,求調(diào)劑 +10 | 幸運(yùn)的醬醬 2026-03-22 | 12/600 |
|
|
[考研] 274求調(diào)劑 +17 | 顧九笙要謙虛 2026-03-24 | 23/1150 |
|
|
[考研] 08開頭275求調(diào)劑 +4 | 拉誰不重要 2026-03-26 | 4/200 |
|
|
[考研] 一志愿鄭大085600,310分求調(diào)劑 +5 | 李瀟可 2026-03-26 | 5/250 |
|
|
[考研] 0703化學(xué)一志愿南京師范大學(xué)303求調(diào)劑 +3 | zzffylgg 2026-03-24 | 3/150 |
|
|
[考研] 324求調(diào)劑 +8 | hanamiko 2026-03-26 | 10/500 |
|
|
[碩博家園] 招收生物學(xué)/細(xì)胞生物學(xué)調(diào)劑 +3 | IceGuo 2026-03-26 | 4/200 |
|
|
[考研] 總分322求生物學(xué)/生化與分子/生物信息學(xué)相關(guān)調(diào)劑 +5 | 星沉uu 2026-03-26 | 6/300 |
|
|
[考研] 材料考研求調(diào)劑 +3 | Dendel 2026-03-23 | 6/300 |
|
|
[考研] 263求調(diào)劑 +6 | yqdszhdap- 2026-03-22 | 10/500 |
|
|
[考研] 環(huán)境專碩324分求調(diào)劑推薦 +5 | 軒小寧—— 2026-03-26 | 5/250 |
|
|
[考研] 一志愿哈工大,085400,320,求調(diào)劑 +4 | gdlf9999 2026-03-24 | 4/200 |
|
|
[考研] 300分,材料,求調(diào)劑,英一數(shù)二 +5 | 超贊的 2026-03-24 | 5/250 |
|
|
[考研] 284求調(diào)劑 +3 | yanzhixue111 2026-03-23 | 6/300 |
|