C++ Boost Accumulators累加器详细讲解

 更新时间:2022年11月28日 08:47:40   作者:无水先生  
Boost是为C++语言标准库提供扩展的一些C++程序库的总称。Boost库是一个可移植、提供源代码的C++库,作为标准库的后备,是C++标准化进程的开发引擎之一,是为C++语言标准库提供扩展的一些C++程序库的总称

Boost.Accumulators 

        Boost.Accumulators 提供了处理样本的类。例如,您可以找到最大或最小的样本,或者计算所有样本的总和。虽然标准库支持其中一些操作,但 Boost.Accumulators 还支持统计计算,例如均值和标准差。

        该库称为 Boost.Accumulators,因为累加器是一个基本概念。累加器是一个容器,每次插入一个值时都会计算出一个新的结果。该值不一定存储在累加器中。相反,累加器在输入新值时不断更新中间结果。

        Boost.Accumulators 包含三个部分:

  • 框架提供了库的整体结构。它提供类 boost::accumulators::accumulator_set,它总是与 Boost.Accumulators 一起使用。虽然您需要了解这个类和框架中的其他一些类,但细节并不重要,除非您想开发自己的累加器。头文件 boost/accumulators/accumulators.hpp 使您可以访问 boost::accumulators::accumulator_set 和框架中的其他类。
  • Boost.Accumulators 提供了许多执行计算的累加器。一旦包含 boost/accumulators/statistics.hpp,您就可以访问和使用所有这些累加器。
  • Boost.Accumulators 提供运算符,例如,将一个 std::complex 类型的复数与一个 int 值相乘或将两个向量相加。头文件 boost/accumulators/numeric/functional.hpp 定义了 std::complex、std::valarray 和 std::vector 的运算符。您不需要自己包含头文件,因为它包含在累加器的头文件中。但是,您必须定义宏 BOOST_NUMERIC_FUNCTIONAL_STD_COMPLEX_SUPPORT、BOOST_NUMERIC_FUNCTIONAL_STD_VALARRAY_SUPPORT 和 BOOST_NUMERIC_FUNCTIONAL_STD_VECTOR_SUPPORT 以使运算符可用。

        Boost.Accumulators 提供的所有类和函数都在 boost::accumulators 或嵌套命名空间中定义。例如,所有累加器都在 boost::accumulators::tag 中定义。

示例 58.1。使用 boost::accumulators::tag::count 计数

#include <boost/accumulators/accumulators.hpp>
#include <boost/accumulators/statistics.hpp>
#include <iostream>
using namespace boost::accumulators;
int main()
{
  accumulator_set<int, features<tag::count>> acc;
  acc(4);
  acc(-6);
  acc(9);
  std::cout << count(acc) << '\n';
}

Example 58.1 

        示例 58.1 使用 boost::accumulators::tag::count,这是一个简单的累加器,用于计算传递给它的值的数量。因此,由于传递了三个值,此示例将 3 写入标准输出。要使用累加器,您需要访问类 boost::accumulators::accumulator_set,这是一个模板,它期望将要处理的值的类型作为其第一个参数。示例 58.1 将 int 作为第一个参数传递。

        第二个参数指定要使用的累加器。您可以使用多个累加器。类名 boost::accumulators::accumulator_set 表示可以管理任意数量的累加器。

        严格来说,您指定的是特征,而不是累加器。特征定义了应该计算什么。你决定什么,而不是如何。功能可以有不同的实现。实现是累加器。

        示例 58.1 使用 boost::accumulators::tag::count 选择一个计算值的累加器。如果存在多个可以计算值的累加器,Boost.Accumulators 会选择默认的累加器。

        请注意,您不能将特征直接传递给 boost::accumulators::accumulator_set。您需要使用 boost::accumulators::features。

        boost::accumulators::accumulator_set 类型的对象可以像函数一样使用。可以通过调用 operator() 来传递值。它们会立即得到处理。传递的值必须与作为第一个模板参数传递给 boost::accumulators::accumulator_set 的类型相同。

        对于每个特征,都有一个同名的提取器。提取器接收累加器的当前结果。示例 58.1 使用提取器 boost::accumulators::count()。传递的唯一参数是 acc。 boost::accumulators::count() 返回 3。

        示例 58.2。使用均值和方差

#include <boost/accumulators/accumulators.hpp>
#include <boost/accumulators/statistics.hpp>
#include <iostream>
using namespace boost::accumulators;
int main()
{
  accumulator_set<double, features<tag::mean, tag::variance>> acc;
  acc(8);
  acc(9);
  acc(10);
  acc(11);
  acc(12);
  std::cout << mean(acc) << '\n';
  std::cout << variance(acc) << '\n';
}

