File: pr83403.h

package info (click to toggle)
gcc-arm-none-eabi 15%3A14.2.rel1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,099,328 kB
  • sloc: cpp: 3,627,108; ansic: 2,571,498; ada: 834,230; f90: 235,082; makefile: 79,231; asm: 74,984; xml: 51,692; exp: 39,736; sh: 33,298; objc: 15,629; python: 15,069; fortran: 14,429; pascal: 7,003; awk: 5,070; perl: 3,106; ml: 285; lisp: 253; lex: 204; haskell: 135
file content (30 lines) | stat: -rw-r--r-- 600 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
__attribute__ ((noinline)) void
calculate (const double *__restrict__ A, const double *__restrict__ B,
	   double *__restrict__ C)
{
  TYPE m = 0;
  TYPE n = 0;
  TYPE k = 0;

  A = (const double *) __builtin_assume_aligned (A, 16);
  B = (const double *) __builtin_assume_aligned (B, 16);
  C = (double *) __builtin_assume_aligned (C, 16);

  for (n = 0; n < 9; n++)
    {
      for (m = 0; m < 10; m++)
	{
	  C[(n * 10) + m] = 0.0;
	}

      for (k = 0; k < 17; k++)
	{
#pragma simd
	  for (m = 0; m < 10; m++)
	    {
	      C[(n * 10) + m] += A[(k * 20) + m] * B[(n * 20) + k];
	    }
	}
    }
}