gpt4 book ai didi

c++ - 使用 OpenCV 插值一维数组

转载 作者:太空宇宙 更新时间:2023-11-03 21:09:18 26 4
gpt4 key购买 nike

我定义了一个包含 2 个值的数组,并尝试使用 imgproc 模块的调整大小函数将其大小调整为 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 对于这种简单的线性插值来说有点矫枉过正,但请帮我解决这里的问题。

最佳答案

其实很简单。OpenCV 是一个图像处理库。所以你应该记住我们正在处理图像。

看看我们在目标图像中只有 8 个像素时的输出

0 0 0.125 0.375 0.625 0.875 1 1

如果您看一下这张图片,就可以非常简单地理解调整大小的行为

Example

正如您在此 link 中看到的那样您正在使用图像转换库:“本节中的函数执行 2D 图像的各种几何转换”

你想要这个结果

enter image description here

但它不会正确插值原始 2 像素图像

关于c++ - 使用 OpenCV 插值一维数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18104609/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com