3#pragma GCC diagnostic push 
    4#pragma GCC diagnostic ignored "-Wshadow" 
    8#pragma GCC diagnostic pop 
  109   using BRange_t = tbb::blocked_range<
decltype(objs.begin())>;
 
  111   auto pred = [redfunc](BRange_t 
const & range, 
T init) {
 
  112      return std::accumulate(range.begin(), range.end(), 
init, redfunc);
 
  115   BRange_t objRange(objs.begin(), objs.end());
 
  117   return tbb::this_task_arena::isolate([&]{
 
  118      return tbb::parallel_reduce(objRange, 
T{}, pred, redfunc);
 
  144      tbb::this_task_arena::isolate([&]{
 
  145         tbb::parallel_for(start, end, step, 
f);
 
  151      return ROOT::Internal::ParallelReduceHelper<double>(objs, redfunc);
 
  156      return ROOT::Internal::ParallelReduceHelper<float>(objs, redfunc);
 
static UInt_t GetPoolSize()
Returns the number of threads running when the scheduler has been instantiated within ROOT.
This class provides a simple interface to execute the same task multiple times in parallel,...
std::shared_ptr< ROOT::Internal::TPoolManager > fSched
void ParallelFor(unsigned start, unsigned end, unsigned step, const std::function< void(unsigned int i)> &f)
TThreadExecutor()
Class constructor.
double ParallelReduce(const std::vector< double > &objs, const std::function< double(double a, double b)> &redfunc)
std::shared_ptr< TPoolManager > GetPoolManager(UInt_t nThreads=0)
Get a shared pointer to the manager.
static T ParallelReduceHelper(const std::vector< T > &objs, const std::function< T(T a, T b)> &redfunc)
A helper function to implement the TThreadExecutor::ParallelReduce methods.
void function(const Char_t *name_, T fun, const Char_t *docstring=0)
Namespace for new ROOT classes and functions.