aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gfortran.dg/matmul_8.f03
diff options
context:
space:
mode:
Diffstat (limited to 'gcc-4.9/gcc/testsuite/gfortran.dg/matmul_8.f03')
-rw-r--r--gcc-4.9/gcc/testsuite/gfortran.dg/matmul_8.f0312
1 files changed, 12 insertions, 0 deletions
diff --git a/gcc-4.9/gcc/testsuite/gfortran.dg/matmul_8.f03 b/gcc-4.9/gcc/testsuite/gfortran.dg/matmul_8.f03
new file mode 100644
index 000000000..fcd4b0d56
--- /dev/null
+++ b/gcc-4.9/gcc/testsuite/gfortran.dg/matmul_8.f03
@@ -0,0 +1,12 @@
+! { dg-do run }
+! Transformational intrinsic MATMUL as initialization expression.
+
+ REAL, PARAMETER :: PI = 3.141592654, theta = PI/6.0
+
+ REAL, PARAMETER :: unity(2,2) = RESHAPE([1.0, 0.0, 0.0, 1.0], [2, 2])
+ REAL, PARAMETER :: m1(2,2) = RESHAPE([COS(theta), SIN(theta), -SIN(theta), COS(theta)], [2, 2])
+ REAL, PARAMETER :: m2(2,2) = RESHAPE([COS(theta), -SIN(theta), SIN(theta), COS(theta)], [2, 2])
+ REAL, PARAMETER :: m(2,2) = MATMUL(m1, m2)
+
+ IF (ANY(ABS(m - unity) > EPSILON(0.0))) CALL abort()
+END