tbb中平行Reduce的Reduce是什么
What is the Reduce for a parallel_reduce in tbb?
parallel_reduce
提供了两个接口,其中一个用于Lambda,可以像前面的链接中所示那样使用
#include "tbb/parallel_reduce.h"
#include "tbb/blocked_range.h"
using namespace tbb;
float ParallelSum( float array[], size_t n ) {
return parallel_reduce(
blocked_range<float*>( array, array+n ),
0.f,
[](const blocked_range<float*>& r, float init)->float {
for( float* a=r.begin(); a!=r.end(); ++a )
init += *a;
return init;
},
[]( float x, float y )->float { // what this lambda does ?
return x+y;
}
);
}
第二个lambda适合const Reduction& reduction
签名,我正在研究这个lambda,试图改变主体或值,但它什么都不做(即使我在里面放了cout
,也不会发生任何事情),看起来它是无缘无故存在的。
这个Reduction
的目的是什么?和0f
有关吗?就我所知,0f
是一个谓词,用于检测哪些值可以跳过,但我仍然无法弄清楚lambda的作用。。。
第一个lambda计算该范围内的表达式,并给出该范围的结果。
第二个lambda组合两个范围计算的结果,给出两个范围组合的结果。
只有当parallel_reduce
将运算分解为多个范围时,才会调用第二个lambda。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 是什么原因导致它无法编译?它是声明签名还是在函数本身的实现中
- tbb中平行Reduce的Reduce是什么