【信号频率估计】MVDR算法及MATLAB仿真

目录

  • 一、MVDR算法
    • 1.1 简介
    • 1.2 原理
    • 1.3 特点
      • 1.3.1 优点
      • 1.3.2 缺点
  • 二、算法应用实例
    • 2.1 信号的频率估计
    • 2.2 MATLAB仿真代码
  • 三、参考文献

一、MVDR算法

1.1 简介

最小方差无失真响应(Mininum Variance Distortionless Response,MVDR)算法最早是J. Capon于1969年提出,用于多维地震阵列传感器的频率-波数分析。随后,Lacoss在1971年将其引入到一维时间序列的分析中。
MVDR算法由于是Capon提出的,所以也将其称为Capon算法。

1.2 原理

根据数字波束形成的原理,得到输入信号 x ( n ) x(n) x(n) 经空域滤波后的输出为:
y ( n ) = w H x ( n ) = w H a ( θ ) s ( n ) ( 1 − 1 ) y(n)=w^{H}x(n)=w^{H}a(θ)s(n) (1-1) y(n)=wHx(n)=wHa(θ)s(n)11
其中,输入信号 x ( n ) x(n) x(n) 为期望、干扰、噪声三种信号的耦合; a ( θ ) a(θ) a(θ) 为导向矢量。
当一个远场窄带信号 s ( n ) s(n) s(n) 入射到 M 个阵元的均匀线阵时,阵列输出信号的平均功率为:
P ( θ ) = E [ ∣ y ( n ) ∣ 2 ] = E [ w H x ( n ) x H ( n ) w ] = w H R w ( 1 − 2 ) P(θ)=E[|y(n)|^2]=E[w^{H}x(n)x^{H}(n)w]=w^{H}Rw (1-2) P(θ)=E[y(n)2]=E[wHx(n)xH(n)w]=wHRw12
式(1-2)中 R = E [ x ( n ) x H ( n ) ] R=E[x(n)x^{H}(n)] R=E[x(n)xH(n)] 为接收信号 x ( n ) x(n) x(n) 的空间相关矩阵。

假设期望信号从 θ 0 θ_{0} θ0 方向入射,阵列接收信号为 x 0 ( n ) = a ( θ 0 ) s ( n ) x_{0}(n)=a(θ_{0})s(n) x0(n)=a(θ0)s(n) ,为了使 x 0 ( n ) x_{0}(n) x0(n) 通过空域滤波器后无失真,权矢量 w w w 需满足:
w H a ( θ 0 ) = 1 ( 1 − 3 ) w^{H}a(θ_{0})=1 (1-3) wHa(θ0)=113
选择的加权矢量 w w w 满足式(1-3)就可以实现对干扰信号以及噪声的抑制,从而使输出信号的平均功率 P ( θ ) P(θ) P(θ) 最小。由此可以建立目标优化方程为:
在这里插入图片描述
采用拉格朗日乘数法对式(1-4)构造代价函数为:
J ( w ) = w H R w + λ ( w H a ( θ 0 ) − 1 ) ( 1 − 5 ) J(w)=w^{H}Rw+λ(w^{H}a(θ_{0})-1) (1-5) J(w)=wHRw+λ(wHa(θ0)1)15
对式(1-5)关于 w w w 求梯度,并令其为零,得到:
▽ J ( w ) = 2 R w − 2 λ a ( θ 0 ) = 0 ( 1 − 6 ) ▽J(w)=2Rw-2λa(θ_{0})=0 (1-6) J(w)=2Rw2λa(θ0)=016
解得: w = λ R − 1 a ( θ 0 ) w=λR^{-1}a(θ_{0}) w=λR1a(θ0) ,将结果代入式(1-3)可得:
λ = 1 a H ( θ 0 ) R − 1 a ( θ 0 ) ( 1 − 7 ) λ=\frac{1}{a^{H}(θ_{0})R^{-1}a(θ_{0})} (1-7) λ=aH(θ0)R1a(θ0)117
将式(1-7)代入求得的权矢量结果中,可得到 MVDR 波束形成器的最优权向量为:
w o p t = R − 1 a ( θ 0 ) a H ( θ 0 ) R − 1 a ( θ 0 ) ( 1 − 8 ) w_{opt}=\frac{R^{-1}a(θ_{0})}{a^{H}(θ_{0})R^{-1}a(θ_{0})} (1-8) wopt=aH(θ0)R1a(θ0)R1a(θ0)18
以上就是 MVDR 波束形成求权值的完整过程。当阵列的阵元个数为 M M M 时,阵列的自由度为 M − 1 M-1 M1,所以 MVDR 波束形成器要求干扰源个数必须小于或等于 M − 1 M-1 M1
在实际情况中,阵列的接收数据协方差矩阵只能在有限次快拍的情况下,用时间平均对采样数据进行估计得到,即:
R ˆ = 1 N ∑ n = 1 N x ( n ) x H ( n ) ( 1 − 9 ) R^{ˆ}=\frac{1}{N}\sum_{n=1}^{N}x(n)x^{H}(n) (1-9) Rˆ=N1n=1Nx(n)xH(n)19
其中, N N N 是采样快拍数, N N N 值越大,估计矩阵 R ˆ R^{ˆ} Rˆ 更接近理想的相关矩阵 R R R

