我定义了一个包含2个值的数组,并尝试使用imgproc模块的resize函数将其大小调整为10个元素,并使用线性插值作为插值方法。
cv::Mat input = cv::Mat(1, 2, CV_32F);
input.at<float>(0, 0) = 0.f;
input.at<float>(0, 1) = 1.f;
cv::Mat output = cv::Mat(1, 11, CV_32F);
cv::resize(input, output, output.size(), 0, 0, cv::INTER_LINEAR);
for(int i=0; i<11; ++i)
{
std::cout<< output.at<float>(0, i) << " ";
}
我预期的输出是:
0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0
但我得到的是:
0 0 0 0.136364 0.318182 0.5 0.681818 0.863636 1 1 1
显然,我对如何调整大小的理解在基础层面上是错误的。有人可以告诉我我做错了什么吗?不可否认,OpenCV对于这种简单的线性插值来说太过分了,但请帮我解决这里的错误。
答案 0 :(得分:1)
这很简单。 OpenCV是一个图像处理库。所以你应该记住我们正在研究图像。
当目标图像中只有8个像素时,请查看输出
0 0 0.125 0.375 0.625 0.875 1 1
如果您看一下这张图片,那么理解调整大小行为非常简单
正如您在link中所看到的,您正在使用图像转换库:“本节中的函数执行2D图像的各种几何变换”
你想要这个结果
但它不会正确插入原始的2像素图像