当前位置:文档之家› lammps初学者in文件中文解析

lammps初学者in文件中文解析

lammps初学者in文件中文解析
lammps初学者in文件中文解析

Lammps初学者——in文件中文解析

(1)初始化

Units:

Units命令是用来设定模拟的原子类型。

Units style(lammps现在提供的有style=LJ、real、metal、si、cgs、electron)LJ是硬球模型

Real是真实的原子模型

Metal是金属原子模型

Si是硅(半导体)原子模型

Cgs

Electron是电子模型

Dimension:

Dimension命令是用来定义模拟的维度,默认情况为三维。

Dimension N (N=2,3)

Boundary:

Boundary命令是用来设定模拟的边界条件。

Boundary x y z (x,y,z=p,s,f,m四种类型中的一种或者两种)

P是周期性边界条件

S是自由边界条件(但是具有收缩性)

F是固定边界条件

M是具有最小值的自由边界条件(但是具有收缩性)

Atom-style:

Atom-style定义了模拟体系中的原子属性。

Delete-atoms:

Pair-style:

Pair-style定义了相互作用力场类型,即势函数。

(2)原子定义

1、

Read-data/read-restart:

Read-data或read-restart为从data或restart文件中读取内容来定义原子。2、

Lattice:

lattice是用来原子类型构建模型晶格结构。

Lattice style scale keyword values...

Style表示点阵类型,点阵类型有none、sc、bcc、fcc、hcp、diamond、sq、sq2、hex、custom。

Scale表示构建的点阵类型的单位长度

Keyword表示后面可以追加0个或者多个关键字,关键字有origin、orient、

spacing、a1、a2、a3、basis。

各关键字意思为:

Region:

Create-box:

Create-box命令用于在region box命令指定的区域内创建一个模拟的盒子。

Create_box N region-ID

N为使用该原子类型进行模拟

Region-ID为使用区域的ID使用模拟域

Create-atoms:

Create-atoms用于在所创建的模拟的盒子中填充某种原子。

Create_atoms type style args keyword values ...

(3)设定:

力场系数

Pair-coeff:

模拟参数

Neighbor

Neighbor是定义

Neighbor skin style

Skin为

Style可取bin、nsq、multi

Neighbor-modify:

Group:

Timestep:

Timestep是定义模拟的时间步长。Timestep dt

Dt为时间步长(时间单位),默认为1ps Reset-timestep:

Fix

Fix为定义对部分原子或者对系综的操作。https://www.doczj.com/doc/fb7726332.html,/doc/fix.html

Fix ID group-ID style args

ID=指定的操作名称编号(如1、2、3…….)Group-ID=制定操作范围的原子(如all……)Style=操作内容,如何操作

Args=相关操作内容的相关操作参数

Fix-nvt:恒定N(原子数量)、V(体积)、T(温度)对时间积分

Fix-npt:恒定N、P、T对时间积分

Unfix:

Compute/compute-modify:

输出选项

Thermo:

Thermo命令用于定义每隔一定时间步长输出一次采样内容。

Thermo N

每隔N个时间步长输出一次采样内容至屏幕或者log文件

Thermo_style:

Thermo_style命令主要是用来说明采样的内容,即输出到屏幕或者LOG 文件中的内容。(https://www.doczj.com/doc/fb7726332.html,/doc/thermo_style.html)Thermo_style style args

Style=one、multi、custom

Args=特定的参数列表

One args=none

Multi args=none

Custom args=list of attributes

Possible attributes=step、elaosed、elaplong、dt、cpu、tpcpu、spcpu、

Atoms、temp、press、pe、ke、otatal、enthalpy、

Evdwl、ecoul、epair、ebond、eangle、edihed、eimp、

Emol、elong、etail、

V ol、lx、ly、lz、xlo、xhi、ylo、yhi、zlo、zhi、

Xy、xz、yz、xlat、ylat、zlat、

Pxx、pyy、pzz、pxy、pyz、pxz、

Fmax、fnorm、

Cella、cellb、cellc、cellalpha、cellbeta、cellgamma、

c_ID、c_ID[I]、c_ID[I][J]、

f_ID、f_ID[I]、f_ID[I][J]、

V_name

Dump:

Dump命令主要是用来输出计算后单个原子的相关信息的。

Dump ID group-ID style N file args

ID:自己给这个dump命令定义的一个代号(自定义)

group-ID:那些信息需要被输出的原子群(预先定义好group)Style:类型

N:每经过多少时间步输出信息

File:输出名称

Args:相关参数(每个类型不同)

Restart:

(4)运行

Run:

Minimize:

例一

units metal # 单位为lammps 中的metel 类型

boundary p p p # 周期性边界条件

atom_style atomic # 原子模式

lattice fcc 3.61 # Cu 的晶格常数3.61

region box block 0 4 0 4 0 4 # x,y,z 各方向上的晶胞重复单元数,也即区域大小create_box 1 box # 将上述区域指定为模拟的盒子

create_atoms 1 box # 将原子按晶格填满盒子

pair_style eam # 选取Cu 的EAM 势作为模型

pair_coeff * * Cu_u3.eam # EAM 势文件名称

run 0 # 运行0 步,仅为启动lammps 的热力学数据计算

variable E equal pe # 定义变量E 为系统总势能

variable N equal atoms # 定义变量N 为系统总原子数

print "the number of atoms & system energy now are $N $E" # 打印信息

create_atoms 1 single 2.45 2.05 2.05 # 在该位置插入一个原子

min_style sd # 能量最小化模式,sd

minimize 1.0e-12 1.0e-12 1000 1000 # 能量最小化参数,指数越大最小化程度越深print "interstitial introduced, minimized: $N atoms, energy is $E"

fix 1 all nvt 100 100 100 drag 0.2 # nvt 系综,原子数、体积和温度保持不变;T=100K

timestep 0.005 # 步长0.005fs

run 1000 # 运行1000 步

print "nvt performed, temperature up: $N atoms, total energy is $E"

fix 1 all nvt 100 0.0001 100 drag 0.2 # nvt 系综,温度由100K 到0.0001K

run 1000 # 运行1000 步

print "nvt performed, temperature down: $N atoms, total energy is $E"

compute 3 all pe/atom # 计算每个原子的势能

compute 4 all ke/atom # 计算每个原子的动能

compute 5 all coord/atom 3.0 # 计算每个原子的近邻原子数

dump 1 all custom 1 dump.atom id xs ys zs c_3 c_4 c_5 # 将信息写入dump.atom min_style sd

minimize 1.0e-12 1.0e-12 10000 10000 # 再次能量最小化

print "the final state: $N atoms, total energy is $E" # 打印信息

~

例二

boundary p s s # 边界条件,拉伸方向是周期性,其余是自由边界;如果是薄膜拉伸则是两个周期性,块体则是三个周期性

units metal #单位制定义为metal

atom_style atomic #原子类型自动

neighbor 2.0 bin #截断半径相关的东西neigh_modifydelay 1 check yes # 邻近原子列表更新速度

#create geometry

lattice fcc 3.61 # 定义晶胞为fcc,晶

格常数3.61A

region box block 0 30 0 3 0 3 #定义一个长方体区域叫box,长30,宽和高是3

create_box 1 box #创建了这样一个box create_atoms 1 box #在box里创建了一种原子mass 1 63.546 #定义这种原子的质量是63.546

# potentials

pair_style eam # 定义势函数是EAM pair_coef * * Cu_u3.eam #势所需要的参数在此文件里

#define groups

region 1 block INF 1 INF INF INF INF # 定义了一个叫1的区域

group left region 1 #定义此区域里的原子叫left

region 2 block 29 INF INF INF INF INF #定义了一个叫2的区域

group right region 2 #定义此区域里的原子叫right

group boundary union left right #定义left+ right = boundary

group mobile subtract all left # 定义mobile= all - left

# initialvelocities

velocity left set 0.0 0.0 0.0 # 设置原子初速度为0

computep all pressure thermo_temp # 计算应力,计算结果记为p

variable pressx equal c_p[1] #定义变量pressx=c_p[1],c_p[1]的意思是p里第一个值

variable pressy equal c_p[2] #定义变量pressy=c_p[2],c_p[2]的意思是p里第二个值

variable pressz equal c_p[3] #定义变量pressz=c_p[3],c_p[3]的意思是p里第三个值

thermo_style custom step temp etotal press v_pressx v_pressy v_pressz vol

dump 1 all atom 1000 dump.tensile # 输出结果到dump.tensile

minimize 1.0e-6 1.0e-6 1000 1000 # 驰豫

fix 1 left setforce 0.0 NULL NULL #固定左边的原子

fix 2 all npt 1.0 1.0 1.0 aniso 0.0 0.0 NULL NULL NULL NULL 10.0 drag 1.0

thermo 1000 # 每1000步输出一次结果

timestep 0.002 #时间步长0.002ps

run 10000 #运行10000步

unfix2

fix 3 all nve

fix 4 all temp/rescale 100 1.0 1.0 5 1.0

fix 5 all deform 1000 x erate 0.002 units box #设置沿x方向拉伸,应变率为0.002(1/ps)

compute s all stress/atom #计算每个原子上的应力,计算结果记为s

compute strea all reduce sum c_s[1] #将s里第一个值求和,计算结果记为strea

variable stressa equal c_strea/vol # 定义变量stressa= strea/vol, vol是体积

compute streb all reduce sum c_s[2]

variable stressb equalc_streb/vol

compute strec all reduce sum c_s[3]

variable stressc equal c_strec/vol

thermo_style custom step tempetotal press v_stressa v_stressb v_stressc vol run 300000

(完整word版)lammps初学者in文件中文解析

Lammps初学者——in文件中文解析 (1)初始化 Units: Units命令是用来设定模拟的原子类型。 Units style(lammps现在提供的有style=LJ、real、metal、si、cgs、electron)LJ是硬球模型 Real是真实的原子模型 Metal是金属原子模型 Si是硅(半导体)原子模型 Cgs Electron是电子模型 Dimension: Dimension命令是用来定义模拟的维度,默认情况为三维。 Dimension N (N=2,3) Boundary: Boundary命令是用来设定模拟的边界条件。 Boundary x y z (x,y,z=p,s,f,m四种类型中的一种或者两种) P是周期性边界条件 S是自由边界条件(但是具有收缩性) F是固定边界条件 M是具有最小值的自由边界条件(但是具有收缩性)

Atom-style: Atom-style定义了模拟体系中的原子属性。 Delete-atoms: Pair-style: Pair-style定义了相互作用力场类型,即势函数。 (2)原子定义 1、 Read-data/read-restart: Read-data或read-restart为从data或restart文件中读取内容来定义原子。2、 Lattice: lattice是用来原子类型构建模型晶格结构。 Lattice style scale keyword values... Style表示点阵类型,点阵类型有none、sc、bcc、fcc、hcp、diamond、sq、sq2、hex、custom。 Scale表示构建的点阵类型的单位长度 Keyword表示后面可以追加0个或者多个关键字,关键字有origin、orient、spacing、a1、a2、a3、basis。 各关键字意思为: Region: Create-box:

lammps初学者in文件中文解析.doc

Lammps初学者——in文件中文解析(1)初始化 Units: Units命令是用来设定模拟的原子类型。 Units style(lammps现在提供的有style=LJ、real、metal、si、cgs、electron) LJ是硬球模型 Real是真实的原子模型 Metal是金属原子模型 Si是硅(半导体)原子模型 Cgs Electron是电子模型 Dimension: Dimension命令是用来定义模拟的维度,默认情况为三维。 Dimension N (N=2,3) Boundary: Boundary命令是用来设定模拟的边界条件。 Boundary x y z (x,y,z=p,s,f,m四种类型中的一种或者两种) P是周期性边界条件 S是自由边界条件(但是具有收缩性) F是固定边界条件 M是具有最小值的自由边界条件(但是具有收缩性) Atom-style: Atom-style定义了模拟体系中的原子属性。 Delete-atoms: Pair-style: Pair-style定义了相互作用力场类型,即势函数。 (2)原子定义 1、 Read-data/read-restart: Read-data或read-restart为从data或restart文件中读取内容来定义原子。 2、 Lattice: lattice是用来原子类型构建模型晶格结构。

Lattice style scale keyword values... Style表示点阵类型,点阵类型有none、sc、bcc、fcc、hcp、diamond、sq、sq2、hex、custom。 Scale表示构建的点阵类型的单位长度 Keyword表示后面可以追加0个或者多个关键字,关键字有origin、orient、spacing、a1、a2、a3、basis。 各关键字意思为: Region: Create-box: Create-box命令用于在region box命令指定的区域内创建一个模拟的盒子。 Create_box N region-ID N为使用该原子类型进行模拟 Region-ID为使用区域的ID使用模拟域 Create-atoms: Create-atoms用于在所创建的模拟的盒子中填充某种原子。 Create_atoms type style args keyword values ... (3)设定: 力场系数 Pair-coeff: 模拟参数 Neighbor Neighbor是定义 Neighbor skin style Skin为 Style可取bin、nsq、multi Neighbor-modify: Group: Timestep: Timestep是定义模拟的时间步长。 Timestep dt Dt为时间步长(时间单位),默认为1ps Reset-timestep: Fix

lammps实例(3)

Project #1 硅的晶格常数和体弹模量的计算 一、平衡晶格常数和内聚能 自然条件下硅为金刚石结构(dc )。计算模拟时,我们可以假定它为各种结构,f cc, bcc, sc, dc. 可以预测,模拟的dc 结构的硅的体系能量最低,也即最稳定。下面我们将运用LAMMPS 来对硅的各种结构进行模拟。 定义晶格能量为Φ, 数密度为 ρ: pot E N Φ= N V ρ= 其中E pot 为势能, N 为体系总原子数,V 为体系的体积。选取 Stillinger-Weber (SW),以下面命令执行 lammps 运算: 其中,lmp_serial 为 lammps 命令;”<” 符号为读取符;in.Silicon 为输入文件,里面包含运算所需要的各种数据和命令;-log 指定输出文件的名称。 可以看到屏幕上显示出lammps 运行的信息。这个计算量很小,所以很快就结束。接下来以如下命令来查看计算得到的数据: grep 是linux 中一个很重要的命令,用来搜索文本,读取匹配的行并打印出来。这里是搜索 dc.log 文件,将 @ 开头的行打印出来。如下: 晶格参数为5.4305埃,数密度为0.0499540303,每个原子的能量为-4.336599609eV.

下面具体来看刚才给的输入文件,in.Silicon . dc.log 文件中有原子总数的信息, 每个金刚石晶胞中有8个原子,383216?=,所以是216个原子。如下给出各种结构下的体系的原子数:

晶体结构类型 晶胞中的原子数 总原子数 简单立方SC 1 27 体心立方BCC 2 54 面心立方FCC 4 108 金刚石DC 8 216 表1. 不同晶体结构中的原子数 下图是计算模拟得出的各种结构下的数密度与每个原子能量的关系图。 横坐标为数密度, 以金刚石为例,ρ= 8/5.4315^3=0.049926,也即我们直接通过 grep 命令得到的第二项值;纵坐标为每个原子的能量,为第三项值。 金刚石之外,还需计算其他结构。只需对 in.Silicon 做稍微改动: 首先,将in.Silicon 复制成in.fcc : 然后编辑 in. fcc 改动如下几项: 然后如下命令执行: 相应的,如下命令查看log 文件中的数据:

LAMMPS in文件注意事项及详细解释

LAMMPS in文件注意事项及详细解释 lammps做分子动力学模拟时,需要一个输入文件(input script),也就是in文件,以及关于体系的原子坐标之类的信息的文件(data file)。lammps在执行计算的时候,从这个in文件中读入命令,所以对LAMMPS的使用最主要的就是对in文件的编写和使用。 下面介绍一些关于in文件的事项: 1.每一非空行都被认为是一条命令(大小写敏感,但极少有命令或参数大写的)。 2.in文件中各命令的顺序可能会对计算产生影响,但大部分情况下不会有影响。 3.每行后的“&” 表示续行(类似fortran)。 4.“#”表示注释(类似bash)。 5.每行命令中的不同字段由空格或者制表符分隔开来,每个字段可以由字母、数字、下划 线、或标点符号构成。 6.每行命令中第一个字段表示命令名,之后的字段都是相关的参数。 7.很多命令都是在需要修改默认值的情况下才特别设置的。 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 definition lammps提供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

LAMMPS手册-中文版讲解

L A M M P S手册-中文版 讲解 https://www.doczj.com/doc/fb7726332.html,work Information Technology Company.2020YEAR

LAMMPS手册-中文解析 一、简介 本部分大至介绍了LAMMPS的一些功能和缺陷。 1.什么是LAMMPS? 2. LAMMPS是一个经典的分子动力学代码,他可以模拟液体中的粒子,固体和汽体的系综。他可以采用不同的力场和边界条件来模拟全原子,聚合物,生物,金属,粒状和粗料化体系。LAMMPS可以计算的体系小至几个粒子,大到上百万甚至是上亿个粒子。 LAMMPS可以在单个处理器的台式机和笔记本本上运行且有较高的计算效率,但是它是专门为并行计算机设计的。他可以在任何一个按装了C++编译器和MPI的平台上运算,这其中当然包括分布式和共享式并行机和Beowulf型的集群机。 LAMMPS是一可以修改和扩展的计算程序,比如,可以加上一些新的力场,原子模型,边界条件和诊断功能等。 通常意义上来讲,LAMMPS是根据不同的边界条件和初始条件对通过短程和长程力相互作用的分子,原子和宏观粒子集合对它们的牛顿运动方程进行积分。高效率计算的LAMMPS通过采用相邻清单来跟踪他们邻近的粒子。这些清单是根据粒子间的短程互拆力的大小进行优化过的,目的是防止局部粒子密度过高。在并行机上,LAMMPS采用的是空间分解技术来分配模拟的区域,把整个模拟空间分成较小的三维小空间,其中每一个小空间可以分配在一个处理器上。各个处理器之间相互通信并且存储每一个小空间边界上的”ghost”原子的信息。LAMMPS(并行情况)在模拟3维矩行盒子并且具有近均一密度的体系时效率最高。 3.L AMMPS的功能 总体功能: 可以串行和并行计算 分布式MPI策略 模拟空间的分解并行机制 开源 高移植性C++语言编写 MPI和单处理器串行FFT的可选性(自定义) 可以方便的为之扩展上新特征和功能 只需一个输入脚本就可运行 有定义和使用变量和方程完备语法规则 在运行过程中循环的控制都有严格的规则

lammps实例(4)

Project #2 金属中的点缺陷:空位和间隙原子 一、空位 从晶体中移去一个原子,即可形成空位。本例将运用 LAMMPS 计算空位形成能, E v. LAMMPS 输入文件为in.vacancy 1) 在 fcc 结构的完整Cu晶体中引入一个空位 沿<100>方向构造一个 4 ×N×N×N 的晶体。N为input 文件中lattice命令指定的个方向上的晶胞重复单元数。 2) 弛豫 当一个原子从晶体中移走之后,周围的原子将相应地调整位置以降低体系势能。为得到稳定的构型,需要对体系进行弛豫,relaxation. LAMMPS提供两种能量最小化方式,cg 和 sd。本例中选用 sd 方式进行能量最小化。 如下是输入文件,in.vacancy:

3) 运行lammps 4) 计算空位形成能 空位浓度由下式给出: [n ] = exp( ? F v / k B T ). 其中 F v = E v ? TS v 为形成一个空位所需要的Helmholtz 自由能. 忽略熵S v , 空位浓度公式简化为 [n ] = exp( ?E v / k B T ). 设 E 1 为完整晶体能量,含N 个原子;E 2 为弛豫后的晶体能量,含N – 1个原子。空位形成能 E v 为: 211v N E E E N -≡- 或 ()21v coh E E N E ≡--, 其中 E coh = E 1 / N , 为完整晶体的内聚能。 本例中以EAM 模型计算4×(20×20×20)=32000个原子的体系,得到空位形成能E v ~ 1.26 eV ,文献中的实验值为~1.28 eV ,符合较好。 另由上式计算得到,300K 温度下的空位浓度为~ 7.59×10-22 ,1350 K (T m ) 时的空位浓度~ 2.2×10-5(文献中的实验值为~2×10-4 )。换算时注意(1 eV/k B = 1.1604×10?4 K) 图1. 空位处于4×(6×6×6) 的 FCC 晶体中心,106c a =,206c a =,306c a =. 颜色依据原子势能标注。

