正确地将 std::valarray 带到谷歌/快速工作台

问题描述

我正在尝试使用 Google Bench 比较使用 std::valarraystd::vector/std::transform 操作的性能。我正在使用 QuickBench。

我的代码(用于 QuickBench)是

#include <random>

class RG {
public:
    double operator()() noexcept { return dis(gen); } 
private:
    std::mt19937 gen {std::random_device{}()};
    std::uniform_real_distribution<> dis {0.0,100.0};
};

static RG rg {};

static constexpr auto N = 1000;

#include <vector>
#include <algorithm>

static void Vector(benchmark::State& state) {
    std::vector<double> v1,v2;
    v1.reserve(N); v2.reserve(N);
    std::generate_n(back_inserter(v1),N,rg);
    std::generate_n(back_inserter(v2),rg);
    for (auto _ : state) {
        std::vector<double> v3; v3.reserve(N);
        std::transform(cbegin(v1),cend(v1),cbegin(v2),back_inserter(v3),[](auto d1,auto d2) noexcept { return 0.5*d1+1.5*d2;});
        benchmark::DoNotOptimize(v3);
    }
}
// Register the function as a benchmark
BENCHMARK(Vector);

#include <valarray>

static void ValArray(benchmark::State& state) {
    std::valarray<double> v1{N},v2{N};
    std::generate(begin(v1),end(v1),rg);
    std::generate(begin(v2),end(v2),rg);
    for (auto _ : state) {
        std::valarray<double> v3{};
        v3=0.5*v1+1.5*v2;
        benchmark::DoNotOptimize(v3);
    }
}
BENCHMARK(ValArray);

QuickBench link Quickbench 说 std::valarraystd::vector 快 72 倍。那不可能是对的,对吧? 我做错了什么?

解决方法

第 36 行:

std::valarray<double> v1{N},v2{N};

这将创建两个单元素 valarray-s,即每个包含一个值为 N=1000 的单个元素。这是因为列表初始化语法 {} 使用带 std::initializer_list 的构造函数:

valarray(std::initializer_list<T> il);

它使用该列表的内容构造一个 valarray,而不是预期的内容:

explicit valarray(std::size_t count);

这将构造一个 valarraycount 元素。

您需要将该行更改为:

std::valarray<double> v1(N),v2(N);

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...