Matlab FFT分析

1. 背景

在分析谐振或者三相电流波形的时候需要对数据或者波形进行FFT分析来确定波形成分。

2. 代码

输入时间和三相电流即可得到FFT的结果。

Matlab 复制代码
clc
clear
%%
file.name = "305 1500 10.csv";
data.raw = readtable(file.name);
% load("data.mat")
data.t = table2array(data.raw(15:end,1));
data.a = table2array(data.raw(15:end,2));
data.b = table2array(data.raw(15:end,3));
data.c = table2array(data.raw(15:end,4));
%% 
figure;
tab = 7799851;
plot(data.t(tab:end),data.a(tab:end),"DisplayName","A相电流");hold on;

plot(data.t(tab:end),data.b(tab:end),"DisplayName","B相电流");hold on;

plot(data.t(tab:end),data.c(tab:end),"DisplayName","C相电流");hold off;

xlabel('t/s')
legend;

%% 
Fs = 1/0.00000001;
N = length(data.a);
f = (0:N-1) * (Fs/N);
data.a_fft = fft(data.a);
figure;
plot(f(1:5000),2*abs(data.a_fft(1:5000)/N));
title('A相电流-FFT')
xlabel('f/Hz')
data.b_fft = fft(data.b);
figure;
plot(f(1:5000),2*abs(data.b_fft(1:5000)/N));
title('B相电流-FFT')
xlabel('f/Hz')
data.c_fft = fft(data.c);
figure;
plot(f(1:5000),2*abs(data.c_fft(1:5000)/N));
title('C相电流-FFT')
xlabel('f/Hz')
%% 
% a = func_FFT(data.t',data.a');
% plot(a)
Matlab 复制代码
function [f X label_even] = func_FFT(t, x)

[m, n] = size(x);
if length(t) ~= n
    error('input size not consistent!')
end
f_1st = 1 / (t(2) - t(1)) / length(t);
f = f_1st * ((1:length(t))-1);

for k=1:m
    input = x(k, :);
    if sum(sum(imag(input))) == 0
        fft_x = fft(input);
        if mod(n, 2) == 0
            fft_x = fft_x(1:(n/2+1));
            label_even = 1;
        else
            fft_x = fft_x(1:((n-1)/2+1));
            label_even = 0;
        end
        X(k, :) = 2 * fft_x / n;
        X(k, 1) = X(k, 1) / 2;
        if mod(n, 2) == 0
            X(k, length(fft_x)) = X(k, length(fft_x)) / 2;
        end
        f = f(1:length(fft_x));
    else
        warning('time domain signal contains imag part, complex FFT executed!')
        fft_x = fft(input) / n;
        if mod(n, 2) == 0
            fft_x(n/2+1) = fft_x(n/2+1) / 2;
            fft_x = [fft_x((n/2+1):n) fft_x(1:(n/2+1))];
            f = [-fliplr(f(2:(n/2+1))) f(1:(n/2+1))];
            label_even = 1;
        else
            fft_x = [fft_x(((n+1)/2+1):n) fft_x(1:((n+1)/2))];
            f = [-fliplr(f(2:((n+1)/2))) f(1:((n+1)/2))];
            label_even = 0;
        end
        X(k, :) = fft_x;
    end
end
plot(f(1:5000),abs(X(1:5000)))
% [mt, nt] = size(t)
% [mx, nx] = size(x)
% [mf, nf] = size(f)
% [mX, nX] = size(X)

% for k=1:m
%     fft_x = fft(x(k, :));
%     if mod(n, 2) == 0
%         fft_x = fft_x(1:(n/2+1));
%         label_even = 1;
%     else
%         fft_x = fft_x(1:((n-1)/2+1));
%         label_even = 0;
%     end
%     X(k, :) = 2 * fft_x / n;
%     X(k, 1) = X(k, 1) / 2;
%     if mod(n, 2) == 0
%         X(k, length(fft_x)) = X(k, length(fft_x)) / 2;
%     end
% end
% f = f(1:length(fft_x));
相关推荐
Evand J2 小时前
【IMM】非线性目标跟踪算法与MATLAB实现:基于粒子滤波的交互式多模型,结合CV和CT双模型对三维空间中的机动目标进行高精度跟踪
算法·matlab·目标跟踪·pf·粒子滤波·imm·多模型
兰文彬2 小时前
n8n 2.x版本没有内嵌Python环境
开发语言·python
yiyaozjk2 小时前
Go基础之环境搭建
开发语言·后端·golang
谁动了我的代码?2 小时前
VNC中使用QT的GDB调试,触发断点时与界面窗口交互导致整个VNC冻结
开发语言·qt·svn
We་ct2 小时前
LeetCode 212. 单词搜索 II:Trie+DFS 高效解法
开发语言·算法·leetcode·typescript·深度优先·图搜索算法·图搜索
OxyTheCrack2 小时前
【C++】简述main函数中的argc与argv
开发语言·c++
历程里程碑2 小时前
Linux 49 HTTP请求与响应实战解析 带http模拟实现源码--万字长文解析
java·开发语言·网络·c++·网络协议·http·排序算法
ZVAyIVqt0UFji2 小时前
高可用虚拟IP(HaVip)技术详解:原理、设计与应用
开发语言·网络·网络协议·tcp/ip·perl
飞Link2 小时前
深度解析 TS2Vec:时序表示学习中的层次化建模(Hierarchical Contrastive Learning)
开发语言·python·学习·数据挖掘