opencv笔记(三十五)——线性插值、双线性插值

1.为什么要用图像的插值?[1]

      在图像的放大和缩小的过程中,需要计算新图像像素点对应原图的位置,如果计算的位置不是整数,就需要用到图像的内插,我们需要寻找在原图中最近的像素点赋值给新的像素点,这种方法最简单是最近邻插法,这种方法好理解、简单,但是不实用,会产生失真现象,产生棋盘格效应,更实用的方法就是双线性内插。

2.一维线性插值

                                                     

我们已经知道(x0,y0)与(x1, y1)的值,并且已知 x 的值,要求 y 的值。根据初中的知识:

我们可以得到:.     

令:

则:

3.双线性内插法的推导过程

       双线性插值是做了三次一维的线性插值,我们用四个最近邻估计给定的点的灰度。我们新图像的像素点对应输入图像的(u0 , v0)(u0,v0不是整数),则其必定落在原始图像四个像素点中间。四个像素点分别是(u' , v' )、(u' , v' +1)、(u'+1 , v' )、(u' +1, v'+1 )。如下图1所示:

                图1 

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++中的OpenCV库是一个广泛使用的计算机视觉和图像处理库,它提供了许多图像处理和计算机视觉算法的实现。双线性插值OpenCV中常用的一种图像插值方法,用于在图像缩放、旋转或变换等操作中平滑地估计新像素的值。 双线性插值是一种基于四个最近邻像素的加权平均方法。它假设在一个像素点的邻域内,像素值的变化是连续的,并且可以通过线性插值来估计新像素的值。具体而言,双线性插值使用了四个最近邻像素的权重来计算新像素的值,这四个最近邻像素通常是原始图像中距离目标位置最近的四个像素。 在OpenCV中,可以使用resize函数来进行图像的缩放操作,并通过指定插值方法参数来选择使用双线性插值。以下是使用OpenCV进行双线性插值的示例代码: ```cpp #include <opencv2/opencv.hpp> int main() { cv::Mat image = cv::imread("input.jpg"); // 读取输入图像 cv::Size newSize(800, 600); // 设置目标图像尺寸 cv::Mat resizedImage; cv::resize(image, resizedImage, newSize, 0, 0, cv::INTER_LINEAR); // 使用双线性插值进行图像缩放 cv::imshow("Resized Image", resizedImage); // 显示缩放后的图像 cv::waitKey(0); return 0; } ``` 在上述示例代码中,首先使用imread函数读取输入图像,然后通过指定目标图像的尺寸和插值方法参数,使用resize函数进行图像的缩放操作。最后,使用imshow函数显示缩放后的图像,并通过waitKey函数等待用户按下键盘任意键退出程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值