用Python来理解分子动力学模拟中的周期性边界处理
ztj100 2024-12-01 07:01 17 浏览 0 评论
目录
- 技术背景
- 不加周期性边界的场景
- 使用uint类型实现周期性边界
- 总结概要
- 版权声明
技术背景
周期性边界是分子动力学模拟中常用的一种技术手段,不仅可以完整的概述完整的分子体系的特性,在一部分场景下还可以提升计算的效率,从作用上来看更像是一类的近似模型(假设有一个原子逃出这个周期性边界封装的盒子,一定会有另一个相同原子从相对的边界走进这个盒子)。
不加周期性边界的场景
首先我们用简单的python代码演示一个没加周期性边界条件的示例,一个红色的原子从坐标轴的0位置处移动到100的位置,但是盒子大小仅仅设置为20,这个大小也是我们的可见范围。也就是说,超过20之后我们就看不见这个原子了,具体代码实现如下所示:
import numpy as np
import time
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from IPython import display
fig = plt.figure()
ims = []
for i in range(100):
plt.xlim(0.0,20.0,5.0)
x1 = i
y1 = 5
im = plt.plot(x1, y1, 'o', color="red")
ims.append(im)
time.sleep(0.1)
ani = animation.ArtistAnimation(fig, ims, repeat_delay=0)
ani.save('mol.gif', writer='pillow')
运行完成后会在当前路径下生成一个名为mol.gif的动态图,效果如下:
使用uint类型实现周期性边界
在python中可以用numpy的数据类型来转换给定的数据,而且性能有一定的保障。如果是用c++来编码,我们知道格式转换和移位操作之类的性能非常高,相比于数据的乘加运算而言,这种操作速度要快上许多。这里我们使用无符号的整型变量来处理周期性边界问题,我们用numpy的一些具体操作来看下无符号整数变量的一些对应操作:
In [1]: import numpy as np
In [2]: np.uint(2**16) # 默认的uint是32位
Out[2]: 65536
In [3]: np.uint(2**16+1) # 默认的uint是32位
Out[3]: 65537
In [4]: np.uint16(2**16) # 指定16位,超过最大数2**16-1之后归零
Out[4]: 0
In [5]: np.uint16(2**16-1) # 指定16位,不超过最大数2**16-1结果不变
Out[5]: 65535
In [6]: np.uint16(-1) # 下限为0,超过下限后从最大数2**16-1开始计算
Out[6]: 65535
In [7]: np.uint16(-2**16) # 越过一个0之后又达到了边界的0
Out[7]: 0
In [8]: np.int16(2**15-1) # 带符号整数的最大数是2**15-1,比无符号整数位少了一个比特位
Out[8]: 32767
In [9]: np.int16(2**15) # 超过最大数是从最小数-2**15开始计数
Out[9]: -32768
In [10]: np.int16(-2**15) # 不越过最小数结果不变
Out[10]: -32768
In [11]: np.int16(-2**15-1) # 越过最小数从最大数2**15-1开始计数
Out[11]: 32767
再回过头来思考一下其中的逻辑,首先,int16的一个比特位被用来做符号存储,因此最大可表示的数字是215?1215?1,最小可表示的数字为?215?215。关于为什么负数的数量比正数多一个,这是因为16个比特位一共可以表示216216个数字,那么如果包括0在内的话,只有在区分正0和负0的情况下,正数和负数的数量才会是一样的。所以,我们可以将负0可以用来表示?215?215这个数,这样看起来就多出来了一个负数,实际上只是一种优化的策略。无符号整数和带符号的整数都是周期性的锯齿形函数,但是无符号整数取得的空间都在正数上,所以在分子动力学模拟中更倾向于取无符号整数来处理周期性边界问题。
为了更加清晰的展现无符号整数的函数图像与周期性边界条件下的原子运动轨迹,我们将两张图画在一起来看下这个结果:
import numpy as np
import time
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from IPython import display
fig = plt.figure()
ims = []
box_size = 20.0
x = []
y = []
for i in range(100):
plt.subplot(211)
x.append(i)
y.append(np.uint16(i*(2**16-1)/box_size)*box_size/(2**16-1))
plt.plot(x, y, color="black")
im = plt.plot(x[-1], y[-1], 'o', color="red")
ims.append(im)
plt.subplot(212)
plt.xlim(0.0,box_size,5.0)
x1 = np.uint16(i*(2**16-1)/box_size)*box_size/(2**16-1)
y1 = 5
im = plt.plot(x1, y1, 'o', color="red")
ims.append(im)
time.sleep(0.1)
ani = animation.ArtistAnimation(fig, ims, repeat_delay=0)
ani.save('mol.gif', writer='pillow')
运行后生成的图片如下图所示:
需要注意的是,这里做类型转换之前,要将周期性盒子的边长转化到跟无符号整数位长度一致,才能够使用无符号整数来处理周期性边界问题,所以先后有两次单位转换。但是如果我们只是需要判断是否超出了边界,那就不需要做第二次的单位转换。值得一提的是,如果采用格式转换的形式来做计算,而免去if的使用,在循环操作下也是有相当的编译优化空间的。
总结概要
本文从分子动力学模拟中的周期性边界处理角度出发,介绍了无符号整数和带符号整数的一些应用的技巧,使用这些格式转换的技术有可能在程序的性能优化中带来一定的效果。同时为了更加直观的展示分子模拟的效果,我们用animation展示了一个简单的动态图绘制的案例,其中还包含了多个子图的绘图技术。
版权声明
本文首发链接为:https://www.cnblogs.com/dechinphy/p/box.html
作者ID:DechinPhy
更多原著文章请参考:https://www.cnblogs.com/dechinphy/
打赏专用链接:https://www.cnblogs.com/dechinphy/gallery/image/379634.html
腾讯云专栏同步:https://cloud.tencent.com/developer/column/91958
- 上一篇:微调自己的SAM 2 分割模型
- 下一篇:Python每日一库之Numpy
相关推荐
- 人生苦短,我要在VSCode里面用Python
-
轻沉发自浅度寺量子位出品|公众号QbitAI在程序员圈子里,VisualStudioCode(以下简称VSCode)可以说是目前最火的代码编辑器之一了。它是微软出品的一款可扩展的轻量...
- 亲测可用:Pycharm2019.3专业版永久激活教程
-
概述随着2020年的到来,又有一批Pycharm的激活码到期了,各位同仁估计也是在到处搜索激活方案,在这里,笔者为大家收录了一个永久激活的方案,亲测可用,欢迎下载尝试:免责声明本项目只做个人学习研究之...
- Python新手入门很简单(python教程入门)
-
我之前学习python走过很多的歧途,自学永远都是瞎猫碰死耗子一样,毫无头绪。后来心里一直都有一个做头条知识分享的梦,希望自己能够帮助曾经类似自己的人,于是我来了,每天更新5篇Python文章,喜欢的...
- Pycharm的设置和基本使用(pycharm运行设置)
-
这篇文章,主要是针对刚开始学习python语言,不怎么会使用pycharm的童鞋们;我来带领大家详细了解下pycharm页面及常用的一些功能,让大家能通过此篇文章能快速的开始编写python代码。一...
- 依旧是25年最拔尖的PyTorch实用教程!堪比付费级内容!
-
我真的想知道作者到底咋把PyTorch教程整得这么牛的啊?明明在内容上已经足以成为付费教材了,但作者偏要免费开源给大家学习!...
- 手把手教你 在Pytorch框架上部署和测试关键点人脸检测项目DBFace
-
这期教向大家介绍仅仅1.3M的轻量级高精度的关键点人脸检测模型DBFace,并手把手教你如何在自己的电脑端进行部署和测试运行,运行时bug解决。01.前言前段时间DBFace人脸检测库横空出世,...
- 进入Python的世界02外篇-Pycharm配置Pyqt6
-
为什么这样配置,要开发带UI的python也只能这样了,安装过程如下:一安装工具打开终端:pipinstallPyQt6PyQt6-tools二打开设置并汉化点击plugin,安装汉化插件,...
- vs code如何配置使用Anaconda(vscode调用anaconda库)
-
上一篇文章中(Anaconda使用完全指南),我们能介绍了Anaconda的安装和使用,以及如何在pycharm中配置Anaconda。本篇,将继续介绍在vscode中配置conda...
- pycharm中conda解释器无法配置(pycharm配置anaconda解释器)
-
之前用的好好的pycharm正常配置解释器突然不能用了?可以显示有这个环境然后确认后可以conda正在配置解释器,但是进度条结束后还是不成功!!试过了pycharm重启,pycharm重装,anaco...
- Volta:跨平台开发者的福音,统一前端js工具链从未如此简单!
-
我们都知道现在已经进入了Rust时代,不仅很多终端常用的工具都被rust重写了,而且现在很多前端工具也开始被Rust接手了,这不,现在就出现了一款JS工具管理工具,有了它,你可以管理多版本的js工具,...
- 开发者的福音,ElectronEgg: 新一代桌面应用开发框架
-
今天给大家介绍一个开源项目electron-egg。如果你是一个JS的前端开发人员,以前面对这项任务桌面应用开发在时,可能会感到无从下手,甚至觉得这是一项困难的挑战。ElectronEgg的出现,它能...
- 超强经得起考验的低代码开发平台Frappe
-
#挑战30天在头条写日记#开始进行管理软件的开发来讲,如果从头做起不是不可以,但选择一款免费的且经得起时间考验的低代码开发平台是非常有必要的,将大幅提升代码的质量、加快开发的效率、以及提高程序的扩展性...
- 一文带你搞懂Vue3 底层源码(vue3核心源码解析)
-
作者:妹红大大转发链接:https://mp.weixin.qq.com/s/D_PRIMAD6i225Pn-a_lzPA前言vue3出来有一段时间了。今天正式开始记录一下梗vue3.0.0-be...
- 基于小程序 DSL(微信、支付宝)的,可扩展的多端研发框架
-
Mor(发音为/mr/,类似more),是饿了么开发的一款基于小程序DSL的,可扩展的多端研发框架,使用小程序原生DSL构建,使用者只需书写一套(微信或支付宝)小程序,就可以通过Mor...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 人生苦短,我要在VSCode里面用Python
- 亲测可用:Pycharm2019.3专业版永久激活教程
- Python新手入门很简单(python教程入门)
- Pycharm的设置和基本使用(pycharm运行设置)
- 依旧是25年最拔尖的PyTorch实用教程!堪比付费级内容!
- 手把手教你 在Pytorch框架上部署和测试关键点人脸检测项目DBFace
- 进入Python的世界02外篇-Pycharm配置Pyqt6
- vs code如何配置使用Anaconda(vscode调用anaconda库)
- pycharm中conda解释器无法配置(pycharm配置anaconda解释器)
- Volta:跨平台开发者的福音,统一前端js工具链从未如此简单!
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)