24小时热门版块排行榜    

Znn3bq.jpeg
查看: 7622  |  回复: 24

从心而觅

新虫 (小有名气)

[交流] 侯老师脚本测试K点、截断能详解,适合零基础! 已有8人参与

学vasp的童鞋估计都知道侯老师,很多童鞋对他教程里面的脚本也略有耳闻,估计也有不少被这些脚本绊住脚,当然也包括我。今天正好有时间,在这里跟大家聊聊侯老师的脚本。这里以K点的测试脚本为例。
1:脚本说明
脚本就像是一句话,把话传给服务器,然后服务器就照着话做,在这里用脚本的目的无非就是省时省力,对于机械的重复性动作,让脚本会省力一下。但是别担心,即使自己对脚本一窍不通,一个个算就可以了,无非多费点劲而已。
2:文件准备
我们都知道提交VASP作业需要四个基本文件,INCAR、KPOINTS、POSTAR、POTCAR,这里我们讲测试K点,也就是KPOINTS里面的内容。所以这时建立脚本文件rvasp.pbs.sh,提交作业时准备这个文件和其它三个,而KPOINTS文件就不必要了。
3:rvasp.pbs.sh脚本内容
这个脚本两个作用,一是充当KPOINTS文件,二是完成提交作业的任务。具体内容如下。

#!/bin/sh
rm WAVECAR
for  i  in  1  2  3
do
cat>KPOINTS<<!
Si-
0
Monkhorst-pack
$i     $i      $i
0.0  0.0    0.0
!
echo "k mesh = $i x $i x $i"
time vasp
E=`grep "TOTEN" OUTCAR | tail -1 | awk '{printf "%12.6f \n", $5 }'`
KP=`grep "irreducible" OUTCAR | tail -1 | awk '{printf "%5i \n", $2 }'`
echo $i $KP $E >>comment
done

下面是脚本说明:

#!/bin/sh                 说明命令类型,使用的shell是bash
rm WAVECAR  删掉波函数,如果INCAR中设置ISTART=0,即重新开始弛豫,这一行需要删除。
for  i  in  1  2  3    for……do……done是循环的整套命令  i是变量
do
cat>KPOINTS<<!   生成KPOINTS文件,而文件的内容为两个!之间的内容
Si-               从此行到下面!号前,是KPOINTS内容,不再详述
0
Monkhorst-pack
$i     $i      $i    $i读入i的数值,也就是从1再2再3
0.0  0.0    0.0
!   与上一个!相应
echo "k mesh = $i x $i x $i"    屏幕上打印引号内的内容
time vasp        运行vas,并在程序跑完后打印时间
E=`grep "TOTEN" OUTCAR | tail -1 | awk '{printf "%12.6f \n", $5 }'`
提取OUTCAR中含有TOTEN的行且最后一行赋值为E  awk后是一些输出格式
KP=`grep "irreducible" OUTCAR | tail -1 | awk '{printf "%5i \n", $2 }'`
提取OUTCAR中含有irreducible的行且最后一行赋值为KP
echo $i $KP $E >>comment   将两个变量输出到comment文件
done  与for do done 配套

4.提交作业
做好INCAR、POSTAR、POTCAR,再加上上面的脚本rvasp.pbs.sh,然后提交脚本即可。

5.特别说明
1:如果作业错误,并显示找不到WAVECAR,那就把rm WAVECAR这一行删除。
2:作业错误,先检查脚本有没有问题,没有问题,注意time vasp
这一行,这个提交作业的命令可能对你的服务器不适用,那你用自己提交作业的命令替换掉这个。
3:2不成功的情况下,如果你本来有提交作业的脚本,找到mpirun这一行(这一行的作用是提交作业),将上面rvasp的所有内容粘贴到这一行的后面,然后剪切mpirun这一行进而替换掉time vasp。再正常提交脚本即可。

完毕。
本教程综合很多前辈的方法,基本是一个整合,感谢他们!对于本教程有错误的地方,请批评指正!
回复此楼

» 收录本帖的淘帖专辑推荐

第一性原理计算-tg 量化软件 第一原理 计算化学
科研

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

» 猜你喜欢

一切有为法,如梦幻泡影!如露亦如电,应作如是观!
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

maoxinxina

银虫 (小有名气)


