【麦克风阵列增强】Delay and sum beamforming

作者:桂。

时间:2017-06-03  15:40:33

链接:http://www.cnblogs.com/xingshansi/p/6937576.html


前言

本文主要记录麦克风阵列的几个基本知识点,并简单介绍基本的波束合成方法:Delay and sum (DSB).

一、栅瓣效应

类似干涉仪中的phase-wrapping问题:传感器的距离超过半波长的距离。

  A-Beam Pattern

以线性阵列为例

【麦克风阵列增强】Delay and sum beamforming_第1张图片

输出为

对应的增益,也就是output,取频率为1KHz的数据:

【麦克风阵列增强】Delay and sum beamforming_第2张图片

有时候也用极坐标表示

【麦克风阵列增强】Delay and sum beamforming_第3张图片

  B-Frequency Response

考虑如下场景

【麦克风阵列增强】Delay and sum beamforming_第4张图片

实际只有一个波峰,却在不同角度长出多个一样的,这就是栅瓣

【麦克风阵列增强】Delay and sum beamforming_第5张图片

相位是角度、频率的共同作用,对应的栅瓣从二维平面更容易理解

【麦克风阵列增强】Delay and sum beamforming_第6张图片

从每一个来看,grating lobe就是栅瓣:

【麦克风阵列增强】Delay and sum beamforming_第7张图片

二、Delay and sum

DSB核心的思想就是延迟相加,对于栅瓣的DOA估计需要解模糊。假设估计出DOA,进行补偿之后(delay)通过叠加(sum)就可以实现目标信号的增强:

【麦克风阵列增强】Delay and sum beamforming_第8张图片

关于delay的操作,可以在时域进行也可以在频域进行,本质上是小数延迟的问题(fractional delays).例如对于下面的dual-channel问题:

【麦克风阵列增强】Delay and sum beamforming_第9张图片

需要延迟 是0.5149ms,也就是24.717samples,而不是整数。

【麦克风阵列增强】Delay and sum beamforming_第10张图片

小数延迟实现的思路有很多种,例如可以通过线性相位(延迟)的FIR构造,对应就是sinc函数,通常构造完成之后会做一个加窗的平滑处理:

double delay = 0.25;               // Fractional delay amount
int filterLength = 11;             // Number of FIR filter taps (should be odd)
int centreTap = filterLength / 2;  // Position of centre FIR tap

for (int t=0 ; t

  其他如:重采样技术(Resample)、Farrow-filter技术,都可以实现这样的功能。

参考

  • http://www.labbookpages.co.uk/audio/beamforming/delaySum.html#pattern

你可能感兴趣的:(【麦克风阵列增强】Delay and sum beamforming)