123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273 |
- #ifndef VARS
- #define VARS
- int a[1500];
- float b[10][15][10];
- __attribute__((noreturn)) void
- noreturn (void)
- {
- for (;;);
- }
- #endif
- #ifndef SC
- #define SC
- #endif
- __attribute__((noinline, noclone)) void
- N(f0) (void)
- {
- int i;
- #pragma omp F S
- for (i = 0; i < 1500; i++)
- a[i] += 2;
- }
- __attribute__((noinline, noclone)) void
- N(f1) (void)
- {
- #pragma omp F S
- for (unsigned int i = __INT_MAX__; i < 3000U + __INT_MAX__; i += 2)
- a[(i - __INT_MAX__) >> 1] -= 2;
- }
- __attribute__((noinline, noclone)) void
- N(f2) (void)
- {
- unsigned long long i;
- #pragma omp F S
- for (i = __LONG_LONG_MAX__ + 4500ULL - 27;
- i > __LONG_LONG_MAX__ - 27ULL; i -= 3)
- a[(i + 26LL - __LONG_LONG_MAX__) / 3] -= 4;
- }
- __attribute__((noinline, noclone)) void
- N(f3) (long long n1, long long n2, long long s3)
- {
- #pragma omp F S
- for (long long i = n1 + 23; i > n2 - 25; i -= s3)
- a[i + 48] += 7;
- }
- __attribute__((noinline, noclone)) void
- N(f4) (void)
- {
- unsigned int i;
- #pragma omp F S
- for (i = 30; i < 20; i += 2)
- a[i] += 10;
- }
- __attribute__((noinline, noclone)) void
- N(f5) (int n11, int n12, int n21, int n22, int n31, int n32,
- int s1, int s2, int s3)
- {
- SC int v1, v2, v3;
- #pragma omp F S collapse(3)
- for (v1 = n11; v1 < n12; v1 += s1)
- for (v2 = n21; v2 < n22; v2 += s2)
- for (v3 = n31; v3 < n32; v3 += s3)
- b[v1][v2][v3] += 2.5;
- }
- __attribute__((noinline, noclone)) void
- N(f6) (int n11, int n12, int n21, int n22, long long n31, long long n32,
- int s1, int s2, long long int s3)
- {
- SC int v1, v2;
- SC long long v3;
- #pragma omp F S collapse(3)
- for (v1 = n11; v1 > n12; v1 += s1)
- for (v2 = n21; v2 > n22; v2 += s2)
- for (v3 = n31; v3 > n32; v3 += s3)
- b[v1][v2 / 2][v3] -= 4.5;
- }
- __attribute__((noinline, noclone)) void
- N(f7) (void)
- {
- SC unsigned int v1, v3;
- SC unsigned long long v2;
- #pragma omp F S collapse(3)
- for (v1 = 0; v1 < 20; v1 += 2)
- for (v2 = __LONG_LONG_MAX__ + 16ULL;
- v2 > __LONG_LONG_MAX__ - 29ULL; v2 -= 3)
- for (v3 = 10; v3 > 0; v3--)
- b[v1 >> 1][(v2 - __LONG_LONG_MAX__ + 64) / 3 - 12][v3 - 1] += 5.5;
- }
- __attribute__((noinline, noclone)) void
- N(f8) (void)
- {
- SC long long v1, v2, v3;
- #pragma omp F S collapse(3)
- for (v1 = 0; v1 < 20; v1 += 2)
- for (v2 = 30; v2 < 20; v2++)
- for (v3 = 10; v3 < 0; v3--)
- b[v1][v2][v3] += 5.5;
- }
- __attribute__((noinline, noclone)) void
- N(f9) (void)
- {
- int i;
- #pragma omp F S
- for (i = 20; i < 10; i++)
- {
- a[i] += 2;
- noreturn ();
- a[i] -= 4;
- }
- }
- __attribute__((noinline, noclone)) void
- N(f10) (void)
- {
- SC int i;
- #pragma omp F S collapse(3)
- for (i = 0; i < 10; i++)
- for (int j = 10; j < 8; j++)
- for (long k = -10; k < 10; k++)
- {
- b[i][j][k] += 4;
- noreturn ();
- b[i][j][k] -= 8;
- }
- }
- __attribute__((noinline, noclone)) void
- N(f11) (int n)
- {
- int i;
- #pragma omp F S
- for (i = 20; i < n; i++)
- {
- a[i] += 8;
- noreturn ();
- a[i] -= 16;
- }
- }
- __attribute__((noinline, noclone)) void
- N(f12) (int n)
- {
- SC int i;
- #pragma omp F S collapse(3)
- for (i = 0; i < 10; i++)
- for (int j = n; j < 8; j++)
- for (long k = -10; k < 10; k++)
- {
- b[i][j][k] += 16;
- noreturn ();
- b[i][j][k] -= 32;
- }
- }
- __attribute__((noinline, noclone)) void
- N(f13) (void)
- {
- int *i;
- #pragma omp F S
- for (i = a; i < &a[1500]; i++)
- i[0] += 2;
- }
- __attribute__((noinline, noclone)) void
- N(f14) (void)
- {
- SC float *i;
- #pragma omp F S collapse(3)
- for (i = &b[0][0][0]; i < &b[0][0][10]; i++)
- for (float *j = &b[0][15][0]; j > &b[0][0][0]; j -= 10)
- for (float *k = &b[0][0][10]; k > &b[0][0][0]; --k)
- b[i - &b[0][0][0]][(j - &b[0][0][0]) / 10 - 1][(k - &b[0][0][0]) - 1]
- -= 3.5;
- }
- __attribute__((noinline, noclone)) int
- N(test) (void)
- {
- int i, j, k;
- for (i = 0; i < 1500; i++)
- a[i] = i - 25;
- N(f0) ();
- for (i = 0; i < 1500; i++)
- if (a[i] != i - 23)
- return 1;
- N(f1) ();
- for (i = 0; i < 1500; i++)
- if (a[i] != i - 25)
- return 1;
- N(f2) ();
- for (i = 0; i < 1500; i++)
- if (a[i] != i - 29)
- return 1;
- N(f3) (1500LL - 1 - 23 - 48, -1LL + 25 - 48, 1LL);
- for (i = 0; i < 1500; i++)
- if (a[i] != i - 22)
- return 1;
- N(f3) (1500LL - 1 - 23 - 48, 1500LL - 1, 7LL);
- for (i = 0; i < 1500; i++)
- if (a[i] != i - 22)
- return 1;
- N(f4) ();
- for (i = 0; i < 1500; i++)
- if (a[i] != i - 22)
- return 1;
- for (i = 0; i < 10; i++)
- for (j = 0; j < 15; j++)
- for (k = 0; k < 10; k++)
- b[i][j][k] = i - 2.5 + 1.5 * j - 1.5 * k;
- N(f5) (0, 10, 0, 15, 0, 10, 1, 1, 1);
- for (i = 0; i < 10; i++)
- for (j = 0; j < 15; j++)
- for (k = 0; k < 10; k++)
- if (b[i][j][k] != i + 1.5 * j - 1.5 * k)
- return 1;
- N(f5) (0, 10, 30, 15, 0, 10, 4, 5, 6);
- for (i = 0; i < 10; i++)
- for (j = 0; j < 15; j++)
- for (k = 0; k < 10; k++)
- if (b[i][j][k] != i + 1.5 * j - 1.5 * k)
- return 1;
- N(f6) (9, -1, 29, 0, 9, -1, -1, -2, -1);
- for (i = 0; i < 10; i++)
- for (j = 0; j < 15; j++)
- for (k = 0; k < 10; k++)
- if (b[i][j][k] != i - 4.5 + 1.5 * j - 1.5 * k)
- return 1;
- N(f7) ();
- for (i = 0; i < 10; i++)
- for (j = 0; j < 15; j++)
- for (k = 0; k < 10; k++)
- if (b[i][j][k] != i + 1.0 + 1.5 * j - 1.5 * k)
- return 1;
- N(f8) ();
- for (i = 0; i < 10; i++)
- for (j = 0; j < 15; j++)
- for (k = 0; k < 10; k++)
- if (b[i][j][k] != i + 1.0 + 1.5 * j - 1.5 * k)
- return 1;
- N(f9) ();
- N(f10) ();
- N(f11) (10);
- N(f12) (12);
- for (i = 0; i < 1500; i++)
- if (a[i] != i - 22)
- return 1;
- for (i = 0; i < 10; i++)
- for (j = 0; j < 15; j++)
- for (k = 0; k < 10; k++)
- if (b[i][j][k] != i + 1.0 + 1.5 * j - 1.5 * k)
- return 1;
- N(f13) ();
- N(f14) ();
- for (i = 0; i < 1500; i++)
- if (a[i] != i - 20)
- return 1;
- for (i = 0; i < 10; i++)
- for (j = 0; j < 15; j++)
- for (k = 0; k < 10; k++)
- if (b[i][j][k] != i - 2.5 + 1.5 * j - 1.5 * k)
- return 1;
- return 0;
- }
|