MATLAB环境下基于频率滑动广义互相关的信号时延估计方法

时间延迟是声信号处理中的主要参数,要想确定信源距离、方位、速度等信息,就要能够精确、快速地估计时延及其他参数。所以,在信号处理领域中时延估计长期W以来都是的非常活跃的研究课题,在声纳、雷达、生物医学、通信、地球物理、石油勘探,语音信号增强和水声信号学、地震检波学等科学领域都有广泛的应用。

对时间延迟信息估计的方法、理论和性能的研究源自上个世纪,孕育于各种实际的工程应用需求,推动了时延估计TDE理论的发展。从目前收集的文献资料分析,臻于成熟和完善的时延估计方法大致可以分为六大类。

第一类是基于相关分析的时延估计方法,基本思想是将一路接收信号在时间上产生移位生成另一路接收信号,比如远处信号抵达接收阵列中不同阵元时产生的各路接收信号,通过解算互相关函数的最大峰值(此时两路信号相似程度最大)的位置信息估计时延。在较高信噪比,相关积分时间够长时此类方法可以做到精准时延估计,当相关积分时间较短、信噪比较低时,相关函数峰值会发生抖动、模糊,甚至会出现伪峰,不利于估计时延信息。

第二类是基于高阶累积量的时延估计方法,基本思想是利用高斯序列的高阶(二阶以上)累积量恒等于零这一特性,因此只需噪声服从高斯分布,便可在高斯噪声环境中有效地抑制噪声干扰,提高系统对非高斯信号的估计性能。

第三类是基于特征结构分析的时延估计方法,基本思想是利用多路接收信号的样本数据构造协方差矩阵,对其特征分解后利用信号和噪声子空间的正交性谱搜索关于时延的伪谱来估计时延信息,这类方法能够超越信号的瑞利极限,因此属于超分辨的时延估计范畴,常用的方法有MUSIC、ESPRIT、最大熵谱估等。

第四类是基于代价函数的时延估计方法,基本思想是依据最小平均代价为准则建立代价函数,通过不断的迭代去求解满足准则下的时延估值,比较传统的最优准则主要有MMSE、ML和非线性最小二乘法NLS等,由于此类方法在通常情况下对信号的统计特性依赖度不高,因此在多途时延估计问题中倍受学者们关注,但其在运算过程中会由于多途参数较多导致算法复杂度较高,不利于工程实现。

第五类是基于自适应处理的时延估计方法,基本思想是在某种最优准则下实时自动调整系统结构和滤波器参数至稳态收敛,进而获取时延信息的最优解,较为常用的准则有MMSE、RLS、最大信噪比(Max-SNR),线性约束最小方差(LCMV)等等。

第六类是其它算法,当信号为平稳信号时,上述时延估计方法具备出色的估计精度和稳健性,但当有用信号为非平稳随机过程或有突发强干扰时,常规的方法会显得捉襟见肘。

鉴于此,提出一种基于频率滑动广义互相关的信号时延估计方法,运行环境为MATLAB R2018A,压缩包=程序+数据+参考文献,部分代码如下:

if ~exist('lagmax','var')
    lags = -N/2:N/2-1;
else
    FSGCCmat = FSGCCmat(N/2-lagmax:N/2+lagmax,:);
    tpwin = tpwin(N/2-lagmax:N/2+lagmax);
    lags = -lagmax:lagmax;  
    N = length(lags);
end

% SVD Low-rank approximation

