我正在使用OpenMP來並行化for循環。我試圖通過線程ID訪問C++ Armadillo向量,但是我想知道是否必須將訪問放在關鍵部分,即使不同線程訪問不相交區域的內存。 這是我的代碼:OpenMP:當我通過線程ID訪問共享變量時是否需要臨界區域
#include <armadillo>
#include <omp.h>
#include <iostream>
int main()
{
arma::mat A = arma::randu<arma::mat>(1000,700);
arma::rowvec point = A.row(0);
arma::vec distances = arma::zeros(omp_get_max_threads());
#pragma omp parallel shared(A,point,distances)
{
arma::vec local_distances = arma::zeros(omp_get_num_threads());
int thread_id = omp_get_thread_num();
for(unsigned int l = 0; l < A.n_rows; l++){
double temp = arma::norm(A.row(l) - point,2);
if(temp > local_distances[thread_id])
local_distances[thread_id] = temp;
}
// Is it necessary to put a critical section here?
#pragma omp critical
if(local_distances[thread_id] > distances[thread_id]){
distances[thread_id] = local_distances[thread_id];
}
}
std::cout << distances[distances.index_max()] << std::endl;
}
是否有必要把讀/在我的情況寫入distances
載體?
不,這不應該要求關鍵部分。 – subzero