版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、LAMMPS 手册 -中文解析一、简介本部分大至介绍了LAMMPS 的一些功能和缺陷。1什么是 LAMMPS?LAMMPS 是一个经典的分子动力学代码,他可以模拟液体中的粒子,固体和汽体的系综。他可以采用不同的力场和边界条件来模拟全原子,聚合物,生物,金属,粒状和粗料化体系。 LAMMPS 可以计算的体系小至几个粒子,大到上百万甚至是上亿个粒子。LAMMPS 可以在单个处理器的台式机和笔记本本上运行且有较高的计算效率,但是它是专门为并行计算机设计的。 他可以在任何一个按装了C+ 编译器和 MPI 的平台上运算,这其中当然包括分布式和共享式并行机和Beowulf 型的集群机。LAMMPS 是一可
2、以修改和扩展的计算程序,比如,可以加上一些新的力场,原子模型,边界条件和诊断功能等。通常意义上来讲, LAMMPS 是根据不同的边界条件和初始条件对通过短程和长程力相互作用的分子,原子和宏观粒子集合对它们的牛顿运动方程进行积分。高效率计算的LAMMPS 通过采用相邻清单来跟踪他们邻近的粒子。这些清单是根据粒子间的短程互拆力的大小进行优化过的,目的是防止局部粒子密度过高。在并行机上,LAMMPS 采用的是空间分解技术来分配模拟的区域,把整个模拟空间分成较小的三维小空间,其中每一个小空间可以分配在一个处理器上。各个处理器之间相互通信并且存储每一个小空间边界上的” ghost”原子的信息。 LAMM
3、PS(并行情况 )在模拟 3 维矩行盒子并且具有近均一密度的体系时效率最高。2LAMMPS 的功能总体功能:可以串行和并行计算分布式 MPI 策略模拟空间的分解并行机制开源高移植性 C+ 语言编写MPI 和单处理器串行FFT 的可选性(自定义)可以方便的为之扩展上新特征和功能只需一个输入脚本就可运行有定义和使用变量和方程完备语法规则在运行过程中循环的控制都有严格的规则只要一个输入脚本试就可以同时实现一个或多个模拟任务粒子和模拟的类型:(atom style命令)原子粗粒化粒子全原子聚合物,有机分子,蛋白质,DNA联合原子聚合物或有机分子金属粒子材料粗粒化介观模型延伸球形与椭圆形粒子点偶极粒子刚
4、性粒子所有上面的杂化类型力场:(命令: pair style, bond style, angle style, dihedral style, improper style, kspace)style对相互作用势: L-J, Buckingham, Morse, Yukawa, soft, class2(COMPASS), tabulated.带点对相互作用势: Coulombic, point-dipole.多体作用势:EAM, Finnis/Sinclair EAM,modified EAM(MEAM),Stillinger-Weber,Tersoff, AIREBO, ReaxFF粗粒
5、化作用势: DPD, GayBerne, Resquared, Colloidal, DLVO介观作用势: granular, Peridynamics键势能: harmonic, FENE, Morse, nonlinear, class2, quartic键角势能: harmonic, CHARMM, cosine, cosine/squared, class2(COMPASS)二面角势能: harmonic, CHARMM, multi-harmonic, helix, OPLS, class2(COMPASS)不合理势能: harmonic, CVFF, class2(COMPASS)
6、聚合物势能: all-atom, united-atom, bead-spring, breakable水势能: TIP3P, TIP4P,SPC隐式溶剂势能: hydrodynamic lubrication, Debye长程库伦与分散: Ewald, PPPM, Ewald/N(针对长程 L-J 作用 )可以有与普适化力场如CHARMM ,AMBER ,OPLS,GROMACS 相兼容的力场可以采用 GPU 加速的成对类型杂化势能函数: multiple pair, bond, angle, dihedral, improper potentials(多对势能处于更高的优先级 )原子创建:
7、(命令: read_data, lattice, create-atoms, delete-atoms, displace-atoms, replicate)从文件中读入各个原子的坐标在一个或多个晶格中创建原子删除几何或逻辑原子基团复制已存在的原子多次替换原子系综,约束条件,边界条件:(命令: fix)二维和三维体系正角或非正角模拟空间常 NVE , NVT , NPT,NPH 积分器原子基团与几何区域可选择不同的温度控制器有 Nose/Hoover 和 Berendsen压力控制器来控制体系的压力(任一维度上)模拟合子的变形(扭曲与剪切)简谐( unbrella)束缚力刚体约束摇摆键与键角约
8、束各种边界环境非平行太分子动力学 NEMD各种附加边界条件和约束积分器:Velocity-verlet积分器Brown 积分器rRESPA 继承时间延化积分器刚体积分器共轭梯度或最束下降算法能量最小化器输出:(命令: dump, restart)热力学信息日志原子坐标,速度和其它原子量信息的文本dump 文件二进制重启文件各原子量包括:能量,压力,中心对称参数,CAN 等用户自定义系统宽度或各原子的计算信息每个原子的时间与空间平均系统宽量的时间平均原子图像, XYZ ,XTC ,DCD ,CFG 格式数据的前处理与后处理 :包里提供了一系列的前处理与后处理工具另外,可以使用独立发行的工具组pi
9、zza.py, 它可以进行LAMMPS 模拟的设置,分析,作图和可视化工作。特别功能:实时的可视化与交互式MD 模拟与有限元方法结合进行原子-连续体模拟在 POEMS 库中提供了刚体积分工具并行裉火并行复制动力学对低密度液体直接使用 MC 模拟Peridynamic介观建模目标型与无目标型分子动力学双温度电子模型LAMMPS 不具备的功能:由于 LAMMPS 是对牛顿运动方程积分的工具, 所以很多必要的数据前处理与后处理功能是 LAMMPS 核心不具备的。 其原因为 :保证 LAMMPS 的小巧性前处理与后处理不能进行并行运算这些功能可以有其它工具来完成原代码开发的局限性特别地, LAMMPS
10、 不能:通过图形用户界面来工作创建分子体系自动的加上力场系数为 MD 模拟提供智能化的数据分析MD 的可视化为输出数据作图我们需要为 LAMMPS 输入一系列的原子类型, 原子坐标,分子拓朴信息和所有原子与键的力场参数。 LAMMPS 不会自动的为我们创建分子体系与力场参数。对与原子体系, LAMMPS 提供了 creat-atoms命令来为固态晶格加上原子。可以能过pair coeff,bond coeff, angle coeff等命来加上小数目的力场参数。对于分子体系或更复杂的模拟体系,我们通常会用其它工具来创建或者是转换LAMMPS 输出文件来做到这些事情。有的还会写一些自已的代码来完
11、成这项任务。对于一个复杂的分子体系 (如,蛋白质),我们需要为之提供上面个拓朴信息与力场参数。所以我们建议用CHARMM 或 AMBER 或其它的分子建模器来完成这些任务,并把之输到一个文件中去。然后,改变其格式以达到LAMMPS 所允许的输入格式。同样, LAMMPS 的输出文件是一种简单的文本格式,我们也可以通过其它的工具来换专这些格式。我们可以用以下几个软件来完成高质量的可视工作:VMDAtomEyePymolRaster3dRasMol最后要说一下的是,以下这些也是自由分子动力学包,它们大多数是并行的,可能也适合来完成你的研究工作,当然也可以与LAMMPS 联合起来使用以完成模拟工作。
12、CHARMMAMBERNAMDNWCHEMDL_POLYTinkerCHARMM ,AMBER, NAMD ,NWCHEM ,Tinker 是专们用于模拟生物分子的。二、开始本部分主要描述如何创建和运行LAMMPS 。1 在 LAMMPS 发行包理含有:READMELICENSEBench:测式任务Doc :文本Examples:简单的测试任务Potentials:嵌入原子方法与力场文件Src:源代码Tools: 前处理与后处理工具假如你下载的是windows 可执行文件的话,你里面只有一个文件(并行与非并行两种)Lmp-windows.exe2. 编译 LAMMPS之前的工作:编译 LAMM
13、PS 不是一个繁琐的工作。首先你可能要写一个makefile 文件,里面要选择编译器,附加的一些将要用到的库等。事先装上MPI 或 FFT 等库。编译出一个可执行LAMMPS :在 SRC目录里头含有C+ 源文件和头文件。当然也包括一个高水平的Makefile,在 MAKE 目录里头有几个低水平的Makefile.*files 分别适有不同的平台。进入SRC目录,输入make 或 gmake,你将会看到一列的可选项。假如其中有一种符合你的机器,你可以输入像下面一样的命令:Make linuxGmake mac注意,在一个多处理器或多核处理器的平台上你可以进行平行编译,在make 命令中使用“-
14、j ”选项就可以,这样编译起来会更快一些。在此过程中不发生错误的话,你可以得到一个类似于lmp-linux 的可执行文件。在编译过程当中将会发生的常见错误:( 1)如果编译过程当中发生错误,并提示不能找到一个含有通配符*为名的文件的话,说明你机器上的make 器允许 makefile 中使用通配符。那就偿式使用gmake。如还不行的话,就试试加入 -f 选项,用Makefile.list 作为 make 对像。如:Make makelistMake f makefile.list linuxGmake f makefile.lst mac(2)当你使用低水平的makefile 时,可能由于对机
15、器的设置不正确,会导致一些错误。假如你的平台叫“ foo” ,的话,你将要在MAKE目录中创建一个Makefile.foo。使用任何一个与你机器相近的文件作为开始总是一个不错的选择。( 3)如你在链接的时候出现库丢失或少了依赖关系的话,可能是由于:你编译的包需要一个附加的库,但却没有事先编译需要的package libaray.你要链接的库在你的系统中不存在。没有连接到必要的系统库后两种问题出现,你就需要修改你的低水平makefile.foo.编辑一个新的低水平makefile.foo:( 1) 在 # 后的句子中,替换 foo,不论你写成什么,这一行将会出现在屏幕上,如果你只输入 make
16、命令的话。( 2)在“ complier/linker settings ”部分为你的C+ 编译器列出编译器与链接器的设置,包括优化符号。你可以在任何UNIX系统中使用G+ 编译器。当然你也可以用MPICC ,如果你的系统中安装了MPI 的话。如过在编译过程当中需要符加的库的话,你必需在LIB 变量中列出来。DEPFLAGS 设置可以让C+ 编译器创建一个源文件的依赖关系列表,当源文件或头文件改变的时候可以加快编译速度。有些编译器不能创建依赖关系列表,或者你可以用选项D 来实现。G+ 可以使用-D 。如果你的编译器不能创建依赖关系文件的话,那么你就需要创建一个Makefile.foo 来与 M
17、akefile.storm(它用一系列的不需要依赖文件的规划)相对应。( 3)“system-specific settings”部分有四个小部分:A LMP INC 变量,包括一些与系统相关的条件选项。B 3 个 MPI 变量用于指定MPI 库。如你要进行并行计算的话,那么你必须在你的平台上安上MPI 库。如你想用 MPI 内置 C+ 编译器的话,你可以让这三个变量空着,如你不用MPICC的话,那么,你要指定MPI.h(MPI_INC)文件在哪, MPI(MPI_PATH) 库在哪,还有库名 (MPI_LIB).如果你想自已安装 MPI 的话,我们建议用MPICH1.2 或 2.0。LAM
18、MPI也可以。 如果我的是大平始的话,你的供应商已经为你装上了MPI ,其可能比 MPICH 或 LAM 更快,你可以把找出来并与之链接。如你用 LAM 或 MPICH ,你必需要设置他并编译他使之适合你的平台。如果你想在单处理器的机器上运行的话,你可以用STIBS 库,这样你就可以不用在你的系统中安装 MPI 库。防照 makefile.serial,看是如果设置这三个变量的。当然你在编译LAMMPS 之前你必需创建 STUBS 库。在 STUBS 目录中,输入make,不出错的话你将会得到一个libmpi.a 文件可供链接到 LAMMPS 。当出错,你则要修改STUBS 下的 MAKEFI
19、LE 。STUBS/MPI.CPP 有一个 CPU 计时器MPI_Wtime() 可以调用 gettimeofday(). 如你的系统不支持gettimeofday(),则你就要插入一句代码来调用另一个计时器,要注意的是,clock()函数在一个小时之后会归 0,所以对于一个长时间的LAMMPS 模拟来说这是不够用的。C FTT 变量用于指定 FFT 库,当要用到kspace-style命令来计算长程库伦作用时使用PPPM 选项时要用到。要使用此选项,你必须要在你的机器上安装一个一维的FFT 库。可以能过开关DFFT XXX来指定,其中 XXX=INTEL ,DEC , SGI,SCSL,或
20、FFTW 。没有办法的情况下可以用供应商提供的库。 FFTW 是一个快速的,可移植性的库,它可以在任何一个平台上运行。最好2.1.X 本。编译 FFTW 库时只要用 ./configure;make 就可以。不任你是用哪一种FFT 库,你都要在makefile.foo中正确的设置咱们的FFT_INC,FFT_PATH,FFT_LIB。当然,你如果不用PPPM 的话,你将没有必要安装FFT 库。这种情况下,你可以把FFT_INC 设成 -DFFT-NONE并让其它几个变量空着。你也可以在编译LAMMPS 时把 KSPACE 包剔除。D几个 SYSLIB 和 SYSPATH 变量你可以忽略,除非你
21、在编译LAMMPS 时其中有一个或几个包要用到附加的系统库。 所有这些包都的的名称都将会是SYSLIB 和 SYSPATH 变量的前辍。 SYSLIB变量将列出系统库。SYSPATH 则是路径,只有当这些库为非默认路径时才有设定。最后, 当你正确的写好了makefile.foo 和预编译好了所有的其它库(MPI,FFT, 包库等 )之后,你只要在 SRC 目录下输入下面其中一个命令就可以了Make fooGmake foo不出意外,你将会得到lmp_foo 的可执行文件。附加建义( 1) 为多平台编译 LAMMPS你可以在同一个SRC 目录下为多平台编译LAMMPS 。每一个目标都有他自已的目标路径,Obj_name 用于存贮指定系统的目标文件。(2)清理输入 make
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 42376-2023大众冰壶运动培训规范
- 造纸工保密意识知识考核试卷含答案
- 2024年大学一年级智能遥感科学与技术专业《遥感数据处理》期末考试测验卷及答案
- 2024年大学一年级智能光学工程专业《光学智能检测》期末考试测验卷及答案
- 蒸化机挡车工改进能力考核试卷含答案
- 《GBT 30428.5-2017 数字化城市管理信息系统 第 5 部分:监管信息采集设备》专题研究报告
- 空气潜水员安全知识竞赛模拟考核试卷含答案
- 冷却筛分工班组管理水平考核试卷含答案
- 横机工班组协作水平考核试卷含答案
- 电动轮自卸车机械装配工达标水平考核试卷含答案
- 烘干塔买卖合同范本
- 2025云南省科技投资管理有限公司招聘二次(19人)笔试考试参考试题及答案解析
- 光伏支架项目可行性研究报告
- (完整)特种设备专项应急预案
- 2025中国电信股份有限公司重庆分公司社会成熟人才招聘考试笔试备考试题及答案解析
- 2026年放射医学技术(士)(基础知识)模拟考试题及解析
- 改良Bacon手术专家共识2026
- 2025年秋人教版小学四年级数学上册竞赛训练试题(含答案解析)
- 2025年广东省春季高考(学考)英语真题(试题+答案)
- 2025年4月自考03450公共部门人力资源管理试题
- 化学反应工程许志美课后习[教学文书]
评论
0/150
提交评论