Lammps语法规则及常用任务

合集下载

lammps20版使用手册

lammps20版使用手册

LAMMPS 20版:分子动力学模拟的全新体验LAMMPS(Large-scale Atomic/Molecular Massively Parallel Simulator)是一款开源的分子动力学模拟软件,广泛应用于材料科学、化学、生物学、地球物理学等多个领域。

随着科技的不断发展,LAMMPS也在不断更新迭代,最新版本为LAMMPS 20版。

我们将以LAMMPS 20版使用手册为中心,介绍LAMMPS 20版的新特性、应用场景以及使用技巧,带您一起探索分子动力学模拟的全新体验。

新特性:更高效、更精确LAMMPS 20版相较于旧版有了很多改进和升级。

LAMMPS 20版支持更多的硬件平台,包括GPU、MPI、OpenMP等,大大提高了计算效率。

LAMMPS 20版新增了一些功能模块,如新的分子力场、新的计算器、新的输出格式等,使得模拟更加精确、更加方便。

LAMMPS 20版还优化了一些算法和数据结构,如改进的Lennard-Jones势函数、新的动态网格算法等,使得模拟更加稳定、更加准确。

应用场景:多领域研究工具LAMMPS 20版作为一款通用的分子动力学模拟软件,被广泛应用于多个领域的研究中。

在材料科学领域,LAMMPS 20版可以用于模拟材料的物理性质,如弹性模量、热膨胀系数、热导率等。

在化学领域,LAMMPS 20版可以用于模拟化学反应的动力学过程,如溶剂化、化学反应速率等。

在生物学领域,LAMMPS 20版可以用于模拟蛋白质的结构和动力学性质,如蛋白质折叠、蛋白质-蛋白质相互作用等。

在地球物理学领域,LAMMPS 20版可以用于模拟地球内部的物理和化学过程,如岩石的形成、地震的发生等。

LAMMPS 20版是一款功能强大、通用性强的分子动力学模拟软件,适用于多个领域的研究。

使用技巧:从入门到精通LAMMPS 20版使用手册详细介绍了LAMMPS的安装、使用、参数设置等方面的内容,对于初学者来说是一个很好的入门指南。

LAMMPS的语法中文解释

LAMMPS的语法中文解释

lammps做分子动力学模拟时,需要一个输入文件(input script),也就是in文件,以及关于体系的原子坐标之类的信息的文件(data file)。

lammps在执行计算的时候,从这个in文件中读入命令,所以对LAMMPS的使用最主要的就是对in 文件的编写和使用。

下面介绍一些关于in文件的事项λ每一非空行都被认为是一条命令(大小写敏感,但极少有命令或参数大写的)。

λ in文件中各命令的顺序可能会对计算产生影响,但大部分情况下不会有影响。

每行后的“λ&” 表示续行(类似fortran)。

λ“#”表示注释(类似bash)。

λ每行命令中的不同字段由空格或者制表符分隔开来,每个字段可以由字母、数字、下划线、或标点符号构成。

λ每行命令中第一个字段表示命令名,之后的字段都是相关的参数。

λ很多命令都是在需要修改默认值的情况下才特别设置的。

in文件整体来看分为4个部分1. Initialization这一部分包含了关于计算体系最基本的信息,例如:units: 单位系统(units style),lammps现在提供包括lj、real、metal、si和cgs几种单位系统。

dimension: 定义了两维或者三维模拟(默认是三维)。

boundary: 定义了分子动力学体系使用的边界条件,例如周期性边界条件或者自由边界条件等。

atom_style: 定义模拟体系中的原子属性,这一命令与力场设置的参数中的原子类型(atom type)不同。

pair_style: 相互作用力场类型,例如范德化势或者硬球势等。

bond_style: 键合相互作用势类型。

angle_style: 键角作用势类型。

dihedral_style: 二面角作用势类型。

improper_style: 混合作用势类型。

其他还有一些参数设置,例如newton, processors,boundary, atom_modify等。

2. Atom definitionlammps提供3种定义原子方式:通过read_data或read_restart命令从data或restart文件读入,这些文件可以包含分子拓扑结构信息,这一方法在续算上也很有用。

lammps解读命令系列

lammps解读命令系列

解读命令系列【1】【fix nve/limit command】这个命令是设置初始状态常用命令,经典命令格式【fix 1 all nve/limit 0.1】,我们一般直接用即可【LJ单位下】,注意此命令只能模拟开始使用,真正需要记录模拟信息时不能用。

