24小时热门版块排行榜    

查看: 1452  |  回复: 12

thelrgbird

金虫 (小有名气)

[求助] 关于脚本书写求助

在提交作业的时候写了这样一个脚本:
#!/bin/sh
rm WAVECAR
rm fcc_mesh
for i in 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95  3.0 3.05
do
cat > POSCAR << !
Pt
1.000
$i/2    $i/2     0.000
$i/2    0.000  $i/2
0.000 $i/2     $i/2
1
d
0.000 0.000 0.000
!
~/vasp
grep F= OS* >> fcc_mesh
done

运行出了不少错误…… 第一个就是不能用$i/2这个方式简单的表示算数关系,第二个是什么原因我也看不明白了…… 好像说我这样写的POSCAR有问题,麻烦各位帮忙看看,应该怎么修改一下可以呢?谢谢啦!
PS:我想建的模型就是简单的立方面心的Pt
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

贺仪

铁杆木虫 (著名写手)

【答案】应助回帖

感谢参与,应助指数 +1
uuv2010(金币+1): 多谢提示 2012-02-17 09:43:37
thelrgbird(金币+2): 有帮助 谢谢啦~ 2012-02-20 16:03:32
thelrgbird(金币+2): 有帮助 谢谢帮助 2012-02-20 16:04:58
一,既然不可以运算,那么你可以先算一下呀
for i in 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95  3.0 3.05(在这里算一下不就行了?)
do
cat > POSCAR << !
Pt
1.000
$i/2    $i/2     0.000
$i/2    0.000  $i/2
0.000 $i/2     $i/2

二,把你提示的错误贴上来
嘟啦啦嘟啦啦嘟
2楼2012-02-17 09:31:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

souledge

专家顾问 (著名写手)

【答案】应助回帖

感谢参与,应助指数 +1
WDD880227(金币+1): 感谢交流 2012-02-18 19:45:57
thelrgbird(金币+2): 有帮助 谢谢~ 2012-02-20 16:03:46
thelrgbird(金币+2): 有帮助 谢谢帮助 2012-02-20 16:05:19
另外,可以用这样的方法计算:
HalfI=`echo "scale=5; $i / 2" | bc -l`
然后在晶格常数位置用$HalfI就可以了~
思想重于技巧,内涵重于表象
3楼2012-02-18 18:04:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dxcharlary

专家顾问 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
liliangfang(金币+2): 多谢指教 2012-02-19 08:45:34
thelrgbird(金币+2): 有帮助 谢谢 2012-02-20 16:03:57
应该是你的第一个错误导致$i/2没被执行,所以可能晶格参数没写POSCAR里面去。所以vasp根本就不认识你的POSCAR。
4楼2012-02-18 21:22:48
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dxcharlary

专家顾问 (职业作家)

另外你的grep F= OS* >> fcc_mesh是想往fcc_mesh里面写什么?
5楼2012-02-18 21:24:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

thelrgbird

金虫 (小有名气)

引用回帖:
: Originally posted by 贺仪 at 2012-02-17 09:31:08:
一,既然不可以运算,那么你可以先算一下呀
for i in 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95  3.0 3.05(在这里算一下不就行了?)
do
cat > POSCAR << !
Pt
1.000
$i/2    $i/2     0.000
$i/2   ...

这样还是不行的,$i/2在这里出现的话,最后反映在POSCAR上就是2.6/2这样的东西,貌似VASP不认……不能继续计算……
6楼2012-02-20 09:29:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

thelrgbird

金虫 (小有名气)

WDD880227(金币+1): 感谢交流 2012-02-20 09:39:12
引用回帖:
: Originally posted by souledge at 2012-02-18 18:04:45:
另外,可以用这样的方法计算:
HalfI=`echo "scale=5; $i / 2" | bc -l`
然后在晶格常数位置用$HalfI就可以了~

我最后也是在木虫上查的,用的是a= python -c "print $i/2" 但是这样的话所有的简单计算都会要重新命名一个新的变量,觉得可麻烦了…… 不知道能不能直接用某个命令让其直接算出呢?例如:
cat > POSCAR << !
Pt
1.000
{一个运算公式}    {一个运算公式}     0.000
{一个运算公式}    0.000  {一个运算公式}
0.000  {一个运算公式}    {一个运算公式}
7楼2012-02-20 09:33:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