lammps输入文件命令中文详解

作者: 御剑江湖收录日期: 2011-03-31 发布 日期: 2011-03-24 Commands 描述了lammps输入文件的格式和在定义lammps模拟所需要的命令. 1.1 LAMMPS input script 我们用lammps做分子动力学模拟, 需要一个输入文件. lammps在执行计算的时候, 从这个文本文件中逐行读入命令. 大多数情况, lammps输入文件中各个命令的顺序并不是很重要. 但是你要注意以下

几点: (1) lammps并不是将你的输入文件全部读入之后才开始进行计算的, 或者说, 每条命令在它被读入之后就会起作用了. 注意, 下面两组命令的执行效果是不相同的. timestep 0.5 run 100 run 100 和 run 100 timestep 0.5

run 100 (2) 有些命令只有在另一些命令已经被定义的情况下才有效. 例如如果你要设定一组原子的温度, 那么用group命令定义哪些原子属于这个组才行. (3) 还有一种情况就是: 命令B要用到命A 设置的一些数值, 这样你也不能颠倒这两个命令的顺序. 每个命令的详细介绍中的Restrictions部分会说明要使用该命令定义的时候哪些命令必须要被预先定义. 如果你的输入文件书写的格式有问题,

lammps在执行的时候会提示ERROR或者WARNING , 出现类似信息时, 你可以到手册的第九章中查询原因. 1.2 Parsing rules 输入文件中的每一非空行都被认为是一条命令. lammps中命令的书写是对大小写敏感的, 不过一般的命令和参数都是小写的, 大写字母用于极少数的情况. (1) 命令行后的& 表示这一行跟下一行是同一条命令. 这一点跟FORTRAN很像. (2) 命令行最开始的# 表示这一行在执行

