【图像融合】基于非下采样Contourlet变换nsct算法实现红外图像和可见光图像的融合matlab源码

简介: 【图像融合】基于非下采样Contourlet变换nsct算法实现红外图像和可见光图像的融合matlab源码

1 简介

本论文主要研究基于非采样Contourlet变换的可见光与红外图像融合技术。本论文首先在国内外的研究基础上,通过分析图像融合技术的基本概念和原理,研究了图像融合技术一些典型算法。结合非采样Contourlet变换多尺度多分辨率和平移不变性的特点,提出一种基于非采样Contourlet变换的可见光与红外图像融合方法。本文的主要工作如下:  首先总结了小波变换的定义、性质,多尺度分析原理,二维小波变换和小波变换在图像处理中的应用。由于小波变换缺乏平移不变性,简明的分析和整理了小波变换在图像处理中的缺陷。然后详细的研究了Contourlet变换的基本理论、非采样Contourlet变换的原理与实现及其在可见光与红外图像融合中的应用。然后针对传统的基于非采样Contourlet变换图像融合准则,提出了一种新的低频和高频通道的融合准则。在非采样Contourlet变换的基础上,通过新的融合准则,对图像进行非采样Contourlet变换的分解,对低频系数进行了平均加权;将高频系数先通过归一化能量之差和阈值的比较,然后进行分步融合;最后进行非采样Contourlet变换的重构,得出融合图像。由于可见光源图像和红外源图像的图像差距较大,融合过程中丢失的信息量较多,所以在非采样Contourlet图像的融合中,提出了“二次”NSCT图像融合。主要是将第一次图像融合后得到的新融合系数,与源图像中图像信息较多的源图像再进行一次融合,获取丢失较多的信息。  通过小波变换、Contourlet变换、非采样Contourlet变换和本文的方法对可见光源图像和红外源图像进行融合,最后的实验结果得出本文提出的方法在人类视觉特点和标准融合评价指标上的优势。

2 部分代码

%NSCT_imagefusion%%实现红外与可见光图像融合;%初始化%clear all;close all;clc;%初始化结束%%计时开始%tic;  path(path,'nsct_toolbox');path(path,'ziji');kk=1.5;%%%%%%%%%%%输入图像%%%%%%%%%%%[input_image_TV_int_RGB, input_image_TV_int_MAP] = imread('红外.jpg');                    %输入gif格式的可见光图像%% input_image_TV_int_RGB = uint8(256*ind2rgb(input_image_TV_int_GIF, input_image_TV_int_MAP));     %将gif格式数据转换为RGB格式数据%[input_image_IR_int_RGB, input_image_IR_int_MAP] =  imread('可见光.jpg');                    %输入gif格式的红外图像%% input_image_IR_int_RGB = uint8(256*ind2rgb(input_image_IR_int_GIF, input_image_IR_int_MAP));     %将gif格式数据转换为RGB格式数据%%%%%%%%%%%%%%%输入图像结束%%%%%%%%%%%%%%[Ny,Nx] = size(input_image_TV_int_RGB);  %%%%%%%%%%%%图像预处理%%%%%%%%%%%%%将可见光图像的格式转换为IHS格式%input_image_TV_int_IHS = rgb2ihs( input_image_TV_int_RGB );input_image_TV_IHS = double(input_image_TV_int_IHS);                    %将输入图像的数据类型转换为双精度数据类型%input_image_TV_I =  256*input_image_TV_IHS(:,:,3);                            %将输入图像的I分量提取出来以进行NSCT分解%%将红外图像的格式转换为gray格式%input_image_IR_int = rgb2gray( input_image_IR_int_RGB );input_image_IR= double(input_image_IR_int);                  %将输入图像的数据类型转换为双精度数据类型%input_image_TV_S =  input_image_TV_IHS(:,:,2);input_image_TV_H =  input_image_TV_IHS(:,:,1);figure;subplot(1,3,1);imshow(uint8(input_image_TV_I));title('Original TV image I')       %显示输入可见光图像的I分量%subplot(1,3,2);imshow(uint8(input_image_IR));title('Original IR image Gray')   %显示输入红外图像的灰度图像%%%%%%%%%%%%%%%%%图像预处理结束%%%%%%%%%%%%%%%%%金字塔表示参数%Nsc = ceil(log2(min(Ny,Nx)) - 7);    %分解尺度的数量 (自适应于图像尺寸)%Nor = 8;                     %每级分解的方向数%%%%%%%%%%%%%%%%%初始化参数结束%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%NSCT子带分解%%%%%%%%%%%%%%%%初始化NSCT子带分解参数%pfilter = 'maxflat' ;                               %金字塔滤波器%dfilter = 'dmaxflat7' ;                             %方向滤波器%nlevels=zeros(1,Nsc+1);for i=1:Nsc+1    nlevels(i)=log2(Nor);                           %初始化分解尺度%end%初始化NSCT子带分解参数结束%%%%%%%%%%%%%%%%NSCT子带重构%%%%%%%%%%%%%%%out_image_end_I = nsctrec( coeffs_rec, dfilter, pfilter ) ;    %重构灰度图像%  subplot(133)imshow(uint8(out_image_end_I));title('融合图像I');out_image_end=zeros(Ny,Nx,3);                            %初始化彩色图像输出矩阵%out_image_end=cat(3,input_image_TV_H,input_image_TV_S,out_image_end_I/256);                      out_image_end_RGB=256*ihs2rgb(double(out_image_end));           %将输出彩色图像转换为RGB格式%              figure;imshow(uint8(out_image_end_RGB));                        %显示融合后彩色图像%imwrite(uint8(out_image_end_RGB),'SWT22.bmp','bmp');toc;

3 仿真结果

4 参考文献

[1]汪攀. 基于非采样Contourlet变换的可见光与红外图像融合[D]. 南昌航空大学, 2012.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

部分理论引用网络文献,若有侵权联系博主删除。

相关文章
|
3天前
|
传感器 算法 C语言
基于无线传感器网络的节点分簇算法matlab仿真
该程序对传感器网络进行分簇,考虑节点能量状态、拓扑位置及孤立节点等因素。相较于LEACH算法,本程序评估网络持续时间、节点死亡趋势及能量消耗。使用MATLAB 2022a版本运行,展示了节点能量管理优化及网络生命周期延长的效果。通过簇头管理和数据融合,实现了能量高效和网络可扩展性。
|
15天前
|
算法
基于ACO蚁群优化的UAV最优巡检路线规划算法matlab仿真
该程序基于蚁群优化算法(ACO)为无人机(UAV)规划最优巡检路线,将无人机视作“蚂蚁”,巡检点作为“食物源”,目标是最小化总距离、能耗或时间。使用MATLAB 2022a版本实现,通过迭代更新信息素浓度来优化路径。算法包括初始化信息素矩阵、蚂蚁移动与信息素更新,并在满足终止条件前不断迭代,最终输出最短路径及其长度。
|
18天前
|
机器学习/深度学习 算法
基于心电信号时空特征的QRS波检测算法matlab仿真
本课题旨在通过提取ECG信号的时空特征并应用QRS波检测算法识别心电信号中的峰值。使用MATLAB 2022a版本实现系统仿真,涵盖信号预处理、特征提取、特征选择、阈值设定及QRS波检测等关键步骤,以提高心脏疾病诊断准确性。预处理阶段采用滤波技术去除噪声,检测算法则结合了一阶导数和二阶导数计算确定QRS波峰值。
|
2月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
123 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
2月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
95 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
2月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
71 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
5月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
5月前
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
|
5月前
|
Serverless
基于Logistic函数的负荷需求响应(matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
下一篇
无影云桌面