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

相关推荐
咖啡里的茶i7 小时前
实验一:利用Matlab运行车牌识别方法
matlab
吃好睡好便好12 小时前
在Matlab中绘制三维等高线图
开发语言·python·学习·算法·matlab·信息可视化
Aaron158813 小时前
RFSOC+VU13P/VU9P+GPU多通道同步一体化解决方案
人工智能·嵌入式硬件·算法·matlab·fpga开发·硬件架构·基带工程
Evand J14 小时前
【MATLAB】多无人机编队协同控制与三维航迹规划仿真。障碍物斥力避障,输出编队误差、控制输入、三维轨迹等
开发语言·matlab·无人机
青春不败 177-3266-052016 小时前
MATLAB 2024b深度学习新特性全面解析与DeepSeek大模型集成开发
人工智能·深度学习·机器学习·matlab·卷积神经网络·自编码器·deepseek
吃好睡好便好16 小时前
Matlab中三种三维图的对比
开发语言·人工智能·学习·算法·matlab·信息可视化
Evand J18 小时前
【MATLAB例程】5个UAV 分布式围捕编队运动仿真 —— 基于PID控制
开发语言·分布式·matlab
吃好睡好便好20 小时前
在Matlab中绘制二维等高线图
开发语言·人工智能·学习·算法·matlab
2zcode20 小时前
基于Matlab元胞自动机模拟(CA)动态再结晶过程
开发语言·matlab·动态再结晶
yong99902 天前
MATLAB仿真计算电磁波回波信号的技术路径与实现指南
开发语言·matlab