Mixed Far-Field and Near-Field Source Localization Based on Subarray Cross-Cumulant
基于子阵列互累积量(Cross-Cumulant)的远场和近场混合声源定位[1]。
文中采用Uniform linear array (ULA)阵列,将其分为两个互相重叠的子阵列,构建关于子阵列输出信号的两个特殊cross-cumulant matrices,而这两个矩阵仅仅与源信号的DOA有关。
信号模型
阵列模型如下:
K个窄带信号,阵元数目为2M+1的对称ULA阵列。假设中间阵元为相位基准。则第m个传感器的接收信号可以表示为:
其中为第k个入射信号的波形,
为第m个传感器的噪声,
为第k个源信号从阵元0到阵元m个传播时间(时延)。
当第k个入射信号是near-field信号时,满足如下形式:
λ表示波长,和
分别表示第k个源信号的DOA和range。根据菲涅耳区域的定义,
,并且
表示阵列孔径。
当第k个入射信号是far-field信号时,满足形式:
将公式(1)写为矩阵形式,可以表示为:
其中和
是维度为
的复数向量,并且有:
其中(2M + 1) × 1 的导向矢量表示为:
需要注意的是,在公式(6)表示的接收信号模型,前个源信号假定为FF源(近场源信号),剩余
个假定为NF源(远场源信号)。
本文有如下先验假设:
(1)源信号是统计独立的,采用非零峭度进行零均值随机处理。
(2)传感器噪声是加性的空间高斯白噪声,具有零均值。并且和源信号互相独立。
(3)已知源信号数目K,或者已经采用信息论准则准确估计得到。
提出算法
1、FF源和NF源的DOA估计
基于上述假设,阵列输出信号的四阶累计量表示为:
有。其中第k个源信号的峭度表示为:
。
使得,
,公式(14)可以写作:
如图1所示,我们将ULA阵列划分为两个相互重叠的子阵列Y和Z,用以构建子阵列输出信号的cross-cumulant matrices,从此推导累积量的平移不变性。子阵列Y和Z的接收信号向量可以表示为:
很明显地,y(t)的第m个元素为,z(t)的第m个元素为
。
根据上述子阵列的输出信号和公式(15),可以构建两个互累积量矩阵,其第
个元素为:
其中。注意上述两个互累积量矩阵可以仅用DOAs表示。
C1表示为紧凑的矩阵形式:
其中,虚拟的“阵列流型矢量”为
,并且
同理,C2可以表示为:
其中。
结合C1和C2,得到(4M - 2) × (4M - 2) 矩阵为:
对C进行特征值分解,得到:
其中,并且
是包含K个C的最大特征值以及(4M-2-K)个C的最小特征是的对角矩阵。
和
分别是对应的特征向量组成的矩阵。
基于子阵列理论,张成
的列空间,这表示存在一个K×K的矩阵T使得:
。
使得E1和E2为Es的最大和最小(2M-1)×K的半矩阵,由上式得到:,组成结果:
其中。公式(28)可以用TLS准则求解
,其特征值是和源信号的DOAs相关的。使得V为
的2K×2K的右奇异向量,当V被划分为4个K×K子阵列:
则公式(28)的解可以给出:
假设是
的第k个特征值,则第k个源信号的DOA可以给出:
2、源辨识和距离估测
对接收信号的相关矩阵进行EVD,得到:
其中和
分别为包含R的K个最大特征值和(2M+1-K)个最小特征值的对角矩阵。
和
分别为对应的特征向量组成的矩阵。
根据上述DOA估计值,代入
到下述谱函数中:
可以计算估计距离。
此处和
无需其他处理,自动匹配。实际上,我们就可以辨别不同的源信号了,当
时,第k个源为NF源;当
时为FF源,此时使得
为
。
3、讨论
1)需要注意的是,为了避免中的元素出现相位模糊性,文中提出算法要求
。
2)鉴于四阶累计量矩阵C1和C2的维度是2M-1,对于一个包含2M+1个真元的ULA,最多可以定位2M-2个不同源信号。不同的是,二阶MUSIC算法和高阶MUSIC算法可以分别最多处理M和2M个源信号。
3)对于文中提出方法,主要的计算量在于构建累积量矩阵,计算协方差矩阵,及其EVDs和距离搜索,需要乘法次数次,其中
为在菲涅尔域内搜索点数。
因为除了搜索距离,还需要估计DOAs,高阶MUSIC算法需要的乘法次数为 。
二阶MUSIC算法需要的乘法次数为。其中
是在角度域中需要搜索的点数。
需要注意的是,文中所提方法的计算复杂度中没有,所以其计算复杂度低于高阶MUSIC。
仿真实验
参考文献
[1] Zhi Zheng, Mingcheng Fu, Wen-Qin Wang,etc. Mixed Far-Field and Near-Field Source Localization Based on Subarray Cross-Cumulant ☆[J]. Signal Processing, 2018.
Mixed Far-Field and Near-Field Source Localization Based on Subarray Cross-Cumulant的更多相关文章
- [field:picname/]和[field:litpic/]区别
显示出二级栏目及以下的所有图片(包含三级栏目的) <ul class="incps"> {dede:arclist row=9 col="3" ty ...
- Huge CSV and XML Files in Python, Error: field larger than field limit (131072)
Huge CSV and XML Files in Python January 22, 2009. Filed under python twitter facebook pinterest lin ...
- Lucene.NET中Field.Index 和 Field.Store的几种属性的用法
转载自 http://blog.csdn.net/yja886/article/details/6612069 lucene在doc.add(new Field("content" ...
- [Struts2] No result defined for action ... and result input & Invalid field value for field ...
"No result defined for action ... and result input"错误一般发生在Struts2的拦截器拦截时遇到了问题时.Struts2会将跳转 ...
- 声源定位之2精读《sound localization based on phase difference enhancement using deep neuarl networks》
2.1.1 题目与摘要 1.为什么要增强IPD? The phase differences between the discrete Fourier transform (DFT) coeffici ...
- ExtJs之Field.Trigger和Field.Spinner
作文本框功能的. <!DOCTYPE html> <html> <head> <title>ExtJs</title> <meta h ...
- android jni ——Field & Method --> Accessing Field
现在我们知道了怎样使用native code访问简单的数据类型和引用参考类型(string,array),下面我们来介绍怎样让jni代码去访问java中的成员变量和成员函数,然后可以再jni中回调ja ...
- 关于能量场和力场弯曲空间的实验证明 EXPERIMENTAL PROOF ON THE BENDING SPACE OF ENERGY FIELD AND FORCE FIELD
前文提到,F = ma, E = mc^2,并且等效是传递的,等效概念具有同属性.所以不止能量,力场也可以弯曲空间. 实验:某人被头顶上方的电站10几万伏的设备吸收,烧毁双臂. (虽然这个实验不应具有 ...
- Django Model field reference
===================== Model field reference ===================== .. module:: django.db.models.field ...
随机推荐
- flask---快速使用
初识falsk django是大而全面的框架,flask是个轻量级的框架. flask快速开发网站 flask可以使用很少的代码就可以直接完成一个项目(6,7行代码),如下: from flask i ...
- Python输出菱形
最近准备熟悉下Python的基础语法,准备练习下输出菱形.刚好作为自己blog的开篇~~ n =10 #控制菱形的大小 for i in range(1, n): for j in range(int ...
- 《算法图解》全本PDF下载附百度云链接
作者使用Python和图画来解释算法,找了好久才找到PDF版本,末尾附百度云链接~ 作者[美]Aditya Bhargava 译者袁国忠 类别 出版 / 非虚构 出版社人民邮电出版社 / 2017-0 ...
- Function Evaluation
Author: Leisureeen Time Limit: 100ms Memory Limit: 65535KB Code Size Limit: 16 KB 64-bit integer IO ...
- leetcode动态规划笔记二
动态规划 题目分类 一维dp 矩阵型DP Unique Paths II : 矩阵型DP,求所有方法总数 Minimum Path Sum:矩阵型,求最大最小值 Triangle : 矩阵型,求最大最 ...
- C# 运行流程
转载 https://www.cnblogs.com/qcloud1001/p/9816956.html 从编译原理说起 一句话介绍编译器:编译器是将用某种程式语言写成的源代码(源语言),转换成另一 ...
- .NET Core随笔把数据库数据查出来转JSON并输出
直接创建WEB项目即可: public class Startup { //startup.cs是站点启动时具体做了哪些事情,主要是开启了一个mvc服务. public Startup(IConfig ...
- 以yarn-client方式提交spark任务,任务一直卡在ACCEPTED状态
问题背景 spark是以客户端的方式安装的,并没有启动spark的mesos集群,这时候的spark就相当与hive客户端. 以local模型和yarn-cluster方式提交任务,都能正确额执行,但 ...
- RabbitMQ知识梳理
RabbitMQ 基本概念 交换机类型: RabbitMQ 运转流程: AMQP协议 入门使用 安装环境: 交换机和队列: 进阶使用 消息去从 消息确认投递 消息防止丢失 过期时间 (TTL) 消息分 ...
- 2019 人民网java面试笔试题 (含面试题解析)
本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.人民网等公司offer,岗位是Java后端开发,因为发展原因最终选择去了人民网,入职一年时间了,之前面试了很多 ...