How i can convert discrete filter to continuous transfer function?

조회 수: 3 (최근 30일)
Dmitry Kiselyov
Dmitry Kiselyov 2016년 11월 28일
답변: Star Strider 2016년 11월 28일
b0 = 12.575612; b1 = -18.9426445; b2 = 6.4607418;
b = [b0 b1 b2];
a0 = 1.7892133; a1 = -0.7892133; a2 = 0;
a = [a0 a1 a2];
hq = dfilt.df1(b,a,);
How i can convert discrete filter to continuous transf
I need sys = tf(hq);
It not working. Is it possible to convert? If is possible, then how?

답변 (1개)

Star Strider
Star Strider 2016년 11월 28일
You need to ‘invert’ the bilinear transform using the Symbolic Math Toolbox, then solve:
syms H(s) T z Z
assume(T > 0)
Eq = s == 2/T * (z - 1)/(z + 1);
Z = solve(Eq, z)
b0 = 12.575612;
b1 = -18.9426445;
b2 = 6.4607418;
b = [b0 b1 b2];
bz = poly2sym(b, z)
bs = subs(bz,z,Z)
bs = vpa(expand(simplify(bs, 'Steps', 10)), 5)
a0 = 1.7892133;
a1 = -0.7892133;
a2 = 0;
a = [a0 a1 a2];
az = poly2sym(a, z)
as = subs(az,z,Z)
as = vpa(expand(simplify(as, 'Steps', 10)), 5)
producing:
bs = (176.38*T*s)/(T^2*s^2 - 4.0*T*s + 4.0) - 151.54/(T^2*s^2 - 4.0*T*s + 4.0) + 37.979
as = (17.471*T*s)/(T^2*s^2 - 4.0*T*s + 4.0) - 6.3137/(T^2*s^2 - 4.0*T*s + 4.0) + 2.5784
The ‘T’ variable is the sampling interval (inverse of the sampling frequency). Substitute your actual sampling interval for ‘T’, then use the numden and sym2poly functions (in that order) to create your polynomials to give to the Control System Toolbox tf function.
I leave prewarping and other design decisions to you. Incorporate it as necessary.

카테고리

Help CenterFile Exchange에서 Dynamic System Models에 대해 자세히 알아보기

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by