【控制之美】利用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猿手15 分钟前
超多目标优化:基于导航变量的多目标粒子群优化算法(NMOPSO)的无人机三维路径规划,MATLAB代码
人工智能·算法·机器学习·matlab·无人机
Evaporator Core2 小时前
MATLAB学习之旅:数据建模与仿真应用
开发语言·学习·matlab
项目申报小狂人3 小时前
改进收敛因子和比例权重的灰狼优化算法【期刊论文完美复现】(Matlab代码实现)
开发语言·算法·matlab
IT猿手20 小时前
2025最新智能优化算法:鲸鱼迁徙算法(Whale Migration Algorithm,WMA)求解23个经典函数测试集,MATLAB
android·数据库·人工智能·算法·机器学习·matlab·无人机
GIS遥感数据处理应用21 小时前
MATLAB | 设置滑动窗口计算栅格数据的CV变异系数
matlab·arcgis·数据分析
圆滚滚的龙猫1 天前
matlab和java混合编程经验分享
java·matlab
studyer_domi1 天前
matlab 七自由度车辆模型轮毂电机驱动电动汽车的振动分析
matlab
没有不重的名么2 天前
MATLAB基础学习相关知识
数据结构·学习·matlab
青橘MATLAB学习2 天前
时间序列预测实战:指数平滑法详解与MATLAB实现
人工智能·算法·机器学习·matlab
lingllllove2 天前
matlab二维艾里光束,阵列艾里光束,可改变光束直径以及距离
开发语言·算法·matlab