使用MATLAB进行CSI数据处理

使用MATLAB进行CSI数据处理

前言:Intel5300网卡获取CSI数据的教程强烈推荐该博文
安装抓取WIFI CSI的工具

  • CSI幅值数据处理
    可以使用MATLAB自带函数abs实现。
% 读取自己的数据集
close all;clear;clc
load("datasets\test_1011\bow_ant1.mat","bow.mat")
bow_amp = abs(bow);
  • CSI相位数据处理

感谢@weixin_44408931 的提醒,使用MATLAB中的unwrap函数需要注意自己的数据格式。若子载波是按行,可将unwrap(YourData,pi,2);若按列,则设置为unwrap(YourData,pi,1)。具体请参考

https://ww2.mathworks.cn/help/matlab/ref/unwrap.html

function [CSI_phase_recovery] = GetPhase(R)
% phase
phase_matrix = angle(R);
no_of_subcarriers = 30;
m = [-28,-26,-24,-22,-20,-18,-16,-14,-12,-10,-8,-6,-4,-2,-1,1,3,5,7,9,11,13,15,17,19,21,23,25,27,28]';
CSI_phase_recovery = zeros(size(phase_matrix));
CSI_phase_temp = zeros(no_of_subcarriers,1);
CSI_phase_unwarp_temp = zeros(no_of_subcarriers,1);
for line_index = 1:(size(phase_matrix,1)/no_of_subcarriers)
    for row_index = 1:size(phase_matrix,2)
        CSI_phase_temp = phase_matrix(no_of_subcarriers*(line_index-1)+1:no_of_subcarriers*line_index,row_index);
        CSI_phase_unwarp_temp = unwrap(CSI_phase_temp,pi,1);
        b = mean(CSI_phase_unwarp_temp);
        k = (CSI_phase_unwarp_temp(no_of_subcarriers)-CSI_phase_unwarp_temp(1))/(m(no_of_subcarriers)-m(1));
        H = zeros(no_of_subcarriers,1);
        for i = 1:no_of_subcarriers
            H(i) = CSI_phase_unwarp_temp(i)-k*m(i)-b;
        end
        CSI_phase_recovery(no_of_subcarriers*(line_index-1)+1:no_of_subcarriers*line_index,row_index) = H;
    end
end

end

上述代码仅针对Wi-Fi 20MHz频宽,如果使用更高的频宽和更多的子载波数,可以参考

https://blog.csdn.net/a_beatiful_knife/article/details/119247331

Reference:

PhaseFi: Phase Fingerprinting for Indoor Localization with a Deep Learning Approach

  • 4
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 22
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值