1つの変数をループし、各ステップで値を計算するプログラムがあります。
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
ます。