共有配列と共有ブールフラグで動作する2つのネストされた for(s) があります。配列に書き込もうとしているときに衝突する可能性があることはわかっていますが、これらのセクションをクリティカルにすると、これを並列化することのすべての利点が失われます。これを回避し、並行して作業する方法はありますか? ありがとう
#pragma omp parallel
{
#pragma omp for schedule (guided)
for(int i=0;i<N-1;i++)
{
for(int j=i+1;j<N;j++)
{
if(cluster[i*N+j]!=0)
{
inner_set[i]=1;// Critical???
inner_set[j]=1;
}
else
{
outter_set[i]=1;
}
}
}
}
do
{
isChanged=false;
#pragma omp parallel for schedule (guided)
for(int i=0; i<N; i++)
{
if(inner_set[i]!=0)
{
for (int j=0; j<N;j++)
{
if(i!=j && outter_set[j]!=0)
{
if(dis[i*N+j]<Dis)
{
isChanged=true;
inner_set[i]=0;//critical???
outter_set[i]=1;
}
}
}
}
}
}while(isChanged);