program test_log
integer, parameter :: Dbl_K = selected_real_kind (14)
real(Dbl_K) :: e = 2.7182818284590451_Dbl_K
real(Dbl_K) :: e2 = 2.7182818284590451D0
real(Dbl_K) :: e3 = exp(1.0)
real(Dbl_K) :: e4 = exp(1.0_Dbl_K)
write(*,*) 'log(2.7..)', log(2.7182818284590451_Dbl_K)
write(*,*) 'log(e)', log(e)
write(*,*) 'log(e2)', log(e2)
write(*,*) 'log(e3)', log(e3)
write(*,*) 'log(e4)', log(e4)
end program test_log
使用 selected_real_kind 而不是依赖 8 作为 double 的值。
在带有 Snow Leopard 的 MacBook Pro 上使用 gfortran 4.6 和 4.7 的输出是:
log(2.7..) 1.0000000000000000
log(e) 1.0000000000000000
log(e2) 1.0000000000000000
log(e3) 0.99999996963214000
log(e4) 1.0000000000000000
e3 的值与 1 不同,因为“exp(1.0)”具有 1 作为单精度实数。
在我的带有 Lion 的新 Mac Air 上,我得到了不正确的结果。我在这台机器上观察到 gfortran 的其他问题。
gfortran 4.6
log(2.7..) 1.6249753165355076
log(e) 1.6249753165355076
log(e2) 1.6249753165355076
log(e3) 1.6438056251294211
log(e4) 1.6438055841322456
gfortran 4.7
log(2.7..) 1.6249753165355076
log(e) 1.0000000000000000
log(e2) 1.0000000000000000
log(e3) 1.0188423211430429
log(e4) 1.0188422801197137
所以问题不是唯一的。不确定它是什么。
PS 在 MacAir 编译器选项更改输出。我不确定哪个选项或选项很重要。
聚苯乙烯
program test2_log
real:: e = 2.7182818284590451
real:: e2 = 2.7182818284590451D0
real:: e3 = exp(1.0)
real:: e4 = exp(1.0)
write(*,*) 'log(2.7..)', log(2.7182818284590451)
write(*,*) 'log(e)', log(e)
write(*,*) 'log(e2)', log(e2)
write(*,*) 'log(e3)', log(e3)
write(*,*) 'log(e4)', log(e4)
end program test2_log
在 MacAir 上,gfortran 4.6 提供:
log(2.7..) 1.3489696
log(e) 0.99999994
log(e2) 0.99999994
log(e3) 1.0188423
log(e4) 1.0188423
使用编译器选项 -fdefault-real-8 它更改为
log(2.7..) 1.6249753165355076
log(e) 1.0000000000000000
log(e2) 1.0000000000000000
log(e3) 1.0188422801197137
log(e4) 1.0188422801197137
这是安装中的一些缺陷。
编辑:两台机器上的所有 gfortran 版本都来自 MacPorts。操作系统版本不同还是其他?适用于雪豹,不适用于狮子。