matlab SAR图像的多视滤波

目录

  • 一、算法原理
    • 1、概述
    • 2、时域多视滤波
    • 3、频域多视滤波
    • 4、参考文献
  • 二、代码实现
    • 1、时域多视滤波
  • 三、结果展示
  • 四、相关链接

一、算法原理

1、概述

  单视复数数据(Single Look Comple)是原始的最高分辨率数据,但是从单个像元散射的雷达回波信号的相干叠加,导致强度信息有很多噪声。SAR的多视处理是对SLC数据方位向和/或距离向做平均,得到的结果是多视后的强度数据。多视处理可以提高SAR图像的信噪比,有效抑制斑点噪声,但是会降低方位分辨率。
  卫星在侧视获取数据的时候,由于入射角、地面和天线的距离决定数据的分辨率不同,SAR数据的像元一般是长方形的。但是参考DEM数据一般是处理之后像素为正方形的栅格数据,这就导致运算的时候计算量过大,所以需要设置多视比,将SAR数据的像元尽可能像正方形,大小贴合参考DEM数据。
  有两种多视方法,一种在时域执行,另一种在频域执行。时域多视由应用程序平均窗口组成,以减少散斑,而频域实现将频谱分为子谱,并对其进行平均。频域多视的优势在于它可以在相同的空间分辨率下实现更好的 ENL(等效视数),但同时对计算的要求更高。

2、时域多视滤波

  1. 计算视数;视数跟距离向分辨率、方位向分辨率以及中心入射角有关。计算公式如下:
    g = p r i a g=\frac{pr}{ia} g=iapr
    g p a ∗ M → 1 \frac{g}{pa*M}\rightarrow1 paMg1
    式中, p r pr pr为距离向分辨率, p a pa pa为方位向分辨率, i a ia ia为中心入射角。

在这里插入图片描述

  1. 滑动平均滤波;根据视数,生成一个的窗口,进行滑动滤波,随着视数的增加,斑点噪声逐渐减少。

3、频域多视滤波

  1. 计算视数。

  2. 傅里叶变换;将图像进行傅里叶变化,得到一幅完整频域图像。

  3. 划分频谱;根据视数 m m m,将第2步中获取的频域图像分成 m m m份,得到 m m m份子谱频域图像;

  4. 逆傅里叶变化;将第3步获取的子谱频域图像进行逆傅里叶变换,得到得到 m m m份子谱时域图像;

  5. 合并子谱时域图像;将子谱时域图像进行合并,获取一张完整的多视处理后的SAR图像。

多视处理后,数据的方位向将变少,直观的就是数据行数变少,若为了保证数据行列号不变,可采用频域补零的方法。

4、参考文献

[1]刘冉. SAR图像相干斑抑制算法研究[D]. 合肥工业大学, 2022. DOI:10.27101/d.cnki.ghfgu.2022.000392.

二、代码实现

1、时域多视滤波

multilookProcessing.m
详细实现过程见:matlab实现的SAR图像多视滤波.rar

main.m

clc;
clear;
close all;%% ----------------------------读取SAR图像----------------------------
sarImg = imread("section.tif");
%% ----------------------------多视滤波-------------------------------
multilook_out = multilookProcessing(sarImg,2,4);
%% ----------------------------结果显示-------------------------------
figure;
subplot(121)
colormap('gray')
imagesc(sarImg);
title("原始图像");
hold on
subplot(122)
colormap('gray')
imagesc(multilook_out);
title('多视滤波后的强度图');
hold on;

三、结果展示

在这里插入图片描述

四、相关链接

  • SAR的单视SLC和多视mlutilooking
  • SAR数据的多视Multi-look,包括range looks和azimuth looks,如何设置多视比
  • 基于matlab编程实现SAR图像多视处理

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

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

相关文章

如何使用捕获过滤器

点击捕获,选项,然后在所选择的捕获过滤器上输入对应的捕获表达式 抓包过滤器 type(类型) 限定符: 比如host,net,port限定符等dir(方向) 限定符: src dstProto(协议类型)限定符: ether ip arp 二层过滤器举例 tcp dst port 135 …

数据库操作-视图

1、视图的概念 视图:是从一个或者几个基本表(或者视图)里的数据的逻辑显示(查询的结果),是一张虚拟表,不会存储数据,只能进行查询结果的封装; 2、创建视图 CREATE VIEW 视…

K3s部署及研究

K3s部署及研究 K3s和K8s详解什么是 Kubernetes (K8s)?什么是 K3s?对比 K8s 和 K3s举个例子1、备份系统自带yum源配置文件2、进入 /etc/yum.repos.d3、删除文件4、设置5、缓存 查看集群是否正常 安装K3S Node节点查看主节点token获取主节点服务地址 添加node节点查看节点状态 …

python—selenium爬虫

文章目录 Selenium与Requests对比一、工作原理二、功能特点三、性能表现 下载对应驱动1.首先我们需要打开edge浏览器,打开设置,找到“关于Microsoft Edge”,点击进入查看浏览器版本。2.查找版本之后,搜索edge驱动下载,…

群管机器人官网源码

一款非常好看的群管机器人html官网源码 搭建教程: 域名解析绑定 源码文件上传解压 访问域名即可 演示图片: 群管机器人官网源码下载:客户端下载 - 红客网络编程与渗透技术 原文链接: 群管机器人官网源码

