多聚焦图像融合算法

 

# @File         :  PerfectFusion.py
# @Author       :  ShawnWang
# @Desc         :  多焦点图像融合
# Time          :  2023/9/24 08:25
import cv2
import matplotlib.pyplot as plt
import numpy as np
import pywt
from PIL import Image

# 基于小波变换的多聚焦图像融合算法

'''
论文中的两种方案:
1,对低频分量的所有像素点计算其局部方差,每张图所有点的方差加起来除以两张图所有点加起来,得到两张图的权重
融合图像每个像素点的值为两张图对应像素点的值加权平均,这个权就是上面算出来的权值。
2,效果不是很好,在小波分块的边缘有明显的灰度跳变(就是有些论文里说的分块效应),but why?
3,已找到原因,要求的不是某一个点对全图的方差,而是在某点附近开个小窗口求窗口的局部方差
4,现用局部方差的方法对多聚焦图像效果非常完美
'''


# 读取图片文件 将其转化成灰度图像,同时转化成包含图像像素值的NumPy数组
def imgOpen(path):
    # Image.open(path) 会返回一个Image对象,表示打开的图像。然后,.convert('L') 方法会将该图像转换为灰度图像
    img = Image.open(path).convert('L')
    # img是一个PIL图像对象。np.array()函数用于将该图像对象转换为NumPy数组。转换后,imgArray就是一个包含图像像素值的NumPy数组。
    # 通过将图像转换为NumPy数组,可以方便地对图像进行各种数值计算和图像处理操作。可以使用NumPy提供的丰富功能来访问、修改和分析图像数据。
    imgArray = np.array(img)
    return imgArray


# 对于低频分量,计算两图的权重比
def varianceWeight(img1, img2):
    # 第一个元素mean1表示图像的均值,第二个元素var1表示图像的方差。
    mean1, var1 = cv2.meanStdDev(img1)
    mean2, var2 = cv2.meanStdDev(img2)
    weight1 = var1 / (var1 + var2)
    weight2 = var2 / (var1 + var2)
    return weight1, weight2


# 用于计算输入数组中每个像素点周围5个像素内的方差(提取一个大小为11x11的窗口),并返回生成的方差图像
def getVarianceImg(array):
    row, col = array.shape
    varImg = np.zeros((row, col))
    for i in range(row):
        for j in range(col):
            up = i - 5 if i - 5 > 0 else 0
            down = i + 5 if i + 5 < row else row
            left = j - 5 if j - 5 > 0 else 0
            right = j + 5 if j + 5 < col else col
            # array[up:down, left:right]表示从数组的第up行(包含)到第down行(不包含),以及从第left列(包含)到第right列(不包含)的区域,即提取了一个11x11的子窗口
            window = array[up:down, left:right]
            # 利用cv2.meanStdDev()函数计算窗口中像素值的平均值和标准差。该函数会返回一个元组,其中第一个元素是窗口中像素值的平均值,第二个元素是窗口中像素值的标准差
            mean, var = cv2.meanStdDev(window)
            varImg[i, j] = var
    return varImg


