Load a dynamic system model.
load numdemo Pd bode(Pd)
Pd has four complex poles and one real pole. The Bode plot shows a resonance around 210 rad/s and a higher-frequency resonance below 10,000 rad/s.
Decompose this model around 1000 rad/s to separate these two resonances.
[Gs,Gf] = freqsep(Pd,10^3); bode(Pd,Gs,Gf) legend('original','slow','fast','Location','Southwest')
The Bode plot shows that the slow component,
Gs, contains only the lower-frequency resonance. This component also matches the DC gain of the original model. The fast component,
Gf, contains the higher-frequency resonances and matches the response of the original model at high frequencies. The sum of the two components
Gs+Gf yields the original model.
Decompose a model into slow and fast components between poles that are closely spaced.
The following system includes a real pole and a complex pair of poles that are all close to s = -2.
G = zpk(-.5,[-1.9999 -2+1e-4i -2-1e-4i],10);
Try to decompose the model about 2 rad/s, so that the slow component cotains the real pole and the fast component contains the complex pair.
[Gs,Gf] = freqsep(G,2);
Warning: One or more fast modes could not be separated from the slow modes. To force separation, increase the absolute or relative tolerances ("AbsTol" and "RelTol" options). Type "help freqsepOptions" for more information.
These poles are too close together for
freqsep to separate. Increase the relative tolerance to allow the separation.
options = freqsepOptions('RelTol',1e-4); [Gs,Gf] = freqsep(G,2,options);
freqsep successfully separates the dynamics about 2 rad/s.
slowpole = pole(Gs) fastpole = pole(Gf)
slowpole = -1.9999 fastpole = -2.0000 + 0.0001i -2.0000 - 0.0001i
G— Dynamic system to decompose
Dynamic system to decompose, specified as a numeric LTI model,
such as a
fcut— Cutoff frequency
options— Options for decomposition
Options for the decomposition, specified as an options set you
freqsepOptions. Available options include
absolute and relative tolerance for accuracy of the decomposed systems.
Gs— Slow dynamics