STM32CUBEIDE FreeRTOS操作教程(一):LED闪灯

STM32CUBEIDE FreeRTOS操作教程(一):LED闪灯 STM32CUBEIDE(不是STM32CUBEMX)开发环境集成了STM32 HAL库进行FreeRTOS配置和开发的组件,不需要用户自己进行FreeRTOS的移植。这里介绍最简化的用户操作类应用教程。以STM32F401RCT6开…

PCB工艺边设计准则

在PCB设计时,通常会在电路板的边缘预留一定的空间,这部分空间被称为工艺边。它有助于在生产过程中确保电路板的尺寸和形状的准确性。以使得组装时更加顺畅、便捷。而工艺边的加工,使得线路板上的元件可以精准地与设备对接,从而提高…

leetcode6 -- z字形变换

题目描述: 将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。 比如输入字符串为 "PAYPALISHIRING" 行数为 3 时,排列如下: P A H N A P L S I I G Y I R 之后&#xff…

springboot系列十一:Thymeleaf

文章目录 官方文档基本介绍Thymeleaf机制说明Thymeleaf语法表达式运算符th属性迭代条件运算使用Thymeleaf th属性需要注意点 Thymeleaf综合案例需求说明思路分析代码实现 作业布置 官方文档 在线文档: https://www.thymeleaf.org/doc/tutorials/3.0/usingthymeleaf.html 离线…

DNS域名管理系统、搭建DNS服务

1.DNS概述 1.DNS(domain name system ) 域名管理系统 域名: 由特定的格式组成,⽤来表示互联⽹中某⼀台计算机或者计算机组的名称,能够使⼈更⽅便的访问互联⽹,⽽不⽤记住能够被机器直接读取的IP地址。 计算…

C++:模板(函数模板,类模板)

目录 泛型编程 函数模板 函数模板格式 函数模板的原理 函数模板的实例化 类模板 类模板格式 类模板实例化 模板分为函数模板和类模板 在C中使用模板可以让我们实现泛型编程 泛型编程 如果我们需要实现一个加法add函数,那么会怎么实现呢? int…

python 闭包、装饰器

一、闭包: 1. 外部函数嵌套内部函数 2. 外部函数返回内部函数 3.内部函数可以访问外部函数局部变量 闭包(Closure)是指在一个函数内部定义的函数,并且内部函数可以访问外部函数的局部变量,即使外部函数已经执行…

Python Formulas模型以JSON格式文件导出导入

1. 导入formulas和json包 在加载模型之前,导入formulas和json包。 import formulas, json2. 加载Excel模型 加载一个公式复杂的Excel模型,该模型耗时较长,我们可以观察使用json格式是否能更高效。 xl_model formulas.ExcelModel().load(…

oracle 基础知识表的主键

一、表的约束条件 •约束条件是施加在表的字段上的一组限制条件,它使得只有符合限制条件要求的数据才能输入表。 •保证了表中的数据的正确性 i.约束条件包括了:非空和唯一和核对,即not null 和unique 和check null的含义:不确定 3个人去捡苹…

重磅 - Github 上免费大屏来啦,教你快速搭建积木报表

先看看大屏效果 JimuReport积木报表的集成版本,已经提供了免费数据可视化设计工具。 支持丰富的数据源连接,能够通过拖拉拽方式快速制作图表和门户设计;目前支持多种图表类型:柱形图、折线图、散点图、饼图、环形图、面积图、漏斗…

Java基础巩固 -- 面向对象

Java基础巩固 – 面向对象 简介:博主本人由于在毕业前忙于找工作,因此选择了Java后端开发,但学习过程比较碎片化,并没有进行系统性学习。本章博客将会系统性重温Java的一些基础知识和概念。 1.面向对象 1.1 概念 面向对象是一…

微服务概念篇-服务提供者/服务消费者

微服务概念篇-服务提供者/服务消费者 提示:以下是本篇文章正文内容,下面案例可供参考 一、服务提供者是什么? 提供接口给其他微服务进行调用的服务称之为服务提供者 二、服务消费者是什么? 调用其他服务的接口的服务称之为服务消费者 三…

学习网络系统的心得体会

网络系统 零拷贝 磁盘是计算机系统中读写速度最慢的的硬件之一,而零拷贝技术是用于提高文件传输性能的,通过减少上下文切换次数与数据拷贝的次数从而提高传输性能。 操作系统中IO的流程 大体流程 收到IO请求由用户态切换到内核态,CPU发送…

【vueUse库Time模块各函数简介及使用方法--全篇】

vueUse库是一个专门为Vue打造的工具库,提供了丰富的功能,包括监听页面元素的各种行为以及调用浏览器提供的各种能力等。其中的Browser模块包含了一些实用的函数,以下是这些函数的简介和使用方法: vueUse库Sensors模块各函数简介及使用方法 vueUseTime函数1. useDateFormat…

# Redis 入门到精通(七)-- redis 删除策略

Redis 入门到精通(七)-- redis 删除策略 一、redis 删除策略–过期数据的概念 1、Redis 中的数据特征 Redis 是一种内存级数据库,所有数据均存放在内存中,内存中的数据可以通过TTL指令获取其状态。 XX :具有时效性…