命令语法[b]Syntax:[/b]fix ID group-ID nve/limit xmax [list][*]ID, group-ID are documented in[color=#0000ff]fix[/color] command[*]nve = style name of this fixcommand[*]xmax = maximum distance an atom can move in one timestep(distance units)[/list][b]Description:[/b]Perform constant NVE updates of position and velocity for atoms in thegroup each timestep. A limit is imposed on the maximum distance anatom can move in one timestep. [color=red]This is useful when startinga simulation with a configuration containing highly overlapped atoms.[/color] Normally this would generate huge forces which would blow atomsout of the simulation box, causing LAMMPS to stop with an error. 【这段话告诉我们这个命令是干什么的】Using this fix can overcome that problem. Forces on atoms must stillbe computable (which typically means 2 atoms must have a separationdistance > 0.0). But large velocities generated by large forces arereset to a value that corresponds to a displacement of length [i]xmax[/i] in a single timestep.【通过你设定的距离计算速度,并用来标度】[i]Xmax[/i] is specified in distance units; see the [color=#0000ff]units[/color] command for details. [color=red]The value of [i]xmax[/i]should be consistent with the neighbor skin distance and the frequencyof neighbor list re-building, so that pairwise interactions are notmissed on successive timesteps as atoms move.[/color] See the[color=#800080]neighbor[/color] and [color=#800080]neigh_modify[/color] commands for details.【如何设定最大限定的距离呢,这句话告诉我们,设置距离要和你的neighbor list的设置有可比性,不能比bin大太多了,个人认为小没有关系,LJ单位下我们设bin一般是0.3】Note that if a velocity reset occurs the integrator will not conserveenergy. On steps where no velocity resets occur, this integrator isexactly like the [color=#0000ff]fix nve[/color] command. Since forcesare unaltered, pressures computed by thermodynamic output will stillbe very large for overlapped configurations. 【这句告诉我们不要担心出现的异常现象,也警告我们真正模拟时最好不要用】系统是通过设定的xlimit和时间步长先计算速度的做大限制【限制速度】,然后计算体系原子的速度,如果这个速度大于【限制速度】,那么就对速度进行标度,最后再计算移动位移。

lammps学习指南(可编辑修改word版)

lammps学习指南(可编辑修改word版)

lammps学习指南(可编辑修改word版)温馨提示:(1)点击标题可直接到相关的“章节”。

(2)为避免混淆,上面的各“章”,在本文中用“步骤2”、“步骤5”这样的词代指;而文中其它地方出现的“章节”是指lammps 手册中的章节。

(3)文中跟某些名词相关的网页已加注超链接,直接点击可浏览该页面以获得更详尽的信息。

0. 写在最开始的话从2007 年5 月初开始接触和学习lammps,时至今日,依然对lammps 存有很多疑惑。

如同一个刚入门的工匠面对着一台功能强大的复杂机器,不知所措。

虽然还有好多好多的东西要学习,但是也已经了解了一些最最基本的东西了。

我可以去帮助那些刚刚入门的人,正如我刚刚开始学习lammps 时诸位热心网友对我的帮助。

现在,我写一写自己知道的东西,希望对lammps 的新手有所帮助,不当之处,真诚地希望各位读者多多指正。

我写的这点儿东西,使用者仅限于使用lammps 的新手,而且里面只讲到了ubuntu 下编译lammps 的单机版,没有涉及并行版的编译。

我希望这个“指南”会帮他们更快地了解和学习lammps。

如果你已经在使用lammps 了,我觉得这个“指南”是不会对你有什么帮助的。

不过,对于高手来说,如果你有时间,我还是希望你能看完这篇,因为我接触lammps 和MD 的时间都不长,我怕我的某些错误会误导新手。

所以,希望大家一起努力,完善这个指南。

对这个“指南”有任何的建议,请联系我,联系方式如下:QQ: 365449075Email: wfc@/doc/8815552588.html,另外,我只把这篇文章放在这个由学校提供的个人网页空间。

之前QQ 空间的那篇文章,因为对其内容改动较大,故我已将其删除。

我并不反对转载,(先自我陶醉一下下,可是会有吗?呵呵)但是转载之前,请注意:(1)文章中的一些表述我尚不肯定正确与否。

所以转载之前,请你负责任地认真读完这篇文章并确认你是否认可我的表述。

lammps各种命令讲解

lammps各种命令讲解

作者: 御剑江湖收录日期: 2011-03-31 发布日期: 2011-03-24 Commands描述了lammps输入文件的格式和在定义lammps模拟所需要的命令.1.1 LAMMPS input script我们用lammps做分子动力学模拟, 需要一个输入文件. lammps在执行计算的时候, 从这个文本文件中逐行读入命令. 大多数情况, lammps输入文件中各个命令的顺序并不是很重要. 但是你要注意以下几点:(1) lammps并不是将你的输入文件全部读入之后才开始进行计算的, 或者说, 每条命令在它被读入之后就会起作用了. 注意, 下面两组命令的执行效果是不相同的.timestep 0.5run 100run 100和run 100timestep 0.5run 100(2) 有些命令只有在另一些命令已经被定义的情况下才有效. 例如如果你要设定一组原子的温度, 那么用group命令定义哪些原子属于这个组才行.(3) 还有一种情况就是: 命令B要用到命A设置的一些数值, 这样你也不能颠倒这两个命令的顺序.每个命令的详细介绍中的Restrictions部分会说明要使用该命令定义的时候哪些命令必须要被预先定义.如果你的输入文件书写的格式有问题, lammps在执行的时候会提示ERROR或者WARNING , 出现类似信息时, 你可以到手册的第九章中查询原因.1.2 Parsing rules输入文件中的每一非空行都被认为是一条命令. lammps中命令的书写是对大小写敏感的, 不过一般的命令和参数都是小写的, 大写字母用于极少数的情况.(1) 命令行后的& 表示这一行跟下一行是同一条命令. 这一点跟FORTRAN很像.(2) 命令行最开始的# 表示这一行在执行过程中被忽略, 你可以用它来写注释.(3) $ 是跟声明变量有关系的, 我暂时还没用到过, 具体请参阅variable命令的详细介绍.(4) 命令行被tabs, spaces间隔成各个“words”, 注意这里的“words”可以包含字母、数字、下划线、或标点符号.(5) 一行中第一个词是命令名, 后续的词是相关的参数.(6) 双引号内的文字空格被整体地当作一个参数, 其中的# 或$ 就没有前面说的作用了.1.3 Input script structurelammps的输入文件一般分为4个部分Initialization, Atom definition, Settings, Run a simulation后面的两个部分可以按照需要多次重复. Remember that almost all the commands need only be used if a non-default value is desired.(1) Initialization在你的模拟体系定义之前, 一些参数必须要被设置. 相关的命令有:units, dimension, newton, processors, boundary, atom_style, atom_modify.units: 选择单位系统, lammps提供了lj、real、metal三种单位系统dimension: 2d模拟还是3d模拟, 默认是3dboundary: 边界条件:周期性边界or自由边界atom_style: 定义你的模拟体系中的原子属性, 注意这个style要区分后面设置力场参数时命令里提到的atom type还有, 这些命令告诉lammps在你的模拟中使用何种力场: pair_style, bond_style, angle_style, dihedral_style, improper_style.(2) Atom definitionlammps提供3种方式定义原子:①通过read_data或read_restart命令从data或restart文件读入, 这些文件可以包含分子拓扑结构信息.②按照晶格的方式创建原子(不包含分子拓扑信息), 你会用到这几个命令: lattice, region, create_box, create_atoms.③已经设置好的原子可以用replicate命令复制以生成一个更大规模的模拟体系.(3)Settings原子和分子的拓扑信息定义好后, 你要制定一系列的设置: 力场系数、模拟参数、输出选项等等.力场系数可以通过这些命令定义: pair_coeff, bond_coeff, angle_coeff, dihedral_coeff, improper_coeff, kspace_style, dielectric, special_bonds. 注意, 其实力场系数也可以在data文件中制定, 详见read_data命令介绍.各种模拟参数由这些命令设置: neighbor, neigh_modify, group, timestep, reset_timestep, run_style, min_style, min_modify.我觉得fix命令是lammps中很重要的一个命令, 它包括很多子命令, 可以施加一系列的边界条件、时间积分、诊断选项等等.模拟过程中通过下面的命令制定lammps进行各种计算: compute, compute_modify, variable.输出选项由thermo, dump, restart命令设置.(4)Run a simulation使用run命令开始一个分子动力学模拟, 用minimize命令来实施能量最小化(molecular statics), 使用temper命令来进行parallel tempering(replica-exchange) simulation.1.4 Commands listed by category这一节分门别类地列出了lammps的所有命令. 注意有些命令的有些选项是特定的lammps package的一部分, 也就是说只有在编译lammps的时候包括了这些packages, 这些命令才能被使用. 默认情况下编译lammps并不包括所有的packages. 这些依赖关系在相关命令的详细介绍中Restrictions部分中列出了.Initialization: atom_modify, atom_style, boundary, dimension, newton, processors, unitsAtom definition: create_atoms, create_box, lattice, read_data, read_restart, region, replicateForce fields: angle_coeff, angle_style, bond_coeff, bond_style, dielectric, dihedral_coeff, dihedral_style, improper_coeff, improper_style, kspace_modify, kspace_style, pair_coeff, pair_modify, pair_style, pair_write, special_bondsSettings: communicate, dipole, group, mass, min_modify, min_style, neigh_modify, neighbor, reset_timestep, run_style, set, shape, timestep, velocityFixes: fix, fix_modify, unfixComputes: compute, compute_modify, uncomputeOutput: dump, dump_modify, restart, thermo, thermo_modify, thermo_style, undump, write_restartActions: delete_atoms, delete_bonds, displace_atoms, displace_box, minimize, run, temperMiscellaneous: clear, echo, if, include, jump, label, log, next, print, shell, variable作者:御剑江湖一、各种文件的介绍:1 in file:建立该文件以便程序的写入2 log file:写入状态信息(if the switch is used?)3 screen file 决定结果的是否进行屏幕输出4 var name file 定义一个变量,name指变量名,可为字母也可为字符串,形式$x / $ {abc}二、屏幕输出:结果显示在屏幕上,同时在log file 中。

Lammps语法规则及常用任务

Lammps语法规则及常用任务

Lammps语法输入脚本中的每个非空行被当作一个命令。

LAMMPS命令是区分大小写的。

命令名是小写的,如指定命令参数。

大写字母可能用于文件名或用户选择的ID字符串。

下面是LAMMPS每一行的输入脚本解析:(1)如果某行的最后一个可打印字符是“&”字符,则假定该命令在下一行继续。

通过删除“&”字符和换行符,下一行将连接到上一行。

这使长命令延续在两条或更多条的命令上。

请参阅(6),如何在不使用“&”字符的情况下在多行上继续执行命令。

(2) “#”字符后的所有字符都被视为注释并被丢弃,详见(6)。

注意,“&”字符后面的注释将阻止命令在下一行继续。

另外请注意,对于多行命令,单个“#”字符将注释整个命令。

(3)某行重复搜索“$”字符,表示用文本字符串替换该变量,详见(6)。

如果字符“$”后跟大括号,则变量名称是大括号内的文本。

如果字符“$”后没有大括号跟随,则变量名称是紧跟在$之后的单个字符。

如${myTemp} 和$x 的变量名分别为"myTemp" and "x"。

变量如何转换为文本字符串取决于变量的样式。

它可以是一个存储多个文本字符串的变量,并返回其中的一个。

返回的文本字符串可以是多个“单词”(空格分隔),然后将其解释为输入命令中的多个参数。

该变量还可以存储为一个数学公式,该公式将被估算,其数值结果作为字符串返回。

如果字符$后跟圆括号则是一种特殊情况,圆括号内的文本被视为“临时”变量,并被评估为等式样式的变量。

这是在输入脚本中使用数字公式的方法,而不必给它们分配变量名称。

variable X equal (xlo+xhi)/2+sqrt(v_area)region 1 block $X 2 INF INF EDGE EDGEvariable X delete等价于:region 1 block $((xlo+xhi)/2+sqrt(v_area)) 2 INF INF EDGE EDGE以便您不必定义(或丢弃)临时变量X.注意,变量的大括号或即时形式都不能包含嵌套的$字符以供其他变量替代。

lammps使用手册

lammps使用手册

lammps使用手册一、简介LAMMPS是一款功能强大的分子动力学模拟软件,可用于研究固体、液体、气体以及它们之间的相互作用。

本手册旨在帮助用户了解LAMMPS的基本使用方法和技巧,以便更好地进行模拟研究。

二、安装与配置1.下载安装包:从LAMMPS官方网站下载适合您操作系统的安装包。

2.安装软件:按照安装指南完成软件安装。

3.配置环境:根据软件要求配置计算环境,包括编译器、库文件和路径等。

三、基本操作1.启动模拟:使用LAMMPS命令行界面或脚本启动模拟。

2.添加系统参数:设置模拟系统的体积、温度、边界条件等参数。

3.添加粒子:创建粒子,设置其质量、电荷等属性。

4.更新系统:执行时间积分算法,更新粒子运动状态。

5.观察结果:使用可视化工具观察模拟系统的动态变化。

四、常用命令1.`fix`:用于设置固定粒子组或边界条件的命令。

2.`atom_modify`:用于修改粒子属性,如质量、电荷等。

3.`pair_style`:设置粒子之间的相互作用模型。

4.`run`:执行模拟并更新粒子运动状态。

5.`dump`/`restart`:保存或恢复模拟结果。

五、高级功能1.粒子相互作用模型:LAMMPS支持多种粒子相互作用模型,如Lennard-Jones势、Ewald方法等。

2.边界条件:支持不同类型的边界条件,如周期性边界、固定边界等。

3.能量最小化:用于优化粒子分布,降低能量波动。

4.温度控制:通过加热和冷却过程保持系统温度恒定。

5.并行计算:支持多核处理器和分布式计算,提高模拟速度。

六、实例应用1.分子动力学模拟固体晶格结构变化。

2.研究液体流动和粘度。

3.计算材料在不同应力条件下的变形行为。

4.模拟药物在生物体系中的分布和相互作用。

七、常见问题及解决方法1.模拟结果波动较大:检查粒子相互作用模型和边界条件设置是否正确,以及积分算法是否适当。

2.模拟时间步长选择不当:过小的步长可能导致系统不稳定,过大的步长则影响模拟精度。

Lammps命令指南

Lammps命令指南

Lammps 命令指南作者: 御剑江湖收录日期: 2011-03-31 发布日期: 2011-03-24Commands描述了lammps输入文件的格式和在定义lammps模拟所需要的命令.1.1 LAMMPS input script我们用lammps做分子动力学模拟, 需要一个输入文件. lammps在执行计算的时候, 从这个文本文件中逐行读入命令. 大多数情况, lammps输入文件中各个命令的顺序并不是很重要. 但是你要注意以下几点:(1) lammps并不是将你的输入文件全部读入之后才开始进行计算的, 或者说, 每条命令在它被读入之后就会起作用了. 注意, 下面两组命令的执行效果是不相同的.timestep 0.5run 100run 100和run 100timestep 0.5run 100(2) 有些命令只有在另一些命令已经被定义的情况下才有效. 例如如果你要设定一组原子的温度, 那么用group命令定义哪些原子属于这个组才行.(3) 还有一种情况就是: 命令B要用到命A设置的一些数值, 这样你也不能颠倒这两个命令的顺序.每个命令的详细介绍中的Restrictions部分会说明要使用该命令定义的时候哪些命令必须要被预先定义.如果你的输入文件书写的格式有问题, lammps在执行的时候会提示ERROR或者WARNING , 出现类似信息时, 你可以到手册的第九章中查询原因.1.2 Parsing rules输入文件中的每一非空行都被认为是一条命令. lammps中命令的书写是对大小写敏感的, 不过一般的命令和参数都是小写的, 大写字母用于极少数的情况.(1) 命令行后的& 表示这一行跟下一行是同一条命令. 这一点跟FORTRAN很像.(2) 命令行最开始的# 表示这一行在执行过程中被忽略, 你可以用它来写注释.(3) $ 是跟声明变量有关系的, 我暂时还没用到过, 具体请参阅variable命令的详细介绍.(4) 命令行被tabs, spaces间隔成各个“words”, 注意这里的“words”可以包含字母、数字、下划线、或标点符号.(5) 一行中第一个词是命令名, 后续的词是相关的参数.(6) 双引号内的文字空格被整体地当作一个参数, 其中的# 或$ 就没有前面说的作用了.1.3 Input script structurelammps的输入文件一般分为4个部分Initialization, Atom definition, Settings, Run a simulation后面的两个部分可以按照需要多次重复. Remember that almost all the commands need only be used if a non-default value is desired.(1) Initialization在你的模拟体系定义之前, 一些参数必须要被设置. 相关的命令有:units, dimension, newton, processors, boundary, atom_style, atom_modify.units: 选择单位系统, lammps提供了lj、real、metal三种单位系统dimension: 2d模拟还是3d模拟, 默认是3dboundary: 边界条件:周期性边界or自由边界atom_style: 定义你的模拟体系中的原子属性, 注意这个style要区分后面设置力场参数时命令里提到的atom type还有, 这些命令告诉lammps在你的模拟中使用何种力场: pair_style, bond_style, angle_style, dihedral_style, improper_style.(2) Atom definitionlammps提供3种方式定义原子:①通过read_data或read_restart命令从data或restart文件读入, 这些文件可以包含分子拓扑结构信息.②按照晶格的方式创建原子(不包含分子拓扑信息), 你会用到这几个命令: lattice, region, create_box, create_atoms.③已经设置好的原子可以用replicate命令复制以生成一个更大规模的模拟体系.(3)Settings原子和分子的拓扑信息定义好后, 你要制定一系列的设置: 力场系数、模拟参数、输出选项等等.力场系数可以通过这些命令定义: pair_coeff, bond_coeff, angle_coeff, dihedral_coeff, improper_coeff, kspace_style, dielectric, special_bonds. 注意, 其实力场系数也可以在data文件中制定, 详见read_data命令介绍.各种模拟参数由这些命令设置: neighbor, neigh_modify, group, timestep, reset_timestep, run_style, min_style, min_modify.我觉得fix命令是lammps中很重要的一个命令, 它包括很多子命令, 可以施加一系列的边界条件、时间积分、诊断选项等等.模拟过程中通过下面的命令制定lammps进行各种计算: compute, compute_modify, variable.输出选项由thermo, dump, restart命令设置.(4)Run a simulation使用run命令开始一个分子动力学模拟, 用minimize命令来实施能量最小化(molecular statics), 使用temper命令来进行parallel tempering(replica-exchange) simulation.1.4 Commands listed by category这一节分门别类地列出了lammps的所有命令. 注意有些命令的有些选项是特定的lammps package的一部分, 也就是说只有在编译lammps的时候包括了这些packages, 这些命令才能被使用. 默认情况下编译lammps并不包括所有的packages. 这些依赖关系在相关命令的详细介绍中Restrictions部分中列出了.Initialization: atom_modify, atom_style, boundary, dimension, newton, processors, unitsAtom definition: create_atoms, create_box, lattice, read_data, read_restart, region, replicateForce fields: angle_coeff, angle_style, bond_coeff, bond_style, dielectric, dihedral_coeff, dihedral_style, improper_coeff, improper_style, kspace_modify,kspace_style, pair_coeff, pair_modify, pair_style, pair_write, special_bondsSettings: communicate, dipole, group, mass, min_modify, min_style, neigh_modify, neighbor, reset_timestep, run_style, set, shape, timestep, velocity Fixes: fix, fix_modify, unfixComputes: compute, compute_modify, uncomputeOutput: dump, dump_modify, restart, thermo, thermo_modify, thermo_style, undump, write_restartActions: delete_atoms, delete_bonds, displace_atoms, displace_box, minimize, run, temperMiscellaneous: clear, echo, if, include, jump, label, log, next, print, shell, variable作者:御剑江湖一、各种文件的介绍:1 in file:建立该文件以便程序的写入2 log file:写入状态信息(if the switch is used?)3 screen file 决定结果的是否进行屏幕输出4 var name file 定义一个变量,name指变量名,可为字母也可为字符串,形式$x / $ {abc}二、屏幕输出:结果显示在屏幕上,同时在log file 中。

计算机代码lammps手册中文解析

计算机代码lammps手册中文解析
(3)“system-specific settings”部分有四个小部分:
ALMP—INC变量,包括一些与系统相关的条件选项。
B 3个MPI变量用于指定MPI库。
如你要进行并行计算的话,那么你必须在你的平台上安上MPI库。如你想用MPI内置C++编译器的话,你可以让这三个变量空着,如你不用MPICC的话,那么,你要指定(MPI_INC)文件在哪,MPI(MPI_PATH)库在哪,还有库名(MPI_LIB).
Make linux
Gmake mac
注意,在一个多处理器或多核处理器的平台上你可以进行平行编译,在make命令中使用“-j”选项就可以,这样编译起来会更快一些。
在此过程中不发生错误的话,你可以得到一个类似于lmp-linux的可执行文件。
在编译过程当中将会发生的常见错误:
(1)如果编译过程当中发生错误,并提示不能找到一个含有通配符*为名的文件的话,说明你机器上的make器允许makefile中使用通配符。那就偿式使用gmake。如还不行的话,就试试加入-f选项,用作为make对像。如:
另外,可以使用独立发行的工具组, 它可以进行LAMMPS模拟的设置,分析,作图和可视化工作。
特别功能:
实时的可视化与交互式MD模拟
与有限元方法结合进行原子-连续体模拟
在POEMS库中提供了刚体积分工具
并行裉火
并行复制动力学
对低密度液体直接使用MC模拟
Peridynamic介观建模
目标型与无目标型分子动力学
如果你想自已安装MPI的话,我们建议用或。LAM MPI也可以。如果我的是大平始的话,你的供应商已经为你装上了MPI,其可能比MPICH或LAM更快,你可以把找出来并与之链接。如你用LAM或MPICH,你必需要设置他并编译他使之适合你的平台。

lammps20版使用手册

lammps20版使用手册

lammps20版使用手册LAMMPS 20 版使用手册LAMMPS 是一个经典的分子动力学模拟软件,用于研究原子和分子的行为。

本文将为您提供 LAMMPS 20 版的使用手册,详细介绍软件的安装、基本命令、输入文件格式和常见功能。

一、安装LAMMPS 20 版可从官方网站下载并安装。

在安装之前,请确保您的计算机满足以下要求:1. 操作系统:Windows、Linux 或 macOS;2. C++ 编译器:例如 g++、icc 或 Clang;3. 并行库:如 MPI(可选)。

请根据您的操作系统选择相应的安装包,并按照官方提供的说明进行安装。

二、基本命令LAMMPS 使用基于命令行的界面,您可以通过输入一系列命令来控制模拟的运行。

1. 运行 LAMMPS:在命令行终端中输入 `lmp_serial` 或 `lmp_mpi` 启动 LAMMPS 应用程序。

2. 选择分子力场:使用 `pair_style` 命令选择适合您研究系统的分子力场。

例如,`pair_style lj/cut` 表示使用 Lennard-Jones 势函数进行计算。

3. 定义模拟盒子:使用 `region` 定义模拟盒子的边界条件和尺寸。

例如,`region box block 0 10 0 10 0 10` 定义了一个尺寸为 10x10x10 的盒子。

4. 添加原子:使用 `create_atoms` 在模拟盒子中添加原子。

例如,`create_atoms 1 random 100 12345 box` 表示在盒子中随机地添加 100 个类型为 1 的原子。

5. 温度控制:使用 `velocity` 控制系统的温度。

例如,`velocity all create 298 123456` 为系统中的所有原子设置一个初始温度为 298K。

6. 运行模拟:使用 `run` 命令来运行模拟。

例如,`run 1000` 表示运行 1000 步模拟。

lammps各种命令讲解

lammps各种命令讲解

作者: 御剑江湖收录日期: 2011-03-31 发布日期: 2011-03-24 Commands描述了lammps输入文件的格式和在定义lammps模拟所需要的命令.1.1 LAMMPS input script我们用lammps做分子动力学模拟, 需要一个输入文件. lammps在执行计算的时候, 从这个文本文件中逐行读入命令. 大多数情况, lammps输入文件中各个命令的顺序并不是很重要. 但是你要注意以下几点:(1) lammps并不是将你的输入文件全部读入之后才开始进行计算的, 或者说, 每条命令在它被读入之后就会起作用了. 注意, 下面两组命令的执行效果是不相同的.timestep 0.5run 100run 100和run 100timestep 0.5run 100(2) 有些命令只有在另一些命令已经被定义的情况下才有效. 例如如果你要设定一组原子的温度, 那么用group命令定义哪些原子属于这个组才行.(3) 还有一种情况就是: 命令B要用到命A设置的一些数值, 这样你也不能颠倒这两个命令的顺序.每个命令的详细介绍中的Restrictions部分会说明要使用该命令定义的时候哪些命令必须要被预先定义.如果你的输入文件书写的格式有问题, lammps在执行的时候会提示ERROR或者WARNING , 出现类似信息时, 你可以到手册的第九章中查询原因.1.2 Parsing rules输入文件中的每一非空行都被认为是一条命令. lammps中命令的书写是对大小写敏感的, 不过一般的命令和参数都是小写的, 大写字母用于极少数的情况.(1) 命令行后的& 表示这一行跟下一行是同一条命令. 这一点跟FORTRAN很像.(2) 命令行最开始的# 表示这一行在执行过程中被忽略, 你可以用它来写注释.(3) $ 是跟声明变量有关系的, 我暂时还没用到过, 具体请参阅variable命令的详细介绍.(4) 命令行被tabs, spaces间隔成各个“words”, 注意这里的“words”可以包含字母、数字、下划线、或标点符号.(5) 一行中第一个词是命令名, 后续的词是相关的参数.(6) 双引号内的文字空格被整体地当作一个参数, 其中的# 或$ 就没有前面说的作用了.1.3 Input script structurelammps的输入文件一般分为4个部分Initialization, Atom definition, Settings, Run a simulation后面的两个部分可以按照需要多次重复. Remember that almost all the commands need only be used if a non-default value is desired.(1) Initialization在你的模拟体系定义之前, 一些参数必须要被设置. 相关的命令有:units, dimension, newton, processors, boundary, atom_style, atom_modify.units: 选择单位系统, lammps提供了lj、real、metal三种单位系统dimension: 2d模拟还是3d模拟, 默认是3dboundary: 边界条件:周期性边界or自由边界atom_style: 定义你的模拟体系中的原子属性, 注意这个style要区分后面设置力场参数时命令里提到的atom type还有, 这些命令告诉lammps在你的模拟中使用何种力场: pair_style, bond_style, angle_style, dihedral_style, improper_style.(2) Atom definitionlammps提供3种方式定义原子:①通过read_data或read_restart命令从data或restart文件读入, 这些文件可以包含分子拓扑结构信息.②按照晶格的方式创建原子(不包含分子拓扑信息), 你会用到这几个命令: lattice, region, create_box, create_atoms.③已经设置好的原子可以用replicate命令复制以生成一个更大规模的模拟体系.(3)Settings原子和分子的拓扑信息定义好后, 你要制定一系列的设置: 力场系数、模拟参数、输出选项等等.力场系数可以通过这些命令定义: pair_coeff, bond_coeff, angle_coeff, dihedral_coeff, improper_coeff, kspace_style, dielectric, special_bonds. 注意, 其实力场系数也可以在data文件中制定, 详见read_data命令介绍.各种模拟参数由这些命令设置: neighbor, neigh_modify, group, timestep, reset_timestep, run_style, min_style, min_modify.我觉得fix命令是lammps中很重要的一个命令, 它包括很多子命令, 可以施加一系列的边界条件、时间积分、诊断选项等等.模拟过程中通过下面的命令制定lammps进行各种计算: compute, compute_modify, variable.输出选项由thermo, dump, restart命令设置.(4)Run a simulation使用run命令开始一个分子动力学模拟, 用minimize命令来实施能量最小化(molecular statics), 使用temper命令来进行parallel tempering(replica-exchange) simulation.1.4 Commands listed by category这一节分门别类地列出了lammps的所有命令. 注意有些命令的有些选项是特定的lammps package的一部分, 也就是说只有在编译lammps的时候包括了这些packages, 这些命令才能被使用. 默认情况下编译lammps并不包括所有的packages. 这些依赖关系在相关命令的详细介绍中Restrictions部分中列出了.Initialization: atom_modify, atom_style, boundary, dimension, newton, processors, unitsAtom definition: create_atoms, create_box, lattice, read_data, read_restart, region, replicateForce fields: angle_coeff, angle_style, bond_coeff, bond_style, dielectric, dihedral_coeff, dihedral_style, improper_coeff, improper_style, kspace_modify, kspace_style, pair_coeff, pair_modify, pair_style, pair_write, special_bondsSettings: communicate, dipole, group, mass, min_modify, min_style, neigh_modify, neighbor, reset_timestep, run_style, set, shape, timestep, velocityFixes: fix, fix_modify, unfixComputes: compute, compute_modify, uncomputeOutput: dump, dump_modify, restart, thermo, thermo_modify, thermo_style, undump, write_restartActions: delete_atoms, delete_bonds, displace_atoms, displace_box, minimize, run, temperMiscellaneous: clear, echo, if, include, jump, label, log, next, print, shell, variable作者:御剑江湖一、各种文件的介绍:1 in file:建立该文件以便程序的写入2 log file:写入状态信息(if the switch is used?)3 screen file 决定结果的是否进行屏幕输出4 var name file 定义一个变量,name指变量名,可为字母也可为字符串,形式$x / $ {abc}二、屏幕输出:结果显示在屏幕上,同时在log file 中。

lammps npt语法

lammps npt语法

lammps npt语法LAMMPS是一个高度可扩展的分子动力学软件包,可以使用一系列命令控制不同类型的分子动力学模拟。

其中,常见的NPT模拟即为指定压强、温度和总体积。

在LAMMPS中,想要进行NPT模拟,需要使用npt命令。

下面我们就来逐步讲解npt命令的语法及使用方式。

1. 定义模拟系统在进行模拟之前,需要通过create_box命令定义模拟系统的尺寸和原子、分子类型等信息。

例如:create_box 1.0 xlo xhi 1.0 ylo yhi 1.0 zlo zhi其中,xlo、xhi、ylo、yhi、zlo、zhi分别表示模拟系统在x、y、z三个方向上的最小值和最大值。

1.0为晶格常数,可以根据需要进行修改。

2. 添加原子信息使用create_atoms命令向模拟系统中添加原子。

例如:create_atoms 1 box其中,1为原子类型编号,box表示在模拟系统中添加原子。

3. 设置原子类型使用set命令可以设置模拟系统中不同类型原子的质量和电荷等信息。

例如:set 1 mass 1.0其中,1为原子类型编号,mass 1.0表示将第1种原子的质量设置为1.0。

4. 定义分子间相互作用力场使用pair_style和pair_coeff命令定义分子间相互作用力场,包括势能和力的计算方式、类型和参数等信息。

例如:pair_style lj/cut/coul/long 10.0pair_coeff 1 1 1.0 1.0 10.0pair_modify shift yes其中,lj/cut/coul/long表示采用Lennard-Jones势和长程库伦相互作用势计算分子间相互作用,10.0为剪切半径。

1 1表示对第1种原子作用力。

1.0 1.0 10.0表示切割距离、吸引力深度和半径。

5. 定义温度和压强使用fix命令定义温度和压强,以实现NPT模拟。

例如:fix 1 all npt temp 300.0 300.0 0.1 iso 1.0 1.0 1.0其中,fix命令可以为不同的分子组和原子绑定不同的操作。

lammps fix语法

lammps fix语法

lammps fix语法LAMMPS Fix语法详解LAMMPS(Large-scale Atomic/Molecular Massively Parallel Simulator)是一款用于分子动力学模拟的开源软件。

在LAMMPS中,Fix是一种用于定义和修改模拟系统中原子或分子行为的命令。

本文将详细介绍LAMMPS中Fix命令的使用语法和功能。

一、基本语法Fix命令的基本语法如下:fix fix_ID group_ID style args其中,fix_ID是Fix命令的标识符,group_ID是定义Fix作用对象的分组标识符,style是Fix的类型,args是Fix的参数。

二、Fix命令的类型LAMMPS中提供了多种类型的Fix命令,可以根据需要选择适合的Fix类型。

下面列举了一些常用的Fix类型及其功能:1. fix nve:用于模拟NVE(固定粒子数、体积和能量)系综,即在模拟过程中保持粒子的数量、体积和能量不变。

2. fix langevin:用于模拟Langevin动力学,可以引入随机力和粘滞阻力,模拟粒子在溶液或气体中的行为。

3. fix deform:用于对模拟系统施加应力或应变,可以模拟拉伸、压缩等力学变形过程。

4. fix addforce:用于施加外力,可以模拟外界作用力对系统的影响。

5. fix ave/spatial:用于计算和输出空间平均值,可以用于分析模拟系统中的局部性质。

三、Fix命令的参数Fix命令的参数根据不同的Fix类型而有所不同,下面以几种常用的Fix类型为例进行介绍:1. fix nve:无需额外参数。

2. fix langevin:参数包括温度、粘滞阻力和随机力的大小。

3. fix deform:参数包括拉伸速度、拉伸方向和应力张量等。

4. fix addforce:参数包括施加力的大小、方向和作用对象等。

5. fix ave/spatial:参数包括计算间隔、输出文件名和计算的空间范围等。

notepad lammps语法

notepad lammps语法

LAMMPS(Large-scale Atomic/Molecular Massively Parallel Simulator)是一种用于分子动力学模拟的开源软件,其语法结构复杂而灵活,能够满足多种复杂的模拟需求。

在该软件中,用户可以通过输入合适的命令或脚本文件来实现各种功能,包括分子模拟、力场建立、能量最小化等。

以下是关于LAMMPS语法的详细讲解:1. 基本结构在LAMMPS语法中,通常包含以下几个基本结构:a. 命令行输入b. 脚本文件输入c. 注释命令行输入是用户直接在命令行中输入LAMMPS命令来进行模拟,而脚本文件输入则是将LAMMPS命令写入一个脚本文件中,通过执行该文件来实现模拟。

注释则是用于解释LAMMPS命令的文本,不会被软件执行。

2. 命令格式LAMMPS的命令格式通常为:命令关键字参数,其中命令是指LAMMPS的具体功能,关键字是该功能的具体参数,参数则是关键字所需的具体数值或选项。

可以使用命令“p本人r_style lj/cut 2.5”来设置LJ势的截断距离为2.5。

3. 常用命令在LAMMPS中,有许多常用的命令,包括但不限于以下几类:a. 模拟控制命令b. 分子定义命令c. 力场设置命令d. 输出控制命令模拟控制命令用于控制模拟的时间步长、总步数、随机数种子等参数,分子定义命令用于定义分子结构、原子属性等信息,力场设置命令用于选择和设置力场模型,输出控制命令用于控制模拟结果的输出格式和频率。

4. 示例下面以一个简单的粒子模拟为例,介绍LAMMPS的语法使用方法:a. 定义模拟系统的基本信息,如维度、原子种类、原子位置等;b. 选择合适的分子力场模型,并设置其参数;c. 设置模拟的时间步长和总步数;d. 执行模拟并输出结果。

通过上述示例,可以看出,在LAMMPS中,用户可以通过简单的命令和脚本文件完成各种复杂的分子模拟任务。

LAMMPS是一款功能强大、灵活多样的分子动力学模拟软件,其语法结构严谨,使用方法多样。

LAMMPS手册-中文版讲解

LAMMPS手册-中文版讲解

LAMMPS手册-中文解析一、简介本部分大至介绍了LAMMPS的一些功能和缺陷。

1.什么是LAMMPS?LAMMPS是一个经典的分子动力学代码,他可以模拟液体中的粒子,固体和汽体的系综。

他可以采用不同的力场和边界条件来模拟全原子,聚合物,生物,金属,粒状和粗料化体系。

LAMMPS可以计算的体系小至几个粒子,大到上百万甚至是上亿个粒子。

LAMMPS可以在单个处理器的台式机和笔记本本上运行且有较高的计算效率,但是它是专门为并行计算机设计的。

他可以在任何一个按装了C++编译器和MPI的平台上运算,这其中当然包括分布式和共享式并行机和Beowulf型的集群机。

LAMMPS是一可以修改和扩展的计算程序,比如,可以加上一些新的力场,原子模型,边界条件和诊断功能等。

通常意义上来讲,LAMMPS是根据不同的边界条件和初始条件对通过短程和长程力相互作用的分子,原子和宏观粒子集合对它们的牛顿运动方程进行积分。

高效率计算的LAMMPS通过采用相邻清单来跟踪他们邻近的粒子。

这些清单是根据粒子间的短程互拆力的大小进行优化过的,目的是防止局部粒子密度过高。

在并行机上,LAMMPS采用的是空间分解技术来分配模拟的区域,把整个模拟空间分成较小的三维小空间,其中每一个小空间可以分配在一个处理器上。

各个处理器之间相互通信并且存储每一个小空间边界上的”ghost”原子的信息。

LAMMPS(并行情况)在模拟3维矩行盒子并且具有近均一密度的体系时效率最高。

2.LAMMPS的功能总体功能:可以串行和并行计算分布式MPI策略模拟空间的分解并行机制开源高移植性C++语言编写MPI和单处理器串行FFT的可选性(自定义)可以方便的为之扩展上新特征和功能只需一个输入脚本就可运行有定义和使用变量和方程完备语法规则在运行过程中循环的控制都有严格的规则只要一个输入脚本试就可以同时实现一个或多个模拟任务粒子和模拟的类型:(atom style命令)原子粗粒化粒子全原子聚合物,有机分子,蛋白质,DNA联合原子聚合物或有机分子金属粒子材料粗粒化介观模型延伸球形与椭圆形粒子点偶极粒子刚性粒子所有上面的杂化类型力场:(命令: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粗粒化作用势: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)聚合物势能: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(多对势能处于更高的优先级)原子创建:(命令:read_data, lattice, create-atoms, delete-atoms, displace-atoms, replicate)从文件中读入各个原子的坐标在一个或多个晶格中创建原子删除几何或逻辑原子基团复制已存在的原子多次替换原子系综,约束条件,边界条件:(命令:fix)二维和三维体系正角或非正角模拟空间常NVE,NVT,NPT,NPH积分器原子基团与几何区域可选择不同的温度控制器有Nose/Hoover和Berendsen压力控制器来控制体系的压力(任一维度上)模拟合子的变形(扭曲与剪切)简谐(unbrella)束缚力刚体约束摇摆键与键角约束各种边界环境非平行太分子动力学NEMD各种附加边界条件和约束积分器:Velocity-verlet积分器Brown积分器rRESPA继承时间延化积分器刚体积分器共轭梯度或最束下降算法能量最小化器输出:(命令:dump, restart)热力学信息日志原子坐标,速度和其它原子量信息的文本dump文件二进制重启文件各原子量包括:能量,压力,中心对称参数,CAN等用户自定义系统宽度或各原子的计算信息每个原子的时间与空间平均系统宽量的时间平均原子图像,XYZ,XTC,DCD,CFG格式数据的前处理与后处理:包里提供了一系列的前处理与后处理工具另外,可以使用独立发行的工具组pizza.py, 它可以进行LAMMPS模拟的设置,分析,作图和可视化工作。

(完整版)LAMMPS手册学习.doc

(完整版)LAMMPS手册学习.doc

(完整版)LAMMPS手册学习.docLAMMPS手册学习一、简介本部分大至介绍了LAMMPS的一些功能和缺陷。

1.什么时LAMMPS?LAMMPS是一个经典的分子动力学代码,他可以模拟液体中的粒子,固体和汽体的系综。

他可以采用不同的力场和边界条件来模拟全原子,聚合物,生物,金属,粒状和粗料化体系。

LAMMPS可以计算的体系小至几个粒子,大到上百万甚至是上亿个粒子。

LAMMPS可以在单个处理器的台式机和笔记本本上运行且有较高的计算效率,但是它是专门为并行计算机设计的。

他可以在任何一个按装了C++编译器和MPI的平台上运算,这其中当然包括分布式和共享式并行机和Beowulf型的集群机。

LAMMPS是一可以修改和扩展的计算程序,比如,可以加上一些新的力场,原子模型,边界条件和诊断功能等。

通常意义上来讲,LAMMPS是根据不同的边界条件和初始条件对通过短程和长程力相互作用的分子,原子和宏观粒子集合对它们的牛顿运动方程进行积分。

高效率计算的LAMMPS通过采用相邻清单来跟踪他们邻近的粒子。

这些清单是根据粒子间的短程互拆力的大小进行优化过的,目的是防止局部粒子密度过高。

在并行机上,LAMMPS采用的是空间分解技术来分配模拟的区域,把整个模拟空间分成较小的三维小空间,其中每一个小空间可以分配在一个处理器上。

各个处理器之间相互通信并且存储每一个小空间边界上的”ghost”原子的信息。

LAMMPS(并行情况)在模拟3维矩行盒子并且具有近均一密度的体系时效率最高。

2.LAMMPS的功能总体功能:可以串行和并行计算分布式MPI策略模拟空间的分解并行机制开源高移植性C++语言编写MPI和单处理器串行FFT的可选性(自定义)可以方便的为之扩展上新特征和功能只需一个输入脚本就可运行有定义和使用变量和方程完备语法规则在运行过程中循环的控制都有严格的规则只要一个输入脚本试就可以同时实现一个或多个模拟任务粒子和模拟的类型:(atom style命令)原子粗粒化粒子全原子聚合物,有机分子,蛋白质,DNA联合原子聚合物或有机分子金属粒子材料粗粒化介观模型延伸球形与椭圆形粒子点偶极粒子刚性粒子所有上面的杂化类型力场:(命令: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 粗粒化作用势: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)聚合物势能: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(多对势能处于更高的优先级)原子创建:(命令:read_data, lattice, create-atoms, delete-atoms, displace-atoms, replicate)从文件中读入各个原子的坐标在一个或多个晶格中创建原子删除几何或逻辑原子基团复制已存在的原子多次替换原子系综,约束条件,边界条件:(命令:fix)二维和三维体系正角或非正角模拟空间常NVE,NVT,NPT,NPH积分器原子基团与几何区域可选择不同的温度控制器有Nose/Hoover和Berendsen压力控制器来控制体系的压力(任一维度上)模拟合子的变形(扭曲与剪切)简谐(unbrella)束缚力刚体约束摇摆键与键角约束各种边界环境非平行太分子动力学NEMD各种附加边界条件和约束积分器:Velocity-verlet积分器Brown积分器rRESPA继承时间延化积分器刚体积分器共轭梯度或最束下降算法能量最小化器输出:(命令:dump, restart)热力学信息日志原子坐标,速度和其它原子量信息的文本dump文件二进制重启文件各原子量包括:能量,压力,中心对称参数,CAN等用户自定义系统宽度或各原子的计算信息每个原子的时间与空间平均系统宽量的时间平均原子图像,XYZ,XTC,DCD,CFG格式数据的前处理与后处理:包里提供了一系列的前处理与后处理工具另外,可以使用独立发行的工具组pizza.py, 它可以进行LAMMPS模拟的设置,分析,作图和可视化工作。

LAMMPS手册-中文版讲解

LAMMPS手册-中文版讲解

LAMMPS手册-中文解析一、简介本部分大至介绍了LAMMPS的一些功能和缺陷。

1.什么是LAMMPS?LAMMPS是一个经典的分子动力学代码,他可以模拟液体中的粒子,固体和汽体的系综。

他可以采用不同的力场和边界条件来模拟全原子,聚合物,生物,金属,粒状和粗料化体系。

LAMMPS可以计算的体系小至几个粒子,大到上百万甚至是上亿个粒子。

LAMMPS可以在单个处理器的台式机和笔记本本上运行且有较高的计算效率,但是它是专门为并行计算机设计的。

他可以在任何一个按装了C++编译器和MPI的平台上运算,这其中当然包括分布式和共享式并行机和Beowulf型的集群机。

LAMMPS是一可以修改和扩展的计算程序,比如,可以加上一些新的力场,原子模型,边界条件和诊断功能等。

通常意义上来讲,LAMMPS是根据不同的边界条件和初始条件对通过短程和长程力相互作用的分子,原子和宏观粒子集合对它们的牛顿运动方程进行积分。

高效率计算的LAMMPS通过采用相邻清单来跟踪他们邻近的粒子。

这些清单是根据粒子间的短程互拆力的大小进行优化过的,目的是防止局部粒子密度过高。

在并行机上,LAMMPS采用的是空间分解技术来分配模拟的区域,把整个模拟空间分成较小的三维小空间,其中每一个小空间可以分配在一个处理器上。

各个处理器之间相互通信并且存储每一个小空间边界上的”ghost”原子的信息。

LAMMPS(并行情况)在模拟3维矩行盒子并且具有近均一密度的体系时效率最高。

2.LAMMPS的功能总体功能:可以串行和并行计算分布式MPI策略模拟空间的分解并行机制开源高移植性C++语言编写MPI和单处理器串行FFT的可选性(自定义)可以方便的为之扩展上新特征和功能只需一个输入脚本就可运行有定义和使用变量和方程完备语法规则在运行过程中循环的控制都有严格的规则只要一个输入脚本试就可以同时实现一个或多个模拟任务粒子和模拟的类型:(atom style命令)原子粗粒化粒子全原子聚合物,有机分子,蛋白质,DNA联合原子聚合物或有机分子金属粒子材料粗粒化介观模型延伸球形与椭圆形粒子点偶极粒子刚性粒子所有上面的杂化类型力场:(命令: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粗粒化作用势: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)聚合物势能: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(多对势能处于更高的优先级)原子创建:(命令:read_data, lattice, create-atoms, delete-atoms, displace-atoms, replicate)从文件中读入各个原子的坐标在一个或多个晶格中创建原子删除几何或逻辑原子基团复制已存在的原子多次替换原子系综,约束条件,边界条件:(命令:fix)二维和三维体系正角或非正角模拟空间常NVE,NVT,NPT,NPH积分器原子基团与几何区域可选择不同的温度控制器有Nose/Hoover和Berendsen压力控制器来控制体系的压力(任一维度上)模拟合子的变形(扭曲与剪切)简谐(unbrella)束缚力刚体约束摇摆键与键角约束各种边界环境非平行太分子动力学NEMD各种附加边界条件和约束积分器:Velocity-verlet积分器Brown积分器rRESPA继承时间延化积分器刚体积分器共轭梯度或最束下降算法能量最小化器输出:(命令:dump, restart)热力学信息日志原子坐标,速度和其它原子量信息的文本dump文件二进制重启文件各原子量包括:能量,压力,中心对称参数,CAN等用户自定义系统宽度或各原子的计算信息每个原子的时间与空间平均系统宽量的时间平均原子图像,XYZ,XTC,DCD,CFG格式数据的前处理与后处理:包里提供了一系列的前处理与后处理工具另外,可以使用独立发行的工具组pizza.py, 它可以进行LAMMPS模拟的设置,分析,作图和可视化工作。

lammp中文手册

lammp中文手册

lammps简要使用说明李小椿北京航空航天大学物理科学与核能工程学院更新于:2010年2月1日星期一目录lammps简要使用说明 (1)LAMMPS介绍 (4)文件 (4)1.系统初始化 (4)units lj/real/metal/si/cgs (4)atom_style angle/atomic/bond/charge/dipole/dpd/ellipsoid/full/granular/molecular/hybrid (5)atom_modify map/first (5)dimension N ,N=2/3 (5)boundary x y z, default=boundary p p p (5)newton flag/flag1 flag2 (5)communicate single/multi group/cutoff (5)processors Px Py Pz (5)2.创建模拟晶胞 (6)lattice none/sc/bcc/fcc/hcp/diamond/sq/sq2/hex/custom scale keyword values (6)region ID style block/cylinder/prism/sphere/union/intersect args keyword value (6)group ID region/type/id/molecule/subtract/union/intersect (6)create_box N region−ID (7)create_atoms type box/region/single args keyword values (7)delete_atoms group/region/overlap/porosity args (7)read_restart file (7)set atom/group/region ID keyword values (8)displace_atoms group−ID move/ramp/random args keyword value (8)displace_box group−ID parameter args ... keyword value . (8)change_box ortho/triclinic (9)replicate nx ny nz (9)3.设置 (9)mass I value (9)velocity group−ID create/set/scale/ramp/zero args keyword value (9)timestep dt (9)reset_timestep N (10)neighbor skin bin/nsq/multi (10)neigh_modify keyword values (10)4.输出 (10)dump ID group−ID bond/dcd/xtc/xyz/custom N (10)dump_modify dump−ID format/scale/image/flush/unwrap/every/precision/region/thresh values (11)undump dump−ID (11)thermo_style one/multi/custom(args) (11)thermo_modify lost/norm/flush/line/format/temp/press value (12)thermo N (12)print string (12)restart N root (12)write_restart file (13)echo none/screen/log/both (13)log (13)5.FIX (13)fix ID group−ID style args (13)系综相关 (14)力和速度的控制 (15)计算特定量 (16)模拟晶胞的控制 (17)模拟过程的控制 (18)unfix fix-id (18)PUTE (18)compute ID group−ID style args (18)compute ID group−ID ackland/atom (19)compute ID group−ID centro/atom (19)compute ID group−ID coord/atom cutoff (19)compute ID group−ID damage/atom (19)compute ID group−ID displace/atom fix−ID (19)compute ID group−ID group/group group2−ID (19)compute ID group−ID ke (19)compute ID group−ID ke/atom (20)compute ID group−ID pe (keyword=pair/bond/angle/dihedral/improper/kspace) (20)compute ID group−ID pe/atom (keyword=pair/bond/angle/dihedral/improper) (20)compute ID group−ID pressure temp−ID keyword=ke/pair/bond/angle/dihedral/im proper/kspace/fix (20)compute ID group−ID reduce mode=sum/min/max input1 input2 ... .. (20)compute ID group−ID stress/atom (keyword= ke/pair/bond/angle/dihedral/improper/kspace/fix) (20)compute_modify compute−ID keyword value (20)compute ID group−ID temp (20)compute ID group−ID temp/com (20)compute ID group−ID temp/deform (20)comp ute ID group−ID temp/partial xflag yflag zflag (21)compute ID group−ID temp/ramp vdim vlo vhi dim clo chi keyword value (21)comput e ID group−ID temp/region region−ID (21)uncompute compute-ID (21)7.势函数 (21)pair_style (21)pair_style tersoff (22)kspace_style (23)kspace_modify (23)pair_write itype jtype N r/rsq/bitmap inner outer Qi Qj (23)8.运行 (23)run N upto/start/stop/pre/post/every values (23)run_style verlet/respa(args) (23)minimize etol ftol maxiter maxeval (23)min_style cg/sd (23)min_modify dmax 0.2 (default=0.1) (24)temper (24)clear (24)9.其他 (24)variable name delete/index/loop/world/universe/uloop/equal/atom (24)next variables (25)jump (25)label string (25)if value1 operator value2 then command1 else command2 (26)include (26)shell cd/mkdir/mv/rm/rmdir (26)10.模拟方法论 (26)缺陷的生成 (26)晶格常数 (27)迁移 (27)表面 (27)立方晶系弹性常数.......................................................................................................................... 错误!未定义书签。

LAMMPS手册中文讲解

LAMMPS手册中文讲解

LAMMPS手册中文讲解LAMMPS手册-中文解析一、简介本部分大至介绍了LAMMPS的一些功能和缺陷。

1.什么是LAMMPS?LAMMPS是一个经典的分子动力学代码,他可以模拟液体中的粒子,固体和汽体的系综。

他可以采用不同的力场和边界条件来模拟全原子,聚合物,生物,金属,粒状和粗料化体系。

LAMMPS可以计算的体系小至几个粒子,大到上百万甚至是上亿个粒子。

LAMMPS可以在单个处理器的台式机和笔记本本上运行且有较高的计算效率,但是它是专门为并行计算机设计的。

他可以在任何一个按装了C++编译器和MPI的平台上运算,这其中当然包括分布式和共享式并行机和Beowulf型的集群机。

LAMMPS是一可以修改和扩展的计算程序,比如,可以加上一些新的力场,原子模型,边界条件和诊断功能等。

通常意义上来讲,LAMMPS是根据不同的边界条件和初始条件对通过短程和长程力相互作用的分子,原子和宏观粒子集合对它们的牛顿运动方程进行积分。

高效率计算的LAMMPS通过采用相邻清单来跟踪他们邻近的粒子。

这些清单是根据粒子间的短程互拆力的大小进行优化过的,目的是防止局部粒子密度过高。

在并行机上,LAMMPS采用的是空间分解技术来分配模拟的区域,把整个模拟空间分成较小的三维小空间,其中每一个小空间可以分配在一个处理器上。

各个处理器之间相互通信并且存储每一个小空间边界上的”ghost”原子的信息。

LAMMPS(并行情况)在模拟3维矩行盒子并且具有近均一密度的体系时效率最高。

2.LAMMPS的功能总体功能:可以串行和并行计算分布式MPI策略模拟空间的分解并行机制开源高移植性C++语言编写MPI和单处理器串行FFT的可选性(自定义)可以方便的为之扩展上新特征和功能只需一个输入脚本就可运行有定义和使用变量和方程完备语法规则在运行过程中循环的控制都有严格的规则只要一个输入脚本试就可以同时实现一个或多个模拟任务粒子和模拟的类型:(atom style命令)原子粗粒化粒子全原子聚合物,有机分子,蛋白质,DNA联合原子聚合物或有机分子金属粒子材料粗粒化介观模型延伸球形与椭圆形粒子点偶极粒子所有上面的杂化类型力场:(命令: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 粗粒化作用势: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)聚合物势能: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(多对势能处于更高的优先级)(命令:read_data, lattice, create-atoms, delete-atoms, displace-atoms, replicate)从文件中读入各个原子的坐标在一个或多个晶格中创建原子删除几何或逻辑原子基团复制已存在的原子多次替换原子系综,约束条件,边界条件:(命令:fix)二维和三维体系正角或非正角模拟空间常NVE,NVT,NPT,NPH积分器原子基团与几何区域可选择不同的温度控制器有Nose/Hoover和Berendsen压力控制器来控制体系的压力(任一维度上)模拟合子的变形(扭曲与剪切)简谐(unbrella)束缚力刚体约束摇摆键与键角约束各种边界环境非平行太分子动力学NEMD各种附加边界条件和约束积分器:Velocity-verlet积分器Brown积分器rRESPA继承时间延化积分器刚体积分器共轭梯度或最束下降算法能量最小化器输出:(命令:dump, restart)热力学信息日志原子坐标,速度和其它原子量信息的文本dump文件二进制重启文件各原子量包括:能量,压力,中心对称参数,CAN等用户自定义系统宽度或各原子的计算信息每个原子的时间与空间平均系统宽量的时间平均原子图像,XYZ,XTC,DCD,CFG格式数据的前处理与后处理:包里提供了一系列的前处理与后处理工具另外,可以使用独立发行的工具组pizza.py, 它可以进行LAMMPS模拟的设置,分析,作图和可视化工作。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

DREIDING 是由戈达德集团在加利福尼亚理工学院开发的通用应力场, 可用 于预测有机, 生物和主要无机分子的结构和动力学。 DREIDING 是基于简单的杂 化考虑使用的一般应力常数和几何参数,而不是依赖于参与键,角或扭转项的原 子的特定组合的单独力常数和几何参数。 DREIDING 具有明确的氢键术语, 用于 描述在非常电负性原子(N,O,F)上涉及氢原子的相互作用。 有关 DREIDING 应力场的描述,请参阅(Mayo)。 这些样式选择计算的应力场公式与 DREIDING 应力场一致。 请参阅每个命 令的文档中的计算公式。
Lammps 语法
输入脚本中的每个非空行被当作一个命令。 LAMMPS 命令是区分大小写的。 命令名是小写的,如指定命令参数。 大写字母可能用于文件名或用户选择的 ID 字 符串。 下面是 LAMMPS 每一行的输入脚本解析: (1) 如果某行的最后一个可打印字符是“&”字符,则假定该命令在下一行 继续。通过删除“&”字符和换行符,下一行将连接到上一行。这使长命令延续在 两条或更多条的命令上。请参阅(6) ,如何在不使用“&”字符的情况下在多行上 继续执行命令。 (2) “#”字符后的所有字符都被视为注释并被丢弃,详见(6) 。注意,“&”字 符后面的注释将阻止命令在下一行继续。 另外请注意, 对于多行命令, 单个 “#” 字符将注释整个命令。 (3)某行重复搜索“$”字符,表示用文本字符串替换该变量,详见(6) 。 如果字符“$”后跟大括号,则变量名称是大括号内的文本。如果字符“$”后没 有大括号跟随,则变量名称是紧跟在$之后的单个字符。如${myTemp} 和 $x 的 变量名分别为 "myTemp" and "x"。 变量如何转换为文本字符串取决于变量的样式。 它可以是一个存储多个文本 字符串的变量,并返回其中的一个。返回的文本字符串可以是多个“单词”(空格 分隔) ,然后将其解释为输入命令中的多个参数。该变量还可以存储为一个数学 公式,该公式将被估算,其数值结果作为字符串返回。 如果字符$后跟圆括号则是一种特殊情况,圆括号内的文本被视为 “临时”变 量,并被评估为等式样式的变量。这是在输入脚本中使用数字公式的方法,而不 必给它们分配变量名称。 variable X equal (xlo+xhi)/2+sqrt(v_area) region 1 block $X 2 INF INF EDGE EDGE variable X delete 等价于: region 1 block $((xlo+xhi)/2+sqrt(v_area)) 2 INF INF EDGE EDGE 以便您不必定义(或丢弃)临时变量 X.
请注意, 以下命令不需要重复, 因为它们的设置包含在重新启动文件中: units, atom_style,special_bonds,pair_style,bond_style。 但是,这些命令确实需要使 用,因为它们的设置不在重新启动文件中:neighbor,fix,timestep。 另一种方法是将重新启动文件转换为数据文件,如下所示: lmp_g++ -r tmp.restart.50 tmp.restart.data 然后,该脚本可用于重新运行最后的 50 步: units lj atom_style bond pair_style lj/cut 1.12 pair_modify shift yes bond_style fene special_bonds 0.0 1.0 1.0 read_data tmp.restart.data neighbor 0.4 bin neigh_modify every 1 delay 1 fix 1 all nve fix 2 all langevin 1.0 1.0 10.0 904297 timestep 0.012 reset_timestep 50 run 50
bond_style harmonic bond_style morse angle_style harmonic angle_style cosine angle_style cosine/periodic dihedral_style charmm improper_style umbrella pair_style buck pair_style buck/coul/cut pair_style buck/coul/long pair_style lj/cut pair_style lj/cut/coul/cut pair_style lj/cut/coul/long pair_style hbond/dreiding/lj pair_style hbond/dreiding/morse special_bonds dreiding
2. 2d 模拟 使用 dimension 命令定义 2d 模拟。 默认情况下,通过 boundary 命令设置 z 轴为周期边界。 如果使用 create box 命令来定义模拟边界,则将 z 轴设置为窄,但是有限, 以便使用 create_atoms 命令将单个 z 平面的原子来平铺 3d 模拟边界。例如: create box 1 -10 10 -10 10 -0.25 0.25
3. CHARMM, AMBER, DREIDING 应力场 应力场有两部分组成:定义它的公式和用于特定系统的系数。在这里,我们 只 讨 论 在 LAMMPS 中 执 行 的 公 式 , 这 些 公 式 与 CHARMM , AMBER 和 DREIDING 应力场中常用的公式相对应。通过 read_data 命令或在输入脚本中使 用命令(如 pair_coeff or bond_coeff)在输入数据文件中设置系数。有关可以使用 CHARMM 或 AMBER 分配应力场系数并将其输出转换为 LAMMPS 输入的其他 工具,请参见第 9 节。 有关 CHARMM 应力场的描述,请参阅(MacKerel) 。有关 AMBER 应力场 的描述,参见(Cornell) 。 这些样式选择计算的应力场公式与 CHARMM 或 AMBER 中常见选项一致。 请参阅每个命令的文档中的计算公式。
如果使用 read data 命令读取原子坐标文件,则将“zlo zhi”值设置为有限但 窄,类似于刚刚描述的 create_box 命令设置。对于文件中的每个原子,分配一个 z 坐标,使其位于 z 轴边界内。例如:0.0。 使用 fix enforce2d 命令作为最后定义的修改,以确保 z 分量的速度和应力在 每个时间步长都被清零。 做这个最后修该的原因是, 其他修补程序可能生成应力, 这样能清除所引起的任何应力。 注意:在 LAMMPS 的一些模型中,将粒子视为有限大小的球体,而不是点 粒子。 在 2d 中,粒子仍然是球体,而不是圆盘,这意味着它们的惯性矩将与 3d 相同。
bond_style harmonic angle_style charmm dihedral_style charmm pair_style lj/charmm/coul/charmm pair_style lj/charmm/coul/charmm/implicit pair_style lj/charmm/coul/long special_bonds charmm special_bonds amber
4. 从一个输入脚本运行多个模拟 从一个输入脚本运行多个模拟可以通过几种方式完成。
若“多次模拟”是想继续先前的模拟以获得更多的时间步长,那么只需多次 使用运行命令即可。例如: units lj atom_style atomic read_data data.lj run 10000 run 10000 run 10000 run 10000 run 10000 这是对相同的系统运行 5 次连续的模拟,总共 50000 个时间步长。 如果想运行完全不同的模拟,一个接着另一个,可以使用清除命令在它们之 间重新初始化 LAMMPS。例如: units lj atom_style atomic read_data data.lj run 10000 clear units lj atom_style atomic read_data data.lj.new run 10000 该脚本是运行 2 个独立的模拟,一个接着另一个。 对于大量的独立模拟, 可以使用变量 (variables) 、 下一个 (next) 和跳转 (jump) 命令多次使用不同的设置循环模拟相同的输入脚本。 例如, 脚本名称为 in.polymer variable d index run1 run2 run3 run4 run5 run6 run7 run8 shell cd $d read_data data.polymer run 10000 shell cd ..
注意:如果参数本身是一个需要引用参数的命令(例如,使用 print 命令作 为 if 或 run 命令的一部分) ,则单引号,双引号或三引号可以以通常的方式 嵌套。ຫໍສະໝຸດ Lammps 常见任务介绍
本节介绍如何使用 LAMMPS 执行常见任务。 1. 重启模拟 通常有 3 种方法可以继续 LAMMPS 模拟。多个运行命令可以在同一个输入 脚本中使用,每次运行将从上次离开时的运行位置开始。或者使用 restart 命令将 二进制重启文件保存到磁盘。稍后,这些二进制文件可以通过新脚本中的 read_restart 命令读取。或者可以使用-r 命令行切换将其转换为文本数据文件,并 在新脚本中通过 read_data 命令读取。 下面,给出读取二进制重新启动文件或转换后的数据文件的 2 个脚本的示 例,然后发出一个新的运行命令以继续上次离开时的运行位置。示例说明了在新 脚本中必须做出的设置。 详细信息在 read_restart 和 read_data 命令的文档中讨论。 如果脚本有如下一行: restart 50 tmp.restart 添加该脚本,它运行时将生成 2 个二进制重新启动文件(tmp.restart.50 和 tmp.restart.100) 。 该脚本可用于读取第一次重新启动文件并继续运行最后 50 个时 间步长: read_restart tmp.restart.50 neighbor 0.4 bin neigh_modify every 1 delay 1 fix 1 all nve fix 2 all langevin 1.0 1.0 10.0 904297 timestep 0.012 run 50
相关文档
最新文档