c – OpenCV遍历列

我试图迭代一个矩阵的列(例如它的一串列向量,它们被连接成一个矩阵,我想分别在每个列向量上操作).使用for循环很容易做到这一点:
for(int n = 0; n < mat.cols; n++)
{
    cv::Mat c = mat.col(n);
    // do stuff to c
}

但是如果可能,我想使用迭代器来做,以便我可以使用std :: accumulate或std :: transform来简化代码.

所以我基本上寻找像

for each Mat c in mat.columns

Mat已经开始<>并且结束<功能,但据我所知,它只能用于迭代单个元素. 可以这样做吗 只是为了清楚我想写

cv::Mat input;

cv::Mat output = std::accumulate(input.begincols(),input.endcols(),cv::Mat::zeros(n,k,CV_64F),[](const cv::Mat &acum,const cv::Mat &column) { return acum + column * 5; });

一个简单的例子.

更新:

所以既然这还没有得到回答,如果有人有一个本土化的解决方案来提供这样的迭代器,我会看看,否则我可以自己研究一下,如果我有机会

解决方法

也许重载累积函数可以帮助.而不是(可能实施标准)
template<class InputIt,class T>
T std::accumulate(InputIt first,InputIt last,T init)
{
   for (; first != last; ++first) {
        init = init + *first;
   }
   return init;
}

你可以自己写,积累.

template<class InputIt,T init,std::size_t incr)
{
   for (; first != last; first += incr) {
        init = init + *first;
   }
   return init;
}

将其用于您的图像.你必须使用steplength(Math :: step1()我猜)为incr.这应该有效,但我还没有测试.如果为您工作,请提供反馈.

相关文章

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