ra1 = mean(abs(tpwin));
ra0 = sqrt(pi/2)*sqrt((tpwin'*tpwin)/N);
w = (ra0 - mean(abs(FSGCCmat)))./(ra0-ra1);
w(w<0)=0;
W = diag(w);

wsvdinput = FSGCCmat*W;
[U,~,~] = svd(wsvdinput,'econ');
GCCwsvd = real(U(:,1));
[~,maxabs] = max(abs(GCCwsvd));
GCCwsvd = GCCwsvd*sign(GCCwsvd(maxabs));

出图如下:

完整代码:MATLAB环境下基于频率滑动广义互相关的信号时延估计方法
工学博士,担任《Mechanical System and Signal Processing》审稿专家,担任《中国电机工程学报》优秀审稿专家,《控制与决策》,《系统工程与电子技术》,《电力系统保护与控制》,《宇航学报》等EI期刊审稿专家。

擅长领域:现代信号处理,机器学习,深度学习,数字孪生,时间序列分析,设备缺陷检测、设备异常检测、设备智能故障诊断与健康管理PHM等。

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

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

相关文章

VS Code 的粘性滚动预览 - 类似于 Excel 的冻结首行

VS Code 的粘性滚动预览 - 类似于 Excel 的冻结首行功能&#xff0c;即滚动 UI 显示当前源代码范围。便于在代码行数比较多的时候更好的知道自己所在的位置。粘性滚动UI 显示用户在滚动期间所处的范围&#xff0c;将显示编辑器顶部所在的类/接口/命名空间/函数/方法/构造函数&a…

UE4 Niagara 关卡1.4官方案例解析

sprites can face the camera&#xff0c;or they can face any arbitrary vector&#xff0c;in this case the vector between the center of the system and the particle itself&#xff08;粒子可以面对摄影机&#xff0c;也可以面对任意向量&#xff0c;在这个实例中的向…

激活函数(Activate Fuction)

注意&#xff1a;本文引用自专业人工智能社区Venus AI 更多AI知识请参考原站 &#xff08;[www.aideeplearning.cn]&#xff09; 激活函数的定义与作用 激活函数是深度学习、人工神经网络中一个十分重要的学习内容&#xff0c;对于人工神经网络模型去学习、理解非常复杂和非…

【数据结构与算法】常见排序算法(Sorting Algorithm)

文章目录 相关概念1. 冒泡排序&#xff08;Bubble Sort&#xff09;2. 直接插入排序&#xff08;Insertion Sort&#xff09;3. 希尔排序&#xff08;Shell Sort&#xff09;4. 直接选择排序&#xff08;Selection Sort&#xff09;5. 堆排序&#xff08;Heap Sort&#xff09;…

06 OpenCV增加图像的对比度

文章目录 理论API代码 理论 图像变换可以看作如下&#xff1a; 像素变换 – 点操作邻域操作 – 区域 调整图像亮度和对比度属于像素变换-点操作 API saturate_cast(value)确保值大小范围为0~255之间Mat.at(y,x)[index]value 给每个像素点每个通道赋值 代码 #include <…

Sqli-labs靶场第18关详解[Sqli-labs-less-18]自动化注入-SQLmap工具注入

Sqli-labs-Less-18 通过测试发现&#xff0c;在登录界面没有注入点&#xff0c;通过已知账号密码admin&#xff0c;admin进行登录发现&#xff1a; 返回了User Agent&#xff0c;设想如果在User Agent尝试加上注入语句&#xff08;报错注入&#xff09;&#xff0c;测试是否会…

one4all 排坑记录

one4all 排坑记录 任务踩坑回顾动作踩坑动作踩坑动作新一步测试Habitat-sim 测试habitat-lab继续ONE4ALL 任务 看了《One-4-All: Neural Potential Fields for Embodied Navigation》这篇论文&#xff0c;感觉挺有意思&#xff0c;他也开源了代码。视觉语言导航是我一直想做的…

重学SpringBoot3-自动配置机制

重学SpringBoot3-自动配置机制 引言Spring Boot 自动配置原理示例&#xff1a;Spring Boot Web 自动配置深入理解总结相关阅读 引言 Spring Boot 的自动配置是其最强大的特性之一&#xff0c;它允许开发者通过最少的配置实现应用程序的快速开发和部署。这一切都得益于 Spring …

JCL中IEFBR14和COND

JCL中IEFBR14和COND ​ COND CODE&#xff0c;就是反映JCL中STEP运行状态的参数&#xff0c;JCL正常终了的COND CODE 是0000&#xff0c;另外笔者在执行某些工具JCL时候&#xff0c;比方说简单一个COMPARE吧&#xff0c;可能会出现0012、0004或者0016&#xff0c;0001&#xf…

linux安全--DNS欺骗,钓鱼网站搭建

目录 一&#xff0c;实验准备 首先让client能上网 1&#xff09;实现全网互通&#xff0c;实现全网互通过程请看 2&#xff09;SNAT源地址转换 3&#xff09;部署DHCP服务 4)配置DHCP服务 5&#xff09;启动服务 6&#xff09;安装DNS服务 7&#xff09;DNS配置 8)启动DNS…

代码随想录第46天|● 121. 买卖股票的最佳时机 ● 122.买卖股票的最佳时机II

文章目录 ● 121. 买卖股票的最佳时机思路一&#xff1a;贪心&#xff08;效率最快&#xff09;代码&#xff1a; 思路二&#xff1a;动态规划-dp数组代码&#xff1a; 思路三&#xff1a;动态规划 常数储存代码&#xff1a; ● 122.买卖股票的最佳时机II思路一&#xff1a;动态…

rocky使用yum安装msyql8.0

先查看一下源是否有mysql和mysql的版本 yum list mysql* 直接yum install mysql-server 会安装相关7个包 安装完毕后systemctl start mysqld启动mysql 然后mysql_secure_installation配置权限 mysql8的配置稍微有点不一样&#xff0c;按照英文提示来就行&#xff0c;不会的…

华为配置攻击检测功能示例

配置攻击检测功能示例 组网图形 图1 配置攻击检测功能示例组网图 业务需求组网需求数据规划配置思路配置注意事项操作步骤配置文件 业务需求 企业用户通过WLAN接入网络&#xff0c;以满足移动办公的最基本需求。且在覆盖区域内移动发生漫游时&#xff0c;不影响用户的业务使用。…

Mysql实战(1)之环境安装

1&#xff0c;进入&#xff1a;MySQL :: MySQL Downloads 2&#xff0c; 3&#xff0c; 4&#xff0c;

STM32用标准库编写按键控制LED灯的proteus仿真

首先打开proteus仿真软件&#xff0c;绘制电路图&#xff1a; 或是下载我已经建立好的工程修改&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1Nx5p3Tif6eHBIVkcPfsj9w?pwd1234 提取码&#xff1a;1234 第一步复制整个工程文件夹&#xff0c;就不用重新配置的辛苦…

解决虚拟机启动报错:“End kernel panic - not syncing: attempted to kill the idle task”

原本能正常运行的虚拟机&#xff0c;很长一段时间没用后&#xff0c;今天再次启动&#xff0c;然后就出现下面的问题&#xff1a; 然后走了一些弯路&#xff0c;比如说删除该虚拟机然后新建一个虚拟机&#xff08;问题未解决&#xff09;、直接删除VitualBox重新安装&#xff0…

【SQL】1321. 餐馆营业额变化增长(自连接;窗口函数rows between 、range between)

前述 窗口函数相关知识推荐阅读&#xff1a; 通俗易懂的学会&#xff1a;SQL窗口函数 窗口函数rows between 、range between的使用 MySQL中的DATEDIFF()函数 mysql data类型的加减 常用函数&#xff1a; ROUND() 函数&#xff1a;用于将数值四舍五入到指定的小数位数。FLOO…

【Linux网络命令系列】ping curl telnet三剑客

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

HADOOP HDFS详解

目录 第一章 概述 1.1大数据的特征(4V) 1.2 大数据的应用场景 1.3大数据的发展前景 1.4企业大数据的一般处理流程 1.4.1数据源 1.4.2数据采集或者同步 1.4.3数据存储 1.4.4 数据清洗 1.4.5 数据分析 1.4.6数据展示 第二章 hadoop介绍 2.1.hadoop 目标 2.2 hadoop的…