| ! { dg-do run } |
| program main |
| integer, parameter :: sz=5, su=3 |
| integer, parameter :: l=2 |
| integer, parameter :: u=l-1+su |
| integer(kind=4), dimension(sz,sz) :: r,a,b |
| integer :: i,j |
| do i=1,4 |
| do j=1,4 |
| a(i,j) = i*10+j |
| b(i,j) = 100+i*10+j |
| end do |
| end do |
| r = -1 |
| b(l:u,l:u) = reshape([(i,i=1,su*su)],[su,su]); |
| a(l:u,l:u) = reshape([(i,i=1,su*su)],[su,su]); |
| |
| r(1:su,1:su) = matmul(a(l:u,l:u),b(l:u,l:u)) |
| if (any(reshape(r,[sz*sz]) /= [30, 36, 42, -1, -1, 66, 81, 96, -1, -1,& |
| & 102, 126, 150, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1])) & |
| STOP 1 |
| end program main |