Commit 0966b2de authored by Oded Green's avatar Oded Green

Removed openmp from code

parent 7579ef5d
...@@ -50,11 +50,6 @@ A previous and less efficient version of the algorithm can be found: ...@@ -50,11 +50,6 @@ A previous and less efficient version of the algorithm can be found:
*/ */
#include "precomp.hpp" #include "precomp.hpp"
//#include <opencv2/opencv.hpp>
#ifdef HAVE_OPENMP
#include <omp.h>
#endif
using namespace cv; using namespace cv;
using namespace std; using namespace std;
...@@ -101,7 +96,6 @@ private: ...@@ -101,7 +96,6 @@ private:
int nc; int nc;
int pr; int pr;
int pc; int pc;
int threads;
std::vector<Combination> combinationsTable; std::vector<Combination> combinationsTable;
}; };
...@@ -110,13 +104,6 @@ private: ...@@ -110,13 +104,6 @@ private:
EstimateCovariance::EstimateCovariance(int pr_, int pc_){ EstimateCovariance::EstimateCovariance(int pr_, int pc_){
pr=pr_; pc=pc_; pr=pr_; pc=pc_;
#ifdef HAVE_OPENMP
threads=omp_get_num_procs();
omp_set_num_threads(threads);
#else
threads=1;
#endif
} }
EstimateCovariance::~EstimateCovariance(){ EstimateCovariance::~EstimateCovariance(){
...@@ -178,47 +165,19 @@ void EstimateCovariance::computeEstimateCovariance(Mat inputData,Mat outputData) ...@@ -178,47 +165,19 @@ void EstimateCovariance::computeEstimateCovariance(Mat inputData,Mat outputData)
void EstimateCovariance::iterateCombinations(Mat inputData,Mat outputData) void EstimateCovariance::iterateCombinations(Mat inputData,Mat outputData)
{ {
int combsPerCPU = combinationCount()/threads; Mat outputVector(pr*pc,1, DataType<std::complex<float> >::type);
int remainder = combinationCount()%threads;
if(remainder>0) std::vector<int> finalMatPosR(pr*pc,0);
combsPerCPU++; std::vector<int> finalMatPosC(pr*pc,0);
int combs=combinationCount();
#ifdef HAVE_OPENMP for (int idx=0; idx<combs; idx++){
#pragma omp parallel outputVector.setTo(Scalar(0,0));
#endif for (unsigned x=0; x<finalMatPosR.size(); x++)
{ finalMatPosR[x]=0;
int idx; for (unsigned x=0; x<finalMatPosC.size(); x++)
int combs; finalMatPosC[x]=0;
#ifdef HAVE_OPENMP computeOneCombination(idx++, inputData, outputData,
int thread_id= omp_get_thread_num(); outputVector,finalMatPosR, finalMatPosC);
#else
int thread_id=0;
#endif
int startComb;
if (remainder > thread_id){
combs=combsPerCPU;
startComb=(thread_id)*combsPerCPU;
}
else{
combs=combsPerCPU-1;
startComb=remainder*combsPerCPU+(thread_id-remainder)*(combsPerCPU-1);
}
Mat outputVector(pr*pc,1, DataType<std::complex<float> >::type);
std::vector<int> finalMatPosR(pr*pc,0);
std::vector<int> finalMatPosC(pr*pc,0);
for (idx=0; idx<combs; idx++){
outputVector.setTo(Scalar(0,0));
for (unsigned x=0; x<finalMatPosR.size(); x++)
finalMatPosR[x]=0;
for (unsigned x=0; x<finalMatPosC.size(); x++)
finalMatPosC[x]=0;
computeOneCombination(startComb++, inputData, outputData,
outputVector,finalMatPosR, finalMatPosC);
}
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment