• 一种用于环境声源的被动到达角(AoA)提取算法(Matlab代码实现)


     👨‍🎓个人主页:研学社的博客 

    💥💥💞💞欢迎来到本博客❤️❤️💥💥

    🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

    ⛳️座右铭:行百里者,半于九十。

    📋📋📋本文目录如下:🎁🎁🎁

    目录

    💥1 概述

    📚2 运行结果

    🌈3 Matlab代码实现

    🎉4 参考文献


    💥1 概述

    AOA 定位方法,主要是测量信号移动台和基站之间的到达角度,以基站为起点形成的射线必经过移动台,两条射线的交点即为移动台的位置。该方法只需两个基站就可以确定 MS 的估计位置,其定位示意图如图所示。

    📚2 运行结果

     

    部分代码:

    %% Initialization

    clear;
    addpath(genpath('../Library/'));
    params = getParams();

    micUsed = params.micUsed;
    fileName = '../data/ReSpeaker/example';
    waveOrig = load([fileName '.mat']).wave(micUsed, :);
    [~, waveLen] = size(waveOrig);

    sampleRate = params.sampleRate;
    readRate = params.readRate;
    readNum = round(waveLen / sampleRate * readRate);
    readSampleNum = params.readSampleNum;
    sourceNum = params.sourceNum;

    %% AoA Extraction

    angleListY = zeros(readNum, sourceNum);
    angleListZ = zeros(readNum, sourceNum);
    for readIdx = 1: readNum
        waveNow = waveOrig(:, ...
            (readIdx - 1) * sampleRate / readRate + 1: (readIdx - 1) * sampleRate / readRate + readSampleNum);
        
        [angleNowY, angleNowZ] = multipleSource(waveNow, sourceNum, params);
        
        angleListY(readIdx, :) = angleNowY;
        angleListZ(readIdx, :) = angleNowZ;
    end

    save([fileName '_result.mat'], 'angleListY', 'angleListZ');

    %% Visualization

    angleListGtY = ones(readNum, 1) * [25 61];
    angleListGtZ = ones(readNum, 1) * [291 101];

    figure(1);
    subplot(1, 2, 1);
    plot((1: readNum) / readRate, angleListY, 'x', ...
        (1: readNum) / readRate, angleListGtY, 'linewidth', 2);
    axis([0 readNum / readRate params.angleRangeY(1) params.angleRangeY(2)]);
    legend('Est_1', 'Est_2', 'Gt_1', 'Gt_2');
    title('Angle Y');
    xlabel('Time (s)');
    ylabel('AoA (Deg)');

    subplot(1, 2, 2);
    plot((1: readNum) / readRate, angleListZ, 'x', ...
        (1: readNum) / readRate, angleListGtZ, 'linewidth', 2);
    axis([0 readNum / readRate params.angleRangeZ(1) params.angleRangeZ(2)]);
    legend('Est_1', 'Est_2', 'Gt_1', 'Gt_2');
    title('Angle Z');
    xlabel('Time (s)');
    ylabel('AoA (Deg)');

    🌈3 Matlab代码实现

    🎉4 参考文献

    部分理论来源于网络,如有侵权请联系删除。

    [1]石月,戴雅伟.一种基于4G AoA的5G天线方位角调优方法[J].电信工程技术与标准化,2022,35(07):48-51.DOI:10.13992/j.cnki.tetas.2022.07.016. 

  • 相关阅读:
    python操作sqlite报错:sqlite3.OperationalError: unrecognized token: “630008.OF“
    C语言刷题篇(备赛中......)--------( 篇章1 )
    【Vue】url拼接参数获取解析
    [LabVIEW]圖像內的物件計算_Count objects
    第七章 正则表达式
    一些对模糊搜索的思考
    [计算机入门] Windows附件程序介绍(办公类)
    物理系统仿真有哪些作用和功能?速看
    国际公认—每个领导者必须拥抱的11项领导力转变
    CSS逻辑组合伪类
  • 原文地址:https://blog.csdn.net/weixin_46039719/article/details/128155314