24小时热门版块排行榜    

查看: 4076  |  回复: 8

valenhou001

至尊木虫 (职业作家)

[交流] 从VASP的OUTCAR提取xyz以及结构优化的轨迹 已有4人参与

将以下内容考虑至一个文件,比如命名为getvaspxyz.sh,然后将它的属性改为可执行的, chmod +x getvaspxyz.sh。另外在linux下,还可能需要使用命令dos2unix来去掉文件里每行多余隐藏的字符:dos2unix getvaspxyz.sh。在含有OUTCAR文件的目录下运行getvaspxyz.sh,就可以取出原子的位置,以及原子所受的力。按xyz的格式输出。 xyz格式的文件可以用Jmol等软件来可视化。

一个缺点就是,如果所计算的体系所包含的原子个数比较多,另外结构弛豫的步数比较多的话,在得到轨迹文件比较慢。
#!/bin/bash
pwd1=`echo ${PWD##*/}`

natom=`grep \'NIONS\' OUTCAR|tail -1 |awk \'{printf "%s\\n", $12}\'`
last=`sed -n \'/total drift:/=\' OUTCAR |tail -1`
iaf=`echo "$last - 2 - $natom" |bc -l `
echo $natom        > opt.xyz
sed -n "$iaf",+"$natom"p OUTCAR  >>opt.xyz
echo "The latest atomic positions are written to opt.xyz!"
iptc=`grep \'ions per type =\' OUTCAR|tail -1 `
ipt=(`echo "${iptc##*=}"`)
ats=(`grep \'VRHFIN =\'  OUTCAR | sed -e \'s/=/  /g\' |sed -e \'s/:/  /g\'| awk \'{printf "%s\\n", $2}\' `)
ntp=${#ipt[@]}
i=2
for  it in `seq 0  $((${ntp}-1))`;do
    for j in `seq 1  ${ipt[$it]}`;do
    i=`echo "$i +1 " |bc`
    elem=${ats[$it]}
    sed -i "$i s/^/$elem/" opt.xyz
done
done

cp opt.xyz   opt-"$pwd1".xyz

nstep=(`sed -n \'/total drift:/=\' OUTCAR `)
etot=(`grep \'energy  without entropy=\' OUTCAR |awk \'{printf "%20.8f\\n", $4}\' `)
myFile="trajec.xyz"
if [ ! -e "$myFile" ]; then
echo $natom  > $myFile
sed -i \'1d\' $myFile
fi


for k in `seq 0  $((${#nstep[@]}-1))`;do
iaf=`echo "${nstep[k]} - 2 - $natom" |bc -l `
if [  $k -eq 0 ];then
echo $natom  > $myFile
else
echo $natom  >> $myFile
fi
sed -n "$iaf",+"$natom"p OUTCAR  >> $myFile
i=`echo "$k * ($natom+2) + 2"|bc -l`
sed -i "$i s/^/#Etotal: ${etot[k]} eV/"  $myFile
for  it in `seq 0  $((${ntp}-1))`;do
    for j in `seq 1  ${ipt[$it]}`;do
    i=`echo "$i +1 " |bc`
    elem=${ats[$it]}
    sed -i "$i s/^/$elem/"  $myFile
done
done
done
echo "The atomic positions in each optimization step are written to trajec.xyz!"
cp  trajec.xyz   trajec-"$pwd1".xyz
回复此楼

» 本帖已获得的红花(最新10朵)

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lion_tiger

至尊木虫 (正式写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
送红花一朵
感谢侯老师的分享
2楼2019-10-29 16:45:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zuocuiping

木虫 (职业作家)


小木虫: 金币+0.5, 给个红包,谢谢回帖
这个有什么用呢?能说说吗?

发自小木虫Android客户端
3楼2019-10-29 18:01:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

valenhou001

至尊木虫 (职业作家)

引用回帖:
3楼: originally posted by zuocuiping at 2019-10-29 19:01:05
这个有什么用呢?能说说吗?

前言已经说的比较清楚了。

在结构优化,CONTCAR里是优化的结构。但是每一步优化的原子位置得需从其他文件里取出,比如OUTCAR。这个工具就是从OUTCAR里把每一步优化的原子位置给取出来,并按xyz的格式输出。
4楼2019-10-29 20:13:04
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zuocuiping

木虫 (职业作家)

引用回帖:
4楼: Originally posted by valenhou001 at 2019-10-29 20:13:04
前言已经说的比较清楚了。

在结构优化,CONTCAR里是优化的结构。但是每一步优化的原子位置得需从其他文件里取出,比如OUTCAR。这个工具就是从OUTCAR里把每一步优化的原子位置给取出来,并按xyz的格式输出。...

谢谢,感谢侯老师。

发自小木虫Android客户端
5楼2019-10-29 22:01:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hy1987007

木虫 (著名写手)

6楼2019-10-29 23:30:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

轻轻飘过之

金虫 (正式写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
感谢侯老师的分享!不过想请教下,什么情况下需要查看每一步优化的原子的位置?或者说查看每一步优化的原子位置可以得到什么信息?这个跟搜索过渡态的计算有什么区别?
7楼2019-10-30 09:35:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

valenhou001

至尊木虫 (职业作家)

引用回帖:
7楼: Originally posted by 轻轻飘过之 at 2019-10-30 10:35:05
感谢侯老师的分享!不过想请教下,什么情况下需要查看每一步优化的原子的位置?或者说查看每一步优化的原子位置可以得到什么信息?这个跟搜索过渡态的计算有什么区别?

只是为了监测结构优化的进展情况。与过渡态搜索无关。
8楼2019-11-13 10:10:24
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

valenhou001

至尊木虫 (职业作家)

在用jmol显示这个脚本所提取出来的轨迹时。通过在jmol的控制台使用如下命令:
set vectorScale 5.0
set vectorsCentered
set vectorSymmetry FALSE
set vibrationPeriod  2.0
set vibrationScale  2.0
set defaults PyMOL
vector ON
vector 0.05
vibration ON
可以用来显示原子所受的力的矢量。

或者将以上几行命令放到一个文件比如名为"label.spt"的文件中,然后将该文件通过鼠标拖到jmol已打开了原子轨迹显示的窗口,那这些原子上就会显示出相应所受的力的矢量,以及原子沿着这个矢量上的振动,这样可以很清楚地看到那个原子受的力是很大。
9楼2019-11-13 10:15:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 valenhou001 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 274求调剂 +3 S.H1 2026-03-18 3/150 2026-03-18 19:31 by q1092522407
[考研] 材料专业求调剂 +3 hanamiko 2026-03-18 3/150 2026-03-18 16:30 by 30660438
[考研] 085601专硕,总分342求调剂,地区不限 +5 share_joy 2026-03-16 5/250 2026-03-18 14:48 by haxia
[考研] 化工学硕306求调剂 +10 42838695 2026-03-12 10/500 2026-03-18 14:42 by haxia
[考研] 材料专硕274一志愿陕西师范大学求调剂 +6 薛云鹏 2026-03-13 6/300 2026-03-18 14:14 by 脱颖而出
[考研] 070300化学319求调剂 +6 锦鲤0909 2026-03-17 6/300 2026-03-18 13:22 by Iveryant
[考研] 304求调剂 +12 小熊joy 2026-03-14 13/650 2026-03-18 12:34 by Linda Hu
[考博] 环境领域全国重点实验室招收博士1-2名 +3 QGZDSYS 2026-03-13 5/250 2026-03-18 11:13 by QGZDSYS
[考研] 303求调剂 +4 睿08 2026-03-17 6/300 2026-03-18 11:01 by Iveryant
[考研] 0703化学求调剂 总分331 +3 ZY-05 2026-03-13 3/150 2026-03-18 10:58 by macy2011
[考研] 211本,11408一志愿中科院277分,曾在中科院自动化所实习 +6 Losir 2026-03-12 7/350 2026-03-17 12:09 by danranxie
[考研] 一志愿211 0703方向310分求调剂 +3 努力奋斗112 2026-03-15 3/150 2026-03-16 16:44 by houyaoxu
[考研] 070300化学学硕求调剂 +6 太想进步了0608 2026-03-16 6/300 2026-03-16 16:13 by kykm678
[考研] 327求调剂 +6 拾光任染 2026-03-15 11/550 2026-03-15 22:47 by 拾光任染
[考研] 085601材料工程315分求调剂 +3 yang_0104 2026-03-15 3/150 2026-03-15 10:58 by peike
[考研] 266求调剂 +4 学员97LZgn 2026-03-13 4/200 2026-03-14 08:37 by zhukairuo
[考研] 311求调剂 +3 冬十三 2026-03-13 3/150 2026-03-13 20:41 by JourneyLucky
[硕博家园] 085600 260分求调剂 +3 天空还下雨么 2026-03-13 5/250 2026-03-13 18:46 by 天空还下雨么
[考研] 求调剂 +3 程雨杭 2026-03-12 3/150 2026-03-13 15:06 by JourneyLucky
[考研] 土木第一志愿276求调剂,科研和技能十分丰富,求新兴方向的导师收留 +3 土木小天才 2026-03-12 3/150 2026-03-13 15:01 by JourneyLucky
信息提示
请填处理意见