Example 58.2 

        示例 58.2 使用两个特征 boost::accumulators::tag::mean 和 boost::accumulators::tag::variance 来计算五个值的均值和方差。该示例将 10 和 2 写入标准输出。

        方差为 2,因为 Boost.Accumulators 为五个值中的每一个分配了 0.2 的权重。使用 boost::accumulators::tag::variance 选择的累加器使用权重。如果未明确设置权重,则所有值都具有相同的权重。

        示例 58.3。计算加权方差

#include <boost/accumulators/accumulators.hpp>
#include <boost/accumulators/statistics.hpp>
#include <iostream>
using namespace boost::accumulators;
int main()
{
  accumulator_set<double, features<tag::mean, tag::variance>, int> acc;
  acc(8, weight = 1);
  acc(9, weight = 1);
  acc(10, weight = 4);
  acc(11, weight = 1);
  acc(12, weight = 1);
  std::cout << mean(acc) << '\n';
  std::cout << variance(acc) << '\n';
}

Example 58.3 

        示例 58.3 将 int 作为第三个模板参数传递给 boost::accumulators::accumulator_set。此参数指定权重的数据类型。在此示例中,权重分配给每个值。

        Boost.Accumulators 使用 Boost.Parameter 以名称/值对的形式传递附加参数,例如权重。权重的参数名称是权重。您可以将参数视为变量并分配一个值。名称/值对作为附加参数在每个值之后传递给累加器。

        在示例 58.3 中,值 10 的权重为 4,而所有其他值的权重为 1。均值仍然是 10,因为权重对均值无关紧要。但是,方差现在是 1.25。与前面的示例相比,它有所减少,因为中间值的权重高于其他值。

        Boost.Accumulators 提供了更多的累加器。它们的用法与本章介绍的累加器相同。该库的文档包含对所有可用累加器的概述。

到此这篇关于C++ Boost Accumulators累加器详细讲解的文章就介绍到这了,更多相关C++ Boost Accumulators内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • c语言中getch,getche,getchar的区别

    c语言中getch,getche,getchar的区别

    getche() 和getch()很相似,它也需要引入头文件conio.h,那它们之间的区别又在哪里呢?不同之处就在于getch()无返回显示,getche()有返回显示
    2013-09-09
  • Pipes实现LeetCode(194.转置文件)

    Pipes实现LeetCode(194.转置文件)

    这篇文章主要介绍了Pipes实现LeetCode(194.转置文件),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • C语言超详细讲解指针的概念与使用

    C语言超详细讲解指针的概念与使用

    本文主要讲解C语言中指针和字符串的关系以及指针和数组的关系,在看本文之前大家可以先看看博主之前的C语言基础篇,先对C语言指针先有个基础的了解,有助于对本文章有更深一步的了解
    2022-05-05
  • C++ 关于MFC多线程编程的注意事项

    C++ 关于MFC多线程编程的注意事项

    这篇文章主要介绍了C++ 关于MFC多线程编程的注意事项的相关资料,需要的朋友可以参考下
    2015-06-06
  • Qt 自定义属性Q_PROPERTY不显示float类型的解决

    Qt 自定义属性Q_PROPERTY不显示float类型的解决

    这篇文章主要介绍了Qt 自定义属性Q_PROPERTY不显示float类型的问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++虚函数注意事项

    C++虚函数注意事项

    这篇文章主要给大家分享了EC++虚函数注意事项,
    2022-01-01
  • C++ 反射机制详解及实例代码

    C++ 反射机制详解及实例代码

    这篇文章主要介绍了C++ 反射机制详解及实例代码的相关资料,需要的朋友可以参考下
    2017-01-01
  • C++ 情怀游戏扫雷的实现流程详解

    C++ 情怀游戏扫雷的实现流程详解

    扫雷是电脑上很经典很经典的传统老游戏,从小编第一次摸到计算机开始就玩过扫雷,虽然当时并不理解玩法原理,但终是第一次玩电脑游戏,下面来从扫雷的前世今生讲起
    2021-11-11
  • 基于Windows API分解路径问题的详解

    基于Windows API分解路径问题的详解

    本篇文章是对Windows API分解路径进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++趣味算法之侦探推理

    C++趣味算法之侦探推理

    本文详细讲解了C++趣味算法之侦探推理,文中通过示例代码介绍的非常详细。对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-12-12

最新评论