博客
关于我
OpenCV-Python图像融合cv2.addWeighted权重加法函数详解
阅读量:92 次
发布时间:2019-02-26

本文共 2244 字,大约阅读时间需要 7 分钟。

图像融合之 OpenCV 权重加法

☞ ░ ░

一、概述

在 OpenCV 中,图像加法运算不仅支持简单的像素相加,还提供了带权重的加法功能。这种方法允许开发者根据需求调整两副图像在融合时的权重比例,从而实现更灵活的图像合成效果。

假设有两个图像矩阵 src1 和 src2,它们的像素通道值相加时分别乘以权重 alpha 和 beta。融合后的目标图像 dst 中像素通道值的计算公式为:

dst(I) = saturate(src1(I) * alpha + src2(I) * beta + gamma)

其中,alpha 和 beta 是权重系数,gamma 是调节系数。权重系数 alpha 和 beta 的取值范围没有严格限制,但在实际应用中建议 alpha + beta = 1。这种设置使得每副图像的明暗度可以独立调整,从而实现更精细的图像融合效果。

如果对上述公式或权重系数的使用有疑问,可以参考相关文档获取更详细的解释。

二、融合 cv2.addWeighted 权重加法函数语法

调用语法:
addWeighted(src1, alpha, src2, beta, gamma, dst=None, dtype=None)
参数说明:
  • src1 和 src2:需要融合相加的两副大小和通道数相等的图像。
  • alpha:src1 的权重系数。
  • beta:src2 的权重系数。
  • gamma:调节系数,不需要修正时设置为 0,具体参数请参考相关文档。
  • dst:可选参数,用于存储融合后图像的输出结果,默认值为 None。如果提供非 None 的值,输出图像将存储到 dst 对应位置。
  • dtype:可选参数,指定输出图像数组的深度(即像素位数)。默认值为 None,与输入图像保持一致。
  • 返回值:融合相加后的结果图像数组。

三、案例

在实际应用中,addWeighted 函数只能处理大小和通道数相同的两副图像。如果需要将小图像与大图像融合,可以通过自定义函数实现。以下是一个实现小图像与大图像融合的示例函数:

def addWeightedSmallImgToLargeImg(largeImg, alpha, smallImg, beta, gamma=0.0, regionTopLeftPos=(0,0)):      srcW, srcH = largeImg.shape[1::-1]      refW, refH = smallImg.shape[1::-1]      x, y = regionTopLeftPos      if (refW > srcW) or (refH > srcH):          raise ValueError("小图像的尺寸必须小于等于大图像的尺寸")      else:          if (x + refW) > srcW:              x = srcW - refW          if (y + refH) > srcH:              y = srcH - refH          destImg = np.array(largeImg)          tmpSrcImg = destImg[y:y+refH, x:x+refW]          tmpImg = cv2.addWeighted(tmpSrcImg, alpha, smallImg, beta, gamma)          destImg[y:y+refH, x:x+refW] = tmpImg          return destImg

该函数的参数与 addWeighted 函数一致,但增加了 regionTopLeftPos 参数,用于指定小图像在大图像中的左上角位置,默认值为 (0,0),即大图像的左上角。

以下是一个使用 addWeightedSmallImgToLargeImg 函数实现图像融合的案例:

import numpy as np  import cv2  def main(): img1 = cv2.imread(r'F:\pic\seaside.jpg') img2 = cv2.imread(r'F:\pic\beauty.jpg') img = addWeightedSmallImgToLargeImg(img1, 1, img2, 0.1, regionTopLeftPos=(300,300)) cv2.imshow('融合图像', img) cv2.waitKey(0) if name == 'main': main()

运行该代码会生成一个融合后的图像,图片中小图像的权重为 1,大图像的权重为 0.1,融合后的图像显示了两副图像的结合效果。

四、小结

本文详细介绍了 OpenCV-Python 中相同大小和通道数的两副图像融合的 cv2.addWeighted 权重加法函数的语法,并在此基础上实现了一个小图像与大图像融合的函数 addWeightedSmallImgToLargeImg。通过该函数,可以实现更加灵活的图像融合效果。

需要注意的是,权重系数 alpha 和 beta 是相互独立的变量,主要用于调整两副图像的明暗度比例。在实际应用中,建议 alpha + beta = 1,以确保图像融合效果的准确性。

转载地址:http://hktk.baihongyu.com/

你可能感兴趣的文章
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLog类库使用探索——详解配置
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>
NLP学习笔记:使用 Python 进行NLTK
查看>>
NLP的神经网络训练的新模式
查看>>
NLP采用Bert进行简单文本情感分类
查看>>
NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
查看>>
NLP:使用 SciKit Learn 的文本矢量化方法
查看>>
Nmap扫描教程之Nmap基础知识
查看>>
Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
查看>>
NMAP网络扫描工具的安装与使用
查看>>
NMF(非负矩阵分解)
查看>>
nmon_x86_64_centos7工具如何使用
查看>>
NN&DL4.1 Deep L-layer neural network简介
查看>>
NN&DL4.3 Getting your matrix dimensions right
查看>>
NN&DL4.8 What does this have to do with the brain?
查看>>
nnU-Net 终极指南
查看>>