我有一个程序循环一个变量并在每一步计算一个值:
program cpout
implicit none
!declarations
integer, parameter :: dp = selected_real_kind(15)
! kind value for double precision
real(dp), parameter :: Ru = 8.314472_dp
real(dp) :: cp
integer :: loT, hiT, i
real(dp) :: iT
real(dp),dimension(14) :: ic8a
real(dp) :: ic8t
real(dp) :: ic8c
loT = 300
hiT = 3000
! ic8a is populated using a subroutine call
! I have checked, it reads in reals as it is supposed to
do i = loT, hiT, 1
iT = real(i,dp)
if (iT > ic8t) then
ic8c = Ru*(ic8a(1) + ic8a(2)*iT + ic8a(3)*(iT**2)
* + ic8a(4)*(iT**3) + ic8a(5)*(iT**4))
else
ic8c = Ru*(ic8a(8) + ic8a(9)*iT + ic8a(10)*(iT**2)
* + ic8a(11)*(iT**3) + ic8a(12)*(iT**4))
end if
end do
end program cpout
在我的第一次尝试中,我用作iT
整数循环计数器,然后在公式中直接使用它。这产生了iT
>的分段图ic8t
。当我添加i
为计数器并iT
在公式中使用它之前转换为实数时,图表应该是平滑的。为什么iT
在插入公式时是实数还是整数很重要?我的编译器是g77。
iT
编辑:该公式也为<提供了一些不准确的值ic8t
。