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

相关推荐
B325帅猫-量子前沿技术研究所13 小时前
MATLAB函数fft(data,N)输入注意事项
matlab·傅里叶分析·fft·噪声功率谱
飞舞哲13 小时前
Coppeliasim基于视觉识别与路径插值的UR机械臂彩色物块自动分拣系统
matlab·视觉检测·coppeliasim·ur·分拣
沅_Yuan13 小时前
基于 CNN-SE Attention-ITCN 多模态融合的多输入单输出回归预测模型【MATLAB】
神经网络·matlab·cnn·回归预测·多输入单输出·se attention·itcn
可编程芯片开发13 小时前
基于Qlearning强化学习的源荷扰动下交直流微电网负荷频率控制算法matlab仿真
matlab·强化学习·交直流微电网·qlearning·负荷频率控制
DS数模14 小时前
2026年Mathorcup数学建模竞赛A题思路解析+代码+论文
开发语言·数学建模·matlab·mathorcup·妈妈杯·2026妈妈杯
yu859395815 小时前
光伏发电系统最大功率点跟踪(MPPT)设计与Simulink仿真
matlab
沅_Yuan15 小时前
基于ARIMA差分自回归移动平均的时间序列预测模型【MATLAB】
机器学习·matlab·arima·时序预测·自回归·移动平均
kernelcraft15 小时前
Matlab读取CSV数据并处理:从入门到实战的完整指南
开发语言·其他·matlab
yong99901 天前
IHAOAVOA:天鹰优化算法与非洲秃鹫优化算法的混合算法(Matlab实现)
开发语言·算法·matlab
沅_Yuan1 天前
基于改进型PNGV的锂电池等效电路模型【MATLAB】
matlab·建模·锂电池·等效电路模型·pngv