Fortran Coder

查看: 256|回复: 6
打印 上一主题 下一主题

[数值问题] 双精度浮点数赋值为啥输出精度只有八位有效数字

[复制链接]

4

帖子

1

主题

0

精华

新人

F 币
18 元
贡献
9 点
跳转到指定楼层
楼主
发表于 2024-11-19 10:16:26 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
我用双精度浮点数写的代码误差一直不能超过1e-8,后来发现赋的初值就只有八位精度,下面是我的一个测试,结果用双精度浮点数赋值出来就只有8位数字是对的

分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

168

帖子

2

主题

1

精华

大师

Vim

F 币
1021 元
贡献
486 点

规矩勋章

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

4

帖子

1

主题

0

精华

新人

F 币
18 元
贡献
9 点
板凳
 楼主| 发表于 2024-11-19 13:44:24 | 只看该作者
Transpose 发表于 2024-11-19 11:36
Fortran常数的默认类型是单精度,加上d0表示的是双精度。
[mw_shl_code=fortran,true]1.22222222233333333d ...

是的哎,明白了,谢谢大佬,没想到fortran赋值不加d0都会降低精度,我还以为只有运算的时候要加

4

帖子

1

主题

0

精华

新人

F 币
18 元
贡献
9 点
地板
 楼主| 发表于 2024-11-19 13:46:31 | 只看该作者
Transpose 发表于 2024-11-19 11:36
Fortran常数的默认类型是单精度,加上d0表示的是双精度。
[mw_shl_code=fortran,true]1.22222222233333333d ...

再请问一个问题,就是双精度的浮点数乘整数怎么操作才能不降低精度呢

2033

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1641 元
贡献
709 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

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

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

其实其他语言也有类似的问题,比如 C 语言,只不过它默认的精度就是双精度,一些时候需要加 1.3F 表示是 float 的常量。

4

帖子

1

主题

0

精华

新人

F 币
18 元
贡献
9 点
6#
 楼主| 发表于 2024-11-19 14:58:41 | 只看该作者
OK,明白了,谢谢大佬

147

帖子

42

主题

1

精华

宗师

F 币
1292 元
贡献
630 点
7#
发表于 2024-11-22 17:13:41 | 只看该作者
-fdefault-real-8   
这样默认双精度
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-12-22 16:04

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表