123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424 |
- /* { dg-do run } */
- extern void abort (void);
- signed char v[5][7][9][21][4][42][3];
- volatile int zero = 0, one = 1, two = 2, three = 3;
- volatile int five = 5, seven = 7, nine = 9, eleven = 11;
- int
- main ()
- {
- for (int i = 0; i < 5; i++)
- for (int j = 0; j < 7; j++)
- for (int k = 0; k < 9; k++)
- for (int l = 2 * j; l < 3 * j; l++)
- for (int m = 7; m < 11; m++)
- for (int n = l; n < 2 * l; n++)
- for (int o = 0; o < 3; o++)
- v[i][j][k][l][m - 7][n][o] = 1;
- int niters = 0;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(7)
- for (int i = 0; i < 5; i++)
- for (int j = 0; j < 7; j++)
- for (int k = 0; k < 9; k++)
- for (int l = 2 * j; l < 3 * j; l++)
- for (int m = 7; m < 11; m++)
- for (int n = l; n < 2 * l; n++)
- for (int o = 0; o < 3; o++)
- {
- niters++;
- if (i < 0 || i >= 5
- || j < 0 || j >= 7
- || k < 0 || k >= 9
- || l < 2 * j || l >= 3 * j
- || m < 7 || m >= 11
- || n < l || n >= 2 * l
- || o < 0 || o >= 3)
- abort ();
- if (v[i][j][k][l][m - 7][n][o] != 1)
- abort ();
- v[i][j][k][l][m - 7][n][o]++;
- }
- if (niters != 117180)
- abort ();
- int niters2 = 0;
- #pragma omp teams reduction(+:niters2)
- #pragma omp distribute collapse(7)
- for (int i = zero; i < five; i += one)
- for (int j = seven - one; j >= zero; j -= one)
- for (int k = nine - one; k >= zero; k += -one)
- for (int l = two * j + zero; l < three * j; l += one)
- for (int m = eleven - one; m >= seven; m -= one)
- for (int n = two * l - one; n > one * l - one; n -= one)
- for (int o = zero; o < three; o += one)
- {
- niters2++;
- if (i < 0 || i >= 5
- || j < 0 || j >= 7
- || k < 0 || k >= 9
- || l < 2 * j || l >= 3 * j
- || m < 7 || m >= 11
- || n < l || n >= 2 * l
- || o < 0 || o >= 3)
- abort ();
- if (v[i][j][k][l][m - 7][n][o] != 2)
- abort ();
- v[i][j][k][l][m - 7][n][o]++;
- }
- if (niters2 != 117180)
- abort ();
- for (int i = 0; i < 5; i++)
- for (int j = 0; j < 7; j++)
- for (int k = 0; k < 9; k++)
- for (int l = 2 * j; l < 3 * j; l++)
- for (int m = 7; m < 11; m++)
- for (int n = l; n < 2 * l; n++)
- for (int o = 0; o < 3; o++)
- if (v[i][j][k][l][m - 7][n][o] != 3)
- abort ();
- int niters3 = 0;
- #pragma omp teams reduction(+:niters3)
- #pragma omp distribute collapse(5)
- for (int i = 4; i >= 0; i--)
- for (int j = 6; j >= 0; --j)
- for (int l = 3 * j - 1; l >= 2 * j; l--)
- for (int n = 2 * l + -1; n > l - 1; --n)
- for (int o = 2; o >= 0; o--)
- {
- niters3++;
- if (i < 0 || i >= 5
- || j < 0 || j >= 7
- || l < 2 * j || l >= 3 * j
- || n < l || n >= 2 * l
- || o < 0 || o >= 3)
- abort ();
- if (v[i][j][0][l][0][n][o] != 3)
- abort ();
- v[i][j][0][l][0][n][o]++;
- }
- if (niters3 != 3255)
- abort ();
- int niters4 = 0;
- #pragma omp teams reduction(+:niters4)
- #pragma omp distribute collapse(5)
- for (int i = zero; i < five; i += one)
- for (int j = zero; j <= seven - one; j += one)
- for (int l = j * two; l < three * j + zero; l += one)
- for (int n = one * l; n <= l * two - one; n += one)
- for (int o = zero; o < three; o += one)
- {
- niters4++;
- if (i < 0 || i >= 5
- || j < 0 || j >= 7
- || l < 2 * j || l >= 3 * j
- || n < l || n >= 2 * l
- || o < 0 || o >= 3)
- abort ();
- if (v[i][j][0][l][0][n][o] != 4)
- abort ();
- v[i][j][0][l][0][n][o]++;
- }
- if (niters4 != 3255)
- abort ();
- for (int i = 0; i < 5; i++)
- for (int j = 0; j < 7; j++)
- for (int l = 2 * j; l < 3 * j; l++)
- for (int n = l; n < 2 * l; n++)
- for (int o = 0; o < 3; o++)
- if (v[i][j][0][l][0][n][o] != 5)
- abort ();
- int niters5 = 0;
- #pragma omp teams reduction(+:niters5)
- #pragma omp distribute collapse(3)
- for (int j = 6; j >= 0; --j)
- for (int l = 2 * j; l <= 3 * j - 1; l++)
- for (int n = 2 * l + -1; n > l - 1; --n)
- {
- niters5++;
- if (j < 0 || j >= 7
- || l < 2 * j || l >= 3 * j
- || n < l || n >= 2 * l)
- abort ();
- if (v[0][j][0][l][0][n][0] != 5)
- abort ();
- v[0][j][0][l][0][n][0]++;
- }
- if (niters5 != 217)
- abort ();
- int niters6 = 0;
- #pragma omp teams reduction(+:niters6)
- #pragma omp distribute collapse(3)
- for (int j = seven - one; j > - one; j -= one)
- for (int l = j * three - one; l >= j * two + zero; l += -one)
- for (int n = two * l - one; n > l - one; n -= one)
- {
- niters6++;
- if (j < 0 || j >= 7
- || l < 2 * j || l >= 3 * j
- || n < l || n >= 2 * l)
- abort ();
- if (v[0][j][0][l][0][n][0] != 6)
- abort ();
- v[0][j][0][l][0][n][0]++;
- }
- if (niters6 != 217)
- abort ();
- for (int j = 0; j < 7; j++)
- for (int l = 2 * j; l < 3 * j; l++)
- for (int n = l; n < 2 * l; n++)
- if (v[0][j][0][l][0][n][0] != 7)
- abort ();
- {
- static int i, j, x;
- static volatile int a, b, c, d, e, f, g, h;
- static int w[13][27];
- for (i = -4; i < 8; i++)
- for (j = 3 * i; j > 2 * i; j--)
- w[i + 5][j + 5] = 1;
- a = -4; b = 8; c = 1; d = 3; e = 0; f = 2; g = 0; h = -1;
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = -4; i < 8; i++)
- for (j = 3 * i; j > 2 * i; j--)
- {
- if (i < -4 || i >= 8 || j > 3 * i || j <= i * 2 || w[i + 5][j + 5] != 1)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (i != 8 || j != 14 || x != 7183 || niters != 28)
- abort ();
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = a; i < b; i += c)
- for (j = d * i + e; j > g + i * f; j += h)
- {
- if (i < -4 || i >= 8 || j > 3 * i || j <= i * 2 || w[i + 5][j + 5] != 2)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (i != 8 || j != 14 || x != 7183 || niters != 28)
- abort ();
- for (int i = -4; i < 8; i++)
- for (int j = 3 * i; j > 2 * i; j--)
- if (w[i + 5][j + 5] == 3)
- w[i + 5][j + 5] = 0;
- else
- abort ();
- for (i = -2; i < 4; i++)
- for (j = -2 * i + 3; j > -3; j -= 2)
- w[i + 5][j + 5] = 1;
- a = -2; b = 4; c = 1; d = -2; e = 3; f = 0; g = -3; h = -2;
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = -2; i < 4; i++)
- for (j = -2 * i + 3; j > -3; j -= 2)
- {
- if (i < -2 || i >= 4 || j <= -3 || j > -2 * i + 3 || w[i + 5][j + 5] != 1)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (/* i != 4 || j != -3 || */x != 3071 || niters != 15)
- abort ();
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = a; i < b; i += c)
- for (j = d * i + e; j > g + i * f; j += h)
- {
- if (i < -2 || i >= 4 || j <= -3 || j > -2 * i + 3 || w[i + 5][j + 5] != 2)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (/*i != 4 || j != -3 || */x != 3071 || niters != 15)
- abort ();
- for (i = -2; i < 4; i++)
- for (j = -2 * i + 3; j > -3; j -= 2)
- if (w[i + 5][j + 5] == 3)
- w[i + 5][j + 5] = 0;
- else
- abort ();
- for (i = 3; i > -3; i--)
- for (j = -2 * i + 7; j > 2 * i + 1; j--)
- w[i + 5][j + 5] = 1;
- a = 3; b = -3; c = -1; d = -2; e = 7; f = 2; g = 1; h = -1;
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = 3; i > -3; i--)
- for (j = -2 * i + 7; j > 2 * i + 1; j--)
- {
- if (i <= -3 || i > 3 || j <= 2 * i + 1 || j > -2 * i + 7 || w[i + 5][j + 5] != 1)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (i != -3 || j != -3 || x != -1026 || niters != 32)
- abort ();
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = a; i > b; i += c)
- for (j = d * i + e; j > g + i * f; j += h)
- {
- if (i <= -3 || i > 3 || j <= 2 * i + 1 || j > -2 * i + 7 || w[i + 5][j + 5] != 2)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (i != -3 || j != -3 || x != -1026 || niters != 32)
- abort ();
- for (i = 3; i > -3; i--)
- for (j = -2 * i + 7; j > 2 * i + 1; j--)
- if (w[i + 5][j + 5] == 3)
- w[i + 5][j + 5] = 0;
- else
- abort ();
- for (i = 3; i > -3; i--)
- for (j = 2 * i + 7; j > -2 * i + 1; j--)
- w[i + 5][j + 5] = 1;
- a = 3; b = -3; c = -1; d = 2; e = 7; f = -2; g = 1; h = -1;
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = 3; i > -3; i--)
- for (j = 2 * i + 7; j > -2 * i + 1; j--)
- {
- if (i <= -3 || i > 3 || j <= -2 * i + 1 || j > 2 * i + 7 || w[i + 5][j + 5] != 1)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (/*i != -3 || j != 3 || */x != -1020 || niters != 50)
- abort ();
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = a; i > b; i += c)
- for (j = d * i + e; j > g + i * f; j += h)
- {
- if (i <= -3 || i > 3 || j <= -2 * i + 1 || j > 2 * i + 7 || w[i + 5][j + 5] != 2)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (/*i != -3 || j != 3 || */x != -1020 || niters != 50)
- abort ();
- for (i = 3; i > -3; i--)
- for (j = 2 * i + 7; j > -2 * i + 1; j--)
- if (w[i + 5][j + 5] == 3)
- w[i + 5][j + 5] = 0;
- else
- abort ();
- for (i = 6; i > -6; i--)
- for (j = 2 * i + 7; j <= -2 * i + 1; j++)
- w[i + 5][j + 5] = 1;
- a = 6; b = -6; c = -1; d = 2; e = 7; f = -2; g = 2; h = 1;
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = 6; i > -6; i--)
- for (j = 2 * i + 7; j <= -2 * i + 1; j++)
- {
- if (i <= -6 || i > 6 || j < 2 * i + 7 || j >= -2 * i + 2 || w[i + 5][j + 5] != 1)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (i != -6 || j != 12 || x != -5109 || niters != 36)
- abort ();
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = a; i > b; i += c)
- for (j = d * i + e; j < g + i * f; j += h)
- {
- if (i <= -6 || i > 6 || j < 2 * i + 7 || j >= -2 * i + 2 || w[i + 5][j + 5] != 2)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (i != -6 || j != 12 || x != -5109 || niters != 36)
- abort ();
- for (i = 6; i > -6; i--)
- for (j = 2 * i + 7; j <= -2 * i + 1; j++)
- if (w[i + 5][j + 5] == 3)
- w[i + 5][j + 5] = 0;
- else
- abort ();
- for (i = 6; i > -6; i -= 2)
- for (j = -2 * i + 7; j <= 2 * i + 1; j++)
- w[i + 5][j + 5] = 1;
- a = 6; b = -6; c = -2; d = -2; e = 7; f = 2; g = 2; h = 1;
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = 6; i > -6; i -= 2)
- for (j = -2 * i + 7; j <= 2 * i + 1; j++)
- {
- if (i <= -6 || i > 6 || j < -2 * i + 7 || j >= 2 * i + 2 || w[i + 5][j + 5] != 1)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (/*i != -6 || j != 15 || */x != 2053 || niters != 33)
- abort ();
- niters = 0; i = -100; j = -100; x = -100;
- #pragma omp teams reduction(+:niters)
- #pragma omp distribute collapse(2) lastprivate (i, j, x)
- for (i = a; i > b; i += c)
- for (j = d * i + e; j < g + i * f; j += h)
- {
- if (i <= -6 || i > 6 || j < -2 * i + 7 || j >= 2 * i + 2 || w[i + 5][j + 5] != 2)
- abort ();
- w[i + 5][j + 5]++;
- x = i * 1024 + (j & 1023);
- niters++;
- }
- if (/*i != -6 || j != 15 || */x != 2053 || niters != 33)
- abort ();
- for (i = 6; i > -6; i -= 2)
- for (j = -2 * i + 7; j <= 2 * i + 1; j++)
- if (w[i + 5][j + 5] == 3)
- w[i + 5][j + 5] = 0;
- else
- abort ();
- }
- return 0;
- }
|