基于稀疏表示的小波变换多光谱图像融合算法matlab仿真

目录

1.算法运行效果图预览

2.算法运行软件版本

3.部分核心程序

4.算法理论概述

5.算法完整程序工程


1.算法运行效果图预览

小波变换融合

PCA融合

基于稀疏表示的小波变换多光谱图像融合算法

性能指标对比

2.算法运行软件版本

matlab2022a

3.部分核心程序

.........................................................................

% %读取数据并显示
% [MS]  = imread('image\MS256.tif');
% [PAN] = imread('image\PAN1024.tif');


% [MS]  = imread('image\数据1\low.jpg');
% [PAN] = imread('image\数据1\high.jpg');
% PAN   = rgb2gray(imresize(PAN,4));

[MS]  = imread('image\数据2\MS.jpg');
[PAN] = imread('image\数据2\PAN.jpg');
PAN   =  (imresize(PAN,4));

MS_show(:,:,1)=MS(:,:,1);
MS_show(:,:,2)=MS(:,:,2);
MS_show(:,:,3)=MS(:,:,3);

% down_size = 1/4;
% PAN  = imresize(PAN,down_size);
%小波变换,得到高频和低频系数
figure; 
imshow(MS_show);

NAME = 'haar';
R = func_fusion_tops(double(MS_show(:,:,1)),double(PAN),NAME);
G = func_fusion_tops(double(MS_show(:,:,2)),double(PAN),NAME);
B = func_fusion_tops(double(MS_show(:,:,3)),double(PAN),NAME);
 
%还原
img(:,:,1)     = R;
img(:,:,2)     = G;
img(:,:,3)     = B;
 

 
%显示重构图像
figure;
subplot(224);
imshow(uint8(img(:,:,1:3)));title('the reconstructed fusion image');
subplot(221);
imshow(img(:,:,1),[]);title('the reconstructed fusion image 1');
subplot(222);
imshow(img(:,:,2),[]);title('the reconstructed fusion image 2');
subplot(223);
imshow(img(:,:,3),[]);title('the reconstructed fusion image 3');
 

%信息熵
entropy = func_entropy(img(:,:,1));
entropy
%边缘强度
outval = edge_intensity(img(:,:,1)); 
outval
%平均梯度
outvals = avg_gradient(img(:,:,1));  
outvals

save R3.mat entropy outval outvals
figure;
subplot(131)
imshow(MS_show);title('待融合图像1');
subplot(132)
imshow(PAN);title('待融合图像2');
subplot(133)
imshow(uint8(img(:,:,1:3)));title('融合图像');
17_007m

4.算法理论概述

        随着遥感技术的飞速发展,多光谱图像融合在地球观测、环境监测、军事侦察等领域的应用日益广泛。本文提出了一种基于稀疏表示的小波变换多光谱图像融合算法,通过结合稀疏表示理论和小波变换的优势,实现了对多源多光谱图像的有效融合。文中详细介绍了该算法的原理、实现步骤及性能评估,并通过实验验证了所提算法的有效性。

       多光谱图像融合是指将来自不同传感器、不同波段的多幅图像融合成一幅具有更高空间分辨率和更丰富光谱信息的图像。传统的多光谱图像融合方法主要包括基于像素级的融合、基于特征级的融合和基于决策级的融合。然而,这些方法在处理复杂场景和多源数据时往往存在信息损失、光谱失真等问题。

       近年来,稀疏表示理论在图像处理领域得到了广泛关注。稀疏表示能够通过学习一组过完备字典中的少量原子来表示信号,从而实现对信号的高效、精确表示。本文将稀疏表示理论引入多光谱图像融合领域,提出了一种基于稀疏表示的小波变换多光谱图像融合算法。该算法利用小波变换对图像进行多尺度分解,然后采用稀疏表示方法对分解后的系数进行融合,最后通过小波逆变换得到融合后的图像。实验结果表明,该算法能够在保持光谱信息的同时,提高空间分辨率,实现对多光谱图像的高质量融合。

5.算法完整程序工程

OOOOO

OOO

O

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

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

相关文章

java八股 spring + mybatis

Spring常用注解(绝对经典)_spring注解-CSDN博客 框架篇-02-Spring-单例bean是线程安全的吗_哔哩哔哩_bilibili 1.spring.bean 单例 线程不安全 2.AOP 项目里可以说记录用户登录日志,利用request去获取姓名、ip、、请求方式、url&#xff0…

ros2中gazebo安装的注意事项

