Fix for TimeTBB not compiling on linux
parent
314c44b0ad
commit
b4942110bc
|
@ -47,14 +47,11 @@ struct ResultWithThreads
|
||||||
typedef map<int, ResultWithThreads> Results;
|
typedef map<int, ResultWithThreads> Results;
|
||||||
|
|
||||||
/* ************************************************************************* */
|
/* ************************************************************************* */
|
||||||
map<int, double> testWithoutMemoryAllocation()
|
struct WorkerWithoutAllocation
|
||||||
{
|
{
|
||||||
// A function to do some matrix operations without allocating any memory
|
|
||||||
struct Worker
|
|
||||||
{
|
|
||||||
vector<double>& results;
|
vector<double>& results;
|
||||||
|
|
||||||
Worker(vector<double>& results) : results(results) {}
|
WorkerWithoutAllocation(vector<double>& results) : results(results) {}
|
||||||
|
|
||||||
void operator()(const tbb::blocked_range<size_t>& r) const
|
void operator()(const tbb::blocked_range<size_t>& r) const
|
||||||
{
|
{
|
||||||
|
@ -66,7 +63,12 @@ map<int, double> testWithoutMemoryAllocation()
|
||||||
results[i] = prod.norm();
|
results[i] = prod.norm();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* ************************************************************************* */
|
||||||
|
map<int, double> testWithoutMemoryAllocation()
|
||||||
|
{
|
||||||
|
// A function to do some matrix operations without allocating any memory
|
||||||
|
|
||||||
// Now call it
|
// Now call it
|
||||||
vector<double> results(numberOfProblems);
|
vector<double> results(numberOfProblems);
|
||||||
|
@ -76,7 +78,7 @@ map<int, double> testWithoutMemoryAllocation()
|
||||||
BOOST_FOREACH(size_t grainSize, grainSizes)
|
BOOST_FOREACH(size_t grainSize, grainSizes)
|
||||||
{
|
{
|
||||||
tbb::tick_count t0 = tbb::tick_count::now();
|
tbb::tick_count t0 = tbb::tick_count::now();
|
||||||
tbb::parallel_for(tbb::blocked_range<size_t>(0, numberOfProblems), Worker(results));
|
tbb::parallel_for(tbb::blocked_range<size_t>(0, numberOfProblems), WorkerWithoutAllocation(results));
|
||||||
tbb::tick_count t1 = tbb::tick_count::now();
|
tbb::tick_count t1 = tbb::tick_count::now();
|
||||||
cout << "Without memory allocation, grain size = " << grainSize << ", time = " << (t1 - t0).seconds() << endl;
|
cout << "Without memory allocation, grain size = " << grainSize << ", time = " << (t1 - t0).seconds() << endl;
|
||||||
timingResults[grainSize] = (t1 - t0).seconds();
|
timingResults[grainSize] = (t1 - t0).seconds();
|
||||||
|
@ -86,14 +88,11 @@ map<int, double> testWithoutMemoryAllocation()
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ************************************************************************* */
|
/* ************************************************************************* */
|
||||||
map<int, double> testWithMemoryAllocation()
|
struct WorkerWithAllocation
|
||||||
{
|
{
|
||||||
// A function to do some matrix operations with allocating memory
|
|
||||||
struct Worker
|
|
||||||
{
|
|
||||||
vector<double>& results;
|
vector<double>& results;
|
||||||
|
|
||||||
Worker(vector<double>& results) : results(results) {}
|
WorkerWithAllocation(vector<double>& results) : results(results) {}
|
||||||
|
|
||||||
void operator()(const tbb::blocked_range<size_t>& r) const
|
void operator()(const tbb::blocked_range<size_t>& r) const
|
||||||
{
|
{
|
||||||
|
@ -117,7 +116,12 @@ map<int, double> testWithMemoryAllocation()
|
||||||
allocator.deallocate(proddata, problemSize * problemSize);
|
allocator.deallocate(proddata, problemSize * problemSize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* ************************************************************************* */
|
||||||
|
map<int, double> testWithMemoryAllocation()
|
||||||
|
{
|
||||||
|
// A function to do some matrix operations with allocating memory
|
||||||
|
|
||||||
// Now call it
|
// Now call it
|
||||||
vector<double> results(numberOfProblems);
|
vector<double> results(numberOfProblems);
|
||||||
|
@ -127,7 +131,7 @@ map<int, double> testWithMemoryAllocation()
|
||||||
BOOST_FOREACH(size_t grainSize, grainSizes)
|
BOOST_FOREACH(size_t grainSize, grainSizes)
|
||||||
{
|
{
|
||||||
tbb::tick_count t0 = tbb::tick_count::now();
|
tbb::tick_count t0 = tbb::tick_count::now();
|
||||||
tbb::parallel_for(tbb::blocked_range<size_t>(0, numberOfProblems), Worker(results));
|
tbb::parallel_for(tbb::blocked_range<size_t>(0, numberOfProblems), WorkerWithAllocation(results));
|
||||||
tbb::tick_count t1 = tbb::tick_count::now();
|
tbb::tick_count t1 = tbb::tick_count::now();
|
||||||
cout << "With memory allocation, grain size = " << grainSize << ", time = " << (t1 - t0).seconds() << endl;
|
cout << "With memory allocation, grain size = " << grainSize << ", time = " << (t1 - t0).seconds() << endl;
|
||||||
timingResults[grainSize] = (t1 - t0).seconds();
|
timingResults[grainSize] = (t1 - t0).seconds();
|
||||||
|
|
Loading…
Reference in New Issue