OpenCores
URL https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk

Subversion Repositories openrisc_2011-10-31

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc1/] [gcc/] [testsuite/] [gfortran.fortran-torture/] [execute/] [forall_7.f90] - Diff between revs 303 and 338

Only display areas with differences | Details | Blame | View Log

Rev 303 Rev 338
! tests FORALL statements with a mask
! tests FORALL statements with a mask
program forall_7
program forall_7
  real, dimension (5, 5, 5, 5) :: a, b, c, d
  real, dimension (5, 5, 5, 5) :: a, b, c, d
  a (:, :, :, :) = 4
  a (:, :, :, :) = 4
  forall (i = 1:5)
  forall (i = 1:5)
    a (i, i, 6 - i, i) = 7
    a (i, i, 6 - i, i) = 7
  end forall
  end forall
  forall (i = 1:5)
  forall (i = 1:5)
    a (i, 6 - i, i, i) = 7
    a (i, 6 - i, i, i) = 7
  end forall
  end forall
  forall (i = 1:5)
  forall (i = 1:5)
    a (6 - i, i, i, i) = 7
    a (6 - i, i, i, i) = 7
  end forall
  end forall
  forall (i = 1:5:2)
  forall (i = 1:5:2)
    a (1, 2, 3, i) = 0
    a (1, 2, 3, i) = 0
  end forall
  end forall
  b = a
  b = a
  c = a
  c = a
  d = a
  d = a
  forall (i = 1:5, j = 1:5, k = 1:5, ((a (i, j, k, i) .gt. 6) .or. (a (i, j, k, j) .gt. 6)))
  forall (i = 1:5, j = 1:5, k = 1:5, ((a (i, j, k, i) .gt. 6) .or. (a (i, j, k, j) .gt. 6)))
    forall (l = 1:5, a (1, 2, 3, l) .lt. 2)
    forall (l = 1:5, a (1, 2, 3, l) .lt. 2)
      a (i, j, k, l) = i - j + k - l + 0.5
      a (i, j, k, l) = i - j + k - l + 0.5
    end forall
    end forall
  end forall
  end forall
  forall (l = 1:5, b (1, 2, 3, l) .lt. 2)
  forall (l = 1:5, b (1, 2, 3, l) .lt. 2)
    forall (i = 1:5, j = 1:5, k = 1:5, ((b (i, j, k, i) .gt. 6) .or. (b (i, j, k, j) .gt. 6)))
    forall (i = 1:5, j = 1:5, k = 1:5, ((b (i, j, k, i) .gt. 6) .or. (b (i, j, k, j) .gt. 6)))
      b (i, j, k, l) = i - j + k - l + 0.5
      b (i, j, k, l) = i - j + k - l + 0.5
    end forall
    end forall
  end forall
  end forall
  forall (i = 1:5, j = 1:5, k = 1:5, ((c (i, j, k, i) .gt. 6) .or. (c (i, j, k, j) .gt. 6)))
  forall (i = 1:5, j = 1:5, k = 1:5, ((c (i, j, k, i) .gt. 6) .or. (c (i, j, k, j) .gt. 6)))
    forall (l = 1:5, c (1, 2, 3, l) .lt. 2)
    forall (l = 1:5, c (1, 2, 3, l) .lt. 2)
      c (i, j, k, l) = i - j + k - l + 0.5 + c (l, k, j, i)
      c (i, j, k, l) = i - j + k - l + 0.5 + c (l, k, j, i)
    end forall
    end forall
  end forall
  end forall
  forall (l = 1:5, d (1, 2, 3, l) .lt. 2)
  forall (l = 1:5, d (1, 2, 3, l) .lt. 2)
    forall (i = 1:5, j = 1:5, k = 1:5, ((d (i, j, k, i) .gt. 6) .or. (d (i, j, k, j) .gt. 6)))
    forall (i = 1:5, j = 1:5, k = 1:5, ((d (i, j, k, i) .gt. 6) .or. (d (i, j, k, j) .gt. 6)))
      d (i, j, k, l) = i - j + k - l + 0.5 + d (l, k, j, i)
      d (i, j, k, l) = i - j + k - l + 0.5 + d (l, k, j, i)
    end forall
    end forall
  end forall
  end forall
  do i = 1, 5
  do i = 1, 5
    do j = 1, 5
    do j = 1, 5
      do k = 1, 5
      do k = 1, 5
        do l = 1, 5
        do l = 1, 5
          r = 4
          r = 4
          if ((i == j .and. k == 6 - i) .or. (i == k .and. j == 6 - i)) then
          if ((i == j .and. k == 6 - i) .or. (i == k .and. j == 6 - i)) then
            if (l /= 2 .and. l /= 4) then
            if (l /= 2 .and. l /= 4) then
              r = 1
              r = 1
            elseif (l == i) then
            elseif (l == i) then
              r = 7
              r = 7
            end if
            end if
          elseif (j == k .and. i == 6 - j) then
          elseif (j == k .and. i == 6 - j) then
            if (l /= 2 .and. l /= 4) then
            if (l /= 2 .and. l /= 4) then
              r = 1
              r = 1
            elseif (l == j) then
            elseif (l == j) then
              r = 7
              r = 7
            end if
            end if
          elseif (i == 1 .and. j == 2 .and. k == 3 .and. l /= 2 .and. l /= 4) then
          elseif (i == 1 .and. j == 2 .and. k == 3 .and. l /= 2 .and. l /= 4) then
            r = 0
            r = 0
          end if
          end if
          s = r
          s = r
          if (r == 1) then
          if (r == 1) then
            r = i - j + k - l + 0.5
            r = i - j + k - l + 0.5
            if (((l == k .and. j == 6 - l) .or. (l == j .and. k == 6 - l)) .and. (i == l)) then
            if (((l == k .and. j == 6 - l) .or. (l == j .and. k == 6 - l)) .and. (i == l)) then
              s = r + 7
              s = r + 7
            elseif (k == j .and. l == 6 - k .and. i == k) then
            elseif (k == j .and. l == 6 - k .and. i == k) then
              s = r + 7
              s = r + 7
            elseif (l /= 1 .or. k /= 2 .or. j /= 3 .or. i == 2 .or. i == 4) then
            elseif (l /= 1 .or. k /= 2 .or. j /= 3 .or. i == 2 .or. i == 4) then
              s = r + 4
              s = r + 4
            else
            else
              s = r
              s = r
            end if
            end if
          end if
          end if
          if (a (i, j, k, l) /= r) call abort ()
          if (a (i, j, k, l) /= r) call abort ()
          if (c (i, j, k, l) /= s) call abort ()
          if (c (i, j, k, l) /= s) call abort ()
        end do
        end do
      end do
      end do
    end do
    end do
  end do
  end do
  if (any (a /= b .or. c /= d)) call abort ()
  if (any (a /= b .or. c /= d)) call abort ()
end
end
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.