如何使用C STL算法重写嵌套循环?

循环很简单,但是我似乎不能用我的头围绕着使用STL算法给出下面相同的嵌套循环.
const int a_size = 5; // input
const int c_size = 2; // output
const int b_size = a_size * c_size; // multipliers

std::vector<float> a(a_size);
std::vector<float> b(b_size);
std::vector<float> c(c_size);

// fill a and b with data

// this nested loop
for(int i = 0; i<c_size; i++) {
    c[i] = 0.0;
    for(int k = 0; k<a_size; k++) {
        c[i] += (a[k] * b[i*a_size+k]);
    }
    c[i] = sigmoid(c[i]);
}

我想这样做的原因是Boost.Compute库,它将使用类似STL的算法(std :: transform,std :: for_each等)对GPU进行计算.

解决方法

我来了 with
auto i = 0;
generate(begin(c),end(c),[&i,&a,&b]
{
    return sigmoid(inner_product
    (
        begin(a),end(a),begin(b) + distance(begin(a),end(a)) * i++,0.f
    ));
});

但是看起来不是很好 – 在这种情况下,我更愿意编写自己的算法.

或使用矩阵形式.与Eigen图书馆将成为:

MatrixXd b;
VectorXd a,c;
// ...
c = (b*a).unaryExpr(sigmoid);

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...