lammps实例(2)

Project #4 表面与界面能 铜的表面能 当物体形成表面时,表面上的原子键发生断裂,接近表面的几层原子不再如之前处于平衡状态,从而导致能量的升高,升高的温度便是物体的表面能。 利用LAMMPS 做出 20*20*40 fcc 的盒子,删去边缘的原子制造出一段真空层;算出此时体系的总能量0E ,然后从中间把盒子切成两半并移至足够远的距离,此时的体系总能量为E final , 从而表面能: 02final surface E E A γ=? A 为表面的面积 (100) 面与 (111) 面 如下是输入文件in.surface_Cu_100 # LAMMPS Cu _Surface_100 units metal boundary p p p atom_style atomic lattice fcc 3.61 region box block 0 20 0 20 0 40 create_box 1 box create_atoms 1 box timestep 0.005 thermo 5 pair_style eam/alloy pair_coeff * * jin_copper_lammps.setfl Cu region boundary1 block INF INF INF INF 29.9 INF region boundary2 block INF INF INF INF INF 9.9 group boundary1 region boundary1 group boundary2 region boundary2 group boundary union boundary1 boundary2

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 联合原子聚合物或有机分子 金属 粒子材料 粗粒化介观模型 延伸球形与椭圆形粒子 点偶极粒子

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, tabulated.

