matlab声源定位算法实现_MATLAB程序

matlab声源定位算法实现_MATLAB程序这是通过传统互相关的方法来进行声源定位的程序,做完互相关之后,红色标注的程序行,应该如何理解呢,是通过什么方法来实现最终延迟差的估计的呢?clclearallcloseall%%%*各参数设置*%–声源相关参数fm=2000;%Hz:信源调频信号最高频率周期0.5msTs=0.2;%s:信源周期0.2s%–采样和信号处理相关参数fs=10*fm;%采样率…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

这是通过传统互相关的方法来进行声源定位的程序,做完互相关之后,红色标注的程序行,应该如何理解呢,是通过什么方法来实现最终延迟差的估计的呢?

cl

clear all

close all

%%

% *各参数设置*

%–声源相关参数

fm=2000;    %Hz: 信源调频信号最高频率 周期0.5ms

Ts=0.2;     %s: 信源周期 0.2s

%–采样和信号处理相关参数

fs=10*fm;   %采样率 也就是50us采一次样

ts=1/fs;    %采样间隔

T=0.2;      %s: 搜集数据T秒,计算一次位置

tMic=0:1/fs:T-1/fs;   %接收数据时间

nMic=length(tMic);    %接收数据长度

Rlen=nMic; %做相关的长度

%–物理参数设置

v=340;      %m/s: 音速

SNR=-10;    %dB

%–声源和MIC位置

Lco_S = [20,30];

Loc_A = [10,0];

Loc_B = [0,10];

Loc_C = [20,0];

%%

% *模拟声源信号及各MIC接收到的信号*

%–产生声源

t = 0:ts:0.4; %假设声波持续时间0.4秒,也就是有2个周期

s = chirp(mod(t,0.2),0,0.2,fm,’linear’);%源信号

%–画出声源的波形

figure();

plot((1:8001)*0.05,s);

xlabel(‘时间/\itms’);

ylabel(‘振幅’);

title(‘声音信号’);

%–计算信源与个MIC之间的距离

dis_SA = sqrt(sum((Lco_S-Loc_A).^2));

dis_SB = sqrt(sum((Lco_S-Loc_B).^2));

dis_SC = sqrt(sum((Lco_S-Loc_C).^2));

%–信源到MIC的时间延迟

Lag_SA = dis_SA/v;

Lag_SB = dis_SB/v;

Lag_SC = dis_SC/v;

%–转化成相差点数

diff_AB =round((Lag_SA-Lag_SB)/ts);

diff_AC =round((Lag_SA-Lag_SC)/ts);

%–MIC接收到的数据

sigMicA=s(1:nMic);

sigMicB=s(1+diff_AB:nMic+diff_AB);

sigMicC=s(1+diff_AC:nMic+diff_AC);

sigMicA=awgn(sigMicA,SNR,’measured’);

sigMicB=awgn(sigMicB,SNR,’measured’);

sigMicC=awgn(sigMicC,SNR,’measured’);

%–信号时域图

figure();subplot(3,1,1);

plot((1:4000)*0.05,sigMicA);

subplot(3,1,2);

plot((1:4000)*0.05,sigMicB);

subplot(3,1,3);

plot((1:4000)*0.05,sigMicC);

%%

% *用CC(Cross-Correlation)算法估计时延差*

%CC算法求延时差

rMicAB=xcorr(sigMicA,sigMicB,Rlen,’biased’); %求MIC A、B信号互相关

rMicAC=xcorr(sigMicA,sigMicC,Rlen,’biased’); %求MIC A、C信号互相关

[val,DelayDifferAB]=max(rMicAB);  %互相关最大值的位置体现了延迟差。

[val,DelayDifferAC]=max(rMicAC);

%最终延迟差估计

delayDifferABRes=-(Rlen+1)+rMicAB(DelayDifferAB+(-3:3))*(DelayDifferAB+(-3:3))’/sum(rMicAB(DelayDifferAB+(-3:3)));

delayDifferACRes=-(Rlen+1)+rMicAC(DelayDifferAC+(-3:3))*(DelayDifferAC+(-3:3))’/sum(rMicAC(DelayDifferAC+(-3:3)));

distDiffAB=delayDifferABRes/fs*v;

distDiffAC=delayDifferACRes/fs*v;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/190841.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Open-Drain V.S. Push-Pull

    Open-Drain V.S. Push-Pull

    2021年8月26日
    50
  • mysql+mongodb_统计和汇总的区别

    mysql+mongodb_统计和汇总的区别MySQL和MongoDB的区别的学习与汇总

    2025年8月6日
    2
  • 高级I/O函数之sendfile函数[通俗易懂]

    高级I/O函数之sendfile函数[通俗易懂]sendfile函数在两个文件描述符之间传递数据(完全在内核中操作),从而避免了内核缓冲区和用户缓冲区之间的数据拷贝,效率很高,被称为零拷贝。函数定义为:#include<sys/sendfile.h>ssize_tsenfile(intout_fd,intin_fd,off_t*offset,size_tcount);in_fd参数是待读出内容的文件描述符,out…

    2022年5月10日
    36
  • Fedora 12 yum源 (很快)[通俗易懂]

    Fedora 12 yum源 (很快)[通俗易懂]新建一个文件,命名为sjtu.repo输入如下代码:[Fedora-ftp.sjtu.edu.cn]name=Fedora10-i386baseurl=http://ftp.sjtu.edu.cn/fedora/linux/releases/10/Fedora/i386/os/enabled=1gpgcheck=0gpgkey=file:///etc/pki/

    2025年11月21日
    6
  • ds1302实时时钟lcd1602显示_电子时钟单片机

    ds1302实时时钟lcd1602显示_电子时钟单片机DS1302时钟模块LCD1602显示DS1302时钟模块相关介绍基本介绍时序图DS1302时钟模块相关介绍基本介绍DS1302可慢速充电实时时钟芯片包含实时时钟/日历和31字节的非易失性静态RAM。它经过一个简单的串行接口与微处理器通信。实时时钟/日历可对秒,分,时,日,周,月,和年进行计数,对于小于31天的月,月末的日期自动进行调整,还具有闰年校正的功能。时钟可以采用24小时格式或带AM(上午)/PM(下午)的12小时格式。31字节的==RAM==可以用来临时保存一

    2025年7月16日
    4
  • ireport使用教程_layout怎么导入图片

    ireport使用教程_layout怎么导入图片ireport插入图片1.在模板上拖一个image组件,设置它的image Expression为变量$P{logo},如图示,属性下面的is lazy勾上。  不然有可能最后页面渲染出来的image的src为nullimage_0_0_0。2.给变量logo的值。  StringbasePath=request.getScheme()+”://”+requ

    2025年10月20日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号