thelrgbird

金虫 (小有名气)

引用回帖:
: Originally posted by dxcharlary at 2012-02-18 21:22:48:
应该是你的第一个错误导致$i/2没被执行,所以可能晶格参数没写POSCAR里面去。所以vasp根本就不认识你的POSCAR。

您说的第一个错误是哪里?
8楼2012-02-20 09:34:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

thelrgbird

金虫 (小有名气)

引用回帖:
: Originally posted by dxcharlary at 2012-02-18 21:24:30:
另外你的grep F= OS* >> fcc_mesh是想往fcc_mesh里面写什么?

这个就是想手动检测晶格参数的意思,OS*其实就是OSZICAR,懒得继续输入了
9楼2012-02-20 09:36:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dxcharlary

专家顾问 (职业作家)

WDD880227(金币+1): 感谢提示 2012-02-20 15:09:02
引用回帖:
7楼: Originally posted by thelrgbird at 2012-02-20 09:33:18:
我最后也是在木虫上查的,用的是a= python -c "print $i/2" 但是这样的话所有的简单计算都会要重新命名一个新的变量,觉得可麻烦了…… 不知道能不能直接用某个命令让其直接算出呢?例如:
cat >  ...

我记得shell根本就不支持浮点运算。用python或者是matlab吧。
10楼2012-02-20 09:51:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 thelrgbird 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂 +6 十三加油 2026-03-21 6/300 2026-03-22 17:00 by i_cooler
[考研] 一志愿中南化学(0703)总分337求调剂 +9 niko- 2026-03-19 10/500 2026-03-22 16:08 by ColorlessPI
[考研] 生物学调剂 +5 Surekei 2026-03-21 5/250 2026-03-22 14:39 by tcx007
[考研] 354求调剂 +7 Tyoumou 2026-03-18 10/500 2026-03-22 11:11 by 人来盛
[基金申请] 山东省面上项目限额评审 +4 石瑞0426 2026-03-19 4/200 2026-03-22 08:50 by Wei_ren
[考研] 资源与环境 调剂申请(333分) +5 holy J 2026-03-21 5/250 2026-03-21 22:42 by Catalysis25
[考研] 333求调剂 +5 87639 2026-03-21 7/350 2026-03-21 19:31 by ColorlessPI
[考研] 一志愿东华大学控制学硕320求调剂 +3 Grand777 2026-03-21 3/150 2026-03-21 19:23 by 简之-
[考研] 296求调剂 +4 www_q 2026-03-20 4/200 2026-03-21 17:26 by 学员8dgXkO
[考研] 266求调剂 +3 哇呼哼呼哼 2026-03-20 3/150 2026-03-21 16:46 by barlinike
[考研] 一志愿重庆大学085700资源与环境总分308求调剂 +7 墨墨漠 2026-03-20 7/350 2026-03-21 16:36 by barlinike
[考研] 265求调剂 +9 梁梁校校 2026-03-17 9/450 2026-03-21 02:17 by JourneyLucky
[考研] 311求调剂 +5 冬十三 2026-03-18 5/250 2026-03-21 00:16 by JourneyLucky
[考研] 308求调剂 +3 阿姐阿姐家啊 2026-03-18 3/150 2026-03-20 23:24 by JourneyLucky
[考研] 一志愿南理工085701环境302求调剂院校 +3 葵梓卫队 2026-03-20 3/150 2026-03-20 19:28 by zhukairuo
[考研] 生物学调剂招人!!! +3 山海天岚 2026-03-17 4/200 2026-03-19 21:34 by 怎么释怀
[考研] 085600材料与化工求调剂 +6 绪幸与子 2026-03-17 6/300 2026-03-19 13:27 by houyaoxu
[考研] 0854可跨调剂,一作一项核心论文五项专利,省、国级证书40+数一英一287 +8 小李0854 2026-03-16 8/400 2026-03-18 14:35 by 搏击518
[考研] 301求调剂 +4 A_JiXing 2026-03-16 4/200 2026-03-17 17:32 by ruiyingmiao
[考研] 085601求调剂 +4 Du.11 2026-03-16 4/200 2026-03-17 17:08 by ruiyingmiao
信息提示
请填处理意见