neighbor和neigh_modify(转载)
(转载:http://blog.sina.com.cn/s/blog_b48a7ac30102w4mg.html###)
以下取自:http://simulation.haotui.com/viewthread.php?tid=11368&jdfwkey=cnypw3
收集1:neighbor选取的大小对实际的计算结果影响很小,但对计算速度应该会有一定影响。
neighbor  2 bin 意思是每个原子在所取对势(即pair style)的截断半径以外,计算机还会在2 bin的额外范围每一时间步检测其原子间的相互作用力。而bin是与N/P线性变化(N原子总数,P是cup数)。总之,这个设定的大小并不是十分重要。
收集2:由于neighbor-list的计算比较耗时,多数MD代码都是在一次build之后的接下来若干步之内都使用这个neighbor-list,而不是每一步都更新。因此,在build是选取的实际截断半径是r_cut+skin,只要在若干步之内原子位移小于skin/2就是安全的(lammps可以检查这个,Dangerous builds就是指在某次build时发现此时刻原子相对上一次build时的位移超过了skin/2)。build的频率需要和skin大小结合起来使用,这样达到最佳的运行速度(不同系统需要自己试,但很显然的道理是较小的skin需要较高的更新频率)。 理论上,skin的大小对最终的结果是没有影响的,但对计算速度有。
neighbor  10 .0 bin 没必要取这么大,这样neighbors太多,内存占用增大和速度下降。甚至超出lammps预定的极限就会溢出。unit real情况下,skin一般2-3,配合使用 neigh_modify delay  5就可以了。 如果使用neigh_modify delay  3 还有很高比例的Dangerous builds,应该是你的积分步长太大,应适当减小积分步长。
以下取自:http://www.360doc.com/content/12/0106/01/8275160_177586409.shtml
收集3:用来设定计算邻位列表的频率。
Delay: never build a new list until at least N steps after the previous build 在建立一次邻位列表后,至少要经过N steps才能建立下一次的邻位列表。
Every:在delay经过之后,每经过M步建立一次邻位列表。个人感觉lammps中这点写的有点混乱。个人理解:每建立一次列表后,经过N+M才能建立下一次列表。如果N不为零,必须为M的倍数,否则没有什么意义了。这里为什么非要这种设置呢,如果设置频率的话只需要一个参数就够了啊?http://simulation.5d6d.scom/viewthread.php?tid=8245&page=1#pid52602
Check:如果值为no,则只需要满足以上两者的设定后就可以重新建立邻位列表了。如果值为yes,则只有当某个原子的位移大于皮肤半径的一半才重新建立列表。
Exclude:用来取消某些原子之间的相互作用。对于以下几种情况很重要:裂纹模拟;冰冻处理;原子被设定为刚体时;这中处理方式可以节约计算时间。这个只影响原子间非键结的相互作用。
Page and one:关于邻位列表的存储问题。
恩,仔细看了下你写的分析过程,结合原始程序,基本上明白了这两个参数的作用。其实,建立邻位列表的频率是由delay every check三个参数共同确定的。
  if (ago >= delay && ago % every == 0)//这是最基本的条件
{
    if (dist_check == 0) return 1;//当dist_check==0的时候,邻位列表定期更新
    else return check_distance();//当dist_check!=0的时候,就是标签更新,只有当列表中某个原子的位移大于skin的一半的时候才建立
  }
else return 0;
    其实首先要明白,更新列表有两种方式,一种是定期更新,另外一种是标签更新。
    因此,如果delay为零,则不管dist_check如何取值,只要当时间步是every的倍数就可以更新列表
    如果delay不为零,every==1,并且dist_check==0,则更新列表的频率与every没有什么关系,只要距离上次更新列表的时间步达到delay就更新。
    而如果delay不为零,every不为1时,手册中有要求,“如果delay不为零,他的值必须是every的倍数”。因此,如果 dist_check==0,则时间步达到delay+every,则列表就开始更新。而如果dist_check不为零,则只有当时间步为 delay+N*every(N=0,1,2……)的时候,邻位列表才更新。
结论:由于neighbor-list的计算比较耗时,多数MD代码都是在一次build之后的接下来若干步之内都使用这个neighbor-list,而不是每一步都更新。因此,在build是选取的实际截断半径是r_cut+skin,只要在若干步之内原子位移小于skin/2就是安全的(lammps可以检查这个,Dangerous builds就是指在某次build时发现此时刻原子相对上一次build时的位移超过了skin/2)。build的频率需要和skin大小结合起来使用,这样达到最佳的运行速度(不同系统需要自己试,但很显然的道理是较小的skin需要较高的更新频率)。 理论上,skin的大小对最终的结果是没有影响的,但对计算速度有。
neighbor取系统默认值即可。neigh_modify取 delay 0 every 5 check yes
neighbor和neigh_modify(转载)的更多相关文章
- in文件注意事项及详细解释(转载)
		
转载自:https://www.cnblogs.com/sysu/p/10817315.html 和 https://www.cnblogs.com/panscience/p/4953940.h ...
 - 开始进行lammps手册的学习啦,跟着Manual一边翻译一边做吧!(转载)
		
转载自:http://blog.sina.com.cn/s/blog_64813e370100ngsz.html 注明:黄色部分基本上为不懂的部分,红色字体为所做注释 一.各种文件的介绍: 1 in ...
 - Clayff力场(转载)
		
本文转载自:http://blog.sina.com.cn/s/blog_b48a7ac30102w4km.html 注意:lammps中并没有完整的clayff势函数,需要将一下三者结合使用. an ...
 - 转载: scikit-learn学习之K最近邻算法(KNN)
		
版权声明:<—— 本文为作者呕心沥血打造,若要转载,请注明出处@http://blog.csdn.net/gamer_gyt <—— 目录(?)[+] ================== ...
 - [转载]opencv MSER
		
最大稳定极值区域(MSER-Maximally Stable Extremal Regions)可以用于图像的斑点区域检测.该算法最早是由Matas等人于2002年提出,它是基于分水岭的概念. MSE ...
 - 【转载】K-NN算法 学习总结
		
声明:作者:会心一击 出处:http://www.cnblogs.com/lijingchn/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接, ...
 - 【cs231n】图像分类 k-Nearest Neighbor Classifier(K最近邻分类器)【python3实现】
		
[学习自CS231n课程] 转载请注明出处:http://www.cnblogs.com/GraceSkyer/p/8763616.html k-Nearest Neighbor(KNN)分类器 与其 ...
 - 【cs231n】图像分类-Nearest Neighbor Classifier(最近邻分类器)【python3实现】
		
[学习自CS231n课程] 转载请注明出处:http://www.cnblogs.com/GraceSkyer/p/8735908.html 图像分类: 一张图像的表示:长度.宽度.通道(3个颜色通道 ...
 - k-Nearest Neighbor algorithm 思想
		
转载 KNN--K最邻近算法思想 KNN算法的决策过程 k-Nearest Neighbor algorithm 上图中,绿色圆要被决定赋予哪个类,是红色三角形还是蓝色四方形?如果K=3, ...
 
随机推荐
- 人工智能?.netcore一样胜任!
			
提起AI,大家都会先想到Python,确实Python作为一门好几十年的老语言,上一波的AI大流行使它焕发了青春.大家用Phtyon来做AI,最主要的原因无非就是编码量更少,很多数学和AI相关的Api ...
 - 环境篇:DolphinScheduler-1.3.1安装部署及使用技巧
			
环境篇:DolphinScheduler-1.3.1安装部署 1 配置jdk JDK百度网盘:https://pan.baidu.com/s/1og3mfefJrwl1QGZGZDZ8Sw 提取码:t ...
 - pass 出错问题
			
''' a = 10 b = 8 print("a>b") if a>b else pass pass 为何报错问题: 第一部分:print 第二部分:("a ...
 - Python os.fstatvfs() 方法
			
概述 os.fstatvfs() 方法用于返回包含文件描述符fd的文件的文件系统的信息,类似 statvfs().高佣联盟 www.cgewang.com Unix上可用. fstatvfs 方法返回 ...
 - Android中Activity启动模式探索
			
Android中启动模式(launchMode)分为standard, singleTop, singleTask, singleInstance四种,可通过AndroidManifest.xml文件 ...
 - php+mysql+apache实现登录注册系统
			
Php+mysql写网页注册登录系统 1.搭建msyql+php+apache的网站环境 (1) 在云服务器上搭建服务器,推荐使用宝塔集成 (2) 在本地windows搭建,推荐自己采用分开安装,这样 ...
 - stm32f407 oled iic例程,成功点亮oled屏
			
写了好久好久,写好多好多代码,终于把oled给驱起来了.话不多说,直接上图,欲要例程的,可以加我微 lichenpoo
 - C#LeetCode刷题之#231-2的幂(Power of Two)
			
问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3858 访问. 给定一个整数,编写一个函数来判断它是否是 2 的幂 ...
 - HTML5+css3 的开心网游戏页面
			
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
 - SpringMVC大威天龙
			
一 SpringMVC简介 SpringMVC是Spring提供的一个强大而灵活的Web框架 借助于注解 SpringMVC提供了几乎是POJO的开发模式 使得控制器的开发和测试更加简单 二 Spri ...