banner
𝖀𝖓𝖘𝖊𝖕𝖙𝖚𝖓𝖎𝖚𝖒

计算xyz动画每一帧的molden

Scroll down

计算xyz动画每一帧的molden

xyz动画由opt,IRC,scan,MD等任务生成,计算每一帧的单点可以研究(反应)过程中电子结构的变化
参考通过键级曲线和ELF/LOL/RDG等值面动画研究化学反应过程


图为CO+H2CO反应IRC的IRI动画,使用ffmpeg将VMD输出的.bmp转为mp4/gif

可以从github获取本文的.sh

其实已经有人写过类似的程序了(

对于IRC,可以将Gaussian与ORCA联用输出每一步的gbw

trj2inp: 生成xyz动画每一帧的ORCA输入文件

也可以生成其他软件的输入文件,但是如果要运行的话需要自己写对应的runall.sh

食用方法: ./trj2inp.sh trj.xyz template.inp

注意输入的xyz和inp文件名不能为数字,否则可能会被覆盖,导致错误

需要一个ORCA输入文件模板:
将输入文件中的xyz部分用[geometry]替代,例如:

1
2
3
4
5
6
! B3LYP D3 def2-TZVP def2/J RIJCOSX noautostart miniprint nopop
%maxcore 1000
%pal nprocs 8 end
* xyz 0 1
[geometry]
*
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#!/bin/bash
xyzfilename=$1
inp=$2

number=$(awk '{print $1}' $xyzfilename | head -1)
rownumber=$(awk '{print NR}' $xyzfilename|tail -1)
xyznumber=$((rownumber / (number + 2)))
for ((i=1; i<=$xyznumber; i=i+1))
do
startline=$(((i - 1)*(number + 2)+3))
endline=$((startline + number - 1))
sed -n "${startline},${endline-1}p" $xyzfilename > temp.txt

new_startline=$(grep -n -i '\[geometry\]' $inp | awk -F : '{print $1}')

sed "${new_startline}r temp.txt" $inp > $i.inp
sed -i "/\[geometry\]/I d" $i.inp
done

rm temp.txt

orcarunall: 运行所有ORCA输入文件

请提前移除/重命名你的模板输入文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#!/bin/bash
# 修改自http://sobereva.com/258

# orca路径
orca_path=/home/usu171/downloads/orca_5_0_4

icc=0
nfile=`ls ./*.inp|wc -l`
for inf in *.inp
do
((icc++))
echo Running ${inf} ... \($icc of $nfile\)
time $orca_path/orca ${inf} > ${inf/inp/out}
$orca_path/orca_2mkl ${inf/.inp} -molden
echo ${inf} has finished
echo
done

trj2xyz: 将xyz动画拆分为单独的.xyz文件

你也可以用split拆分文件

食用方法: ./trj2xyz.sh trj.xyz

注意输入的xyz文件名不能为数字,否则可能会被覆盖,导致错误

1
2
3
4
5
6
7
8
9
10
11
#!/bin/bash
xyzfilename=$1
number=$(awk '{print $1}' $xyzfilename | head -1)
rownumber=$(awk '{print NR}' $xyzfilename|tail -1)
xyznumber=$((rownumber / (number + 2)))
for ((i=1; i<=$xyznumber; i=i+1))
do
startline=$(((i - 1)*(number + 2)+1))
endline=$((startline + number + 1))
sed -n "${startline},${endline-1}p" $xyzfilename > $i.xyz
done

xtbrunall: 用xtb计算所有.xyz文件

请提前移除/重命名你的xyz动画文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#!/bin/bash
# 修改自http://sobereva.com/258

xtb_args="--gfn 2 --chrg 0 --uhf 0 --molden"

icc=0
nfile=`ls ./*.xyz|wc -l`
for inf in *.xyz
do
((icc++))
echo Running ${inf} ... \($icc of $nfile\)
time xtb ${inf} ${xtb_args} > ${inf/xyz/out}
mv molden.input ${inf/xyz}molden.input
echo ${inf} has finished
echo
done

rm charges wbo xtbrestart xtbtopo.mol

batch.sh: 调用Multiwfn生成用于IRI的cub文件

batch.sh:

1
2
3
4
5
6
for inf in *.molden.input
do
Multiwfn ${inf} < batch.txt
mv func1.cub f1_${inf/.molden.input}.cub
mv func2.cub f2_${inf/.molden.input}.cub
done

根据实际情况修改
batch.txt:

1
2
3
4
5
20
4
4
0.1
3

VMD渲染IRI动画

食用方法: 打开VMD,输入source isoall.tcl

将此文件保存到VMD安装目录
isoall.tcl

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
color Display Background white
color scale method BGR
color scale midpoint 0.666
display depthcue off
set isoval 1
axes location Off
display distance -8.0
light 3 on

#根据实际情况进行修改
for {set i 1} {$i<=51} {incr i} {
set name $i
puts "Processing f1_$name.cub and f2_$name.cub..."
mol default style CPK
mol new f1_$name.cub
mol addfile f2_$name.cub

# 根据实际情况进行修改
scale to 0.4
rotate y by -15
translate by 0.000000 0.00000 -2.000000

mol modstyle 0 top CPK 0.700000 0.300000 18.000000 16.000000
mol addrep top
mol modstyle 1 top Isosurface $isoval 1 0 0 1 1
mol modcolor 1 top Volume 0
mol scaleminmax top 1 -0.04 0.02
render snapshot $name.bmp
mol delete top
}

reverse

如果你的xyz动画反了,可以翻转它

1
2
3
4
5
6
7
8
9
10
11
12
13
#!/bin/bash
xyzfilename=$1
number=$(awk '{print $1}' $xyzfilename | head -1)
rownumber=$(awk '{print NR}' $xyzfilename|tail -1)
xyznumber=$((rownumber / (number + 2)))
truncate -s 0 ${xyzfilename%.*}_reverse.${xyzfilename##*.}
for ((i=$xyznumber; i >= 1; i=i-1))
do
startline=$(((i - 1)*(number + 2)+1))
endline=$((startline + number + 1))

sed -n "${startline},${endline-1}p" $xyzfilename >> ${xyzfilename%.*}_reverse.${xyzfilename##*.}
done
其他文章
  1. 1. 计算xyz动画每一帧的molden
    1. 1.1. trj2inp: 生成xyz动画每一帧的ORCA输入文件
    2. 1.2. orcarunall: 运行所有ORCA输入文件
    3. 1.3. trj2xyz: 将xyz动画拆分为单独的.xyz文件
    4. 1.4. xtbrunall: 用xtb计算所有.xyz文件
    5. 1.5. batch.sh: 调用Multiwfn生成用于IRI的cub文件
    6. 1.6. VMD渲染IRI动画
    7. 1.7. reverse
请输入关键词进行搜索