Lammps 石墨烯实例

一、简介 1.SiC热分解制备石墨烯 自2004年Novoselov、Geim和合作者们从石墨上剥离出世界上第一种二维材料——单层石墨:石墨烯(Graphene)以来,石墨烯就受到了科技界的广泛重视[1]。Novoselov 和Geim两人因此在2010年获得了诺贝尔物理学奖。因为石墨烯的独特特性,在许多技术领域例如光电子学上它都被寄予厚望。研究石墨烯这种材料相关的物理化学特性和发展大面积、高质量生长石墨烯的技术,同时将其与器件物理学联系起来是我们研究和应用石墨烯的必由途径。 石墨烯是由碳元素组成的二维六边形材料,其在光学、电学、热学、力学等性质十分优异。它有可能在后摩尔定律时代成为硅(Silicon)的继任者,在单分子气体传感器[2]、自旋电子学[3]、量子计算[4]、太赫兹振荡器[5]等等领域发挥重要作用。如今,从石墨上剥离出石墨烯仍然是一种重要的石墨烯制备方方法。然而,这种方法产生的石墨烯大小通常不超过1000 μm2,只适合实验室研究,尚不能在工业上大规模应用。科学家发展了其他的石墨烯制备方法,包括将石墨烯视作一种薄膜来生长的化学气相沉积(Chemical Vapor Deposition, CVD)法、热分解碳化硅法(SiC thermal decomposition)、氧化石墨烯还原法(Graphene oxide reduction)等。 CVD法通过使含碳气源在有催化作用的金属表面分解或者使溶入到这些有催化作用的金属中的碳(C)发生表面偏析,使得在金属表面生成石墨烯或者多层石墨烯(Few-Layer Graphene, FLG)。能否直接在半导体/绝缘体上生长石墨烯呢?碳化硅热分解成功的解决了这一问题。最早试图使六方晶系的SiC晶体石墨化的研究报告见于1961年,Badami在高温和真空环境下得到了发生了一定石墨化的SiC[6]。在一定的退火条件下,SiC晶体表面发生热分解,Si原子发生解吸附,而C原子留下来重新排列和组合可以生长成外延型的石墨烯层[7]。更细致的研究发现用热退火的方法在六方SiC的Si面上生长的石墨烯比C面有更好的可控性,例如:可以更好的控制石墨烯的层数。Si面上生长的石墨烯生长方向与基底晶体结构有密切关系,这样提供了在基底上均匀覆盖和特定方向生长石墨烯的可能性。特别地,石墨烯直接生长在半导体SiC上使得我们无

