百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

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

zhezhongyun 2024-12-03 06:33 83 浏览

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 定义了相互作用力场类型,即势函数。

  1. 原子定义

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

  1. 设定: 力场系数

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 为定义对部分原子或者对系综的操作。

http://lammps.sandia.gov/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

文件中的内容。(http://lammps.sandia.gov/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、

Vol、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:

  1. 运行

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

最后,有相关需求欢迎通过微信公众号联系我们。

相关推荐

Python入门学习记录之一:变量_python怎么用变量

写这个,主要是对自己学习python知识的一个总结,也是加深自己的印象。变量(英文:variable),也叫标识符。在python中,变量的命名规则有以下三点:>变量名只能包含字母、数字和下划线...

python变量命名规则——来自小白的总结

python是一个动态编译类编程语言,所以程序在运行前不需要如C语言的先行编译动作,因此也只有在程序运行过程中才能发现程序的问题。基于此,python的变量就有一定的命名规范。python作为当前热门...

Python入门学习教程:第 2 章 变量与数据类型

2.1什么是变量?在编程中,变量就像一个存放数据的容器,它可以存储各种信息,并且这些信息可以被读取和修改。想象一下,变量就如同我们生活中的盒子,你可以把东西放进去,也可以随时拿出来看看,甚至可以换成...

绘制学术论文中的“三线表”具体指导

在科研过程中,大家用到最多的可能就是“三线表”。“三线表”,一般主要由三条横线构成,当然在变量名栏里也可以拆分单元格,出现更多的线。更重要的是,“三线表”也是一种数据记录规范,以“三线表”形式记录的数...

Python基础语法知识--变量和数据类型

学习Python中的变量和数据类型至关重要,因为它们构成了Python编程的基石。以下是帮助您了解Python中的变量和数据类型的分步指南:1.变量:变量在Python中用于存储数据值。它们充...

一文搞懂 Python 中的所有标点符号

反引号`无任何作用。传说Python3中它被移除是因为和单引号字符'太相似。波浪号~(按位取反符号)~被称为取反或补码运算符。它放在我们想要取反的对象前面。如果放在一个整数n...

Python变量类型和运算符_python中变量的含义

别再被小名词坑哭了:Python新手常犯的那些隐蔽错误,我用同事的真实bug拆给你看我记得有一次和同事张姐一起追查一个看似随机崩溃的脚本,最后发现罪魁祸首竟然是她把变量命名成了list。说实话...

从零开始:深入剖析 Spring Boot3 中配置文件的加载顺序

在当今的互联网软件开发领域,SpringBoot无疑是最为热门和广泛应用的框架之一。它以其强大的功能、便捷的开发体验,极大地提升了开发效率,成为众多开发者构建Web应用程序的首选。而在Spr...

Python中下划线 ‘_’ 的用法,你知道几种

Python中下划线()是一个有特殊含义和用途的符号,它可以用来表示以下几种情况:1在解释器中,下划线(_)表示上一个表达式的值,可以用来进行快速计算或测试。例如:>>>2+...

解锁Shell编程:变量_shell $变量

引言:开启Shell编程大门Shell作为用户与Linux内核之间的桥梁,为我们提供了强大的命令行交互方式。它不仅能执行简单的文件操作、进程管理,还能通过编写脚本实现复杂的自动化任务。无论是...

一文学会Python的变量命名规则!_python的变量命名有哪些要求

目录1.变量的命名原则3.内置函数尽量不要做变量4.删除变量和垃圾回收机制5.结语1.变量的命名原则①由英文字母、_(下划线)、或中文开头②变量名称只能由英文字母、数字、下画线或中文字所组成。③英文字...

更可靠的Rust-语法篇-区分语句/表达式,略览if/loop/while/for

src/main.rs://函数定义fnadd(a:i32,b:i32)->i32{a+b//末尾表达式}fnmain(){leta:i3...

C++第五课:变量的命名规则_c++中变量的命名规则

变量的命名不是想怎么起就怎么起的,而是有一套固定的规则的。具体规则:1.名字要合法:变量名必须是由字母、数字或下划线组成。例如:a,a1,a_1。2.开头不能是数字。例如:可以a1,但不能起1a。3....

Rust编程-核心篇-不安全编程_rust安全性

Unsafe的必要性Rust的所有权系统和类型系统为我们提供了强大的安全保障,但在某些情况下,我们需要突破这些限制来:与C代码交互实现底层系统编程优化性能关键代码实现某些编译器无法验证的安全操作Rus...

探秘 Python 内存管理:背后的神奇机制

在编程的世界里,内存管理就如同幕后的精密操控者,确保程序的高效运行。Python作为一种广泛使用的编程语言,其内存管理机制既巧妙又复杂,为开发者们提供了便利的同时,也展现了强大的底层控制能力。一、P...