Install From source(推荐安装Fortress版本,好像很方便) ROS Be sure youve installed ROS Humble (at least ROS-Base). More ROS dependencies will be installed below. Gazebo Install either Edifice, Fortress, or Garden.(没有har…

MFC 运行时类信息机制

目录 运行时类信息机制概述 测试 宏代换分析 结构体 CRuntimeclass 函数 GetRuntimeClass() 总结 执行过程分析 运行时类信息机制概述 在程序运行过程中可以获知对象的类的相关信息(例如∶对象是否属于某个类) 如何使用? 类必须派生自CObject类…

MFC 动态创建机制

目录 动态创建机制概述 代码测试分析 执行过程 总结 动态创建机制概述 MFC 动态创建机制是 MFC 中的一项重要功能,它允许开发者在运行时动态创建和管理窗口控件。通过动态创建机制,开发者可以根据需要在程序运行过程中创建、显示和销毁窗口&#xf…

【K8S in Action】服务:让客户端发现pod 并与之通信(2)

一 通过Ingress暴露服务 Ingress (名词) 一一进入或进入的行为;进入的权利;进入的手段或地点;入口。一个重要的原因是每个 LoadBalancer 服务都需要自己的负载均衡器, 以及 独有的公有 IP 地址, 而 Ingres…

基于STM32的DS1302实时时钟模块应用及原理介绍

在嵌入式系统中,实时时钟模块是一个常见的功能模块,用于记录和管理系统的时间信息。DS1302是一款低功耗、具有多种功能的实时时钟芯片,被广泛应用于各种电子产品中。本文将介绍基于STM32微控制器的DS1302实时时钟模块的应用及原理&#xff0c…

案例163:基于微信小程序的校园二手交易平台系统设计与开发

文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序…

快速入门学习定时任务框架-xxljob

定时任务框架-xxljob 简介 主要用于分布式任务调度,可以将任务调度和执行分布在多个节点上。它提供了一个集中式的管理平台,支持动态添加、修改、删除任务,以及任务的分片执行,确保任务在分布式环境中的高可用性的一个框架 spr…

OSI 七层参考模型及TCP/IP 四层模型

OSI 七层参考模型 七层模型,亦称 OSI ( Open System Interconnection )参考模型,即开放式系统互联。参考模型是国际标准化组织(ISO )制定的一个用于计算机或通信系统间互联的标准体系,一般称为…

在使用 npm install的时候提示node-sass command faile 解决方案

在使用npm install的时候错误提示node-sass 相关的。错误信息如下图: 解决方法(PS:凯哥的不适用) 出现这种问题基本是由于node版本与sass版本不匹配导致的 方案1:卸载node,安装对应版本 方案2&#xff1…

基于Arduino和HC-SR04的超声波测距系统设计

本文介绍了如何使用Arduino和HC-SR04超声波传感器设计并构建一个简单的超声波测距系统。我们将详细讨论硬件连线和编程步骤,并提供完整的Arduino代码。此系统可以应用于各种需要测量距离的项目,例如智能车辆、机器人和安防系统。 引言: 超声…

工具系列:PyCaret介绍_编写和训练自定义机器学习模型

文章目录 PyCaret安装PyCaret👉 让我们开始吧👉 数据集👉 数据准备PyCaret中的设置函数👉 可用模型👉 模型训练与选择👉 编写和训练自定义模型👉 GPLearn模型👉 NGBoost 模型&#x…

解决log4j多个日志都写到一个文件

之前客户端程序由于Websockt包依赖的log4j,就用log4j写日志了,Web用的log4j2没毛病。用log4j的多个logger的日志都写到一个文件里了,查了很多资料都没解决。今天闲了解决一下。 最后好使的配置 # 设置日志根 log4j.rootLogger INFO,Except…

嵌入式开发中利用strstr()对部分模块回传数据进行解析的问题(坑)

受到以下博文的启发: https://www.cnblogs.com/yup1983/p/11337837.html 验证: 最近通过ESP8266远程控制小车,在wifi回传的数据解析过程中遇到标题所述的烦恼 如上截图所示,数据回传过程中会接受到‘\0’字节对应的ASCII码为0x0…

基于IPP-FFT的线性调频Z(Chirp-Z,CZT)的C++类库封装并导出为dll(固定接口支持更新)

上一篇分析了三种不同导出C++类方法的优缺点,同时也讲了如何基于IPP库将FFT函数封装为C++类库,并导出为支持更新的dll库供他人调用。 在此基础上,结合前面的CZT的原理及代码实现,可以很容易将CZT变换也封装为C++类库并导出为dll,关于CZT的原理和实现,如有问题请参考: …

大数据应用开发1——配置基础环境

一、基础环境配置 1.配置虚拟网络 1.1、点击1、编辑2和3, 1.2、点开4,编辑网关 2、配置虚拟机环境 1.1、安装一台虚拟机,使用root用户登录,打开终端 1.2修改主机名 终端输入: vim /etc/hostname使用vim编辑/etc/ho…

MQ(消息队列)相关知识

1. 什么是mq 消息队列是一种“先进先出”的数据结构 2. 应用场景 其应用场景主要包含以下3个方面 应用解耦 系统的耦合性越高,容错性就越低。以电商应用为例,用户创建订单后,如果耦合调用库存系统、物流系统、支付系统,任何…

SpringMVC核心处理流程梳理

1、处理流程图展示 当我拿出这张图,阁下又该如何应对呢?执行流程是不是一目了然了。 2、DispatcherServlet:中央处理器或者中央调度器 下图官方的解释应该最完善了。 3、SpringMVC三大核心组件 HandlerMapping 处理器映射器,…

iApp最新版无服务器多功能软件库源码

无需服务器的多功能软件库源码分享,仅需添加一个后台应用和一个文档即可 使用教程如下: 在浏览器中打开理想后台地址:http://apps.xiaofei.run/user/ 如果没有账号,请注册一个免费账号。 登录账号后,添加一个后台应…

Oracle 学习(1)

Oracle简介 Oracle是殷墟(yīn Xu)出土的甲骨文(oracle bone inscriptions)的英文翻译的第一个单词,在英语里是“神谕”的意思。Oracle公司成立于1977年,总部位于美国加州,是世界领先的信息管…