从刘维尔方程到Velocity-Verlet算法
haoteby 2024-11-08 12:34 37 浏览
注:头条排版问题,公式有点混乱,建议阅读原始cnblogs中的文章。
目录
- 技术背景
- Verlet算法
- Leap-Frog算法
- 刘维尔方程与Velocity VerletTrotter-Suzuki分解Velocity Verlet算法
- 总结概要
- 版权声明
技术背景
我们说分子动力学模拟是一个牛顿力学的过程,在使用量子化学的手段或者深度学习的方法或者传统的力场方法,去得到某个时刻某个位置的受力之后,就可以获取下一步的整个系统的状态信息。这个演化的过程所使用的算法,也在历史上演化了多次,从1967年的Verlet算法,到后来的Leap-Frog算法,再到Velocity-Verlet算法。我们可以先看一看这三种算法的形式,再从刘维尔方程出发,看看Velocity-Verlet算法的由来。
Verlet算法
我们把r(t+δt)r(t+δt)和r(t?δt)r(t?δt)看做是两个函数,分别对r(t+δt)r(t+δt)和r(t?δt)r(t?δt)在时刻tt处进行二阶泰勒展开有:
r(t+δt)=r(t)+v(t)δt+F(t)2mδt2r(t?δt)=r(t)?v(t)δt+F(t)2mδt2r(t+δt)=r(t)+v(t)δt+F(t)2mδt2r(t?δt)=r(t)?v(t)δt+F(t)2mδt2
将上面第二个公式中的v(t)δtv(t)δt项移到左侧,把r(t?δt)r(t?δt)移到右侧,再代入到第一个公式中,就可以得到下一步的坐标:
r(t+δt)=2r(t)?r(t?δt)+F(t)mδt2+O(δt4)r(t+δt)=2r(t)?r(t?δt)+F(t)mδt2+O(δt4)
然后再把1、2两个公式相减,就可以得到当前时刻的速度:
v(t)=r(t+δt)?r(t?δt)2δt+O(δt2)v(t)=r(t+δt)?r(t?δt)2δt+O(δt2)
到这里就得到了Verlet算法的更新步骤,过程也非常的简单。但是有个比较致命的问题是,Verlet算法的更新中,不仅仅需要到上一步的坐标位置,还需要用到上上一步的坐标位置,这就有可能导致两个问题:
- 第一步的更新,没有上上一步的信息;
- 在算法执行的过程中,每次迭代不仅仅要存储上一步的坐标位置,还需要额外存储上上一步的位置,更新较为麻烦,也会占据额外的空间。
目前这种传统的Verlet算法应用已经较少,主要还是使用接下来要讲到的Leap-Frog算法和Velocity-Verlet算法。
Leap-Frog算法
在蛙跳法中,引入了另外一个概念:用两点之间的中间时刻的速度近似为两个点之间的平均速度,这样就可以得到一个坐标更新公式:
r(t+δt)=r(t)+v(t+δ2)δtr(t+δt)=r(t)+v(t+δ2)δt
其中半步的速度是基于上一个半步的速度来更新的:
v(t+δt2)=v(t?δt2)+F(t)δtm=v(t?δt2)??V?r(t)?δtmv(t+δt2)=v(t?δt2)+F(t)δtm=v(t?δt2)??V?r(t)?δtm
在上面的方程中已经用势能对坐标的偏导来替代力的计算,这也跟哈密顿力学中只有势能项显含坐标有关。虽然到这里我们已经完成了坐标和速度的更新,但是速度和坐标之间是不同步的,为此我们还需要用两个半步速度取平均来计算一个时间同步的速度:
v(t+δt)=v(t+δt2)?v(t?δt2)2v(t+δt)=v(t+δt2)?v(t?δt2)2
由于这里只涉及到前半步的速度,而不涉及到前一步的坐标,因此Leap-Frog算法在实际应用场景中有着较为广泛的使用。
刘维尔方程与Velocity Verlet
首先我们看一下刘维尔方程的形式:
dρ(p,q,t)dt=?ρ?t+L^ρ=0dρ(p,q,t)dt=?ρ?t+L^ρ=0
其中刘维尔算子L^L^的形式为:
L^=L1^+L2^=∑i=13N(?H?pi??qi??H?qi??pi)L^=L1^+L2^=∑i=13N(?H?pi??qi??H?qi??pi)
其中写成L1^L1^和L2^L2^的形式也是为了方便后面做Trotter分解:
L1^=∑i=13N?H?pi??qiL2^=?∑i=13N?H?qi??piL1^=∑i=13N?H?pi??qiL2^=?∑i=13N?H?qi??pi
写完刘维尔方程的表述之后,我们再回过头看看刘维尔方程的物理含义,这里的密度函数ρ(p,q,t)ρ(p,q,t)是指在相空间中粒子的分布密度,对于整体的积分有:
N=∫ρ(p,q,t)dqdpN=∫ρ(p,q,t)dqdp
这里的NN所表示的就是整个系统的总粒子数。因此,实际上刘维尔方程所表述的内容就是:分布函数沿着相空间的任何轨迹是常数。
Trotter-Suzuki分解
我们首先需要回顾一个知识点,虽然对于两个常数a,ba,b来说,其加和的指数可以等于指数的乘积,即ea+b=eaebea+b=eaeb,但如果是对于两个矩阵A,BA,B的话,类似的等式往往是不成立的。而Trotter-Suzuki公式,将其表示为一个显式的误差:
e∑mj=1Hjt=∏j=1meHjt+O(m2t2)e∑j=1mHjt=∏j=1meHjt+O(m2t2)
此时我们再回顾刘维尔算子的分解:L^=L1^+L2^L^=L1^+L2^,再进一步将其分解为:L^=L2^2+L1^+L2^2L^=L2^2+L1^+L2^2,至于为什么用这个形式来分解,我也不懂,也许是尝试出来的。基于这个形式的分解,我们将其代入到刘维尔算子的演化中。定义一个广义参量x(t)={p(t),q(t)}x(t)={p(t),q(t)},则刘维尔算子对该参量的演化为:
eL^tx(0)=e(L2^2+L1^+L2^2)tx(0)≈eL2^t/2eL1^teL2^t/2x(0)≈eL2^t/2eL1^t(1+L2^δt2)x(0)=eL2^t/2eL1^t(x(0)?δt2∑i=13N?H?qi?x(0)?pi)=eL2^t/2eL1^tx(1)(1)(2)(3)(4)(5)(1)eL^tx(0)=e(L2^2+L1^+L2^2)tx(0)(2)≈eL2^t/2eL1^teL2^t/2x(0)(3)≈eL2^t/2eL1^t(1+L2^δt2)x(0)(4)=eL2^t/2eL1^t(x(0)?δt2∑i=13N?H?qi?x(0)?pi)(5)=eL2^t/2eL1^tx(1)
观察上述推导过程的倒数第二步,因为x(t)={p(t),q(t)}x(t)={p(t),q(t)},并且在相空间中所有的pipi是正交的关系,因此?x(0)?pi?x(0)?pi得到的结果全为1。又因为在哈密顿力学中有??H?q=dpdt,?H?p=dqdt??H?q=dpdt,?H?p=dqdt。因此,假定x(0)={pi(t0),qi(t0)},i=1,2,...,3Nx(0)={pi(t0),qi(t0)},i=1,2,...,3N,则x(1)={pi(t0)+dp(t0)dtδt2,qi(t0)},i=1,2,...,3Nx(1)={pi(t0)+dp(t0)dtδt2,qi(t0)},i=1,2,...,3N。使用类似的方法,我们继续往下推导:
eL^tx(0)≈eL2^t/2eL1^tx(1)=eL2^t/2(x(1)+δt∑i=13N?H?pi?x(1)?qi)=eL2^t/2x(2)(6)(7)(8)(6)eL^tx(0)≈eL2^t/2eL1^tx(1)(7)=eL2^t/2(x(1)+δt∑i=13N?H?pi?x(1)?qi)(8)=eL2^t/2x(2)
其中x(2)={pi(t0)+dp(t0)dtδt2,qi(t0)+dq(t0)dtδt},i=1,2,...,3Nx(2)={pi(t0)+dp(t0)dtδt2,qi(t0)+dq(t0)dtδt},i=1,2,...,3N,同样的方法,再完成最后一步的分解:
eL^tx(0)≈eL2^t/2x(2)=x(2)?δt2∑i=13N?H?qi?x(2)?pi=x(3)(9)(10)(11)(9)eL^tx(0)≈eL2^t/2x(2)(10)=x(2)?δt2∑i=13N?H?qi?x(2)?pi(11)=x(3)
需要注意的是,虽然在前面x(0)→x(1)x(0)→x(1)的演化中共轭动量项在L2^L2^的作用下发生了变化,但是显含的动量项保持不变,因此这里的偏导项得到的结果依然是1,那么就有x(3)={pi(t0)+dp(t0)dtδt,qi(t0)+dq(t0)dtδt},i=1,2,...,3Nx(3)={pi(t0)+dp(t0)dtδt,qi(t0)+dq(t0)dtδt},i=1,2,...,3N。到这一步,问题逐渐露出端倪,我们发现在刘维尔算子的作用下,经过Trotter-Suzuki分解和Taylor展开的操作,正则坐标qq和共轭动量pp已经完成了一个时间单位deltatdeltat的演化,正对应到分子动力学模拟中的单步演化。
Velocity Verlet算法
参考上一个章节中刘维尔算子的演化过程x(0)→x(1)x(0)→x(1),我们可以先将速度进行半步演化:
v(t+δt2)=v(t)+F(t)mδt2+O(δt3)v(t+δt2)=v(t)+F(t)mδt2+O(δt3)
参考x(1)→x(2)x(1)→x(2)过程,我们可以将坐标进行单步演化:
r(t+δt)=r(t)+v(t+δt2)δt+O(δt4)r(t+δt)=r(t)+v(t+δt2)δt+O(δt4)
最后参考x(2)→x(3)x(2)→x(3)的过程,将半步演化的速度再同步到单步演化:
v(t+δt)=v(t+δt2)+F(t+δt)mδt2+O(δt2)v(t+δt)=v(t+δt2)+F(t+δt)mδt2+O(δt2)
这个过程最漂亮的地方在于,演化的参数不依赖于上一步或者上半步的任何参数,只需要具备了v(t),r(t)v(t),r(t)即可演化得到v(t+δt),r(r+δt)v(t+δt),r(r+δt),当然,这里面需要用量子化学或者深度学习或者是力场参数的形式,去分别计算得tt和t+δtt+δt时刻的作用力。
总结概要
本文延续历史上分子动力学模拟演化算法的发展顺序,分别讲述了Verlet、LeapFrog和Velocity-Verlet三个算法的形式,并且结合刘维尔方程,推导了Velocity-Verlet算法中的三个演化步骤的内在含义。三种不同的演化算法,都有不同的初始依赖,而对于计算过程而言,越多的初始依赖,就会涉及到越多的参数存储问题。一个好的演化算法,只需要依赖于少量的参数,而具备较高的精度。
版权声明
本文首发链接为:https://www.cnblogs.com/dechinphy/p/liouville.html
作者ID:DechinPhy
更多原著文章请参考:https://www.cnblogs.com/dechinphy/
打赏专用链接:https://www.cnblogs.com/dechinphy/gallery/image/379634.html
腾讯云专栏同步:https://cloud.tencent.com/developer/column/91958
相关推荐
- 一日一技:用Python程序将十进制转换为二进制
-
用Python程序将十进制转换为二进制通过将数字连续除以2并以相反顺序打印其余部分,将十进制数转换为二进制。在下面的程序中,我们将学习使用递归函数将十进制数转换为二进制数,代码如下:...
- 十进制转化成二进制你会吗?#数学思维
-
六年级奥赛起跑线:抽屉原理揭秘。同学们好,我是你们的奥耀老师。今天一起来学习奥赛起跑线第三讲二进制计数法。例一:把十进制五十三化成二进制数是多少?首先十进制就是满十进一,二进制就是满二进一。二进制每个...
- 二进制、十进制、八进制和十六进制,它们之间是如何转换的?
-
在学习进制时总会遇到多种进制转换的时候,学会它们之间的转换方法也是必须的,这里分享一下几种进制之间转换的方法,也分享两个好用的转换工具,使用它们能够大幅度的提升你的办公和学习效率,感兴趣的小伙伴记得点...
- c语言-2进制转10进制_c语言 二进制转十进制
-
#include<stdio.h>intmain(){charch;inta=0;...
- 二进制、八进制、十进制和十六进制数制转换
-
一、数制1、什么是数制数制是计数进位的简称。也就是由低位向高位进位计数的方法。2、常用数制计算机中常用的数制有二进制、八进制、十进制和十六进制。...
- 二进制、十进制、八进制、十六进制间的相互转换函数
-
二进制、十进制、八进制、十六进制间的相互转换函数1、输入任意一个十进制的整数,将其分别转换为二进制、八进制、十六进制。2、程序代码如下:#include<iostream>usingna...
- 二进制、八进制、十进制和十六进制等常用数制及其相互转换
-
从大学开始系统的接触计算机专业,到现在已经过去十几年了,今天整理一下基础的进制转换,希望给还在上高中的表妹一个入门的引导,早日熟悉这个行业。一、二进制、八进制、十进制和十六进制是如何定义的?二进制是B...
- 二进制如何转换成十进制?_二进制如何转换成十进制例子图解
-
随着社会的发展,电器维修由继电器时代逐渐被PLC,变频器,触摸屏等工控时代所替代,特别是plc编程,其数据逻辑往往涉及到数制二进制,那么二进制到底是什么呢?它和十进制又有什么区别和联系呢?下面和朋友们...
- 二进制与十进制的相互转换_二进制和十进制之间转换
-
很多同学在刚开始接触计算机语言的时候,都会了解计算机的世界里面大多都是二进制来表达现实世界的任何事物的。当然现实世界的事务有很多很多,就拿最简单的数字,我们经常看到的数字大多都是十进制的形式,例如:我...
- 十进制如何转换为二进制,二进制如何转换为十进制
-
用十进制除以2,除的断的,商用0表示;除不断的,商用1表示余0时结束假如十进制用X表示,用十进制除以2,即x/2除以2后为整数的(除的断的),商用0表示;除以2除不断的,商用1表示除完后的商0或1...
- 十进制数如何转换为二进制数_十进制数如何转换为二进制数举例说明
-
我们经常听到十进制数和二进制数,电脑中也经常使用二进制数来进行计算,但是很多人却不清楚十进制数和二进制数是怎样进行转换的,下面就来看看,十进制数转换为二进制数的方法。正整数转二进制...
- 二进制转化为十进制,你会做吗?一起来试试吧
-
今天孩子问把二进制表示的110101改写成十进制数怎么做呀?,“二进制”简单来说就是“满二进一”,只用0和1共两个数字表示,同理我们平常接触到的“十进制”是“满十进一”,只用0-9共十个数字表示。如果...
- Mac终于能正常打游戏了!苹果正逐渐淘汰Rosetta转译
-
Mac玩家苦转译久矣!WWDC2025苹果正式宣判Rosetta死刑,原生游戏时代终于杀到。Metal4光追和AI插帧技术直接掀桌,连Steam都连夜扛着ARM架构投诚了。看到《赛博朋克2077》...
- 怎么把视频的声音提出来转为音频?音频提取,11款工具实测搞定
-
想把视频里的声音单独保存为音频文件(MP3/AAC/WAV/FLAC)用于配音、播客、听课或二次剪辑?本文挑出10款常用工具,给出实测可复现的操作步骤、优缺点和场景推荐。1)转换猫mp3转换器(操作门...
- 6个mp4格式转换器测评:转换速度与质量并存!
-
MP4视频格式具有兼容性强、视频画质高清、文件体积较小、支持多种编码等特点,适用于网络媒体传播。如果大家想要将非MP4格式的视频转换成MP4的视频格式的话,可以使用MP4格式转换器更换格式。本文分别从...