1

コンウェイのライフ ゲーム用に openMP コードを最適化しようとしています。私の主な問題は、おそらく偽の共有に関連しています。これが私のコードです: これは私のクラス「mondo」のメソッドです。m は私のスキーム、r は行数、c は列数で、トロイダル スキームを使用しています。

void evolution() {
    mondo tmp(r, c);
    #pragma omp parallel for schedule(static)
    for(int i=0; i<r; i++) {  
        unsigned a=(i+1)%r, b=(i-1+r)%r;        
        for(int j=0; j<c; j++)  {                                 
            unsigned d=(j+1)%c, e=(j-1+c)%c;     
            int v=(m[a][j]+m[b][j]+m[a][d]+m[b][d]+m[a][e]+m[b][e]+m[i][d]+m[i][e]);             
            if(m[i][j]==1) {              
                if(v<2 || v>3)
                   tmp.m[i][j]=0;
                else  
                    tmp.m[i][j]=1;              
            } 
            else {
                if(v==3)
                   tmp.m[i][j]=1;
                else
                   tmp.m[i][j]=0;
            }                          
        }
    }    
    (*this)=tmp;
}
4

0 に答える 0