OpenCV 图像金字塔算子

        本文是OpenCV图像视觉入门之路的第14篇文章,本文详细的介绍了图像金字塔算子的各种操作,例如:高斯金字塔算子 、拉普拉斯金字塔算子等操作。

        高斯金字塔中的较高级别(低分辨率)是通过先用高斯核对图像进行卷积再删除偶数行和列,然后较高级别的每个像素由基础级别的5个像素的贡献与高斯权重形成,通过这样的操作M x N的图像变为M/2 x N/2图像,因此面积减少到原来的四分之一,我们称之为Octave,当我们的金字塔越靠上时这种模式就越继续。

    向下采样方法:1.对图像进行高斯内核卷积;2.将所有偶数行和列去除。 图像的较低级别(高分辨率)是通过较高级别(低分辨率)在每个维度上扩大为原来的两倍,新增的行和列(偶数行和列)以0填充,然后使用指定的滤波器进行卷积去估计丢失像素的近似值。

    向上采样方法:1.将图像在每个维度扩大到原来的两倍,以新增的行和列以0填充;2.使用原先同样的内核(x4)与方法后的图像卷积,获得新增像素的近似值。  在缩放过程中以及丢失了一些信息,如果想在缩放过程中减少信息的丢失,就需要用到拉普拉斯金字塔。

OpenCV 图像金字塔算子目录

1 高斯金字塔

2 拉普拉斯金字塔


1 高斯金字塔

高斯金字塔:向上采样法(放大)        cv.pyrUp(src)函数:其中只需要传入一个参数,代表图像资源,用于对图像做向上采样

高斯金字塔:向下采样法(缩小)        cv.pyrDown()函数:参数传递与cv.pyrUp()一致,用于对图像做向下采样,通常也可以做图像模糊化处理

import cv2
import numpy as np
from numpy import unicode

if __name__ == '__main__':
    img = cv2.imread('D:/Jupyter_Notebooks/0.jpg') #, cv2.IMREAD_GRAYSCALE

    cv2.imshow("img", img)
    print(img.shape)

    up = cv2.pyrUp(img)
    up2 = cv2.pyrUp(up)


    cv2.namedWindow("up", 0)
    cv2.imshow("up", up)
    print(up.shape)

    cv2.namedWindow("up2", 0)
    cv2.imshow("up2", up2)
    print(up2.shape)


    down = cv2.pyrDown(img)
    up_down = cv2.pyrDown(up)

    cv2.namedWindow("down", 0)
    cv2.imshow("down", down)
    print(down.shape)

    cv2.namedWindow("up_down", 0)
    cv2.imshow("up_down", up_down)
    print(up_down.shape)

    cv2.waitKey(0)
    cv2.destroyAllWindows()

import cv2
import numpy as np
from numpy import unicode

if __name__ == '__main__':
    img = cv2.imread('D:/Jupyter_Notebooks/0.jpg') #, cv2.IMREAD_GRAYSCALE

    up = cv2.pyrUp(img)
    up_down = cv2.pyrDown(up)
    cv2.imshow("up_down", up_down)

    cv2.imshow("up_downs", np.hstack((img, up_down)))

    up = cv2.pyrUp(img)
    up_down = cv2.pyrDown(up)
    cv2.imshow("img-up_down", img - up_down)


    cv2.waitKey(0)
    cv2.destroyAllWindows()

这段代码使用了 OpenCV 中的图像金字塔函数 cv2.pyrUp()cv2.pyrDown(),并在屏幕上显示了 img - up_down 的差异图像。

图像金字塔是一种常见的多分辨率图像处理技术,它可以将图像按照不同的尺度进行缩小或放大,从而得到一系列图像。cv2.pyrUp()cv2.pyrDown() 分别是向上采样和向下采样的函数,可以用来生成高斯金字塔和拉普拉斯金字塔。

在这段代码中,首先使用 cv2.pyrUp() 对原始图像 img 进行向上采样,得到一个更高分辨率的图像 up。然后使用 cv2.pyrDown()up 进行向下采样,得到一个分辨率与原始图像相同但内容可能有所不同的图像 up_down

最后,通过 cv2.imshow() 函数显示 img - up_down 的差异图像,即原始图像与经过向上-向下采样后的图像之间的差异。这样做可以帮助我们了解金字塔图像处理的效果,以及对图像内容的改变情况进行可视化分析。

2 拉普拉斯金字塔

1.左上角的图片为原始图片

2.对原始图像进行高斯平滑

3.执行一次下采样,图像变为原来的1/4

4.执行一次上采样,图像变为原图的大小

5.再次执行高斯模糊

6.用原图像减去高斯模糊后的图像,得到拉普拉斯图像

import cv2
import numpy as np
from numpy import unicode

if __name__ == '__main__':
    img = cv2.imread('D:/Jupyter_Notebooks/0.jpg') #, cv2.IMREAD_GRAYSCALE

    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    down = cv2.pyrDown(img)
    dst = cv2.pyrUp(down)
    res = img - dst
    cv2.imshow("img", img)
    cv2.imshow("res", res)


    cv2.waitKey(0)
    cv2.destroyAllWindows()

猜你喜欢

转载自blog.csdn.net/qq_37529913/article/details/129053722