石墨烯拉伸的in文件

单层石墨烯拉伸in文件(lammpstrj) Data文件:直接可以自己在VMD中生成石墨烯模型,保存为data格式即可# 3d relax simulation dimension 3 boundary s s s units metal atom_style atomic neighbor 2.0 bin neigh_modify every 1 delay 0 check yes read_data my.data group g-1 type 1 group g-2 type 2 group g-3 type 3 pair_style airebo 3.0 1 1 pair_coeff * * CH.airebo C C C compute 1 g-2 stress/atom compute 1x g-2 reduce sum c_1[1] compute 1y g-2 reduce sum c_1[2] compute 1z g-2 reduce sum c_1[3] velocity g-2 create 300 4928459 mom yes rot no velocity g-1 set 0.0 0.0 0.0 units box velocity g-3 set 0.0 0.0 0.0 units box timestep 0.001 fix 1 g-2 nve fix 2 g-2 langevin 300.0 300.0 0.08 48279 fix 3 g-1 rigid single force 1 off off off torque 1 off off off fix 4 g-3 rigid single force 1 off off off torque 1 off off off

lammps的in文件详解

例一 units metal # 单位为lammps 中的metel 类型 boundary p p p # 周期性边界条件 atom_style atomic # 原子模式 lattice fcc 3.61 # Cu 的晶格常数3.61 region box block 0 4 0 4 0 4 # x,y,z 各方向上的晶胞重复单元数,也即区域大小 create_box 1 box # 将上述区域指定为模拟的盒子 create_atoms 1 box # 将原子按晶格填满盒子 pair_style eam # 选取Cu 的EAM 势作为模型 pair_coeff * * Cu_u3.eam # EAM 势文件名称 run 0 # 运行0 步,仅为启动lammps 的热力学数据计算 variable E equal pe # 定义变量E 为系统总势能 variable N equal atoms # 定义变量N 为系统总原子数 print "the number of atoms & system energy now are $N $E" # 打印信息 create_atoms 1 single 2.45 2.05 2.05 # 在该位置插入一个原子 min_style sd # 能量最小化模式,sd minimize 1.0e-12 1.0e-12 1000 1000 # 能量最小化参数,指数越大最小化程度越深 print "interstitial introduced, minimized: $N atoms, energy is $E" fix 1 all nvt 100 100 100 drag 0.2 # nvt 系综,原子数、体积和温度保持不变;T=100K timestep 0.005 # 步长0.005fs run 1000 # 运行1000 步 print "nvt performed, temperature up: $N atoms, total energy is $E" fix 1 all nvt 100 0.0001 100 drag 0.2 # nvt 系综,温度由100K 到0.0001K run 1000 # 运行1000 步 print "nvt performed, temperature down: $N atoms, total energy is $E" compute 3 all pe/atom # 计算每个原子的势能 compute 4 all ke/atom # 计算每个原子的动能 compute 5 all coord/atom 3.0 # 计算每个原子的近邻原子数 dump 1 all custom 1 dump.atom id xs ys zs c_3 c_4 c_5 # 将信息写入dump.atom min_style sd minimize 1.0e-12 1.0e-12 10000 10000 # 再次能量最小化 print "the final state: $N atoms, total energy is $E" # 打印信息 ~ 例二 boundary p s s # 边界条件,拉伸方向是周期性,其余是自由边界;如果是薄膜拉伸则是两个周期性,块体则是三个周期性 units metal #单位制定义为metal atom_style atomic #原子类型自动 neighbor 2.0 bin #截断半径相关的东西 neigh_modifydelay 1 check yes # 邻近原子列表更新速度

