摘抄:用高斯做势能面扫描(二):柔性扫描
柔性扫描简介
势能面扫描可以用来研究势能随少数几个坐标变化的情况,分为刚性扫描和柔性扫描两种。刚性扫描是指被扫描的坐标变化后,不改变未被扫描的坐标,相当于做一系列单点能计算。对于刚性扫描,本公众号之前已经有过介绍,见《用高斯做势能面扫描(一):刚性扫描》。
柔性扫描是指被扫描的坐标变化后,固定被扫描的坐标优化分子结构,相当于做一系列限制性优化。刚性扫描所需的计算资源更少,但是由于刚性扫描只考虑了一个自由度,其计算结果对势能面的描述不如柔性扫描更真实。
做柔性扫描时高斯输入文件的书写
柔性扫描可以使用任意坐标描述分子结构(内坐标或笛卡尔坐标),由于要做一系列限制性优化,routine section 中要写入 opt=modredundant
,一般还要写入 nosymm
,最后在输入文件末尾写入被扫描的坐标及其步数和步长。
柔性扫描时文件末尾内坐标的描述方式为:
[Type] N1 N2 [N3 [N4]] S steps step-size
中括号代表可选项。Type 代表内坐标的类型,写入 B 代表键长,A 代表键角,D 代表二面角。NX 代表第 X 个原子在这个分子结构中的序号,当只有 N1 和 N2 存在时代表扫描 N1-N2 间的键长,N3 存在时代表扫描 N1-N2-N3 间的键角,N3 和 N4 都存在时代表扫描 N1-N2-N3-N4 间的二面角。[Type] 为可选项,因为内坐标的类型可以通过给出原子的个数确定。S 为保留字,表明这是个柔性扫描作业。steps 代表步数,step-size 代表步长(需写浮点数),这两项与描述刚性扫描时的输入项相同。被扫描变量的初始值即为当前输入文件中该变量的值,因此需要注意将初始结构调整为想要的结构。
例如,给出一个柔性扫描作业的输入文件,文件尾写着:
2 3 S 3 0.05
代表扫描原子 2 和原子 3 间的键长,扫描 3 步(加上起点一共得到 4 个结构),每步键长增加 0.02 埃。
笛卡尔坐标同样也可以用于柔性扫描,不过此时扫描的不再是内坐标,而是笛卡尔坐标。当用笛卡尔坐标描述柔性扫描时,输入文件结尾应写入:
X atom S x-steps x-size y-steps y-size z-steps z-size
其中 X 为保留字代表笛卡尔坐标,atom 代表原子在分子中的号,x-steps 和 x-size 代表原子在 x 方向上的步数和步长,y 方向和 z 方向上同理。
例如,给出一个笛卡尔坐标柔性扫描的作业,文件尾写着
X 1 S 5 0.2 0 0.0 3 0.1
这代表相对起始结构,原子 1 在 x 方向移动 5 步,每步 0.2 埃,在 z 方向上移动 3 步,每步 0.1 埃。
注意,柔性扫描时,扫描内坐标并不要求分子结构用内坐标表示,扫描笛卡尔坐标不要求分子结构用笛卡尔坐标表示。与刚性扫描要求分子结构用内坐标描述不同,柔性扫描对分子结构的描述方式没有要求。
下面用两个实例说明柔性扫描的输入文件的书写和计算结果的分析。第一个例子为一维势能面柔性扫描,第二个例子为二维势能面柔性扫描。
一维势能面柔性扫描
为了与刚性扫描一文对比,本文同样用丁烷分子绕 C-C 键旋转过程为例。丁烷分子的结构如下所示,由丁烷分子的三维结构可知,被扫描的内坐标应该选取 1-5-8-11 二面角。
丁烷分子的三维结构
其输入文件如下:
1 | %nproc=48 |
关键词 opt=modredundant
表明每一步都需要做限制性优化,写入 nosymm
一方面是为了方便观察轨迹,另一方面防止扫描过程中对称性改变带来的问题。D 1 5 8 11 S 36 10.00 表明扫描原子 1-5-8-11 构成的二面角,扫描步长为 36 步,每一步二面角增大 10 度。因为步长是 36,再加上初始结构,我们最后一共会得到 37 个结构。
得到的扫描轨迹如下:
柔性扫描轨迹
计算结束后,输出文件中有每一步能量和结构的记录:
1 | Summary of Optimized Potential Surface Scan (add -158.0 to energies): |
用 GaussView 打开输出文件,点击 Results->Scan 可以得到 GaussView 绘制的势能曲线,如下图所示:
柔性扫描势能曲线
一般在论文中不使用 GaussView 作的图,而是自行使用 Origin 等程序作图。柔性扫描不像刚性扫描一样在文件末尾以两列的形式给出扫描变量和能量,若要取出能量,可以借助 GaussView,在上述图势能曲线处右击,选择 Save Data,即可将扫描变量与能量写入 txt 文件中。
柔性扫描势能曲线与刚性扫描得到的势能曲线形状相同,但是由于进行过限制性优化总体能量更低,而且几个势能面上的极大值相对能量也有差别。将势能曲线中的最高点作为初猜做过渡态搜索,依然可以搜索到相应过渡态。读者可以自行将柔性扫描与刚性扫描的结果做比较。
二维势能面柔性扫描
Gaussian 除了支持一维势能面扫描外,还支持多维的势能面扫描,这里以二维势能面扫描为例。二维势能面扫描的输入文件与一维势能面扫描的唯一不同就是文件尾有两行描述被扫描的两个内坐标。
[Type] N1 N2 [N3 [N4]] S steps step-size
[Type] N1 N2 [N3 [N4]] S steps step-size
这里我们称第一行描述的坐标为 1st coordinate,第二行描述的坐标为 2nd coordinate。
做一维势能面扫描时,程序只需要沿着势能面上的一个方向移动就可以了,做二维势能面扫描时就会出现移动方向的选择问题。Gaussian 做二维势能面扫描时移动方向如下图所示:
二维势能面扫描示意图
从起点 O 开始,首先固定 1st coordinate 不变,依次改变 2nd coordinate 直至最大步长。在 2nd coordinate 的最大步长处,固定 2nd coordinate,让 1st coordinate 移动一步。继续固定 1st coordinate 不变,依次改变 2nd coordinate 直至最小步长。在 2nd coordinate 的最小步长处,固定 2nd coordinate,让 1st coordinate 移动一步。以此类推。因此二维势能面扫描产生的结构的总数为 (steps_1+1)*(steps_2+1),更多维势能面扫描产生的结构总数同理。在做多维势能面扫描时,变量之间最好不要有关联,否则会使扫描结果混乱或出错。
本文二维势能面柔性扫描所研究的体系为 SN2 反应,反应式如下。
Cl−+CH3Cl → ClCH3+Cl−
定义的两个内坐标分别为下图中两个 C-Cl 键的键长。扫描的起点时两个键长均为 2.0 埃,两个坐标的步数均为 7,步长均为 0.1 埃。
输入文件如下:
1 | %chk=sn2-scan.chk |
计算结束后,在输出文件中同样有每一步的能量和结构信息:
1 | Summary of Optimized Potential Surface Scan (add-960.0 to energies): |
用和上文打开一维势能面扫描输出文件时一样的操作,打开二维势能面扫描的输出文件时,GaussView 会输出三维的势能图,如下所示。可以看到有鞍点存在。
二维势能面