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

相关推荐
suoge22311 分钟前
六面体传热单元(热通量边界条件)有限元MATLAB程序【理论文本+代码】|热传导有限元|纽曼边界条件|有限元传热分析
matlab·有限元·有限元编程·传热有限元·稳态传热·热传导有限元·热固耦合
suoge22312 分钟前
六面体传热单元(固定温度边界条件)有限元MATLAB程序【理论文本+代码】|热传导有限元|狄利克雷边界|有限元传热分析
matlab·有限元·热传导·传热有限元·迪利克雷边界条件·有限元法·稳态传热
foundbug99914 分钟前
基于MATLAB的TDMP-LDPC译码器模型构建、仿真验证及定点实现
开发语言·matlab
Evand J15 分钟前
【MATLAB代码介绍】基于累积概率的三维轨迹匹配与定位,由轨迹匹配和卡尔曼滤波形成算法,带测试结果演示
算法·matlab·滤波·定位·导航·轨迹匹配
wuk9981 小时前
梁非线性动力学方程MATLAB编程实现
前端·javascript·matlab
一个与程序bug抗争的程序员2 小时前
Matlab App Designer设计人机交互界面并打包成exe——加法计算器
matlab·人机交互
kaikaile19953 小时前
matlab计算流场
人工智能·算法·matlab
gihigo19983 小时前
基于MATLAB的周期方波与扫频信号生成实现(支持参数动态调整)
开发语言·matlab
yong99906 小时前
基于MATLAB的大变形悬臂梁求解程序
前端·数据库·matlab
guygg887 小时前
基于捷联惯导与多普勒计程仪组合导航的MATLAB算法实现
开发语言·算法·matlab