c – OpenCV – 赋予运算符“不工作”?

我有一个函数来计算卷积(测试我们是否正在使用filter2D的正确设置),我认为函数体并不重要,所以这里只是标题和结尾:

template<typename T>
cv::Mat conv(const cv::Mat &input,const cv::Mat &kernel) {
    cv::Mat output(input); // or should I rather use output( input.rows,input.cols,input.depth())?

    ...
    return output;
}

cv::Mat result = conv( input,kernel);

在这一点上,我在结果中有完全无用的结果(那些甚至不是随机数据,它们有一些奇怪的模式,每次运行函数时都会重复).

当我重写函数时:

template<typename T>
void conv(const cv::Mat &input,cv::Mat &output,const cv::Mat &kernel) {
   ...
}

cv::Mat result(input);
conv( input,result,kernel);

一切都很好,结果矩阵包含它应该是什么.

所以我的问题是:第一种方法出了什么问题?难道我做错了什么?为什么不分配运算符/返回功能

*注意:OpenCv版本:extra / opencv 2.3.1_a-3(archlinux包)*

当我从opencv存储加载外部数据并且数据丢失直到我使用数据(loaded.clone())时,发生了类似的事情

解决方法

好吧,似乎filter2d或者你做的任何事情都不能“就地”工作,也就是说,当输入和输出相同时.有了你的第一行功能,

cv::Mat output(input); // or should I rather use output( input.rows,input.depth())?

您将输出指向与输入相同的数据!它不是克隆,它是另一个参考!

你想做的事情写在你的评论中.另一个选项可能是(取决于你的代码)让输出完全没有初始化,因为通常C OpenCV函数会为你初始化它们的输出矩阵,如果它们是空的.

请注意,即使给出正确的结果,你的conv()也总会在途中破坏你的输入矩阵. OpenCV在其内部数据引用机制中不尊重const.是的,这是糟糕的设计.

相关文章

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