【控制之美】利用fft求解bode图-matlab

方法一:基于 frd 对象转换数据

生成频率向量和响应数据:使用 logspace 函数生成频率向量 freq ,并计算对应的频率响应数据 resp 。示例代码如下:

freq = logspace(1, 2); % 生成从10^1到10^2的对数间距频率向量

resp = 0.05 * (freq).* exp(1i * 2 * freq); % 计算频率响应数据

创建 frd 模型:使用 frd 函数将频率响应数据 resp 和频率向量 freq 创建成 frd 模型 sys 。示例代码如下:

sys = frd(resp, freq);

绘制Bode图:使用 bode 函数绘制 frd 模型 sys 的Bode图。示例代码如下:

bode(sys);

方法二:直接处理FFT结果

定义系统和输入输出数据:定义系统的传递函数的分子分母,生成输入输出数据。示例代码如下:

num = [0 1]; % 传递函数分子

den = [1 -0.8]; % 传递函数分母

u = randn(100,1); % 输入信号

t = 1:length(u);

ym,\~,\~\] = lsim(tf(num, den), u, t); % 系统输出 计算FFT:对输入输出数据进行FFT计算,并计算对应的频率向量。示例代码如下: ts = 1; fs = 1/ts; l = length(ym); nfft = 2\^nextpow2(l); % 取大于等于l的最小2的幂次方 h2 = fft(ym, nfft)./fft(u, nfft); f = fs/2\*linspace(0, 1, nfft/2 + 1); ww = f\*2\*pi; figure semilogx(ww, 20\*log10(abs(h2(1:nfft/2 + 1)))); % 幅值Bode图 figure semilogx(ww, (180/pi)\*angle(h2(1:nfft/2 + 1))); % 相位Bode图

相关推荐
EW Frontier2 小时前
【无标题】
matlab
技术净胜2 小时前
MATLAB文本文件读写实操fopen/fscanf/fprintf/fclose全解析
开发语言·matlab
listhi5203 小时前
MOEAD算法实现详解(基于Python与MATLAB)
python·算法·matlab
rit84324994 小时前
基于MATLAB的多变量动态矩阵控制(DMC)仿真实现
开发语言·matlab·矩阵
民乐团扒谱机7 小时前
【微科普】GN 算法:在网络的脉络中,寻找社群的边界
开发语言·算法·matlab·语言学·语义网络分析
chao1898449 小时前
基于DWT-MFCC-LPC的MATLAB语音识别系统实现
开发语言·matlab·语音识别
cici1587411 小时前
基于不同算法的数字图像修复Matlab实现
算法·计算机视觉·matlab
椰萝Yerosius1 天前
MATLAB简介
开发语言·数学建模·matlab
moonquakeTT1 天前
雷达调试5大核心思路:从理论到实战
人工智能·matlab·目标跟踪·雷达