24小时热门版块排行榜    

查看: 3942  |  回复: 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的回帖

zuocuiping

木虫 (职业作家)


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

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

lion_tiger

至尊木虫 (正式写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
送红花一朵
感谢侯老师的分享
2楼2019-10-29 16:45:23
已阅   回复此楼   关注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的回帖
普通表情 高级回复 (可上传附件)
信息提示
请填处理意见