-1

我是 cilk 编程的新手。我正在尝试使用 cilk 进行块矩阵乘法。但由于某种原因,我遇到了分段错误。你能帮我解决这个问题吗?

void cilk_vec_mmm(int m, int n, int p, float A[m][1000], float B[p][1000], float C[m][1000]) 
   {
    int s=50;
           for(int i=0;i<m;i+=s)
          {
                for(int j=0;j<p;j+=s)
               {
                   for(int k=0; k<n;k+=s)
                  {
                   C[i:i+(s-1)][j:j+(s-1)]+= A[i:i+s-1][k:k+s-1]*B[k:k+s-1][j:j+s-1];
                  }
               } 
          }
   }
4

1 回答 1

0

下标是错误的。在 Cilk Plus 中,[m:n] 表示下标 m, m+1, m+2, ... m+n-1,这与 Fortran90 中类似的 (m:n) 表示法不同。

于 2014-02-18T16:22:20.850 回答