为什么C++升压库中的累加器具有类似功能的界面?
Why do the accumulators from the C++ boost library have a function-like interface?
在提升库中,我们使用这样的累加器:
acc(1); // push things into acc
cout << max( acc ) << endl; // get its result
为什么我们不能像这样定义它的接口:
acc.push(1);
cout << acc.max() << endl;
那么,为什么来自 boost 库的累加器具有类似函数的界面呢?它有什么好处?
这里有两个原因:
-
您可以将它们传递给算法,例如
for_each
:acc = std::for_each(range.begin(), range.end(), acc);
-
这为所有累加器提供了一个统一的接口。这有助于将它们结合起来,例如。与
accumulator_set
.
这是我的猜测
运算符()
用于推送而不是push()
的原因是因为acc(value)
读取"累积另一个值">,这听起来比acc.push(value)
"将值推送到累加器">更自然
此外,累加器可以接收协变量或权重等可选功能,这样结果看起来和听起来可能比acc.push(value, feature)
更好。文档中的一些示例:
acc( 1.2, covariate1 = 12 );
acc( 2.3, covariate1 = -23 );
acc( 3.4, covariate1 = 34 );
acc( 4.5, covariate1 = -45 );
acc(1, weight = 2); // 1 * 2
acc(2, weight = 4); // 2 * 4
acc(3, weight = 6); // + 3 * 6
acc(1, weight = 2, covariate1 = 3);
acc(0, weight = 4, covariate1 = 4);
acc(2, weight = 9, covariate1 = 8);
然后使用max(acc)
而不是acc.max()
,因为它允许可扩展性,同时仍保持一致性。通过编写一个接收累加器的新功能,您将能够对累积列表执行其他操作
std::cout << "Mean: " << mean(acc) << std::endl;
std::cout << "Moment: " << accumulators::moment<2>(acc) << std::endl;
如果使用了成员方法,那么将只有有限数量的默认操作,如acc.mean()
、acc.max()
,其余的东西必须像product(acc)
、rolling_moment<2>(acc)
、kurtosis(acc)
、skewness(acc)
等函数一样使用......这会破坏一致性
相关文章:
- 在执行其他功能的同时播放动画(LED矩阵和Arduino/ESP8266)
- 多态性和功能结合
- 带内存和隔离功能的SQLite
- 在CMakeLists.txt的安装功能中使用.cmake文件有什么用
- 类模板的成员功能的定义在单独的TU中完全专业化
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++中获得"静态纯虚拟"功能?
- 两个文件使用彼此的功能-如何解决
- 我应该实现右值推送功能吗?我应该使用std::move吗
- QML按钮点击功能执行顺序
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 有没有可能有一个只有ADL才能找到的非好友功能
- 功能样式转换从 'int' 到 'ItemType' 的匹配转换
- 文件系统:复制功能的速度秘诀是什么
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 可以使用仅功能成员属性进行回调界面
- 为什么C++升压库中的累加器具有类似功能的界面?
- 界面设计:超载功能的安全性采用字符串和字符阵列
- 声明迭代功能的界面
- 用户界面-GUI和文本模式C++设计,以消除冗余(可选参数?功能过载?)