(转)图片拼接算法

图片拼接镶嵌算法(image spline and mosaics经典算法)实现过程和效果展示
2010-01-01 14:56
       图片拼接镶嵌(image spline and mosaics)应用很广,可以实现不同图片之间的拼接和镶嵌。这方面的一个经典算法是Peter J. Burt和Edward H. Adelson在《A Multiresolution Spline With Application To Image Mosaics》中提出的。实现该算法还需要精读一篇论文 "The Laplacian pyramid as a compact image code" (Burt & Adelson 1983)。
       用Multiresolution Spline算法来消除这些痕迹。Multiresolution Spline的基本原理是使用Gaussian算子通过对图像进行层叠分解(pyramid decomposition),使用REDUCE和EXPAND算子来获得G k(Gaussian图)和L k (Laplacian图),并在给定曲线(一般指重叠的痕迹)上对每层的两个L k图进行融合。然后将融合后的P K图放大,以得到S k(即每层的最终图像,由P k和S k+1求得)。最终的图像是S 0 。如下图所示:

 


       实现该算法,主要需要以下步骤:

1、完成对图像的高斯和拉普拉斯金字塔存储转换。主要有以下三个函数:
          [p] = gaussianPyramid(im,n,a)
          [p] = laplacianPyramid(im,n,a)
          [im] = collapsePyramid(p,a)

      2、写出对两张图像进行融合拼接的函数:
          [im] = imBlend(fg,bg,n)

      3、根据不同的应用问题,可以 按照Peter J. Burt和Edward H. Adelson的经典算法的要求, 对上面的函数的进行修改。

由于该算法是比较早期提出的,现已经有许多改进。但该算法仍然是一个经典算法,通过该算法,可以进一步理解图像分层数据结构的原理和应用。

以下是一些效果展示:
1、原文中苹果和梨的拼接效果:

苹果                                               梨

直接拼接效果                               该算法实现效果

2、不同风格图片的拼接:

小狗                                             壁画形式

直接拼接效果                               该算法实现效果

       可以认真阅读论文《A Multiresolution Spline With Application To Image Mosaics》,上面对这个算法讲得很详细。另外,有个开源项目:http://enblend.sourceforge.net/,是关于图像拼接处理的,有源代码哦。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值