def testWave(img1, img2):
    # 使用PyWavelets库中的小波变换函数对图像进行二维小波分解的操作,通过进行小波分解,可以将图像转换到频域,并提取不同频率上的信息。这对于图像处理任务如去噪、压缩和特征提取等方面非常有用
    # pywt.wavedec2() 函数以 'haar' 作为小波基函数(可根据需要更改为其他小波基函数),并指定了分解的级数为4
    # 分解的层数就越多,也就意味着能够分析的频率范围就越广。这种分解可以理解为将图像从空间域转换到频域,从而可以更好地分析图像的频率特性。。
    # 结果,transf1和transf2将是包含小波分解系数的元组(tuple)数据结构,其中每个元素都是一个二维数组(矩阵),表示对应尺度的小波系数。最顶层的元素是低频部分,而较低层的元素是高频部分。
    transf1 = pywt.wavedec2(img1, 'haar', level=4)
    transf2 = pywt.wavedec2(img2, 'haar', level=4)
    # 确保变量transf1和transf2具有相同的长度。
    assert len(transf1) == len(transf2)
    # 创建了一个空列表recWave,用于存储重构后的小波系数
    recWave = []
    for k in range(len(transf1)):
        # 处理低频分量
        if k == 0:
            # 调用varianceWeight函数,计算transf1[0] 和transf2[0]之间的权重比,并将结果分配给loWeight1和loWeight2两个变量。
            loWeight1, loWeight2 = varianceWeight(transf1[0], transf2[0])
            # 创建一个形状与transf2[0]相同的全零数组lowFreq,用于存储加权合并后的低频分量。
            lowFreq = np.zeros(transf2[0].shape)
            # 获取transf1[0]的行数和列数,并将它们分别赋值给变量row和col
            row, col = transf1[0].shape
            # 使用权重对低频分量进行加权融合,并将结果添加到recWave列表中
            for i in range(row):
                for j in range(col):
                    # 加权
                    lowFreq[i, j] = loWeight1 * transf1[0][i, j] + loWeight2 * transf2[0][i, j]
            recWave.append(lowFreq)
            continue
        # 处理高频分量
        cvtArray = []
        # 使用了zip() 函数将transf1[k] 和transf2[k] 两个列表中的元素进行逐个配对。
        # 在每一次迭代中,array1和array2分别表示来自transf1[k]和transf2[k]的配对元素
        for array1, array2 in zip(transf1[k], transf2[k]):
            tmp_row, tmp_col = array1.shape
            highFreq = np.zeros((tmp_row, tmp_col))
            # 调用getVarianceImg()函数分别计算当前数组元素array1和array2的方差图像,保存在var1和var2变量中
            var1 = getVarianceImg(array1)
            var2 = getVarianceImg(array2)
            # 双重循环遍历当前数组元素的每个像素点,根据对应位置上的方差值判断选择使用array1还是array2的像素值,并将选取的值赋给highFreq[i, j]
            for i in range(tmp_row):
                for j in range(tmp_col):
                    # 目的:在图像处理中,方差常被用作衡量像素值变化程度的指标。较大的方差通常表示像素值在该位置上的变化较大,可能对应着图像中的高频信息(如边缘、纹理等)。而较小的方差则表示像素值变化较小,对应着图像的低频信息(如平坦区域)。
                    # 通过比较var1[i, j]和var2[i, j]的大小,可以判断哪个数组元素所对应位置的像素值变化较大,即具有更高的频率成分。
                    highFreq[i, j] = array1[i, j] if var1[i, j] > var2[i, j] else array2[i, j]
            cvtArray.append(highFreq)
        recWave.append(tuple(cvtArray))
    return pywt.waverec2(recWave, 'haar')


# 在一个窗口中显示融合图像
def testPlot(org1, org2, img):
    # 函数中使用的子图编号(131、132、133)是一种常见的约定,用于表示一个1行3列的子图网格中的三个子图位置。
    plt.subplot(131)
    # 每个子图都使用plt.imshow()函数来显示对应的图像,并可以通过cmap='gray'参数将图像以灰度的形式进行显示。
    plt.imshow(org1, cmap='gray')
    # 调用plt.axis('off')可以去除图像周围的坐标轴标签和刻度。
    plt.axis('off')

    plt.subplot(132)
    plt.imshow(org2, cmap='gray')
    plt.axis('off')

    plt.subplot(133)
    plt.imshow(img, cmap='gray')
    plt.axis('off')

    plt.show()


if __name__ == '__main__':
    img1 = imgOpen('data/lytro-03-A.jpg')
    img2 = imgOpen('data/lytro-03-B.jpg')
    #
    # img1 = imgOpen('data/lytro-02-A.jpg')
    # img2 = imgOpen('data/lytro-02-B.jpg')

    rec = testWave(img1, img2)
    testPlot(img1, img2, rec)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/163161.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于SSM的古董拍卖系统

