在命令行上估计频率响应
这个例子展示了如何在MATLAB®命令行中估计Simulink®模型的频率响应。
打开Simulink模型。
mdl =“scdplane”;open_system (mdl)
有关频率响应估计的一般模型要求的更多信息,请参见模型要求.
使用分析点指定频率响应估计的输入和输出点。避免将分析点放在总线信号上。
io (1) = linio (“scdplane / Sum1”1);io (2) = linio (“scdplane / Gain5”, 1“输出”);
有关线性分析点的更多信息,请参见指定部分模型要线性化而且linio
.
将模型线性化,并基于生成的线性系统的动力学创建一个正弦流信号。有关更多信息,请参见估计输入信号而且弗列斯特。Sinestream
.
sys =线性化(“scdplane”io);输入= frest.Sinestream(系统);
如果您的模型没有达到稳态,在估计频率响应之前,使用稳态工作点初始化模型。您可以通过模拟模型来检查模型是否处于稳定状态。有关寻找稳态工作点的更多信息,请参见计算稳态工作点.
找出产生时变信号的线性化输出信号路径中的所有源块。这种时变信号会干扰线性化输出点的信号,导致估计结果不准确。
srcblks = frest.findSources (“scdplane”io);
若要禁用时变源块,请创建frestimateOptions
选项集,并指定BlocksToHoldConstant
选择。
选择= frestimateOptions;选择。BlocksToHoldConstant = srcblks;
估计频率响应。
[sys, simout] = frestimate (“scdplane”、io、输入、选择);
sys
是估计的频率响应。simout
是一个仿真软件。Timeseries
对象,表示模拟输出。
要加快估算速度或减少其内存需求,请参见管理估计速度和内存.
打开仿真结果查看器以分析估计的频率响应。
frest.simView (simout、输入、系统)
你也可以比较估计的频率响应,sys
,精确的线性化你的系统,sys
.
frest.simView (simout输入、sys sys)
的波德图图显示了响应sys
用蓝线表示。
另请参阅
linio
|operspec
|findop
|frest.findSources
|frestimateOptions
|frestimate