学习lammps 对in文件的一个概述性心得

写在开头: 1.尽量列举了大部分(几乎)的命令 2.带星号命令非常重要,大家在看mannual中命令的解释的时候可以重点先看带星号的 3.非斜命令是运行一个常用模拟所必备的 4.命令顺序为一个基本的脚本文件命令顺序,骨架如此 5.我主要是做金属的,所以其他方向的希望有一个借鉴作用,大同小异 6.对于初学者切不可认为in文件就是这个固定顺序,其实正常模拟过程中做平衡、以及随后的运行在某些阶段都会重复使用某一段命令,比如fix 1 …run;fix 2 …run ………,以及作循环,等等等 7.本文的目的旨在让初学者对in文件有一个总体的把握,希望对新手入门有帮助 8.括号里为这个命令的默认值,我列举的是在使用过程中比较关心的默认值 9.纯属个人学习心得,希望大家多多指点讨论 10.复制的时候希望能留下足迹,如果觉得哪里有问题,随时回来讨论!方便其他人学习! 11.对in文件通俗点的理解就像洗衣服,洗衣机就是lammps的主程序,这个in文件就是在设定怎么洗衣服 ----------------------------------Initialization基本模拟系统设置------------------------- units (lj) ** 单位系统 boundary (ppp) ** 边界条件 atom_style (atomic) ** 粒子类型 atom_modify * 粒子类型调整,,,凡是后面带一个modify的,都是对头命令的补充修改newton (on) processors dimension (3) * 维数 ------------------------------Atom definition---这一组命令主要用来构建模拟模型的--------------- lattice ** 晶格参数 region ** 选择一个区域 create_box ** 创建一个盒子 create_atoms ** 创建原子 group, ** 给原子分组 delete_atoms,** 删除某些原子 delete_bonds, displace_atoms,* 移动某些原子 replicate* 将已经构建的模型在三维重复复制放大 read_data***这个命令就是用来读取其他软件建的模型的 read_restart* 以之前运行的结果作为这次计算的初始构型 ---------------------------------------Potencial---定义粒子相互作用势------------------------------ pair_style** 势函数类型 pair_coeff,** 势函数文件名(一般这个文件放在与此in文件的同一个目录下)

lammps模拟实例详解

