24小时热门版块排行榜    

查看: 1360  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

lbh_xt

新虫 (小有名气)

[求助] linux下的计算精度的设置

大家好,最近在linux下用lammps算的东西,结果数据都保只保留了四位小数点,而在window下却是16位的,请问这是什么原因?是linux系统和windows系统的原因?还是lammps在两个系统下不同的原因?
例如:
linux下: 2278.2239
windows下:2278.3329129329420233


我想要更高的截断数据(16位),请问应该怎么设置
回复此楼
安静
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

bluewhale

铁杆木虫 (正式写手)

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
jiaoyixiong: 金币+2, 鼓励交流 2012-09-26 20:57:25
// dump_custom.cpp
in constructor():
...
for (int i = 0; i < size_one; i++) {
    if (vtype == INT) format_default = strcat(format_default,"%d ";
    else if (vtype == DOUBLE) format_default = strcat(format_default,"%g ";
    else if (vtype == STRING) strcat(format_default,"%s ";
    vformat = NULL;
  }
...
可以将%g 改成 %20.14g或者其它什么的,不知你为什么要这么高的精度,好像缺省的就够用了。
3楼2012-09-26 20:33:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

love5264

木虫 (正式写手)

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
jiaoyixiong: 金币+2, 鼓励交流 2012-09-26 20:57:14
没用过lammps,
感觉可能是你编译的问题,
单精度还是双精度?
谋定而动
2楼2012-09-26 20:31:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lbh_xt

新虫 (小有名气)

引用回帖:
3楼: Originally posted by bluewhale at 2012-09-26 20:33:57
// dump_custom.cpp
in constructor():
...
for (int i = 0; i < size_one; i++) {
    if (vtype == INT) format_default = strcat(format_default,"%d ";
    else if (vtype == DOUBLE) for ...

谢谢哈,我先试试,可是为什么windows版本的lammps直接输出的都是那么多位数的呢?还有那个20.14g表示什么啊
安静
4楼2012-09-27 09:42:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lbh_xt

新虫 (小有名气)

引用回帖:
3楼: Originally posted by bluewhale at 2012-09-26 20:33:57
// dump_custom.cpp
in constructor():
...
for (int i = 0; i < size_one; i++) {
    if (vtype == INT) format_default = strcat(format_default,"%d ";
    else if (vtype == DOUBLE) for ...

不是dump,我是在lammps里用variable  equal进行运算,可是数据的精度不够,所以都都导致为0 了,脚本中本分如下:

variable  poten1 equal pe
variable p1 equal ${poten1}
...
variable  poten2 equal pe
variable p2 equal ${poten1}
...
variable  poten3 equal pe
variable p3 equal ${poten1}
...
variable  poten4 equal pe
variable p4 equal ${poten1}
...
variable mype equal ${p1}+${p2}-${p3}-${p4}
...

然后在log文件中,就会有这样的表示:
variable  poten1 equal pe
variable p1 equal ${poten1}
variable p1 equal 2775.42283
...
variable  poten2 equal pe
variable p2 equal 2775.42283
...
variable  poten3 equal pe
variable p3 equal 2775.42283
...
variable  poten4 equal pe
variable p4 equal 2775.42283
...
variable mype equal ${p1}+${p2}-${p3}-${p4}
variable mype equal 2775.42283+2775.42283-2775.42283-2775.42283

所以就等于0了。
但实际上,每个variable先都进行了相应的操作,所以上面的p1,p2,p3,p4都是不相等的数,例如:2775.422832424和2775.4228292324,只是它四舍五入了。这种情况在windows下就不会产生,windows下会输出到小数点后面很多位,而这个linux下就只能截断到后5位了,请问该怎么处理。
安静
5楼2012-09-27 10:47:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见