OpenMPを使用してコードを並列化しています。私はループを2つのイテレータで並列化しようとします。イテレータopenMPのループ
#include <iostream>
#include <vector>
#include <omp.h>
using namespace std;
int main(int argc, char *argv[])
{
vector<float> v = {1, 2, 3, 4};
vector<float> d = {0, 0, 0, 0};
vector<float>::iterator iterV, iterD;
for(iterV = v.begin(), iterD = d.begin(); iterV < v.end(); ++iterV, ++iterD)
{
*iterD = *iterV;
}
for(iterD = d.begin(); iterD < d.end(); ++iterD)
cout << *iterD << endl;
return 0;
}
このコードの私の並列バージョン:
#include <iostream>
#include <vector>
#include <omp.h>
using namespace std;
int main(int argc, char *argv[])
{
vector<float> v = {1, 2, 3, 4};
vector<float> d = {0, 0, 0, 0};
vector<float>::iterator iterV, iterD;
iterV = v.begin();
iterD = d.begin();
#pragma omp parallel for
for(int i = 0; i < v.size(); ++i)
{
*(iterD + i) = *(iterV + i) ;
}
for(iterD = d.begin(); iterD < d.end(); ++iterD)
cout << *iterD << endl;
return 0;
}`
_ "私のコードを麻痺させる" _ああ、いけません。それに値するコードはありません。あなたはおそらくそれを並列化しようとしました。 –
通常、並列化はパフォーマンス向上のためだけではありません。残念ながら、貴重なパフォーマンス最適化のアドバイスを与えるためにあなたの例はあまりにも合成されています。私はシリアルバージョンで 'std :: copy. 'を使うべきだと言うことができます。 – Zulan
私は私のニーズをよく理解するために例を合成します。私はちょうどopenMPで並列化する最良の方法を2つのイテレータでループしているかどうかを知りたいと思います。 – axel