小木虫: 金币+0.5, 给个红包,谢谢回帖
你好,就是我按这种方法输进去之后,然后运行脚本。系统会提醒我这样的错误,我想请教下你也遇到过吗?
line 16: warning: here-document at line 5 delimited by end-of-file (wanted `!')
line 17: syntax error: unexpected end of file
16行是最后一行
4楼2016-10-09 09:32:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

匿名

本帖仅楼主可见
2楼2016-09-05 21:51:44
已阅   申请1ST强帖   回复此楼   编辑   查看我的主页
送红花一朵
本帖仅楼主可见
3楼2016-09-05 21:52:17
已阅   申请1ST强帖   回复此楼   编辑   查看我的主页

从心而觅

新虫 (小有名气)

引用回帖:
4楼: Originally posted by maoxinxina at 2016-10-09 09:32:53
你好,就是我按这种方法输进去之后,然后运行脚本。系统会提醒我这样的错误,我想请教下你也遇到过吗?
line 16: warning: here-document at line 5 delimited by end-of-file (wanted `!')
line 17: syntax erro ...

注意!号需要顶格写,你最好贴上自己的脚本。
一切有为法,如梦幻泡影!如露亦如电,应作如是观!
5楼2016-10-09 19:46:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tsglss

铁杆木虫 (著名写手)

学习了

[ 发自手机版 http://muchong.com/3g ]
做好自己
6楼2016-10-09 22:25:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chally123

铁虫 (著名写手)

学习了

[ 发自手机版 http://muchong.com/3g ]
7楼2016-10-10 00:12:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

maoxinxina

银虫 (小有名气)


小木虫: 金币+0.5, 给个红包,谢谢回帖
引用回帖:
4楼: Originally posted by maoxinxina at 2016-10-09 09:32:53
你好,就是我按这种方法输进去之后,然后运行脚本。系统会提醒我这样的错误,我想请教下你也遇到过吗?
line 16: warning: here-document at line 5 delimited by end-of-file (wanted `!')
line 17: syntax erro ...

哥:这是我的东西
#!/bin/sh
rm WAVECAR
for  i  in  150   200   250  300   350   400
do
cat > INCAR <<!
SYSTEM = Si-Diamond
ENCUT = $i
ISTART = 0 ; ICHARG = 2
ISMEAR = -5
PREC = Accurate
!
echo "ENCUT = $i eV" ;    time vasp
E=`grep "TOTEN" OUTCAR | tail -1 | awk    '{printf    "%12.6f \n",    $5 }'`
echo $i   $E  >>comment
done
然后我把这个放在根目录下~/bin
执行chmode +x run_ecut.sh
然后放在我的文件夹下执行


提示错误如下:
[lyj@cluster si]$ run_ecut.sh
rm: cannot remove `WAVECAR': No such file or directory
/home/lyj/bin/run_ecut.sh: line 16: warning: here-document at line 5 delimited by end-of-file (wanted `!')
/home/lyj/bin/run_ecut.sh: line 17: syntax error: unexpected end of file
想知道怎么弄才能消除这些错误
8楼2016-10-10 10:23:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

从心而觅

新虫 (小有名气)

引用回帖:
8楼: Originally posted by maoxinxina at 2016-10-10 10:23:14
哥:这是我的东西
#!/bin/sh
rm WAVECAR
for  i  in  150   200   250  300   350   400
do
cat > INCAR <<!
SYSTEM = Si-Diamond
ENCUT = $i
ISTART = 0 ; ICHARG = 2
ISMEAR = -5
P ...

把rm WAVECAR这一行注释掉
一切有为法,如梦幻泡影!如露亦如电,应作如是观!
9楼2016-10-10 10:29:56
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

maoxinxina

银虫 (小有名气)

引用回帖:
9楼: Originally posted by 从心而觅 at 2016-10-10 10:29:56
把rm WAVECAR这一行注释掉...

删了也没用,
10楼2016-10-10 10:32:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 从心而觅 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 267求调剂 +5 再忙也要吃饭啊 2026-04-09 5/250 2026-04-09 18:47 by stone_128
[考研] 一志愿中科大070300化学,314分求调剂 +11 wakeluofu 2026-04-09 11/550 2026-04-09 18:03 by lijunpoly
[考研] 296求调剂 +5 汪!?! 2026-04-09 5/250 2026-04-09 17:47 by 柠檬不酸zy
[考研] 280求调剂 +5 兮兮夜夜 2026-04-09 8/400 2026-04-09 11:15 by 兮兮夜夜
[考研] 070300化学279求调剂 +17 哈哈哈^_^ 2026-04-08 18/900 2026-04-09 10:49 by 三七七想上岸
[考研] 一志愿北京2,材料与化工308求调剂 +17 熊二想上岸 2026-04-04 18/900 2026-04-09 09:13 by leyan1127
[考研] 285求调剂 +12 AZMK 2026-04-05 18/900 2026-04-08 20:43 by 逆水乘风
[考研] 专硕310求调剂 +7 捞捞我…. 2026-04-04 8/400 2026-04-08 20:24 by yutian743
[考研] 求调剂 +14 张zic 2026-04-05 15/750 2026-04-08 16:14 by 一只好果子?
[考研] 化学0703-一志愿211-338分求调剂 +10 vants 2026-04-05 11/550 2026-04-08 16:02 by screening
[考研] 调剂 +3 电气300求调剂不 2026-04-08 6/300 2026-04-08 09:39 by 电气300求调剂不
[考研] 信工所11408 340分 本科西安交大自动化 +3 moontrek 2026-04-06 3/150 2026-04-07 09:56 by chongya
[考研] 307求调剂 +3 Youth@@ 2026-04-07 3/150 2026-04-07 09:25 by 小黑不怕难
[考研] 生物学求调剂 一志愿沪9,326分 +6 刘墨墨 2026-04-06 6/300 2026-04-06 19:36 by lijunpoly
[考研] 070300化学学硕311分求调剂 +11 梁富贵险中求 2026-04-04 13/650 2026-04-06 07:24 by houyaoxu
[考研] 男生,一志愿沪9生物学071000,初试308求调剂 +3 刘墨墨 2026-04-04 3/150 2026-04-05 08:26 by barlinike
[考研] 材料与化工306分找调剂 +12 沧海轻舟e 2026-04-03 13/650 2026-04-04 23:45 by lqwchd
[考研] 材料383求调剂 +5 郭阳阳阳成 2026-04-04 5/250 2026-04-04 19:06 by dongzh2009
[考研] 281求调剂 +10 aaawhy 2026-04-03 10/500 2026-04-03 21:42 by lbsjt
[考研] 289-求调剂 +4 这里是_ 2026-04-03 4/200 2026-04-03 14:23 by 1753564080
信息提示
请填处理意见