1. Nội dung thực tập 2
2. Nội dung phương pháp 3
2.1 Bài toán điều khiển tối ưu LQR 4
2.2 Bài toán điều khiển tối ưu LQG 7
3. Bài toán điều khiển bám 9
3.1 Bộ điều khiển phản hồi trạng thái, có khâu lọc trước 10
3.2 Bộ điều khiển có khâu lọc trước và có khâu quan sát trạng thái 12
3.3 Bộ điều khiển có khâu tích phân, không có khâu quan sát 14
3.4 Bộ điều khiển có khâu tích phân và có khâu quan sát 16
4. Thực hiện chương trình điều khiển viết bằng ngôn ngữ lập trình C++/Fmol 19
5. Ví dụ chương trình thiết kế và mô phỏng 26
30 trang |
Chia sẻ: huong.duong | Lượt xem: 1187 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Thực hiện chương trình điều khiển viết bằng ngôn ngữ lập trình C++/Fmol, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
h C++/Fmol
Tõ lý thuyÕt ®· ®îc t×m hiÓu ë phÇn tríc ta ®i ®Õn x©y dùng phÇn mÒm ®iÒu khiÓn cho c¸c ®èi tîng thùc.
Môc 5. VÝ dô ch¬ng tr×nh thiÕt kÕ vµ m« pháng
PhÇn nµy kiÓm chøng l¹i ®é chÝnh x¸c cña phÇn mÒm th«ng qua m« pháng vµ c¸c vÝ dô têng minh.
2. Néi dung ph¬ng ph¸p
Cho hÖ thèng MIMO cã m« h×nh
plant
K
u
y
H×nh 2.1: M« h×nh bé ®iÒu khiÓn ph¶n håi tr¹ng th¸i
(2.1)
Trong ®ã AR, BR, CR, D
u tÝn hiÖu ®iÒu khiÓn
y tÝn hiÖu ra cña ®èi tîng
K bé ®iÒu khiÓn ph¶n håi tr¹ng th¸i
Bµi to¸n cã nhiÖm vô x¸c ®Þnh bé ®iÒu khiÓn K sao cho hµm môc tiªu lµ nhá nhÊt
= (2.2)
Bµi to¸n cã tªn lµ LQR (Linear Quadratic Regulator), nÕu vector tÝn hiÖu tr¹ng th¸i x ph¶n håi lµ kh«ng ®o ®îc, song ®èi tîng lµ quan s¸t ®îc th× ta cã thÓ thiÕt kÕ thªm bé quan s¸t tr¹ng th¸i nh»m x¸c ®Þnh gi¸ trÞ x(t) th«ng qua viÖc ®o nh÷ng tÝn hiÖu vµo ra u(t), y(t) trong kho¶ng thêi gian T h÷u h¹n, nÕu ta dïng bé quan s¸t trang th¸i Kalman th× bµi to¸n ®ã ®îc gäi lµ nµi to¸n LQG (Linear Quadratic Gaussian). Do ta dïng m¸y tÝnh ®Ó ®iÒu khiÓn hÖ thèng nªn ta ph¶i chuyÓn c¸c ph¬ng tr×nh liªn tôc sang d¹ng rêi r¹c, c¸c ph¬ng tr×nh cã d¹ng nh sau
M« h×nh rêi r¹c ®èi tîng
(2.3)
trong ®ã
M« h×nh hµm môc tiªu
J= (2.4)
víi Q1, Q2 lµ ma trËn träng sè do ngêi thiÕt kÕ ®a vµo dùa vµo mèi quan hÖ gi÷a tr¹ng th¸i c¸c biÕn x vµ bé ®iÒu khiÓn.
§Ó t×m ®îc bé ®iÒu khiÓn ta ph¶i gi¶i ph¬ng tr×nh Riccati, do viÖc t×m ph¬ng tr×nh Riccati t¬ng ®èi phøc t¹p nªn ta chØ ®a ra kÕt qu¶
(2.5)
Thêng viÕt díi d¹ng
(2.6)
víi
Cuèi cïng ta ®¹t ®îc
(2.7)
víi
(2.8)
PhÇn tiÕp theo ta sÏ t×m hiÓu vÒ bµi to¸n LQR, LQG x¸c ®Þnh bé ®iÒu khiÓn tèi u, phÇn mµ ta sÏ thùc hiÖn xuyªn suèt trong bµi thùc tËp.
2.1 Bµi to¸n ®iÒu khiÓn tèi u LQR
Trong phÇn tríc chóng ta x©y dùng bé ®iÒu khiÓn tèi u b»ng c¸ch tèi thiÓu hµm môc tiªu, ta thÊy r»ng kÕt qu¶ cña K(k) thay ®æi trong tõng bíc tÝnh, do vËy ®Ó thuËn tiÖn trong viÖc ®iÒu khiÓn hÖ thèng ta x¸c ®Þnh bé ®iÒu khiÓn tèi u K lµ kh«ng ®æi, trong thùc tÕ ®©y lµ c¸ch gi¶i quyÕt tèi u, ta gäi ®ã lµ bµi to¸n Linear Quadratic Gaussian (LQR). Trong phÇn nµy ta sÏ t×m ra bé ®iÒu khiÓn LQR (hay K) vµ hiÖu qu¶ cña nã th«ng qua c¸c vÝ dô.
Nh ta ®· nãi ë phÇn tríc ®Ó x¸c ®Þnh K ta ph¶i dùa vµo ph¬ng tr×nh Riccati, vµ t¹i tr¹ng th¸i æn ®Þnh, S(k) trë thµnh S(k+1) (c¶ hai ®îc gäi lµ S), ph¬ng tr×nh Riccati trë thµnh.
(2.10)
Cã nhiÒu c¸ch ®Ó tÝnh S, tuy nhiªn ta sö dông ph¬ng ph¸p eigenvector composition, ®©y lµ ph¬ng ph¸p phÇn lín c¸c phÇn mÒm sö dông. Nã dùa trªn c«ng thøc Hamilton
(2.11)
vµ ma trËn Hamilton
(2.12)
Víi lµ vector Lagrange cña mçi gi¸ trÞ k
Gi¶i ph¬ng tr×nh Hamilton ®· chøng minh ®îc r»ng hÖ cã 2n nghiÖm, trong ®ã cã n nghiÖm lµ æn ®Þnh vµ n nghiÖm kh«ng æn ®Þnh. H¬n thÕ nöa n nghiÖm æn ®Þnh lµ tèi u, lµm cho bé khuÕch ®¹i kh«ng ®æi trong hÖ thèng kÝn. Chóng ta sÏ ®a ma trËn Hamilton vÒ d¹ng ®êng chÐo, víi c¸ch gi¶i quyÕt nµy ta sÏ ®¹t ®îc bé ®iÒu khiÓn tèi u. Chóng ta ph©n chia nh sau, mét n÷a nghiÖm cña hÖ thèng ë bªn trong ®êng trßn vµ mét nöa nghiÖm ë bªn ngoµi ®êng trßn. Khi Êy trë thµnh
(2.13)
Víi lµ ma trËn ®êng chÐo cña quü ®¹o nghiªm kh«ng æn ®Þnh (|z|>1) vµ lµ ma trËn ®êng chÐo cña quü ®¹o nghiÖm æn ®Þnh (|z|<1). ®¹t ®îc b»ng c¸ch biÕn ®æi
(2.14)
Trong ®ã
(2.15)
víi
lµ ma trËn eigenvector kÕt hîp víi ma trËn Hamilton bªn ngoµi ®êng trßn ®¬n vÞ vµ
lµ ma trËn eigenvector kÕt hîp víi ma trËn Hamilton bªn trong ®êng trßn ®¬n vÞ.
Sau khi gi¶i ph¬ng tr×nh Riccati kÕt qu¶ ta cã
(2.16)
vµ luËt ®iÒu khiÓn
(2.17)
K ®îc tÝnh nh sau
= (2.18)
VËy bµi to¸n LQR ®îc thùc hiÖn qua c¸c bíc sau.
+X¸c ®Þnh ma trËn Hamilton
+X¸c ®Þnh ma trËn kÕt hîp víi ma trËn Hamilton cã quü ®¹o nghiÖm bªn trong ®êng trßn ®¬n vÞ.
+X¸c ®Þnh K tõ (2.16) vµ (2.18)
Ta cã dïng phÇn mÒn Matlab ®Ó tÝnh gi¸ trÞ cña bé ®iÒu khiÓn K lÖnh nh sau:
[K,S]=dlqr(A,B,Q1,Q2)
Trong qu¸ tr×nh x©y dùng phÇn mÒm em sö dông phÇn mÒm FMOL [1] ®Ó tÝnh gi¸ trÞ bé ®iÒu khiÓn lÖnh nh sau:
[K,S]=dare(A,B,Q1,Q2)
VÝ dô:
Cho ®èi tîng cã c¸c ma trËn sau
A= B= C =
Ma trËn hµm môc tiªu
1
LÖnh thùc hiÖn trªn Matlab
[K,S]=dlqr(A,B,Q1,Q2) ;
KÕt qu¶ nh sau
2.2 Bµi to¸n ®iÒu khiÓn tèi u LQG
Ph¬ng ph¸p quan s¸t tr¹ng th¸i tèi u rÊt hÊp dÉn bëi nã sö dông ®îc cho hÖ thèng MIMO rÊt dÔ dµng, vµ cho phÐp ngêi thiÕt kÕ nhanh chãng x¸c ®Þnh ®îc ma trËn quan s¸t tr¹ng th¸i L. Trong phÇn nµy ta sÏ sö dông bé läc Kalman ®Ô x©y dùng thuËt to¸n bëi bé läc nµy lo¹i bá mét c¸ch triÖt ®Ó ¶nh hëng cña nhiÔu vµo hÖ thèng vµ mét ®iÒu lý thó lµ thuËt to¸n x¸c ®Þnh bé quan s¸t Kalman hoµn toµn gièng nh viÖc thiÕt kÕ bé ®iÒu khiÓn tèi u ph¶n håi tr¹ng th¸i (LQR). Víi c¸ch gi¶i quyÕt t¬ng tù nh víi bµi to¸n LQR, ta sÏ x©y dùng c¸ch gi¶i quyÕt bé quan s¸t tr¹ng th¸i tèi u víi bé ®iÒu khiÓn L.
M« h×nh rêi r¹c cña ®èi tîng.
(2.19)
Víi nhiÔu qu¸ tr×nh vµ nhiÔu ®o ®Çu ra , gi¸ trÞ nhiÔu ®îc x¸c ®Þnh bëi
(2.20)
T¬ng tù nh phÇn tríc ta cñng cã kÕt qu¶ nh sau.
(2.21)
Tõ kÕt qu¶ nµy ta thÊy cã sù t¬ng ®ång gi÷a hai c«ng thøc do vËy ta cã b¶ng t¬ng ®¬ng nh sau.
Control Estimation
Khi Êy ma trËn Hamilton cã d¹ng sau.
(2.22)
Gi¸ trÞ cña ma trËn M nh sau
(2.23)
víi
lµ ma trËn kÕt hîp víi ma trËn n»m trong vßng trßn ®¬n vÞ, kÕt qu¶ ma trËn khuÕch ®¹i tr¹ng th¸i æn ®Þnh Kalman-filter.
(2.24)
Còng thùc hiÖn t¬ng tù nh phÇn x©y dùng bé khuÕch ®¹i tèi u, ta ®îc bé khuÕch ®¹i æn ®Þnh tr¹ng th¸i cña bé läc Kalman.
KÕt hîp c¶ hai phÇn mét vµ hai ta cã m« h×nh tæng qu¸t cña hÖ thèng ®iÒu khiÓn LQG, LQR víi sù tån t¹i cña nhiÔu trong hÖ thèng. §©y lµ m« h×nh ®¹t hiÖu qu¶ cao kh«ng chØ cho hÖ MIMO mµ cßn cho c¶ hÖ thèng SISO.
LQG
K
Plant
r
yr
-
Estimator
w
LQR
v
H×nh 2.2: M« h×nh bµi to¸n LQG
LÖnh trong Matlab ®Ó tÝnh ma trËn L
L=dlqr(A’,C’,S,T)
T¬ng tù lÖnh trong qu¸ tr×nh viÕt phÇn mÒm
L=dare(A’,B’,S,T)
VÝ dô:
Cho ®èi tîng cã c¸c ma trËn sau
A= B= C =
Ma trËn hµm tæn hao
1
LÖnh thùc hiÖn trªn Matlab
L=lqr(A’,C’,S,T) ;
KÕt qu¶ nh sau
L=[1.0536 -0.3899]
3. Bµi to¸n ®iÒu khiÓn b¸m
ë phÇn tríc ta ®· ph©n tÝch hai bµi to¸n LQR, LQG viÖc tån t¹i sai lÖch tÜnh lµ kh«ng thÓ tr¸nh khái, ®iÒu nµy g©y khã chÞu cho ngêi sö dông lµ tÝn hiÖu r(t) ®îc ®a vµo díi dang mét h»ng sè, song hÖ thèng l¹i kh«ng cho ra tÝn hiÖu mong muèn. §Ó lo¹i bá sai lÖch tÜnh ta ph¶i bç xung thªm mét kh©u tiÒn xö lý. Tuú vµo ®iÒu kiÖn cô thÓ mµ ta thªm kh©u tiÒn xö lý díi lµ h»ng sè hay lµ mét kh©u tÝch ph©n, ®èi víi kh©u tÝch ph©n thêng dïng khi hÖ thèng cã nhiÔu can thiÖp.
Lóc nµy ta cã thÓ ph©n tÝch toµn bé hÖ thèng gåm ®èi tîng, kh©u tiÒn xö lý vµ bé ®iÒu khiÓn thµnh m« h×nh cã d¹ng tæng qu¸t nh sau:
C
P
r
uc
yr
xp
H×nh 3.1: M« h×nh rót gän cña hÖ thèng
trong ®ã
C (Controller) bé ®iÒu khiÓn thùc hiÖn thuËt to¸n ®iÒu khiÓn sè thu ®îc tõ mçi m« h×nh t¬ng øng
P (Plant) ®èi tîng ®iÒu khiÓn
r gi¸ trÞ ®Æt cña tÝn hiÖu ®iÒu khiÓn
xp biÕn tr¹ng th¸i cña ®èi tîng
yr ®Çu ra cña ®èi tîng
Nh vËy bé ®iÒu khiÓn C ta cã thÓ coi lµ mét ®èi tîng ®iÒu khiÓn cã hai ®Çu vµo lµ r vµ xp cßn tÝn hiÖu ra lµ uc ®îc ®a vµo ®Ó ®iÒu khiÓn ®èi tîng P.
Ph¬ng tr×nh tr¹ng th¸i rêi r¹c m« t¶ bé ®iÒu khiÓn C cã d¹ng
(3.1)
ë ®©y xc lµ biÕn tr¹ng th¸i cña bé ®iÒu khiÓn C
v lµ tÝn hiÖu vµo cña bé ®iÒu khiÓn C
AcR, BcR, CcR, Dc lµ c¸c ma trËn cã vai trß t¬ng tù nh c¸c ma trËn cña ®èi tîng ë trªn.
NhiÖm vô cña ta lµ trong mçi trêng hîp cô thÓ ta ph¶i x¸c ®Þnh c¸c ma trËn Ac, Bc, Cc, Dc cña bé ®iÒu khiÓn tõ ®ã lµm c¬ së ®Ó x©y dùng thuËt to¸n ®iÒu khiÓn sè b»ng ng«n ng÷ C/C++.
3.1 Bé ®iÒu khiÓn ph¶n håi tr¹ng th¸i, cã kh©u läc tríc
M« h×nh bµi to¸n
Nu
Nx
K
Plant
Hr
Controller
r
xp
xr
uss
yr
-
uc
H×nh 3.1: S¬ ®å khèi hÖ thèng cã kh©u läc tríc vµ ph¶n håi
C¸c ma trËn Nx R, Nu R chÝnh lµ c¸c ma trËn cña kh©u läc tríc, Nx cã t¸c dông t¹o ra tÝn hiÖu ra xr vµo ®Çu vµo cña ®èi tîng ®Ó ®¹t ®îc gi¸ trÞ mong muèn. Th«ng thêng ngêi thiÕt kÕ cã ®ñ nh÷ng hiÓu biÕt vÒ ®èi tîng, nªn biÕt ®îc tr¹ng th¸i nµo ®Ó cã thÓ duy tr× tr¹ng th¸i ®Çu ra mong muèn. Trong trêng hîp ®èi tîng lµ phøc t¹p, chóng ta sÏ gÆp rÊt nhiÒu khã kh¨n ®Ó x¸c ®Þnh tr¹ng th¸i ®ã, do vËy ta x©y dùng mét bé ®iÒu khiÓn tr¹ng th¸i lµm c©n b»ng víi ®Çu vµo, tøc lµ khi ®Çu ra ë tr¹ng th¸i mong muèn th× tÝn hiÖu ®iÒu khiÓn uc lu«n ®îc duy tr× ë mét gi¸ trÞ nµo ®ã chø nã kh«ng h«i tô vÒ 0, Nu lµ bé ®iÒu khiÓn cã t¸c dông nh vËy.
Ph¬ng tr×nh tr¹ng th¸i rêi r¹c cña bé ®iÒu khiÓn C lóc nµy thu ®îc tõ m« h×nh trªn cã d¹ng sau
(3.2)
hay (3.3)
vµ m« h×nh cña ®èi tîng
(3.4)
Tõ (3.3) vµ coi c¸c biÕn tr¹ng th¸i cña bé ®iÒu khiÓn trong trêng hîp nµy lµ b»ng kh«ng. C¸c ma trËn cña bé ®iÒu khiÓn C trong trêng hîp nµy nh sau:
Ac=, Bc=, Cc=
Dc=
(3.5)
víi lµ ma trËn gåm c¸c phÇn tö cã hÖ sè 0
BiÕn tr¹ng th¸i xP cña ®èi tîng sÏ t×m ®îc theo ph¬ng tr×nh tr¹ng th¸i quen thuéc sau
(3.6)
C¸c ma trËn Nx, Nu sÏ t×m ®îc qua viÖc biÕn ®æi t¬ng ®¬ng c¸c ph¬ng tr×nh sau
ë tr¹ng th¸i x¸c lËp ta cã
VËy víi vµ ta thu ®îc hay
Cuèi cïng ta cã (3.7)
mÆt kh¸c
Vµ ë tr¹ng th¸i x¸c lËp
(3.8)
kÕt hîp (3.6), (3.7) ta cã
(3.9)
ë ®©y c¸c ma trËn R, R, IR,I1R
Sau khi x¸c ®Þnh ®îc Nx, Nu ta x¸c ®Þnh K t¬ng tù nh phÇn trªn ta ®· xÐt
VÝ dô:
Do trong phÇn thùc tËp nµy chóng em cha cã ®iÒu kiÖn m« pháng nªn tõ vÝ dô nµy trë ®i chØ ®a ra kÕt qu¶ cña ®Çu ra y(k) trong c¸c bíc tÝnh.
Cho ®èi tîng MIMO cã m« h×nh nh sau.
KÕt qu¶ ch¹y trªn phÇn mÒm m« pháng nh sau
Sau 12 bíc tÝnh ta cã kÕt qu¶ ®Çu ra y(12) vµ uc(k) nh sau
Víi tÝn hiÖu ®Æt hai ®Çu vµo r lµ [2 1] ta thÊy kÕt qu¶ t¬ng ®èi chÝnh x¸c, tuy nhiªn khi cho nhiÔu vµo kÕt qu¶ kh«ng ®îc chÝnh x¸c nh tríc.
3.2 Bé ®iÒu khiÓn cã kh©u läc tríc vµ cã kh©u quan s¸t tr¹ng th¸i
M« h×nh bµi to¸n
Nu
Nx
K
Plant
Controller
r
xr
uss
yr
-
Estimator
uc
H×nh 3.1: S¬ ®å khèi hÖ thèng cã kh©u läc tríc vµ ph¶n håi
Khi tÝn hiÖu tr¶ vÒ kh«ng ®o ®îc ta cÇn ph¶i thªm mét kh©u quan s¸t tr¹ng th¸i ®Ó quan s¸t gÝa trÞ xP (k). T¬ng tù nh c¸c phÇn tríc thuËt to¸n t×m ma trËn ph¶n håi tr¹ng th¸i K kh«ng thay ®æi, thuËt to¸n nµy cßn ®îc ¸p dông ®Ó t×m ma trËn LP cña kh©u quan s¸t tr¹ng th¸i Kalman. Nhng ë ®©y khi t×m LP ta cÇn thay thÕ t¬ng ®¬ng vµ , mét ®iÒu cÇn chó ý lµ sè chiÒu cña ma trËn LP lóc nµy sÏ lµ LP R, c¸c ma trËn Nx, Nu vÉn ®îc t×m theo ph¬ng ph¸p trªn.
LP=dlqr(A’,C’,S,T)
S, T ma trËn träng sè cña kh©u läc Kalman
Ph¬ng tr×nh tr¹ng th¸i rêi r¹c cña bé ®iÒu khiÓn C lóc nµy thu ®îc tõ m« h×nh trªn cã d¹ng sau
= (3.10)
Ph¬ng tr×nh cña biÕn tr¹ng th¸i khi cã bé quan s¸t tr¹ng th¸i lµ
(3.11)
thay thÕ biÓu thøc uc võa t×m ®îc ë trªn ta cã
(3.12)
víi tÝn hiÖu ®Æt cña bé ®iÒu khiÓn lµ gi¸ trÞ ®Æt r vµ biÕn tr¹ng th¸i th× tõ (3.10) vµ (3.12) ta t×m ®îc c¸c ma trËn t¬ng øng cña bé ®iÒu khiÓn C nh sau:
(3.13)
Víi c¸c ma trËn cña bé ®iÒu khiÓn t×m ®îc trªn ta cã thÓ dÔ dµng sö dông nã cho viÖc lËp tr×nh.
VÝ dô:
Dïng l¹i vÝ dô ë môc 1 víi ma trËn träng sè kh©u läc Kalman ®îc bæ xung kÕt qu¶ m« pháng nh sau.
Sau 13 bíc tÝnh kªt qu¶ nh sau
vµ
Nhîc ®iÓm cña 2 bµi to¸n trªn lµ hÖ thèng rÊt nhËy víi nhiÔu cña ma trËn K do v©y ta cã thÓ thªm kh©u tÝch ph©n vµo hÖ thèng ®Ó hy väng khö ®îc hoµn toµn ¶nh hëng cña ma trËn K còng nh sai lÖch tÜnh sña hÖ thèng.
ë hai phÇn trªn chóng ta ®· cïng nhau xem xÐt ¶nh hëng cña m« h×nh cã Nx, Nu ®èi víi mét ®èi tîng bÊt kú vµ ®i ®Õn nhËn xÐt r»ng chÊt lîng cña hÖ thèng ®îc n©ng lªn râ rÖt. §¸p øng ®Çu ra lu«n thùc hiÖn ®îc nh gi¸ trÞ ®Æt yªu cÇu. Tuy nhiªn víi hai m« h×nh trªn vÊn ®Ò kh¸ng nhiÔu vÉn cha ®îc ®Ò cËp ®Õn. Nãi mét c¸ch kh¸c hÖ thèng sÏ kh«ng gi÷ ®îc gi¸ trÞ ®Æt nh yªu cÇu nÕu cã nhiÔu bªn ngoµi t¸c ®éng vµo hÖ thèng.
Bëi vËy díi ®©y ta sÏ tr×nh bÇy vÒ hai m« h×nh trong ®ã cã ®a thªm vµo hÖ thèng kh©u tÝch ph©n cã nhiÖm vô khö nhiÔu nh»m n©ng cao chÊt lîng hÖ thèng h¬n.
3.3 Bé ®iÒu khiÓn cã kh©u tÝch ph©n, kh«ng cã kh©u quan s¸t
M« h×nh bµi to¸n lóc nµy ®îc céng thªm vµo c¸c biÕn tr¹ng th¸i ë kh©u tÝch ph©n mµ ta ®· thªm vµo hÖ thèng nh»m kh¾c phôc nhiÔu
Controller
Nx
K
Plant
Hr
r
xp
xr
yr
-
uc
w
-
H×nh 3.1: S¬ ®å khèi hÖ thèng cã kh©u tÝch ph©n kh«ng cã kh©u quan s¸t
§èi tîng vÉn cã m« h×nh tr¹ng th¸i
(3.14)
biÕn tr¹ng th¸i xI lóc nµy thu ®îc vÉn lµ
Cuèi cïng ta ®îc m« h×nh ®èi tîng cã sè bËc t¨ng lªn nh sau
(3.15)
LuËt ®iÒu khiÓn lóc nµy sÏ lµ
(3.16)
Nh vËy ta sÏ sö dông m« h×nh nµy ®Ó t×m ma trËn ph¶n håi . ThuËt to¸n t×m K1 vÉn kh«ng thay ®æi theo c¸c ph¬ng ph¸p ®· tr×nh bÇy ë trªn.
§Ó thuËn tiÖn cho viÖc lËp tr×nh ta vÉn t×m c¸ch biÓu diÔn bé ®iÒu khiÓn C theo ph¬ng tr×nh tr¹ng th¸i rêi r¹c nh ®· nãi ë trªn
Tõ m« h×nh ta cã thÓ coi xI lµ biÕn tr¹ng th¸i cña bé ®iÒu khiÓn, víi
(3.17)
vµ tÝn hiÖu ra cña bé ®iÒu khiÓn lµ
(3.18)
KÕt hîp (3.17) vµ (3.18) th× c¸c ma trËn tr¹ng th¸i t¬ng øng cña bé ®iÒu khiÓn C nh sau
(3.19)
VÝ dô:
Sö dông l¹i vÝ dô 1 bæ xung thªm vÐcto ®©y lµ vector cña ma trËn ®êng chÐo ghÐp víi ma tr©n Q1 thu ®îc ma trËn míi lµ ma trËn träng sè cña hÖ míi. KÕt qu¶ nh sau
Ma trËn träng sè cña hÖ míi lµ
Víi nhiÔu lµ kÕt qu¶ sau 35 bíc tÝnh
KÕt qu¶ cho ta thÊy nhiÔu kh«ng ¶nh hëng ®Õn hÖ thèng, thùc tÕ khi cho nhiÔu lín h¬n n÷a th× kÕt qu¶ ®Çu ra vÉn héi tô ë gi¸ trÞ mong muèn khi t¨ng bíc tÝnh lªn, ®©y lµ kÕt qu¶ mµ c¸c phÇn tríc kh«ng cã.
3.4 Bé ®iÒu khiÓn cã kh©u tÝch ph©n vµ cã kh©u quan s¸t
Khi tÝn hiÖu tr¶ vÒ kh«ng ®o ®îc chóng ta ph¶i x©y dùng thªm kh©u quan s¸t ®Ó x¸c ®Þnh cña ®èi tîng thay v× c¸c gi¸ trÞ ®îc gi¶ thiÕt lµ ®· biÕt nh ë phÇn trªn
M« h×nh bµi to¸n
Controller
Nx
K
Plant
Hr
r
xr
yr
-
uc
w
-
Estimator
H×nh 3.1: S¬ ®å khèi hÖ thèng cã kh©u tÝch ph©n vµ kh©u quan s¸t tr¹ng th¸i
Víi m« h×nh míi nµy thuËt to¸n t×m ma trËn ph¶n håi tr¹ng th¸i K1 v½n kh«ng thay ®æi tøc lµ K1 vÉn lµ nghiÖm cña hµm dare() víi c¸c ma trËn ë m« h×nh më réng nh ®· nãi ë trªn. Nhng ma trËn quan s¸t tr¹ng th¸i LP trong trêng hîp nµy vÉn sö dông ®èi tîng cò.
Ph¬ng tr×nh rêi r¹c cña bé ®iÒu khiÓn C ®îc t×m nh sau:
Tõ m« h×nh trªn ta cã tÝn hiÖu ra tõ kh©u tÝch ph©n
(3.20)
Khi cã kh©u quan s¸t tr¹ng th¸i th× biÕn tr¹ng th¸i cña ®èi tîng b»ng
(3.21)
Víi viÖc coi c¸c biÕn trong trêng hîp nµy lµ vµ ta ®îc
(3.22)
TÝn hiÖu ra uc cña bé ®iÒu khiÓn b»ng
(3.23)
KÕt hîp (3.22) vµ (3.23) ta thu ®îc ma trËn cña bé ®iÒu khiÓn C cã d¹ng
(3.24)
VÝ dô :
Dïng ®èi tîng nh c¸c vÝ dô tríc ta cã
Víi nhiÔu ®Çu vµo ta cã kÕt qu¶ sau 40 bíc tÝnh
vµ
Trong phÇn nµy ta ®· x©y dùng c¸c thuËt to¸n ®iÒu khiÓn nh»m n©ng cao chÊt lîng hÖ thèng vµ c¸c tham sè cña bé ®iÒu khiÓn còng nh nh÷ng vÝ dô minh ho¹ têng minh, phÇn tiÕp theo ta sÏ tiÕn hµnh x©y dùng phÇn mÒm thùc hiÖn c¸c thuËt to¸n trªn b»ng ng«n ng÷ C/C++
4. Thùc hiÖn ch¬ng tr×nh ®iÒu khiÓn viÕt b»ng ng«n ng÷ lËp tr×nh C++/Fmol
Ng«n ng÷ C++ lµ ng«n ng÷ rÊt phæ biÕn trong viÖc x©y dùng phÇn mÒm ®iÒu khiÓn tù ®éng, bëi nã thuËn tiÖn cho ngêi sö dông (kh«ng nh ng«n ng÷ m¸y hay Assembler) vµ ®¶m b¶o tÝnh thêi gian thùc rÊt cao.
§Ó ch¬ng tr×nh ®iÒu khiÓn ®îc râ rµng, dÔ hiÓu tríc tiªn chóng em xin tr×nh bÇy kh¸i qu¸t vÒ mét sè líp trong th viÖn Fmol mµ sÏ sö dông trong ch¬ng tr×nh sau nµy.
+ Líp Matrix ®îc thùc hiÖn trong file “Matrix.h”, gåm nhiÒu tÝnh n¨ng nh khai b¸o mét ma trËn, céng trõ nh©n chia ma trËn…®Ô hiÓu râ h¬n ta ®äc file “doc” trong th viÖn FMOL [1].
+ Líp Vector ®îc thùc hiÖn trong file ”Vector.h”, nã còng cã tÝnh n¨ng t¬ng tù nh líp ma trËn.
+ Ngoµi ra ta cßn sö dông th viÖn “Control.lib” ®Ó tÝnh bé ®iÒu khiÓn tèi u (K=dare(A,B,Q,R) ta ®· ®Ò cËp ®Õn ë phÇn tríc), ®Ó sö dông th viÖn nµy ta cÇn khai b¸o c¸c lÖnh sau trong hµm main().
using namespace fmol;
using namespace fmol::control;
+ Líp DSS vÒ c¬ b¶n ®Þnh nghÜa c¸c hµm ®Ó tÝnh to¸n ®a ra c¸c ma trËn tr¹ng th¸i A, B, C, D khi ta ®a vµo hµm nµy ®èi sè lµ sè biÕn tr¹ng th¸i, sè tÝn hiÖu ®Çu vµo, sè tÝn hiÖu ®Çu ra, vµ thêi gian trÝch mÉu Td.
VÝ dô:
DSS plant(2,2,2,0.1,0); // khai b¸o ®èi tîng cã 2 biÕn tr¹ng th¸i, 2 ®Çu vµo, 2 ®Çu ra, thêi gian trÝch mÉu 0.1 sec, kh«ng cã trÔ.
Vector u(2);
plant.A // gäi ma trËn A cña ®èi tîng plant (cã kiÓu DSS)
Vector y = plant.step(u) // tÝnh ®Çu ra cña ®èi tîng y khi cho vector ®Çu vµo u (lÖnh nµy ta cã sö dông trong ch¬ng tr×nh).
TiÕp theo x©y dùng mét th viÖn cã tªn “lq.h” gåm 4 hµm sau:
Tr¶ vÒ bé ®iÒu khiÓn díi d¹ng ph¬ng tr×nh tr¹ng th¸i A, B, C, D trong trêng hîp bµi to¸n LQR, c¸c ®èi cña hµm ®Òu ®Ó ë d¹ng tham chiÕu ®Ó ta kh«ng thÓ thay ®æi néi dung cña ®èi, plant lµ m« h×nh cña ®èi tîng cho díi d¹ng ph¬ng tr×nh tr¹ng th¸i gåm c¸c ma trËn A, B, C, D. C¸c ma trËn träng sè Q, R cña hµm môc tiªu ®Òu cã kiÓu ma trËn, c¸c hµm sau ®Òu khai b¸o theo chuÈn nh vËy.
DSS lqr(const DSS& plant,const Matrix& Q,const Matrix& R);
- Tr¶ vÒ bé ®iÒu khiÓn trong bµi to¸n LQG, trong ®ã ma trËn S, T lµ ma trËn cña kh©u läc Kalman.
DSS lqg(const DSS& plant,const Matrix& Q,const Matrix& R, const Matrix& S,const Matrix& T);
Cã kh©u tÝch ph©n, kh«ng cã kh©u quan s¸t.
Trong ®ã vector qi lµ vector ®êng chÐo cña ma trËn chÐo ghÐp víi ma tr©n Q t¹o thµnh ma trËn míi ®Ó tÝnh K.
VÝ dô:
vector míi cã d¹ng
K=dare(A,B,Q’,R)
DSS lqri(const DSS& plant,const Matrix Q,const Matrix R, const Vector& qi);
- Cã kh©u tÝch ph©n, cã kh©u quan s¸t.
DSS lqgi(const DSS& plant,const Matrix& Q,const Matrix& R, const Vector& qi, const Matrix& S,const Matrix& T);
Ngoµi ra ®Ó cho ch¬ng tr×nh kh«ng dµi dßng ta x©y dùng thªm mét hµm cã t¸c dông tÝnh Nx, Nu, hµm nµy cã ®èi lµ ®èi tîng ®a vµo vµ tr¶ vÒ hai gi¸ trÞ lµ Nx, Nu.
pair Nxnu(const DSS& plant);
Bèn hµm nµy ®îc khai b¸o ë header file “lq.h” nh sau
// lq.h: interface for the lq class.
//////////////////////////////////////////////////
#if !defined(AFX_LQ_H__ADA7F2E3_26FF_11D7_913B_D04105F11C69__INCLUDED_)
#define AFX_LQ_H__ADA7F2E3_26FF_11D7_913B_D04105F11C69__INCLUDED_
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
#include
#include
namespace fmol {
namespace control {
pair Nxnu(const DSS& plant);
// bo dieu khien phan hoi trang thai, co khau loc truoc
DSS lqr(const DSS& plant,const Matrix& Q,const Matrix& R);
// khong co khau I va co khau quan sat va khau loc truoc
DSS lqg(const DSS& plant,const Matrix& Q,const Matrix& R, const Matrix& S,const Matrix& T);
// co khau I va khong co quan sat
DSS lqri(const DSS& plant,const Matrix Q,const Matrix R, const Vector& qi);
// co khau I va co khau quan sat
DSS lqgi(const DSS& plant,const Matrix& Q,const Matrix& R, const Vector& qi, const Matrix& S,const Matrix& T);
}
}
#endif // !defined(AFX_LQ_H__ADA7F2E3_26FF_11D7_913B_D04105F11C69__INCLUDED_)
Sau ®ã thùc hiÖn c¸c hµm trªn ë file cã ®u«i .cpp “lq.cpp”.
// lq.cpp: implementation of the lq class.
//////////////////////////////////////////////////
#include "lq.h"
#include
#include
#include
//////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////
namespace fmol {
namespace control {
pair Nxnu(const DSS& plant)
{
//Nx, Nu duoc tinh theo cong thuc (3.8)
int m,n;Matrix Nx,Nu;
m=plant.A.nrows(); n=plant.B.ncols();
Matrix I(m,m),I2(n,n),M,O(n,n),I1(m+n,n),H;
M=colx(rowx(plant.A-I.eye(m),plant.C),rowx(plant.B,O));
I1(m+1,m+n,1,n)=I2.eye(n);
H=inv(M)*I1;
Nx=H(1,m,1,n);
Nu=H(m+1,m+n,1,n);
return make_pair(Nx,Nu);
}
// bo dieu khien phan hoi trang thai, co khau loc truoc
DSS lqr(const DSS& plant,const Matrix& Q,const Matrix& R) {
//Bo dieu khien da duoc xay dung trong (3.5)
int n = plant.nX();
int m = plant.nI();
int p = plant.nO();
DSS ctrl(0,p+n,m,plant.Ts);
Matrix Nx, Nu, K, X;
(Nx,Nu) = Nxnu(plant);
(X,K) = dare(plant.A,plant.B,Q,R);
cout<<"K:"<<K;
ctrl.D = colx(K*Nx+Nu,-K);
return ctrl;
}
// khong co khau I va co khau quan sat va khau loc truoc
DSS lqg(const DSS& plant,const Matrix& Q,const Matrix& R, const Matrix& S,const Matrix& T)
{
//Bo dieu khien da duoc xay dung trong (3.13)
int n = plant.nX();
int m = plant.nI();
int p = plant.nO();
DSS ctrl(n,p+n,m,plant.Ts);
Matrix Nx, Nu, K, X,L,V(m,n);
(Nx,Nu) = Nxnu(plant);
(X,K) = dare(plant.A,plant.B,Q,R);
(X,L) = dare(plant.A.t(),plant.C.t(),S,T);
cout<<"L:"<<L;
ctrl.A=(plant.A-L.t()*plant.C-plant.B*K);
ctrl.B=colx(plant.B*(Nu+K*Nx),L.t()*plant.C);
ctrl.C=-K;
ctrl.D=colx(Nu+K*Nx,V);
return ctrl;
}
// co khau I va khong co quan sat
DSS lqri(const DSS& plant,const Matrix Q,const Matrix R, const Vector& qi)
{
int n = plant.nX();
int m = plant.nI();
int p = plant.nO();
DSS ctrl(p,p+n,m,plant.Ts);
Matrix Nx, Nu, K1(m,n),Ki(m,m),K, X,I(p,p),Ad,
J(m,m),O(n,m),Bd,Qd(m+n,m+n),Qi(m,m);
Ad=colx(rowx(J.eye(m),O),rowx(plant.C,plant.A));
//Bo dieu khien da duoc xay dung trong (3.17)
Bd=rowx(O,plant.B);
Qi.diag()=qi;
Qd(1,n,1,n)=Q(1,n,1,n);
Qd(n+1,n+m,n+1,m+n)=Qi(1,m,1,m);
(Nx,Nu) = Nxnu(plant);
(X,K) = dare(Ad,Bd,Qd,R);
Ki(1,m,1,m)=K(1,m,1,m);
K1(1,m,1,n)=K(1,m,m+1,m+n);
cout<<"Ki=:"<<Ki;
cout<<"K1=:"<<K1;
ctrl.A=I.eye(m);
ctrl.B=colx(Ki,-Ki*plant.C);
ctrl.C=I.eye(m);
ctrl.D=colx(K1*Nx,-K1);
return ctrl;
}
// co khau I va co khau quan sat
DSS lqgi(const DSS& plant,const Matrix& Q,const Matrix& R, const Vector& qi, const Matrix& S,const Matrix& T)
{
//Bo dieu khien da duoc xay dung trong (3.24)
int n = plant.nX();
int m = plant.nI();
int p = plant.nO();
DSS ctrl(n+p,p+n,m,plant.Ts);
Matrix Nx, Nu, K1(m,n), Ki(m,m), K, X, I(m,m), L,Ad,Bd,Qd(m+n,m+n),Qi(m,m),O(n,m),O1(m,n),J(m,m);
Ad=colx(rowx(J.eye(m),O),rowx(plant.C,plant.A));
Bd=rowx(O,plant.B);
Qi.diag()=qi;
Qd(1,n,1,n)=Q(1,n,1,n);
Qd(n+1,n+m,n+1,m+n)=Qi(1,m,1,m);
(Nx,Nu) = Nxnu(plant);
(X,K) = dare(Ad,Bd,Qd,R);
(X,L) = dare(plant.A.t(),plant.C.t(),S,T);
Ki(1,m,1,m)=K(1,m,1,m);
K1(1,m,1,n)=K(1,m,m+1,m+n);
cout<<"K:"<<K;
cout<<"L:"<<L;
ctrl.A=colx(rowx(I.eye(m),plant.B),rowx(O1,pla nt.A-L.t()*plant.C-plant.B*K1));
ctrl.B=colx(rowx(Ki,plant.B*K1*Nx),rowx(- Ki*plant.C,L.t()*plant.C));
ctrl.C=colx(I.eye(m),-K1);
ctrl.D=colx(K1*Nx,O1);
return ctrl;
}
}
}
5. VÝ dô ch¬ng tr×nh thiÕt kÕ vµ m« pháng
** §Ó thö kÕt qu¶ nhËn ®îc ta x©y dùng 4 file vÝ dô cã tªn
lq_test.cpp
#include "fmol\matrix.h"
#include "fmol\vector.h"
#include "fmol\control\ssmodels.h"
#include
#include "lq.h"
using namespace fmol;
using namespace fmol::control;
void main()
{
Matrix Q(2,2),R(2,2),Nx,Nu;
DSS plant(2,2,2,1);
Q(1,1)=1;
R(1,1)=1;R(2,2)=1;
plant.A(1,1)=1.5;plant.A(1,2)=1;
plant.A(2,1)=-.5;plant.A(2,2)=0;
plant.B(1,1)=1 ;plant.B(1,2)=2;
plant.B(2,1)=0 ;plant.B(2,2)=1.5;
plant.C(1,1)=1 ;plant.C(1,2)=0;
plant.C(2,1)=0 ;plant.C(2,2)=1;
(Nx,Nu)=Nxnu(plant);
cout<<"Nx:"<<Nx;
cout<<"Nu:"<<Nu;
DSS ctrl=lqr(plant,Q,R) ;
int s;
cout<<"nhap so lan tinh\n";
cin>>s;
Vector v(2,1.0),u(2),v1(4,1.0),e;
v1(1)=2;
for(int i=1;i<=s;++i)
{
v=plant.step(u);
e=plant.x;
v1(3,4)=e(1,2);
u=ctrl.step(v1);
cout<<v<<"\t "<<u<<"\n";
}
}
lqg_test.cpp
#include "fmol\matrix.h"
#include "fmol\vector.h"
#include "fmol\control\ssmodels.h"
#include
#include "lq.h"
using namespace fmol;
using namespace fmol::control;
using namespace std;
void main()
{
Matrix Q(2,2),R(2,2),S(2,2),T(2,2),Nx,Nu;
DSS plant(2,2,2,1);
Q(1,1)=1;
R(1,1)=1;R(2,2)=1;
plant.A(1,1)=1.5;plant.A(1,2)=1;
plant.A(2,1)=-.5;plant.A(2,2)=0;
plant.B(1,1)=1 ;plant.B(1,2)=2;
plant.B(2,1)=0 ;plant.B(2,2)=1.5;
plant.C(1,1)=1 ;plant.C(1,2)=0;
plant.C(2,1)=0 ;plant.C(2,2)=1;
S(1,1)=0.5;
T(1,1)=1;T(2,2)=1;
(Nx,Nu)=Nxnu(plant);
cout<<"Nx:"<<Nx;
cout<<"Nu:"<<Nu;
DSS ctrl=lqg(plant,Q,R,S,T) ;
int s;
cout<<"nhap so lan tinh\n";
cin>>s;
Vector v,u(2),v1(4,1.0),e,w(2,0.5);
v1(1)=2;
for(int i=1;i<=s;++i)
{
v=plant.step(u);
e=plant.x;
v1(3,4)=e(1,2);
u=ctrl.step(v1);
cout<<v<<"\t "<<u<<"\n";
}
}
lqri_test.cpp
#include "fmol\matrix.h"
#include "fmol\vector.h"
#include "fmol\control\ssmodels.h"
#include
#include "lq.h"
using namespace fmol;
using namespace fmol::control;
using namespace std;
void main()
{
Matrix Q(2,2),R(2,2),Nx,Nu;
Vector Qi(2);
DSS plant(2,2,2,1);
Qi(1)=1;Qi(2)=1;
Q(1,1)=1;Q(2,2)=1;
R(1,1)=1;R(2,2)=1;
plant.A(1,1)=1.5;plant.A(1,2)=1;
plant.A(2,1)=-0.5;plant.A(2,2)=0;
plant.B(1,1)=1 ;plant.B(1,2)=2;
plant.B(2,1)=0 ;plant.B(2,2)=1.5;
plant.C(1,1)=1 ;plant.C(1,2)=0;
plant.C(2,1)=0 ;plant.C(2,2)=1;
(Nx,Nu)=Nxnu(plant);
cout<
Các file đính kèm theo tài liệu này:
- BC401.doc