基于SSM的古董拍卖系统的设计与实现~ 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringMyBatisSpringMVC工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 主页 拍卖界面 管理员界面 摘要 古董拍卖系统是一个基于SSM框架&#xff08;Spring …

两数之和 II - 输入有序数组

给你一个下标从 1 开始的整数数组 numbers &#xff0c;该数组已按 非递减顺序排列 &#xff0c;请你从数组中找出满足相加之和等于目标数 target 的两个数。如果设这两个数分别是 numbers[index1] 和 numbers[index2] &#xff0c;则 1 < index1 < index2 < numbers.…

人工智能基础_机器学习044_逻辑回归代码实现与手动计算概率---人工智能工作笔记0084

上面我们已经把逻辑回归的公式,以及,公式对应的图形都画画出来了,然后我们再来看看 如何用代码实现 可以看到上面是代码,咱们自己去写一下 import numpy as np from sklearn.linear_model import LogistieRegression from sklearn import datasets # 训练数据和测试数据拆分…

BGP的基础知识

BGP——边界网关协议 IGP——内部网关协议——OSPF、RIP、ISIS EGP——外部网关协议——EGP、BGP 边界网关协议BGP是一种实现自治系统AS之间的路由可达&#xff0c;并选择最佳路由的路径矢量路由协议。目前在IPV4环境下主要使用BGPV4&#xff0c;目前市场上也存在BGPV4&…

什么是java反射机制?

类的正常加载 反射概述 JAVA反射机制是在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所有属性和方法&#xff1b;对于任意一个对象&#xff0c;都能够调用它的任意一个方法和属性&#xff1b;这种动态获取的信息以及动态调用对象的方法的功能称为jav…

多因素方差分析(Multi-way Analysis of Variance) R实现

1, data0507 flower 是某种植物在两个海拔和两个气温下的开花高度&#xff0c;采用合适 的统计方法&#xff0c;检验该种植物的开花高度在不同的海拔之间和不同的气温之间有无差异&#xff1f;如果有差异&#xff0c;具体如何差异的&#xff1f;&#xff08;说明依据、结论等关…

网络运维与网络安全 学习笔记2023.11.18

网络运维与网络安全 学习笔记 第十九天 今日目标 冲突域和交换机工作原理、广播域和VLAN原理 VLAN配置、TRUNK原理与配置、HYBRID原理与配置 冲突域和交换机工作原理 冲突域概述 定义 网络设备发送的数据&#xff0c;产生冲突的区域&#xff08;范围&#xff09; 对象 “数…

开源情报 (OSINT)

开源情报 (OSINT)是出于情报目的收集和分析公开数据的行为。 什么是开源数据&#xff1f; 开源数据是公众容易获得或可根据要求提供的任何信息。 OSINT 来源可包括&#xff1a; ▶ 报纸杂志文章以及媒体报道▶ 学术论文和发表的研究▶ 书籍和其他参考资料▶ 社交媒体活动▶…

rabbitmq默认交换机锁绑定的routingkey-待研究

例如这个是我的一个消息队列&#xff0c;它默认绑定的交换机是 什么类型呢? 看到这个图&#xff0c;感觉应该是一个默认的交换机&#xff0c;因为是default exchange 于是来到交换机来看看其他默认的交换机&#xff1a; 这里可以看到默认的交换机是direct&#xff08;应该没…

损失函数(Loss Function)与代价函数(Cost Function)、目标函数(Objective Function)区别

损失函数定义在单个样本上&#xff0c;算的是一个样本的误差。 代价函数定义在整个训练集上&#xff0c;是所有样本误差的平均&#xff0c;也就是损失函数的平均。 目标函数定义为最终需要优化的函数&#xff0c;等于经验风险 结构风险&#xff08;也就是Cost Function 正则化…

UE 调整材质UV贴图长宽比例

