Fortran Coder

标题: 双精度浮点数赋值为啥输出精度只有八位有效数字 [打印本页]

作者: ysgs    时间: 2024-11-19 10:16
标题: 双精度浮点数赋值为啥输出精度只有八位有效数字
我用双精度浮点数写的代码误差一直不能超过1e-8,后来发现赋的初值就只有八位精度,下面是我的一个测试,结果用双精度浮点数赋值出来就只有8位数字是对的


作者: Transpose    时间: 2024-11-19 11:36
Fortran常数的默认类型是单精度,加上d0表示的是双精度。
[Fortran] 纯文本查看 复制代码
1.22222222233333333d0

作者: ysgs    时间: 2024-11-19 13:44
Transpose 发表于 2024-11-19 11:36
Fortran常数的默认类型是单精度,加上d0表示的是双精度。
[mw_shl_code=fortran,true]1.22222222233333333d ...

是的哎,明白了,谢谢大佬,没想到fortran赋值不加d0都会降低精度,我还以为只有运算的时候要加
作者: ysgs    时间: 2024-11-19 13:46
Transpose 发表于 2024-11-19 11:36
Fortran常数的默认类型是单精度,加上d0表示的是双精度。
[mw_shl_code=fortran,true]1.22222222233333333d ...

再请问一个问题,就是双精度的浮点数乘整数怎么操作才能不降低精度呢
作者: fcode    时间: 2024-11-19 13:56
ysgs 发表于 2024-11-19 13:46
再请问一个问题,就是双精度的浮点数乘整数怎么操作才能不降低精度呢

确保参与计算的浮点数都是双精度就行了。
如果是变量,那么变量要定义为双精度。
如果是常量,那么要加 d0,表示双精度的常量。

其实其他语言也有类似的问题,比如 C 语言,只不过它默认的精度就是双精度,一些时候需要加 1.3F 表示是 float 的常量。
作者: ysgs    时间: 2024-11-19 14:58
OK,明白了,谢谢大佬

作者: weixing1531    时间: 2024-11-22 17:13
-fdefault-real-8   
这样默认双精度




欢迎光临 Fortran Coder (http://bbs.fcode.cn/) Powered by Discuz! X3.2