【控制之美】利用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图

相关推荐
IT猿手14 小时前
多目标优化算法:多目标蛇优化算法(Multiple Objective Snake Optimizer,MOSO)(提供MATLAB代码)
开发语言·算法·matlab·动态路径规划·光伏模型参数估计
Evand J19 小时前
【代码介绍】RSSI定位程序,N个锚点、三维空间,使用CKF对轨迹进行滤波,MATLAB代码
matlab·滤波·定位·三维
加成BUFF20 小时前
《机器人学》MATLAB 机器人工具箱 应用指南二
matlab·机器人·机器人工具箱
吃好睡好便好1 天前
矩阵的左乘和右乘
人工智能·学习·线性代数·算法·matlab·矩阵
jllllyuz1 天前
通信信号调制识别系统(MATLAB实现)
开发语言·matlab
彬鸿科技1 天前
bhSDR Studio/Matlab入门指南(十一):AI数据集采集实验界面全解析
人工智能·matlab·软件定义无线电
yuan199972 天前
基于 MATLAB PSO 工具箱的函数寻优算法
开发语言·算法·matlab
wearegogog1232 天前
基于MATLAB实现雷达RCS Swerling模型
开发语言·matlab
强盛机器学习~2 天前
2026热门方向!基于强化学习的多无人机移动边缘计算与路径规划研究(完整代码&数据)
人工智能·matlab·无人机·边缘计算·强化学习·无人机路径规划
nwsuaf_huasir2 天前
哈工大latex模板学位论文参考文献引用方法
matlab