1.3 特点

1.3.1 优点

(1)高分辨率:MVDR算法能够有效地分辨出多个声源的方向,具有较高的分辨率。这使得它在处理复杂声学环境时能够提供更准确的声源定位信息。

(2)鲁棒性强:MVDR算法对噪声和混响信号具有较强的鲁棒性。在存在噪声和混响的环境中,该算法能够较好地保持对声源方向的估计能力,提高系统的稳定性和可靠性。

(3)计算量相对较小:相较于一些更复杂的算法,MVDR算法的计算量相对较小,这使得它在实时性要求较高的应用场景中具有一定的优势。

(4)干扰抑制能力强:MVDR算法通过最小化其他方向的信号功率,能够有效地抑制多径干扰和噪声,提高信号的质量。这在无线通信、声纳和雷达等领域尤为重要。

1.3.2 缺点

(1)远场假设限制:MVDR算法假设声源位于远场,即声源与麦克风阵列之间的距离远大于阵列的尺寸。这一假设限制了算法在近场声源定位中的应用,因为对于近场声源,算法的定位精度会显著下降。

(2)对导向矢量误差敏感:MVDR算法的性能在很大程度上依赖于导向矢量的准确性。如果导向矢量存在误差,将会对算法的估计结果产生较大影响,降低定位精度。

(3)阵列尺寸限制:MVDR算法的性能与阵列尺寸有关。一般来说,阵列尺寸越大,算法的性能越好。然而,在实际应用中,受到成本和空间等因素的限制,阵列尺寸往往无法做到足够大,这可能会限制算法的性能。

(4)计算复杂度较高:尽管相对于一些更复杂的算法而言,MVDR算法的计算量较小,但在实时性要求极高的应用场景中,其计算复杂度仍然可能成为一个挑战。此外,为了获得更好的性能,可能需要对算法进行进一步的优化和加速。

二、算法应用实例

2.1 信号的频率估计

仿真1:对目标信号的到达角进行估计
设一维均匀线阵的阵元数目为8,其间距为半波长,有3个目标信号的到达角分别为-30°,0°,20°,利用MVDR算法对该目标信号进行到达角估计,计算结果如下图所示。
在这里插入图片描述
读者可根据自己的需求,设置阵元数、目标信号个数及目标真实角度、信号的信噪比等条件进行实验。

2.2 MATLAB仿真代码

