aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gfortran.dg/gamma_5.f90
diff options
context:
space:
mode:
authorBen Cheng <bccheng@google.com>2014-03-25 22:37:19 -0700
committerBen Cheng <bccheng@google.com>2014-03-25 22:37:19 -0700
commit1bc5aee63eb72b341f506ad058502cd0361f0d10 (patch)
treec607e8252f3405424ff15bc2d00aa38dadbb2518 /gcc-4.9/gcc/testsuite/gfortran.dg/gamma_5.f90
parent283a0bf58fcf333c58a2a92c3ebbc41fb9eb1fdb (diff)
downloadtoolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.tar.gz
toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.tar.bz2
toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.zip
Initial checkin of GCC 4.9.0 from trunk (r208799).
Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba
Diffstat (limited to 'gcc-4.9/gcc/testsuite/gfortran.dg/gamma_5.f90')
-rw-r--r--gcc-4.9/gcc/testsuite/gfortran.dg/gamma_5.f9042
1 files changed, 42 insertions, 0 deletions
diff --git a/gcc-4.9/gcc/testsuite/gfortran.dg/gamma_5.f90 b/gcc-4.9/gcc/testsuite/gfortran.dg/gamma_5.f90
new file mode 100644
index 000000000..467c57962
--- /dev/null
+++ b/gcc-4.9/gcc/testsuite/gfortran.dg/gamma_5.f90
@@ -0,0 +1,42 @@
+! { dg-do run }
+! PR 33683 - we used to pick up the wrong gamma function
+! from the library on some systems.
+program main
+ implicit none
+ integer, parameter :: n_max = 20
+ double precision, dimension(0:n_max) :: c
+ double precision :: pi
+ integer :: n
+ double precision :: td, xd
+ real :: ts,xs
+
+ pi = 4 * atan(1.d0)
+ c(0) = 1.
+ do n=1, n_max
+ c(n) = (2*n-1)*c(n-1)*0.5d0
+ end do
+
+ do n=1, n_max
+ xs = n + 0.5
+ xd = n + 0.5d0
+ td = c(n)*sqrt(pi)
+ ts = c(n)*sqrt(pi)
+ if (abs(gamma(xs)-ts)/ts > 9e-6) call abort
+ if (abs(gamma(xd)-td)/td > 5e-14) call abort
+ end do
+ call tst_s(2.3, gamma(2.3))
+ call tst_s(3.7, gamma(3.7))
+ call tst_s(5.5, gamma(5.5))
+ call tst_d(4.2d0, gamma(4.2d0))
+ call tst_d(8.1d0, gamma(8.1d0))
+contains
+ subroutine tst_s(a, b)
+ real :: a, b
+ if (abs(gamma(a) - b)/b > 1e-6) call abort
+ end subroutine tst_s
+
+ subroutine tst_d(a, b)
+ double precision :: a,b
+ if (abs(gamma(a) - b)/b > 5e-14) call abort
+ end subroutine tst_d
+end program main