首先&#xff0c;为什么要先减去0.5呢&#xff0c;因为缩放的贴图中心在0,0原点&#xff0c;以这个点缩放效果是这样&#xff1a; 它缩放的图案不会在正中间&#xff0c;因为是以0,0点进行缩放的 以这个图的箭头去缩放图片的&#xff0c;所以不能使得缩放后的图片放在正中心 那…

<C++>类和对象下|初始化列表|explicit static|友元|内部类|匿名对象|构造函数的优化

文章目录 1. 初始化列表2. explicit关键字3. 友元3.1 友元函数3.2 友元类 4. static关键字4.1 概念4.2 特性 5.内部类5.1 概念5.2 特性 6. 匿名对象7. 拷贝构造时的优化 1. 初始化列表 在类的构造函数体中&#xff0c;对成员属性写的操作叫做赋值&#xff0c;那么成员的初始化…

深度学习数据集—细胞、微生物、显微图像数据集大合集

最近收集了一大波关于细胞、微生物、显微图像数据集&#xff0c;有细胞、微生物&#xff0c;细菌等。 接下来是每个数据的详细介绍&#xff01;&#xff01; 1、12500张血细胞增强图像&#xff08;JPEG&#xff09;数据集 该数据集包含12500张血细胞增强图像&#xff08;JPE…

实验(三):微程序计数器uPC实验

一、实验内容与目的 实验要求&#xff1a; 利用 CP226 实验仪上的 K16..K23 开关做为 DBUS 的数据&#xff0c;其它开关做为控制信号&#xff0c;实现微程序计数器 uPC 的写入和加1功能。 实验目的&#xff1a; 1、了解模型机中微程序的基本概念。 2、了解 uPC 的结构、工作原理…

windows nodejs 15.0.0下载安装

下载 Node v15.0.0 (Current) | Node.js (nodejs.org) 下载地址 https://nodejs.org/dist/v15.0.0/node-v15.0.0-x64.msi 安装 双击运行 等待安装完成 确认安装成功 管理员运行cmd 查看版本号

微信(小程序开发): 解决播放音乐没有声音的情况 代码不报错的情况下依旧没有声音的解决方案

解决无声的问题 在此之前&#xff0c;确保代码能够正常执行哈&#xff01;发这个其实没什么&#xff0c;就是有些人光写代码不调试出现了这个问题 其实解决方法特别简单 第一步&#xff1a; 打开项目后&#xff0c;点击三个点&#xff0c;然后选择模拟操作 第二步&#xff…

AIGC 是通向 AGI 的那条路吗?

AIGC 是通向 AGI 的那条路吗&#xff1f; 目录 一、背景知识 1.1、AGI&#xff08;人工通用智能&#xff09; 1.1.1、概念定义 1.1.2、通用人工智能特质 1.1.3、通用人工智能需要掌握能力 1.2、AIGC 二、AIGC 是通向 AGI 的那条路吗&#xff1f; 三、当前实现真正的 A…

python趣味编程-5分钟实现一个打字速度测试(含源码、步骤讲解)

Python速度打字测试是用 Python 编程语言编写的,速度打字测试 Python项目理念,我们将构建一个令人兴奋的项目,通过它您可以 检查 甚至 提高 您的打字速度。 为了创建图形用户界面(GUI),我们将使用 用于处理图形的pygame库。 Python 打字速度测试有利于学生或初学者提高…

基于动物迁徙算法优化概率神经网络PNN的分类预测 - 附代码

基于动物迁徙算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于动物迁徙算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于动物迁徙优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针对PNN神…

问卷工具价格一览:合理定价,满足您的预算需求

在市场调研、市场营销和客户反馈收集等方面&#xff0c;问卷调查是一项重要而有效的工具。而在众多的问卷工具中&#xff0c;Zoho Survey以其丰富的功能和灵活的定价模式而备受关注。Zoho Survey的定价如何&#xff1f;今天我们来聊一聊。 Zoho Survey提供了多种定价方案&…