clc;
clear;
close all;%% MVDR算法估计到达角
d_lambda = 0.5;         % 阵元间距与波长比
Rx_Num = 8;             % 接收天线阵元数N = 1000;               % 采样快拍数
sigNum = 3;             % 信源数目
theta0 = [-30,0,20];     % 真实来波角度
snr = 10;               % 信噪比S = randn(sigNum,N)+1j*randn(sigNum,N);     % 远场窄带信号
A = exp(1j*2*pi*d_lambda*sind(theta0).'*(0:Rx_Num-1)).';     % 导向矢量
X = A*S;                            % 接收信号
Y = awgn(X,snr,'measured');         % 添加噪声的接收信号R = Y*Y'/N;         % 接收数据的协方差矩阵
R_ = inv(R);        % 协方差矩阵的逆矩阵thetaScan = (-90:0.1:90);       % 扫描角度范围
As = exp(1j*2*pi*d_lambda*sind(thetaScan).'*(0:Rx_Num-1)).';num = 0;
P = zeros(1,length(thetaScan));     % 谱峰函数初始化
for ii = thetaScannum = num+1;P(num) = 1/(As(:,num)'*R_*As(:,num));
end
P = 10*log10(abs(P)/max(abs(P)));   % 对谱峰函数进行归一化并取对数
figure;
plot(thetaScan,P,'b','LineWidth',1);xlabel('扫描角范围');ylabel('归一化幅度/dB');hold on
ylim = get(gca,'Ylim');
for jj = 1:sigNum% 画出真实波达角的值进行对比line([theta0(jj) theta0(jj)],[ylim(1) ylim(2)],'Color','r','LineStyle','--');hold on;
end
legend('MVDR估计值','真实值');

三、参考文献

[1] Capon J. High-resolution frequency-wavenumber spectrum analysis[J]. Proc. IEEE, 1969, 57(8): 1408-1418.
[2] Lacoss R T. Data adaptive spectral analysis methods[J]. Geophysics, 1971, 36(8): 661-675.
[3] 胡君丽.数字阵列接收同时多波束技术研究[D].电子科技大学,2019.

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

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

相关文章

XLPR车牌自动识别开发包

XLPR SDK适用于为各种应用增加车牌自动识别能力,支持多个区域检测,支持车牌颜色和号码输出,提供Web API和 原生API。官方下载地址:XLPR车牌识别开发包。 XLPR主要由三个主要部分构成:D-Net、R-NET和C-Net,…

基于Java的疫情防控期间某村外出务工人员信息管理系统

你好呀,我是计算机学姐码农小野!如果有相关需求,可以私信联系我。 开发语言:Java 数据库:MySQL 技术:Java MySQL 工具:Eclipse、MySQL环境配置工具 系统展示 首页 用户管理界面 行程分析…

【Python游戏】编程开发贪吃蛇游戏(第一期)

本文收录于 《一起学Python趣味编程》专栏,从零基础开始,分享一些Python编程知识,欢迎关注,谢谢! 文章目录 一、前言二、贪吃蛇游戏开发简介2.1 贪吃蛇游戏规则2.2 贪吃蛇游戏开发步骤 三、贪吃蛇游戏开发实战四、总结…

昇思25天学习打卡营第03天|数据集 Dataset

数据集是深度学习的灵魂,就像做饭需要好的食材一样,没有高质量的数据,再牛的模型也训练不出来。而MindSpore的数据集处理真的很方便,就像是一个强大的厨房,提供了各种工具和食材。通过这个教程,我学会了怎么…

活用 localStorage

我维护的这款工具 https://editor.yunwow.cn/ 已经帮我写了 7 篇文章了, 用起来很顺手,因此我打算再给它升级下让它更方便,我决定要给它加个本地缓存功能。我给它提的要求是: 1. 至少能缓存 5 篇文章 2. 能有选择的加载模板 3…

VBA技术资料MF172:UDF向任何单元格添加数据验证

我给VBA的定义:VBA是个人小型自动化处理的有效工具。利用好了,可以大大提高自己的工作效率,而且可以提高数据的准确度。“VBA语言専攻”提供的教程一共九套,分为初级、中级、高级三大部分,教程是对VBA的系统讲解&#…

线性表的链式存储结构————双链表(java)

线性表的链式存储结构————双链表(java) 文章目录 线性表的链式存储结构————双链表(java)双链表双链表的创建插入数据元素头插法尾插法 求链表的长度输出双链表删除双链表中的指定元素总代码运行效果用Java内部类实现双链表…

在组件中显示tuku的照片

一、问题 (1)错误:域名前面一定要加http://要不然会报错 (2)在使用 defineModel传值时一定要动态绑定,要不然图片不显示 (3)改完后在商品列表中显示图片信息必须 在显示的图片中取…

基于天地图使用Leaflet.js进行WebGIS开发实战

目录 前言 一、天地图的key 1、创建应用 2、调用限制策略 注: (1)日服务调用超量会暂时拒绝访问,次日自动开启; (2)如果服务调用过程中存在数据爬取或者下载行为,服务调用会被自…

ssh -D 选项用于动态(Dynamic)端口转发

举例实现不同ssh连接功能目录 一、功能简介 -D 支持 SOCKS5 协议,可以同时转发 TCP 和 UDP 报文 二、原理介绍 假设拥有三台主机,具体环境如下: 1. 主机 A:本地主机,即 SSH 客户 所在的主机,IP&#xff1…

C语言switch的使用

switch的使用语句 switch(表达式) { case 值1: 语句1; break; case 值2: 语句2; break; default: break; } 注意事项:1.表达式计算结果只能为(字符/整数) 2.case值只能是(字…

最大文件句柄数

优质博文:IT-BLOG-CN 灵感来源 一、什么是文件句柄 文件句柄File Handle是操作系统中用于访问文件的一种数据结构,通常是一个整数或指针。文件句柄用于标识打开的文件,每个打开的文件都有一个唯一的文件句柄。 它们是对文件、网络套接字或…

哪些工科专业要学C语言或C++?

在开始前刚好我有一些资料,是我根据网友给的问题精心整理了一份「c++的资料从专业入门到高级教程」,点个关注在评论区回复“666”之后私信回复“666”,全部无偿共享给大家!!!工科专业…

鸿蒙语言基础类库:【@system.configuration (应用配置)】

应用配置 说明: 从API Version 7 开始,该接口不再维护,推荐使用新接口[ohos.i18n]和[ohos.intl]。本模块首批接口从API version 3开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 导入模块 import configurati…

网安小贴士(19)入侵检测技术原理与应用

前言 入侵检测技术(Intrusion Detection System, 简称IDS)是一种用于监测和防止计算机网络中的恶意活动的安全系统。它通过收集系统状态信息、特征提取、建立模型、入侵检测以及反馈更新等步骤,及时检测网络和系统中可能遭受攻击的迹象并发出…

python项目为什么用WSGI

小背景 Java用的时间久了,web项目启动的时候直接启动主程序就行,因为spring web项目内置了Tomcat web服务器,服务器的配置一般也是采用默认的配置,所以很少关注底层实现,关注点主要在应用程序功能。 初学python的时候…

打破运维“冷门槛“|暴雨液冷数据中心方案再升级

如果将数据比喻为驱动世界运转的新引擎,那数据中心便是为引擎提供源源不断动力的泵站。但随着泵站功率的日益增强,热浪成了不可避免的副产品。如何将数据热能转化为科技动能,是人工智能可持续发展的重要前提。 液冷技术,不仅可实现…

视频素材网站无水印的有哪些?热门视频素材网站分享

当我们走进视频创作的精彩世界时,一个难题常常摆在面前——那些高品质、无水印的视频素材究竟应该在哪里寻找?许多视频创作者感叹,寻找理想的视频素材难度甚至超过了寻找伴侣!但不用担心,今天我将为您介绍几个优质的视…

人工智能导论-确定性推理

确定性推理 概述 上一章:讨论了“知识与知识表示”,可以把知识用某种模式表示出来存储到计算机中,但为使计算机具有智能,还必须使它具有思维能力。 本章:1)推理是求解问题的一种重要方法。因此&#xff…

对消息队列进行深入学习

目录 1.什么是消息队列。1.1消息队列1.1.1同步的理解1.1.2异步的理解 1.2消息传递与消息队列 2. 消息队列应用场景2.1 异步处理2.2 流量削锋2.3 应用解耦2.4 日志处理2.5 消息通讯2.6 延时任务2.7 广播消费2.8 分布式事务 3. 主流消息队列3.1 RabbitMQ3.1.1 RabbitMQ工作原理3.…