转载链接:
【原创】并行编译SIESTA
最近闲的无聊,在曙光集群上并行编译了SIESTA,把其中的过程和教训跟大家分享一下. 1.获得SIESTA SIESTA对科研人员是可以免费使用的,因此可以在主页上注册,大概两个星期后管理员会通过审核,通知您可以使用SIESTA.然后就可以从上面下载到源文件,赝势文件等。 2.编译器安装 我这里使用的FORTRAN编译器是PGI7.0,并行使用MPI-1.2.7. PGI的安装很友好,因此不做介绍。 接着使用PGI编译MPICH,先进行配置生成MAKEFILE文件具体是: ./configure -prefix=/your/mpich/directory -fc="pgf77 -Mx,119,0x200000" \ -f90="pgf90 -Mx,119,0x200000" \ -without-romio --without-mpe -opt=-O -rsh=ssh 然后进入你的安装目录,使用make完成安装,最好是测试下例子确认安装成功。 安装完之后将MPICH的BIN加入环境变量中。 3.安装数学库 并行编译SIESTA需要以下4个数学库BLAS,LAPACK,BLACS以及SCALAPACK,这些都可以从免费获得。对于BLAS和LAPACK可以使用优化过的MKL(INTEL处理器),ACML(AMD处理器),同样后者也可以从网上免费获得。SIESTA也能使用NETCDF数学库(这里没有使用)。 在这里我使用的ACML,BLACS以及SCALAPACK数学库,ACML的安装很友好,不过要下载对应好编译器的版本。这里主要介绍下BLACS和SCALAPCK的编译。 3.1BLACS的安装 从获得mpiblacs.gz,使用tar -zxvf mpiblacs.gz解压缩后进入BLACS目录,从BMAKES目录下拷贝出你对应系统系统的Bmake.X-X文件到上一目录的Bmake.inc对于我的系统使用的是 cp Bmake.MPI-LINUX ../Bmake.inc 然后修改Bmake.inc文件中相关内容 先修改安装目录 BTOPdir =/your/BLACS/directory 接着修改MPI目录MPIdir = /your/MPICH/directory 最重要的是将 INTFACE = -DAdd_ 这里设置成-DAdd_ 然后设置 TRANSCOMM = -DUseMpich 最后将系统默认编译器改成PGI编译 F77 = pgf77 F77NO_OPTFLAGS = F77FLAGS = $(F77NO_OPTFLAGS) -O F77LOADER = $(F77) F77LOADFLAGS = CC = pgcc CCFLAGS = -O4 CCLOADER = $(CC) CCLOADFLAGS = 完成修改之后使用make mpi进行安装,安装成功后就会在LIB目录下生成三个BLACS库文件。 (这里注意的是如果不使用-DAdd_以及PGI编译器,系统会在编译到最后一部(生成可执行文件是对数学库文件报错))。 3.2SCALAPACK安装 装好BLACS后就可以进行SCALAPACK的安装了 如同安装BLACS,下载SCALAPACK后解压缩,从子目录下拷贝出相应系统的SLmake.inc然后对里面制定MPICH,BLACS,BLAS,LAPACK数学库的相应位置的地方进行修改,指定到你所安装的MPICH,BLACS,BLAS,LAPACK数学库位置,如果BLAS,LAPACK使用的是MKL或者ACML的则指定相应文件夹下的相应文件,如我的是制定到/libacml.a。 同样最重要是的设置CDEFS = -DAdd_ -DNO_IEEE $(USEMPI) (这里主要要指定好BLACS库函数的位置,对于BLAS和LAPACK影响不大) 编译使用MPI进行 F77 = mpif77 CC = mpicc NOOPT = F77FLAGS = -O3 $(NOOPT) CCFLAGS = -O4 SRCFLAG = F77LOADER = $(F77) CCLOADER = $(CC) F77LOADFLAGS = CCLOADFLAGS = 4.编译SIESTA SIESTA编译同样先解压缩,然后进入Src目录,将/Src/Sys目录下对应的X-X.make拷贝到Src,并更改名字为arch.make,然后根据你具体的数学库地址和编译器名字修改arch.make. 由于时间关系这里我直接给出我自己的arch.make.给大家做个参考 更改完成后,make即可生成SIESTA文件,然后可以去TESTS目录下进行测试。
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) $< # |