最近邻插值算法 python实现

一. 最近邻插值法放大图像:

        最近邻插值法在放大图像时补充的像素是最近邻的像素的值。由于方法简单,所以处理速度很快,但是放大图像画质劣化明显,常常含有锯齿边缘。

最近邻插值法算法原理 ↑


二. 最近邻插值法算法流程:

        插值法放大图像的第一步都是相同的,计算新图的坐标点像素值对应原图中哪个坐标点的像素值来填充,计算公式为:

        srcX = dstX * (srcWidth/dstWidth)

        srcY = dstY * (srcHeight/dstHeight)

        其中,src表示旧图,dst表示新图。新图的坐标(dstX,dstY)对应于旧图的坐标(srcX,srcY)。 srcWidth/dstWidth 和 srcHeight/dstHeight 分别表示宽和高的放缩比。

        那么问题来了,通过这个公式算出来的 srcX,scrY (旧图坐标)有可能是小数,但是坐标点是不存在小数的,都是整数,得想办法把它转换成整数才行。

        不同插值法的区别就体现在 srcX,scrY 是小数时,怎么变成整数去取原图像中的像素值。

        最近邻插值法:看名字就很直白,四舍五入选取最接近的整数。这样的做法会导致像素的变化不连续,在新图中会产生锯齿。


三. 实验 python实现最近邻插值算法

from PIL import Image
import matplotlib.pyplot as plt
import numpy as np 
import math

# 最近邻插值算法
# dstH为新图的高;dstW为新图的宽
def NN_interpolation(img,dstH,dstW):
    scrH,scrW,_=img.shape
    retimg=np.zeros((dstH,dstW,3),dtype=np.uint8)
    for i in range(dstH-1):
        for j in range(dstW-1):
            scrx=round(i*(scrH/dstH))
            scry=round(j*(scrW/dstW))
            retimg[i,j]=img[scrx,scry]
    return retimg

im_path='../paojie.jpg'
image=np.array(Image.open(im_path))

image1=NN_interpolation(image,image.shape[0]*2,image.shape[1]*2)
image1=Image.fromarray(image1.astype('uint8')).convert('RGB')
image1.save('out.png')

四. 实验结果:

原图 ↑

最近邻插值后图像 ↑

        可以看到新图中产生了锯齿状的边缘。


五. 参考内容:

        https://www.cnblogs.com/wojianxin/p/12515061.html

        https://www.jianshu.com/p/4954643f7514

  • 12
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
图像旋转是数字图像处理中常见的操作之一。在Python中,我们可以使用Pillow这个图像处理库来实现图像的旋转。下面是使用Python实现图像旋转使用最近邻插值的步骤: 1. 导入Pillow库 在Python中,我们可以使用Pillow这个库来处理图像。我们需要先导入这个库: from PIL import Image 2. 打开原始图像 在使用Python处理图像之前,我们需要先打开原始图像。我们可以使用Image.open()函数来打开原始图像: img = Image.open('image.jpg') 其中,'image.jpg'为图像的文件名。 3. 创建一个新的图像 我们可以使用Image.new()函数来创建一个新的图像: new_img = Image.new('RGB', (width, height)) 其中,'RGB'表示图像类型为RGB格式,(width, height)表示图像的宽度和高度。 4. 对图像进行旋转 我们可以使用Image.rotate()函数来对图像进行旋转,其中,第一个参数为旋转的角度,第二个参数为旋转方式,最后一个参数为插值算法。这里我们使用最近邻插值算法: rotated_img = img.rotate(angle, resample=Image.NEAREST) 其中,angle表示旋转的角度,resample表示插值算法,Image.NEAREST表示最近邻插值算法。 5. 保存旋转后的图像 最后,我们需要将旋转后的图像保存成新文件: rotated_img.save('rotated_image.jpg') 其中,'rotated_image.jpg'为保存后的文件名。 通过以上步骤,我们就可以使用Python实现图像旋转使用最近邻插值
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值