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

news2024/9/28 16:23:34

目录

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Redis相关的那些事(一)

背景 目前工作所负责的工作主要是投放业务,属于读高并发场景,记录一下之前碰到的redis相关的问题。 热点大值Key&缓存击穿问题 问题表现 在某次流量峰值过程中,redis的CPU突然飙升,从监控看起来就是CPU飙升到一定程度&…

微信小程序(uniapp)api讲解

Uniapp是一个基于Vue.js的跨平台开发框架,可以同时开发微信小程序、H5、App等多个平台的应用。下面是Uniapp常用的API讲解: Vue.js的API Uniapp采用了Vue.js框架,因此可以直接使用Vue.js的API。例如:v-show、v-if、v-for、comput…

基于HC-SR04传感器的避障机器人设计与实现

本文介绍了如何设计和实现一个基于HC-SR04超声波传感器的避障机器人。我们将详细讨论硬件和电路连接,并提供完整的Arduino代码。该机器人可以利用超声波传感器检测周围的障碍物,并采取相应的动作进行避障,实现自主导航。 引言: 避…

微服务架构<2>

在电商项目中,我们针对一些核心业务,比较复杂的业务需要做一些设计以及优化的过程首先我们针对于订单的模块拆分了2个子模块1.order-curr实时下单业务 2.order-his 做一些历史的订单归档我们的订单业务 >商品添加至购物车 >购物车结算--> 订单…

sklearn 逻辑回归Demo

逻辑回归案例 假设表示 基于上述情况,要使分类器的输出在[0,1]之间,可以采用假设表示的方法。 设 h θ ( x ) g ( θ T x ) h_θ (x)g(θ^T x) hθ​(x)g(θTx), 其中 g ( z ) 1 ( 1 e − z ) g(z)\frac{1}{(1e^{−z} )} g(z)(1e−z)1​…

Go语言中的`sync`包同步原语

通过sync包掌握Go语言的并发 并发是现代软件开发的基本方面,而Go(也称为Golang)为并发编程提供了一套强大的工具。在Go中用于管理并发的基本包之一是sync包。在本文中,我们将概述sync包,并深入探讨其最关键的同步原语…

第二十一章博客

计算机应用实现了多台计算机间的互联,使得它们彼此之间能够进行数据交流。网络应用程序就是在已连接的不同计算机上运行的程序,这些程序借助于网络协议,相互之间可以交换数据。编写网络应用程序前,首先必须明确所要使用的网络协议…

1 手写第一个Win32窗口程序

1 基础概念 什么是窗口? 答:窗口就是屏幕上的一片区域,接受用户的输入,显示程序的输出。可以包含标题栏、菜单栏、工具栏以及控件等。什么是句柄? 答: 作为一种管理和操作系统资源的机制,提供了…

【AI提示词故事】雪的诗意:静谧与活力的奇妙交织

雪的诗意:沉浸在雪景的浪漫氛围中 冬日的清晨,窗外的世界被一层洁白的雪覆盖着,仿佛是大自然为我们准备的一幅美丽画卷。 我走出房门,踏上雪地, 那柔软的雪粒在脚下发出轻柔的咯吱声,仿佛是在诉说着冬日的…

SQL进阶:子查询

一般情况下,我们都是直接对表进行查询,但有时候,想要的数据可能通过一次select 获取不到,需要嵌套select,这样就形成了子查询。 子查询可以位于查询语句的任意位置,主要的注意点在于用于不同的位置,和不同的关键字一起使用时,需要注意返回的列的数量和行的数量。 位于…

Kubernetes(K8S)快速入门

概述 在本门课程中,我们将会学习K8S一些非常重要和核心概念,已经操作这些核心概念对应组件的相关命令和方式。比如Deploy部署,Pod容器,调度器,Service服务,Node集群节点,Helm包管理器等等。 在…

第十四章 集合(List)

一、集合框架体系 集合: (1)可以动态保存任意多个对象。 (2)提供了一系列方便的操作对象的方法:add、remove、set、get等。 二、Collection 1. Collection 接口常用方法 (1)add&a…

华为OD机试 - 多段线数据压缩(Java JS Python C)

在线OJ刷题 题目详情 - 多段线数据压缩 - Hydro 题目描述 下图中,每个方块代表一个像素,每个像素用其行号和列号表示。 为简化处理,多线段的走向只能是水平、竖直、斜向45度。 上图中的多线段可以用下面的坐标串表示:(2,8),(3,7),(3,6),(3,5),(4,4),(5,3),(6,2),(7,3),(…

C语言中常见的笔试题(二)

题目一: 问题: 在C语言中,const关键字有哪些用途?请列举出至少三种用途,并给出相应的代码示例。 答案: 定义常量:使用const关键字可以定义常量,它们的值在程序运行期间不能被修改…

React 路由跳转

1. push 与 replace 模式 默认情况下,开启的是 push 模式,也就是说,每次点击跳转,都会向栈中压入一个新的地址,在点击返回时,可以返回到上一个打开的地址, 就像上图一样,我们每次返…

U4_2 语法分析-自底向上分析-算符优先分析

文章目录 一、回顾1、推导 vs 规约2、句型、短语、简单短语、句柄 二、自底向上(移进-规约)分析方法1、基本思想2、分析过程3、移进—归约分析(Shift-Reduce Parsing) 三、算符优先分析1、概念2、分析流程1)先确定终结符之间的优先…

Codeforces Round 917 (Div. 2)(A~D)(又是数学题)

A - Least Product 题意&#xff1a; 思路&#xff1a;若有奇数个负数&#xff0c;则不需要任何操作。若存在0&#xff0c;也不需要任何操作。其余情况将任意一个数改为0即可。 #include <bits/stdc.h> using namespace std; void solve() {int n;cin >> n;int …

CUMT--Java复习--网络编程

目录 一、Java网络API 1、InetAddress类 2、URL类 3、URLConnection类 4、URLDecoder类和URLEncoder类 二、基于TCP的网络编程 1、Socket类 2、ServerSocket类 三、网络通信过程 一、Java网络API Java中有关网络方面的功能都定义在java.net中。 1、InetAddress类 Jav…

MySQL undo日志精讲3-从回滚段中申请 Undo 页面链表

回滚段-Rollback Segment Header 页面 回滚段的概念 我们现在知道一个事务在执行过程中最多可以分配4个 Undo 页面链表&#xff0c;在同一时刻不同事务拥有的 Undo 页面链表是不一样的&#xff0c;所以在同一时刻系统里其实可以有许许多多个 Undo 页面链表存在。为了更好的管…

工业互联网:数字化制造的未来

引言 在当今的数字化时代&#xff0c;制造业正经历着革命性的变革。工业互联网&#xff08;Industrial Internet of Things"&#xff0c;简称 IIoT&#xff09;作为这一变革的核心引擎&#xff0c;正在重新定义现代工业和制造。本文将探讨工业互联网的基础、关键技术、应…