本文共 1781 字,大约阅读时间需要 5 分钟。
第一次写博客,写得不好请大家不要见怪。
MEEP是一款开源软件,支持MPI并行计算。之前使用过一段时间,感觉计算的结果还是有一定的参考价值。唯一不太满意的地方是这款软件占用内存太多,特别是进行Plasma仿真时,60um*12um*80(resolution)二维结构占用内存空间超过2GB。三维仿真时需要降低resolution,否则单台计算机无法提供足够多的内存。
在编译开发之前先要考虑两个问题:
1)是否需要并行计算
2)32位还是64位
第一个问题,如果不是特别复杂的结构,例如二维波导,不需要并行计算。使用并行计算后速度反而更慢。不过并行计算有一个好处,就是可以把内存消耗平均分配到多台计算机,从而可以在程序里增加resolution,使结果更加精确。第二个问题就看个人喜好。不过我在64位下没有成功编译Harminv,估计是使用的某个库只有32位的。
好,现在开始准备编译MEEP。接下来只介绍在64位下编译并行MEEP,非并行以及32位MEEP请依葫芦画瓢自行编译。
首先,开发环境windows 7+visual studio 2012。
接着,下载这几个库:
1)MPICH2,http://www.mpich.org/downloads/。选择最底下Unofficial Binary Packages里的windows x86_64。选择这个的原因是这个库安装之后就可以用,不用自己编译。
2)BLAS和LAPACK,http://icl.cs.utk.edu/lapack-for-windows/clapack/index.html。去最底下下载clapack-3.2.1-CMAKE.tgz后解压,然后用cmake转为visual studio版本,然后编译。
3)HDF5,http://www.hdfgroup.org/HDF5/release/obtain5.html,选择底下hdf5-1.8.13-win64-VS2012-shared.zip。如果不需要HDF5可以不用安装这个库。
最后,建立一个名为config.h的文件,以后要用内容为:
#pragma once
/* Define if you have a BLAS library. */
#define HAVE_BLAS 1
/* Define if you have libharminv */
//#define HAVE_HARMINV 1
/* Define if we have & link HDF5 */
#define HAVE_HDF5 1
/* Define to 1 if you have the header file. */
#define HAVE_HDF5_H 1
/* Define if you have LAPACK library. */
#define HAVE_LAPACK 1
/* Define to 1 if you have the `fftw3' library (-lfftw3). */
#define HAVE_LIBFFTW3 1
/* Define if you have the MPI library. */
#define HAVE_MPI 1
/* Define to 1 if you have the header file. */
#define HAVE_STDINT_H 1
/* Define to 1 if you have the header file. */
#define HAVE_STDLIB_H 1
/* Define to 1 if you have the header file. */
#define HAVE_STRING_H 1
/* Define to 1 if you have the header file. */
#define HAVE_SYS_STAT_H 1
/* Define to 1 if you have the header file. */
#define HAVE_SYS_TYPES_H 1
好,第一部分到此结束。有时间的时候就会放上第二部分。这里放一张windows下并行64位添加了许多内容的MEEP程序:
转载地址:http://codqv.baihongyu.com/