1121123211234321用python金字塔型_【python-opencv】图像金字塔

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

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

1、高斯金字塔

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

importcv2 as cvimportnumpy as npfrom matplotlib importpyplot as pltfrom google.colab.patches importcv2_imshow

img=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)

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

higher_reso1 = cv.pyrUp(lower_reso1)

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

2、拉普拉斯金字塔

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

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

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

#高斯金字塔

defpyramid_image(image):

level= 3#金字塔的层数

temp = image.copy()#拷贝图像

pyramid_images =[]for i inrange(level):

dst=cv.pyrDown(temp)

pyramid_images.append(dst)

cv2_imshow(dst)

temp=dst.copy()returnpyramid_images#拉普拉斯金字塔

deflaplian_image(image):

image=cv.resize(image,(224,224))

pyramid_images=pyramid_image(image)

level=len(pyramid_images)for i 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("梅西.jpg",1)

cv2_imshow(src)

laplian_image(src)

结果:

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

3、使用金字塔进行融合

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

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

加载苹果和橙子的两个图像

查找苹果和橙子的高斯金字塔(在此示例中, 级别数为6)

在高斯金字塔中,找到其拉普拉斯金字塔

然后在每个拉普拉斯金字塔级别中加入苹果的左半部分和橙子的右半部分

最后从此联合图像金字塔中重建原始图像。

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

importcv2 as cvimportnumpy as np,sys

A= cv.imread('apple.jpg')

B= cv.imread('orange.jpg')#生成A的高斯金字塔

G =A.copy()

gpA=[G]for i in xrange(6):

G=cv.pyrDown(G)

gpA.append(G)#生成B的高斯金字塔

G =B.copy()

gpB=[G]for i in xrange(6):

G=cv.pyrDown(G)

gpB.append(G)#生成A的拉普拉斯金字塔

lpA = [gpA[5]]for i in xrange(5,0,-1):

GE=cv.pyrUp(gpA[i])

L= cv.subtract(gpA[i-1],GE)

lpA.append(L)#生成B的拉普拉斯金字塔

lpB = [gpB[5]]for i in xrange(5,0,-1):

GE=cv.pyrUp(gpB[i])

L= cv.subtract(gpB[i-1],GE)

lpB.append(L)#现在在每个级别中添加左右两半图像

LS =[]for la,lb inzip(lpA,lpB):

rows,cols,dpt=la.shape

ls= np.hstack((la[:,0:cols/2], lb[:,cols/2:]))

LS.append(ls)#现在重建

ls_ =LS[0]for i in xrange(1,6):

ls_=cv.pyrUp(ls_)

ls_=cv.add(ls_, LS[i])#图像与直接连接的每一半

real = np.hstack((A[:,:cols/2],B[:,cols/2:]))

cv.imwrite('Pyramid_blending2.jpg',ls_)

cv.imwrite('Direct_blending.jpg',real)

参考:http://woshicver.com/FifthSection/4_8_%E5%9B%BE%E5%83%8F%E9%87%91%E5%AD%97%E5%A1%94/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值