# Big colloid particles and small LJ particles units lj This command sets the style of units used for a simulation. It determines the units of all quantities specified in the input script and data file, as well as quantities output to the screen, log file, and dump files. Typically, this command is used at the very beginning of an input script.这个指令设定模拟的格式,它决定了在输入脚本文件和数据文件以及在屏幕上显示的输出物,日志文件和垃圾文件中所有的单元格式。典型的是,它经常用于输入脚本的开头 For style lj, all quantities are unitless. Without loss of generality, LAMMPS sets the fundamental quantities mass, sigma, epsilon, and the Boltzmann constant = 1. The masses, distances, energies you specify are multiples of these fundamental values. The formulas relating the reduced or unitless quantity (with an asterisk) to the same quantity with units is also given. Thus you can use the mass & sigma & epsilon values for a specific material and convert the results from a unitless LJ simulation into physical quantities. 对于lj格式,所有数量都是无量纲的。不失一般性的,lammps设定了基本量质量sigma epsilon 和波尔兹曼常数=1。你定义的质量,距离,能量是这些基本值的倍数。公式把衰减量或者是无量纲量(用*)和单元给出的相同的量关联起来。因此你可以用mass,sigma,epsilon值表示一个具体材料并且改变一个无量纲lj模拟的物理量的结果。 mass = mass or m distance = sigma, where x* = x / sigma time = tau, where tau = t* = t (epsilon / m / sigma^2)^1/2 energy = epsilon, where E* = E / epsilon velocity = sigma/tau, where v* = v tau / sigma force = epsilon/sigma, where f* = f sigma / epsilon torque = epsilon, where t* = t / epsilon temperature = reduced LJ temperature, where T* = T Kb / epsilon pressure = reduced LJ pressure, where P* = P sigma^3 / epsilon dynamic viscosity = reduced LJ viscosity, where eta* = eta sigma^3 / epsilon / tau charge = reduced LJ charge, where q* = q / (4 pi perm0 sigma epsilon)^1/2 dipole = reduced LJ dipole, moment where *mu = mu / (4 pi perm0 sigma^3 epsilon)^1/2 electric field = force/charge, where E* = E (4 pi perm0 sigma epsilon)^1/2 sigma / epsilon density = mass/volume, where rho* = rho sigma^dim atom_style atomic 原子类型atomic(原子的) Define what style of atoms to use in a simulation. This determines what attributes are associated with the atoms. This command must be used before a simulation is setup via a read_data, read_restart, or create_box command. 定义在模拟中用到的原子类型,这个决定了与原子有关的属性,这个命令必须用在模拟被设定之前通过read_data, read_restart, or create_box Atomic only the default values coarse-grain liquids, solids, metals Atomic 附加属性是只是默认值用于粗粒液体,固体和金属的模拟

完整word版lammps初学者in文件中文解析

in文件中文解析初学者——Lammps 1)初始化(Units:Units命令是用来设定模拟的原子类型。electron)si、cgs、metalUnits style(lammps现在提供的有style=LJ、real、、LJ是硬球模型Real 是真实的原子模型Metal是金属原子模型Si是硅(半导体)原子模型Cgs Electron是电子模型:Dimension命令是用来定义模拟的维度,默认情况为三维。Dimension ),3Dimension N (N=2Boundary: Boundary命令是用来设定模拟的边界条件。 Boundary x y z (x,y,z=p,s,f,m四种类型中的一种或者两种) P是周期性边界条件 S是自由边界条件(但是具有收缩性) F是固定边界条件 是具有最小值的自由边界条件(但是具有收缩性)M. :Atom-style Atom-style定义了模拟体系中的原子属性。Delete-atoms::Pair-style Pair-style定义了相互作用力场类型,即势函数。2)原子定义(1、:Read-data/read-restart restart文件中读取内容来定义原子。或read-restart为从data或Read-data 2、:Lattice lattice是用来原子类型构建模型晶格结构。Lattice style scale keyword values... 、sc、bcc、fcc、hcp、diamond、sq、Style表示点阵类型,点阵类型有nonesq2、hex、custom。 Scale表示构建的点阵类型的单位长度 Keyword表示后面可以追加0个或者多个关键字,关键字有origin、orient、spacing、a1、a2、a3、basis。 各关键字意思为:

lammps实例(5)

Project #5 熔化与凝固:氩,铜,铝 铜和铝的熔化转变: 对于铜和铝,LAMMPS建立8×8×5的FCC晶格体系;充分弛豫后利用Nose-Hover方法,保持压强为零,使体系从T=2.5K开始加热,直至发生熔化转变。 下面是铜熔化的输入文件: # LAMMPS Melt_Cu or Al units metal # 单位,指定为lammps里的金属类的单位,长度为?,能量为eV。boundary p p p # 周期性边界条件 atom_style atomic # 原子模式 variable x equal 2.5 # 定义变量 x为初始温度 lattice fcc 3.61 # Cu 的晶格常数3.61 #lattice fcc 4.05 region box block 0 8 0 8 0 5 # x,y,z各方向上的晶胞重复单元数,也即区域大小 create_box 1 box # 将上述区域指定为模拟的盒子 create_atoms 1 box # 将原子按晶格填满盒子 timestep 0.01 # 步长 0.005fs thermo 1000 #每隔1000步输出热力学结果 pair_style eam/alloy # 选取 Cu 的EAM势作为模型 pair_coeff * * jin_copper_lammps.setfl Cu # EAM 势文件名称 #pair_style eam/fs #pair_coeff * * Al_FM.eam.fs Al neighbor 0.5 bin neigh_modify every 5 delay 0 check yes #velocity all create $x 825577 dist gaussian fix 1 all nvt $x $x 1.0 drag 0.2 #保持初始温度,在NVT下弛豫 #compute 3 all pe/atom

相关主题
文本预览
相关文档 最新文档