麦克风阵列声源定位四通道麦克风数据库及TDOA双曲交汇定位算法实验

麦克风阵列声源定位四通道麦克风数据库建立

图一 四通道麦克风数据库建立物理模型
四通道麦克风数据库建立物理模型的建立,来源于文献:SLoClas: A DATABASE FOR JOINT SOUND LOCALIZATION AND CLASSIFICATION图二 参考文献1
根据图一,声源处于红色圆形上,且声源距离麦克风阵列中心O点的距离为1.5m,其中
mic1(0,-d)、mic2(d,0)、mic3(0,d)、mic4(-d,0) d为0.03m
声源会沿着红色圆圈按照θ角度旋转,麦克风阵列会依次按照一定的采样率每θ角度采集相同数据长度的声源数据,不同麦克风会因为距离角度而导致采集到的信号的幅度和相位不同。实验数据是按照θ=5°采集完成的,实验部分数据集如下图:
图三 不同角度下的麦克风阵列定位数据集
图四 麦克风阵列定位数据集下的声音文件
图五 麦克风阵列定位数据集下采集的四通道声音时域波形图

TDOA相关法时延求解

TDOA相关法时延求解原理与算法

双曲交汇定位算法

参考文献:运 用 双 曲 线 知 识 测 定 声 源
———研究性学习课题成果

图六 参考文献二双曲交汇算法
结合图一,以mic2、mic4为焦点构建双曲线方程1:
图七 双曲线方程1
以mic1、mic3为焦点构建双曲线方程2:
图七 双曲线方程2
现在定义,T42为声源到mic4的时间与声源到mic2的时间的差,T13为声源到mic1的时间与声源到mic3的时间的差c为声音传播的速度,在这里c=340m/s。
根据双曲线的特性,其中,
图八 双曲线方程1的参数
图九 双曲线方程2的参数
两个双曲线方程联立求解,双曲线的交点就是声源的坐标。根据作者何晓东 郑东风 指导教师 支 静的文献,联立两个双曲线方程组求解得:
图十 声源位置
我们只需要根据T42和T13和0的关系来判定声源的具体位置即可,如下图所示:
图十一 T42和T13和0的关系与声源的具体位置判定

声源位置、角度求解与算法代码验证

matlab的算法代码如下:

clc;
clear;
close all
m=100;
filedir=('E:\***\SoClas_database\Segmented_Sound\class06\class06_360\*.wav');%%
infiledir=('E:\***\SoClas_database\Segmented_Sound\class06\class06_360\');
files = dir(filedir);
for num = 1:m
    infile = [infiledir,files(num).name];
    [y0,Fs]= audioread(infile);
    for j = 1:3
        [c,lags] = xcorr(y0(:,j+1),y0(:,1));
        [Am,Lm] =  max(c);
        d = Lm - (length(c)+1)/2;
        Delay(num,j)=d/Fs;
    end
    for k = 1:2
        [c1,lags1] = xcorr(y0(:,k+2),y0(:,2));
        [Am1,Lm1] =  max(c1);
        d1 = Lm1 - (length(c1)+1)/2;
        Delay(num,k+3)=d1/Fs;   
    end
    [c2,lags2] = xcorr(y0(:,3),y0(:,4));
    [Am2,Lm2] =  max(c2);
    d2 = Lm2 - (length(c2)+1)/2;
    Delay(num,6)=d2/Fs;   
end

Length = length(y0);
T = 1 / Fs;
t = (1 : Length) * T;
t = t';
figure;
 subplot(411);
plot(t,y0(:,1));
title('mic1');
xlabel('(秒)')
ylabel('幅度(V)')
subplot(412);
plot(t,y0(:,2));
title('mic2');
xlabel('(秒)')
ylabel('幅度(V)')
subplot(413);
plot(t,y0(:,3));
title('mic3');
xlabel('(秒)')
ylabel('幅度(V)')
subplot(414);
plot(t,y0(:,4));
title('mic4');
xlabel('(秒)')
ylabel('幅度(V)')
%%%%%%%%%%%%%%%%%%%%%%%%%%%%
c = 340;
ddd = 0.03;
a1 = c*Delay(1,5);
b1 = sqrt(ddd*ddd - a1 * a1);
a2 = c*Delay(1,2);
b2 = sqrt(ddd*ddd - a2 * a2);
kk = b1*b1*b2*b2 - a1*a1*a2*a2;
mm1 = a1*a1*b2*b2;
mm2 = a2*a2*b1*b1;
nn1 = a2*a2+b1*b1;
nn2 = a1*a1+b2*b2;
ppp = sqrt(mm1*nn1/kk);
qqq = sqrt(mm2*nn2/kk);
if a2 > 0
    yyy = -qqq;
else
    yyy = qqq;
end 
if a1 > 0
    xxx = ppp;
else
    xxx = -ppp;
end
angle = atan(xxx / yyy)*180/pi
% if angle <= 0
%     theta = -angle + 180
% else
%     theta = angle
% end



上述代码可以通过c语言移植到具备算力的开发板中,根据数据集中的按照不同θ角度的麦克风阵列数据,分别进行角度验证,锁定声源的坐标,根据求得的角度在代入R即可求出声源的实际距离。测试结果如下:
360度声源的测试结果
45度声源的测试结果
90度声源的测试结果
120度声源的测试结果
135度声源的测试结果
180度声源的测试结果
225度声源的测试结果
270度声源的测试结果
315度声源的测试结果
可以看出,双曲交汇定位算法是有一定效果的。良好的定位效果和声源距离麦克风阵列的距离、声源所发声信号的类型频率、背景噪声等有关,下一步将继续优化定位算法,使定位结果更加精准。

上述结构四通道麦克风定位数据集下载

链接:https://pan.baidu.com/s/1t63N73ZDFx9Ih6aeBISrRA
提取码:esnp

定位精度时延改进——时域预处理

为了提高数据精度,需要对时域信号进行预处理——立方处理。就是对时域信号的每个点做三次幂处理。

未预处理实验

close all;
clear;
clc;
[time_txt,Fs] = audioread('E:\***\SoClas_database\Segmented_Sound\class06\class06_270\class06_270_001.wav');
LEN = 7361;
x1 = time_txt(:,1);
x2 = time_txt(:,2);
% xxx1 = x1.*x1.*x1;
% xxx2 = x2.*x2.*x2;
xxx1 = x1;
xxx2 = x2;
X1=(fft(xxx1));
X2=(fft(xxx2));
Sxy=X1.*conj(X2);
Bxy=fftshift(abs(ifft(Sxy)));
figure;
subplot(211);
Xxy=xcorr(xxx1,xxx2);
plot(Xxy);
title('DSP hxg')
subplot(212);
plot((Bxy));
title('MATLAB hxg')

在这里插入图片描述

预处理实验

close all;
clear;
clc;
[time_txt,Fs] = audioread('E:\***\SoClas_database\Segmented_Sound\class06\class06_270\class06_270_001.wav');
LEN = 7361;
x1 = time_txt(:,1);
x2 = time_txt(:,2);
xxx1 = x1.*x1.*x1;
xxx2 = x2.*x2.*x2;
X1=(fft(xxx1));
X2=(fft(xxx2));
Sxy=X1.*conj(X2);
Bxy=fftshift(abs(ifft(Sxy)));
figure;
subplot(211);
Xxy=xcorr(xxx1,xxx2);
plot(Xxy);
title('DSP hxg')
subplot(212);
plot((Bxy));
title('MATLAB hxg')

在这里插入图片描述

麦克风阵列声源定位是指通过多个麦克风的接收时间差(TDOA)来确定声源的位置。该算法的基本思想是在特定的时刻同时记录麦克风信号,并计算信号到达不同麦克风的时间差,然后利用三角定位法或其他定位算法计算声源位置。声源定位技术广泛应用于无线通信、音频信号处理、语音识别、语音合成和安防等领域。 为了验证基于TDOA算法麦克风阵列声源定位的可行性和准确性,需要进行仿真实验。仿真实验可以通过模拟麦克风阵列接收声波信号,并计算信号到达时间差来模拟真实环境下的声源定位。在仿真实验中,可以通过控制声源位置、噪声水平和麦克风阵列的几何形状等因素来模拟不同的场景。 基于TDOA算法麦克风阵列声源定位仿真实验需要实现以下步骤: 1. 生成声源信号:通过声波信号发生器生成不同频率和振幅的声源信号。 2. 模拟麦克风阵列接收信号:将声源信号通过声波传播模型模拟成麦克风阵列接收的信号。 3. 计算TDOA:通过信号处理技术计算信号到达不同麦克风的时间差。 4. 声源定位:使用三角定位法或其他定位算法计算声源位置。 5. 分析实验结果:比较仿真实验结果与真实环境下的声源定位结果差异,评估算法的准确性和可靠性。 基于TDOA算法麦克风阵列声源定位算法仿真实验是一个复杂的过程,需要综合运用声学、信号处理、数学和编程等知识。通过实验,可以深入了解声源定位算法的实现原理和应用现状,为真实环境下的声源定位问题提供重要参考。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值