function zpk and linmod

4 views (last 30 days)
Rafaella Barrêto Campos
Rafaella Barrêto Campos on 10 Oct 2024
How are matrices A,B,C,D found?
How is the calculation done to find the transfer function gains?
Example:
X_trim =
0.0156566822191464
0.0795424262493709
196.412468864823
15.6561280499959
0
-3048
U_trim =
-0.091567106993385
[A,B,C,D]=linmod(modelName,X_trim,U_trim)
A =
x1 x2
x1 -0.7302 195.5
x2 -0.1373 -0.67
B =
u1
x1 -25.91
x2 -36.5
C =
x1 x2
y1 -0.7302 195.5
y2 0 1
D =
u1
y1 -25.91
y2 0
-25.905 s (s+276.1)
az: --------------------
(s^2 + 1.4s + 27.32)
-36.503 (s+0.6328)
q: --------------------
(s^2 + 1.4s + 27.32)

Answers (2)

Sam Chak
Sam Chak on 10 Oct 2024
Once you have the state-space, you can apply the zpk() function to obtain the TF in zpk mode.
A = [-0.7302 195.5
-0.1373 -0.67];
B = [-25.91
-36.5];
C = [-0.7302 195.5
0 1];
D = [-25.91
0];
sys = ss(A, B, C, D)
sys = A = x1 x2 x1 -0.7302 195.5 x2 -0.1373 -0.67 B = u1 x1 -25.91 x2 -36.5 C = x1 x2 y1 -0.7302 195.5 y2 0 1 D = u1 y1 -25.91 y2 0 Continuous-time state-space model.
G = zpk(sys)
G = From input to output... -25.91 s (s+276.1) 1: -------------------- (s^2 + 1.4s + 27.33) -36.5 (s+0.6327) 2: -------------------- (s^2 + 1.4s + 27.33) Continuous-time zero/pole/gain model.
  3 Comments
Rafaella Barrêto Campos
Rafaella Barrêto Campos on 10 Oct 2024
Yes, how find A,B,C,D?
Sam Chak
Sam Chak on 10 Oct 2024
Edited: Sam Chak on 10 Oct 2024
I don't know the algorithm used in the linmod.m file. However, the state-space matrices A, B, C, D are obtained by computing the Jacobian with respect to the trim condition.

Sign in to comment.


Aquatris
Aquatris on 11 Oct 2024
Here explains how it is done. Basically you have your function that describes the relation between states and inputs. If they are nonlinear functions, you use Jacobian to linearize the relation at a particular operating point, depicted with x_trim and u_trim in your example.
Once you have a state space representation, then you can convert it to a transfer function. From the transfer function, finding the zeros poles and gain are a simple mathematical manipulation to make the transfer function look like this
  8 Comments
Rafaella Barrêto Campos
Rafaella Barrêto Campos on 14 Oct 2024
Would you like to understand how the matrices A,B,C,D are calculated?
Rafaella Barrêto Campos
Rafaella Barrêto Campos on 16 Oct 2024
Loading these files generates two transfer functions, one az and the other q. I would like to know how the calculation of matrices A, B, C and D is done?

Sign in to comment.

Categories

Find more on Dynamic System Models in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!