`
handspeaker
  • 浏览: 66199 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

双线性插值算法及需要注意事项

 
阅读更多

最近在编程时用到了双线性插值算法,对图像进行缩放。网上有很多这方面的资料,介绍的也算明白。但是,这些文章只介绍了算法,并没有具体说怎么实现以及怎么实现最好,举个例子,你可以按照网上文章的算法自己写一个双线性插值程序,用它对一张图片进行处理,然后再用matlab或者openCV的resize函数对同一张图片进行处理,得到的结果是不一样的,如果源图片较小,效果差距就更大。以下是对于双线性插值的讲解以及上述现象的解释:


1.双线性插值

假设源图像大小为mxn,目标图像为axb。那么两幅图像的边长比分别为:m/a和n/b。注意,通常这个比例不是整数,编程存储的时候要用浮点型。目标图像的第(i,j)个像素点(i行j列)可以通过边长比对应回源图像。其对应坐标为(i*m/a,j*n/b)。

显然,这个对应坐标一般来说不是整数,而非整数的坐标是无法在图像这种离散数据上使用的。双线性插值通过寻找距离这个对应坐标最近的四个像素点,来计算该点的值(灰度值或者RGB值)。如果你的对应坐标是(2.5,4.5),那么最近的四个像素是(2,4)、(2,5)、(3,4),(3,5)。

若图像为灰度图像,那么(i,j)点的灰度值可以通过一下公式计算:

f(i,j)=w1*p1+w2*p2+w3*p3+w4*p4;

其中,pi(i=1,2,3,4)为最近的四个像素点,wi(i=1,2,3,4)为各点相应权值。关于权值的计算,在维基百科和百度百科上写的很明白。


2.存在的问题

这部分的前提是,你已经明白什么是双线性插值并且在给定源图像和目标图像尺寸的情况下,可以用笔计算出目标图像某个像素点的值。当然,最好的情况是你已经用某种语言实现了网上一大堆博客上原创或转载的双线性插值算法,然后发现计算出来的结果和matlab、openCV对应的resize()函数得到的结果完全不一样。

那这个究竟是怎么回事呢?

其实答案很简单,就是坐标系的选择问题,或者说源图像和目标图像之间的对应问题。

按照网上一些博客上写的,源图像和目标图像的原点(0,0)均选择左上角,然后根据插值公式计算目标图像每点像素,假设你需要将一幅5x5的图像缩小成3x3,那么源图像和目标图像各个像素之间的对应关系如下:

只画了一行,用做示意,从图中可以很明显的看到,如果选择右上角为原点(0,0),那么最右边和最下边的像素实际上并没有参与计算,而且目标图像的每个像素点计算出的灰度值也相对于源图像偏左偏上。

那么,让坐标加1或者选择右下角为原点怎么样呢?很不幸,还是一样的效果,不过这次得到的图像将偏右偏下。

最好的方法就是,两个图像的几何中心重合,并且目标图像的每个像素之间都是等间隔的,并且都和两边有一定的边距,这也是matlab和openCV的做法。如下图:

如果你不懂我上面说的什么,没关系,只要在计算对应坐标的时候改为以下公式即可,

 

int x=(i+0.5)*m/a-0.5

int y=(j+0.5)*n/b-0.5

 

instead of 

 

 

int x=i*m/a

int y=j*n/b


利用上述公式,将得到正确的双线性插值结果


总结:

总结一下,我得到的教训有这么几条。

1.网上的一些资料有的时候并不靠谱,自己还是要多做实验。

2.不要小瞧一些简单的、基本的算法,让你写你未必会写,而且其中可能还藏着一些玄妙。

3.要多动手编程,多体会算法,多看大牛写的源码(虽然有的时候很吃力,但是要坚持看)。

 

分享到:
评论

相关推荐

    quartusii平台通过verilog编程实现bilinear双线性插值,将100x100图像进行插值处理

    1.领域:FPGA,bilinear双线性插值算法 2.内容:quartusii平台通过verilog编程实现bilinear双线性插值,将100x100图像进行插值处理 3.用处:用于bilinear双线性插值算法编程学习 4.指向人群:本科,硕士,博士等...

    通过MATLAB实现逆Preisach模型双线性插值数值仿真+代码操作视频

    1.领域:matlab,逆Preisach模型双线性插值算法 2.内容:题目,通过MATLAB实现逆Preisach模型双线性插值数值仿真+代码操作视频 3.用处:用于逆Preisach模型双线性插值算法编程学习 4.指向人群:本硕博等教研学习...

    J2ME插值算法实现图片的放大缩小

    为了获得更好的视觉效果,可以考虑使用更复杂的插值算法,如双线性插值或三次立方插值,它们能更好地平滑像素过渡,但计算量也会增加。 总结,J2ME平台上的图片缩放功能主要依赖于像素级别的操作,通过插值算法来...

    code.zip_image rotation_unclek2s_zip

    4. **插值**:使用双线性插值算法,根据新坐标计算出每个像素的新值。 5. **创建新图像**:在新的尺寸上创建图像,并将插值得到的像素值填入对应位置。 为了正确使用这个代码包,用户需要了解MATLAB的基本语法,...

    DMA2D_bilinear_resize_resize_bilinear_dma_

    双线性插值是一种图像缩放算法,它通过在原有像素之间进行线性插值来生成新的像素点,以提高图像质量。DMA2D(Direct Memory Access Controller for 2D)则是一种硬件加速器,用于在内存和图形处理器之间快速传输...

    matlab开发-imageresampling.zip.zip

    四、图像重采样的注意事项 1. 尺寸比例:在调整图像大小时,应保持原始图像的宽高比,以防止形状失真。 2. 噪声放大:放大采样可能会使图像噪声更加明显,因此需要谨慎操作。 3. 分辨率变化:重采样会影响图像的...

    matlab插值曲线拟合公开课获奖课件.pptx

    interp2 函数还可以指定插值算法,包括 Linear 双线性插值(默认方式)、Nearest 最邻近插值、spline 三次样条插值和 cubic 双三次插值。 3. Fourier 插值函数 interpft interpft 是 Matlab 中的 Fourier 插值函数...

    c++实现图像扭曲、球面化灯变形

    这种变换需要精确的数学模型,例如使用经纬度坐标系,并结合插值算法计算每个像素的新位置。 TPS(Thin-Plate Spline)变形则是一种强大的非线性变换方法,常用于生物形状分析和图像配准。它通过定义控制点来决定...

    MATLAB图像缩放,matlab实现图像缩放,matlab源码.zip

    六、优化与注意事项 1. 当缩放比例过大时,可能会降低图像质量,应选择合适的插值方法以平衡质量与计算效率。 2. 缩放过程中可能会引入边界问题,可以使用镜像填充或复制边缘像素来处理。 3. 对于高分辨率图像,计算...

    算法源码-数据处理:基于二维数据内插值代码.zip

    5. 注意事项: - 内插值方法的选择应考虑数据特性,如数据的连续性、噪声水平以及计算效率。 - 插值过程中可能会引入误差,特别是对于非线性或有噪声的数据。 - 在处理大数据集时,需注意内存和计算资源的限制。 ...

    MATLAB.zip_Matlab图像缩放_matlab 图像缩放_woodenpem_图像缩放_缩放 matlab

    插值缩放通过在原始像素之间插入新的像素值来生成新尺寸的图像,常见的插值算法有最近邻插值、双线性插值和三次样条插值等。非插值缩放则简单地删除或复制像素,可能会导致图像质量损失。 3. **子函数解析**: - *...

    VC++缩放显示位图

    常见的插值算法有最近邻插值、双线性插值和三次样条插值等。其中,双线性插值由于其较好的平滑效果,在实际应用中较为常用。缩放过程中,原始位图的每个像素被映射到新的坐标系中,通过插值算法计算出新位置的像素...

    opencv中Bayer 图像到RGB图像装换的问题.rar_OPENCV bayer_bayer opencv_bayer r

    这种布局使得传感器能够捕获到每个像素位置周围的颜色信息,从而通过插值算法重构出完整的RGB图像。 2. **Bayer图像格式**: Bayer图像的每个像素仅包含一个颜色通道,常见的Bayer滤镜模式有BGGR、GBRG、GRGB和...

    基于Rhythm&Hues 的 DeltaMush算法的 Maya 的C ++ 变形器

    2. **插值**:学习线性插值(Lerp)和双线性插值(Bilerp)等基本插值方法,以及如何根据DeltaMush的需要进行修改。 3. **变形算法**:理解如何应用变形,包括变形前后形状的计算,以及如何通过挤压和恢复阶段来平滑...

    MATLAB图像缩放,matlab实现图像缩放,matlab

    综上所述,MATLAB提供了强大的图像缩放功能,通过imresize函数可以轻松实现等比例和非等比例缩放,并选择不同的插值算法以平衡速度与图像质量。在实际应用中,应根据具体需求选择合适的缩放方式和插值方法。

    图片旋转效果

    常见的插值算法有最近邻插值、双线性插值和三次样条插值等,它们会影响旋转后的图像质量和清晰度。 图片旋转的实现方法: 1. **编程语言支持**:许多编程语言如Python、Java、C++等都有现成的库函数来实现图片旋转...

    js 图象旋转算法及说明

    #### 三、注意事项 在实现图像旋转功能时,还需注意以下几点: - **性能考虑**:直接对图像进行像素级别的操作可能会导致性能瓶颈,尤其是在处理大尺寸图像时。可考虑使用CSS3的`transform`属性来进行硬件加速的...

    图片放大无马赛克软件

    2. **插值算法**:传统的图像放大通常使用插值算法,如最近邻插值、双线性插值等。这些方法简单易用,但往往无法有效减少马赛克现象。较新的插值算法,如立方插值和样条插值,能提供更好的平滑效果,但在复杂图像上...

    数学三角函数查表方式.zip

    对于更高精度的需求,还可以使用更复杂的插值算法,如双线性插值或三次样条插值。 3. **角度转换**:如果输入的角度是以度为单位,需要将其转换为弧度,因为大多数单片机库函数使用弧度作为输入。转换公式是 `θ_...

    02-Transform.rar

    在图像处理领域,旋转是常见的操作之一,它允许我们根据需求改变图像...综上所述,"02-Transform"可能涵盖了上述知识点,通过这个压缩包的学习,你可以深入理解图像旋转的原理和实现方法,以及在实际应用中的注意事项。

Global site tag (gtag.js) - Google Analytics