首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >opencv图像融合

opencv图像融合

作者头像
淼学派对
发布2023-10-14 11:03:50
发布2023-10-14 11:03:50
41500
代码可运行
举报
文章被收录于专栏:云开发小程序1云开发小程序1
运行总次数:0
代码可运行

图像融合

  • 背景:图像融合是图像处理的一个基本问题,目的是将源图像中一个物体或者一个区域嵌入到目标图像生成一个新的图像。在对图像进行合成的过程中,为了使合成后的图像更自然,合成边界应当保持无缝。但如果源图像和目标图像有着明显不同的纹理特征,则直接合成后的图像会存在明显的边界。
  • 引入:基于泊松方程而引入的泊松融合求解像素最优值的方法,在保留了源图像梯度信息的同时,融合源图像与目标图像。该方法根据用户指定的边界条件求解一个泊松方程,实现了梯度域上的连续,从而达到边界处的无缝融合。

对比传统图像融合和泊松融合

  • 传统的图像融合:
    • 精确地选择融合区域:过程单调乏味且工作量大,常常无法得到好的结果。
    • Alpha-Matting:功能强大,但是实现复杂。
  • 基于Poisson方程的无缝融合:
    • 选择融合区域的过程简单且方便。
    • 最终可以得到无缝融合的结果。

变分法的解释泊松图像编辑

表示融合图像块的梯度。

变分方程的意义表明我们的无缝融合是以源图像块内梯度场为指导,将融合边界上目标场景和源图像的差异平滑地扩散到融合图像块 I 中,这样的话,融合后的图像块能够无缝地融合到目标场景中,并且其色调和光照可以与目标场景相一致。

 读取需要融合的两张图

代码语言:javascript
代码运行次数:0
运行
复制
import cv2
import numpy as np 

src = cv2.imread("1.jpg")
dst = cv2.imread("2.jpg")

 创建飞机的mask

代码语言:javascript
代码运行次数:0
运行
复制
src_mask = np.zeros(src.shape, src.dtype)
# 绘制多边形
poly = np.array([ [4,80], [30,54], [151,63], [254,37], [298,90], [272,134], [43,122] ], np.int32)
cv2.fillPoly(src_mask, [poly], (255, 255, 255))

  • 融合操作使用 cv2.eamlessClone() :
    • 参数1:融合图(飞机)
    • 参数2:目标图(天空)
    • 参数3:融合图的mask
    • 参数4:融合图位置中心
    • 参数5:融合方式,常用 cv2.MIXED_CLONE 和 cv2.NORMAL_CLONE
代码语言:javascript
代码运行次数:0
运行
复制
# 飞机中心位置在dst的坐标
center = (500,100)
# 泊松融合.
output1 = cv2.seamlessClone(src, dst, src_mask, center, cv2.MIXED_CLONE)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-10-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 图像融合
  • 对比传统图像融合和泊松融合
  • 变分法的解释泊松图像编辑
  •  读取需要融合的两张图
  •  创建飞机的mask
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档