【python-opencv】图像金字塔

【python-opencv】图像金字塔,第1张

概述通常,我们过去使用的是恒定大小的图像。但是在某些情况下,我们需要使用不同分辨率的(相同)图像。例如,当在图像中搜索某些东西(例如人脸)时,我们不确定对象将以多大的尺寸显示在图像中。在这种情况下,我们将

通常,我们过去使用的是恒定大小的图像。但是在某些情况下,我们需要使用不同分辨率的(相同)图像。例如,当在图像中搜索某些东西(例如人脸)时,我们不确定对象将以多大的尺寸显示在图像中。在这种情况下,我们将需要创建一组具有不同分辨率的相同图像,并在所有图像中搜索对象。这些具有不同分辨率的图像集称为“图像金字塔”(因为当它们堆叠在底部时,最高分辨率的图像位于顶部,最低分辨率的图像位于顶部时,看起来像金字塔)。

有两种图像金字塔。1)高斯金字塔和2)拉普拉斯金字塔

1、高斯金字塔

高斯金字塔中的较高级别(低分辨率)是通过删除较低级别(较高分辨率)图像中的连续行和列而形成的。然后,较高级别的每个像素由基础级别的5个像素的贡献与高斯权重形成。通过这样做,$M×N$图像变成$M/2 × N/2$图像。因此面积减少到原始面积的四分之一。它称为Octave。当我们在金字塔中越靠上时(即分辨率下降),这种模式就会继续。同样,在扩展时,每个级别的面积变为4倍。我们可以使用cv.pyrDown()和cv.pyrUp()函数找到高斯金字塔。

@H_301_23@import cv2 as cv numpy as npfrom matplotlib pyplot as pltfrom Google.colab.patches cv2_imshowimg=cv.imread('梅西.jpg',1)lower_reso1 = cv.pyrDown(img)lower_reso2 = cv.pyrDown(lower_reso1)cv2_imshow(img)cv2_imshow(lower_reso1)cv2_imshow(lower_reso2)

同理可以使用以下函数来放大图像:

@H_301_23@higher_reso1 = cv.pyrUp(lower_reso1)

记住,higher_reso1不等于原始img,因为一旦降低了分辨率,就会丢失信息。下面的图像是3层的金字塔从最小的图像在前面的情况下创建。

2、拉普拉斯金字塔

拉普拉斯金字塔由高斯金字塔形成。没有专用功能。拉普拉斯金字塔图像仅像边缘图像。它的大多数元素为零。它们用于图像压缩。拉普拉斯金字塔的层由高斯金字塔的层与高斯金字塔的高层的扩展版本之间的差形成。拉普拉斯等级的三个等级如下所示(调整对比度以增强内容):

要求:拉普拉斯金字塔时,图像大小必须是2的n次方*2的n次方,不然会报错。

我们可以将其用函数表示:

@H_301_23@#高斯金字塔def pyramID_image(image): level = 3金字塔的层数 temp = image.copy()拷贝图像 pyramID_images = [] for i in range(level): dst = cv.pyrDown(temp) pyramID_images.append(dst) cv2_imshow(dst) temp = dst.copy() return pyramID_images 拉普拉斯金字塔 laplian_image(image): image=cv.resize(image,(224,224)) pyramID_images = pyramID_image(image) level = len(pyramID_images) in range(level-1,-1,-1): if(i-1) < 0 : expand = cv.pyrUp(pyramID_images[i],dstsize=image.shape[:2]) lpls = cv.subtract(image,expand) cv2_imshow(lpls) else: expand = cv.pyrUp(pyramID_images[i],dstsize=pyramID_images[i-1].shape[:2]) lpls = cv.subtract(pyramID_images[i-1],expand) cv2_imshow(lpls) src = cv.imread("",1)">)cv2_imshow(src)laplian_image(src)

结果:

参考:https://blog.csdn.net/u011321546/article/details/79599393 

3、使用金字塔进行融合

金字塔的一种应用是图像融合。例如,在图像拼接中,您需要将两个图像堆叠在一起,但是由于图像之间的不连续性,可能看起来不太好。在这种情况下,使用金字塔混合图像可以无缝混合,而不会在图像中保留大量数据。一个经典的例子是将两种水果,橙和苹果混合在一起。现在查看结果本身,以了解我在说什么:

请检查其他资源中的第一个参考,它具有图像混合,拉普拉斯金字塔等的完整图解详细信息。只需完成以下步骤即可:

加载苹果和橙子的两个图像查找苹果和橙子的高斯金字塔(在此示例中, 级别数为6)在高斯金字塔中,找到其拉普拉斯金字塔然后在每个拉普拉斯金字塔级别中加入苹果的左半部分和橙子的右半部分最后从此联合图像金字塔中重建原始图像。

下面是完整的代码。(为简单起见,每个步骤都是单独进行的,这可能会占用更多的内存。如果需要,可以对其进行优化)。

@H_301_23@ numpy as np,sysA = cv.imread(apple.jpg')B = cv.imread(orange.jpg) 生成A的高斯金字塔G = A.copy()gpA = [G]in xrange(6): G = cv.pyrDown(G) gpA.append(G) 生成B的高斯金字塔G = B.copy()gpB = cv.pyrDown(G) gpB.append(G) 生成A的拉普拉斯金字塔lpA = [gpA[5]]in xrange(5,1)">): GE = cv.pyrUp(gpA[i]) L = cv.subtract(gpA[i-1 生成B的拉普拉斯金字塔lpB = [gpB[5 cv.pyrUp(gpB[i]) L = cv.subtract(gpB[i-1 现在在每个级别中添加左右两半图像 LS = []for la,lb zip(lpA,lpB): rows,cols,dpt = la.shape ls = np.hstack((la[:,0:cols/2],lb[:,cols/2:])) LS.append(ls) 现在重建ls_ = LS[0]in xrange(1,6): ls_ = cv.pyrUp(ls_) ls_ = cv.add(ls_,LS[i]) 图像与直接连接的每一半real = np.hstack((A[:,:cols/2],B[:,1)">:]))cv.imwrite(PyramID_blending2.jpg,ls_)cv.imwrite(Direct_blending.jpg 总结

以上是内存溢出为你收集整理的【python-opencv】图像金字塔全部内容,希望文章能够帮你解决【python-opencv】图像金字塔所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1190024.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存