Main Content

このページの内容は最新ではありません。最新版の英語を参照するには、ここをクリックします。

PI コントローラーを使用したカスケード制御システムの設計

この例では、pidtune コマンドを使って、2 つの PI コントローラーをもつカスケード制御ループを設計する方法を示します。

カスケード制御の紹介

カスケード制御は主に、プラントの他の部分へ伝播する前に外乱の抑制を高速に行うために使用します。非常にシンプルなカスケード制御システムには、次のブロック線図に示すように、2 つの制御ループ (内側および外側) が含まれています。

外側のループのコントローラー C1 は、内側のループの設定値を設定することによって主要制御変数 y1 を調節するプライマリ コントローラーです。内側のループのコントローラー C2 は、P1 に伝播する前にローカルで外乱 d2 を抑圧するセカンダリ コントローラーです。カスケード制御システムが正しく動作するには、内側のループが外側のループより高速に応答しなければなりません。

この例では、1 つの PI コントローラーで単一ループ制御システムを、また、2 つの PI コントローラーでカスケード制御システムを設計します。2 つの制御システムの応答を、設定値追従と外乱の抑制において比較します。

プラント

この例では、内側のループのプラント P2 は、以下のようになります。

P2(s)=3s+2

外側のループのプラント P1 は、以下のようになります。

P1(s)=10(s+1)3

P2 = zpk([],-2,3);
P1 = zpk([],[-1 -1 -1],10);

PI コントローラーを使用した単一ループ制御システムの設計

pidtune コマンドを使用して、プラントモデル P = P1 * P2 全体に対する標準型 PI コントローラーを設計します。

適切な開ループ幅は 0.2 rad/s で、これは約 10 秒の応答時間に相当します。

% The plant model is P = P1*P2
P = P1*P2; 
% Use a PID or PIDSTD object to define the desired controller structure
C = pidstd(1,1);
% Tune PI controller for target bandwidth is 0.2 rad/s
C = pidtune(P,C,0.2);
C
C =
 
             1      1 
  Kp * (1 + ---- * ---)
             Ti     s 

  with Kp = 0.0119, Ti = 0.849
 
Continuous-time PI controller in standard form

2 つの PI コントローラーを使用したカスケード制御システムの設計

内側のループのコントローラー C2 を設計する最適な方法としては、まず内側のループを閉じた状態で外側のループのコントローラー C1 を設計します。この例では、内側のループ幅には、目的とする外側のループ幅の 10 倍である 2 rad/s を選択します。効果的なカスケード制御システムにするには、内側のループが外側のループより高速に応答することが必要です。

開ループの帯域幅を 2 rad/s にして、内側のループのコントローラー C2 を調整します。

C2 = pidtune(P2,pidstd(1,1),2);
C2
C2 =
 
             1      1 
  Kp * (1 + ---- * ---)
             Ti     s 

  with Kp = 0.244, Ti = 0.134
 
Continuous-time PI controller in standard form

同じ帯域幅で単一ループ システムとして外側のループのコントローラー C1 を調整します。

% Inner loop system when the control loop is closed first
clsys = feedback(P2*C2,1); 
% Plant seen by the outer loop controller C1 is clsys*P1
C1 = pidtune(clsys*P1,pidstd(1,1),0.2);
C1
C1 =
 
             1      1 
  Kp * (1 + ---- * ---)
             Ti     s 

  with Kp = 0.015, Ti = 0.716
 
Continuous-time PI controller in standard form

性能の比較

まず、両方の制御システムについて、ステップ設定値追従応答をプロットします。

% single loop system for reference tracking 
sys1 = feedback(P*C,1);
sys1.Name = 'Single Loop';
% cascade system for reference tracking
sys2 = feedback(clsys*P1*C1,1); 
sys2.Name = 'Cascade';
% plot step response
figure;
step(sys1,'r',sys2,'b')
legend('show','location','southeast')
title('Reference Tracking')

Figure contains an axes object. The axes object contains 2 objects of type line. These objects represent Single Loop, Cascade.

次に、両方の制御システムについて、d2 のステップ外乱の抑制応答をプロットします。

% single loop system for rejecting d2
sysd1 = feedback(P1,P2*C); 
sysd1.Name = 'Single Loop';
% cascade system for rejecting d2
sysd2 = P1/(1+P2*C2+P2*P1*C1*C2); 
sysd2.Name = 'Cascade';
% plot step response
figure;
step(sysd1,'r',sysd2,'b')
legend('show')
title('Disturbance Rejection')

Figure contains an axes object. The axes object contains 2 objects of type line. These objects represent Single Loop, Cascade.

2 つの応答プロットから、カスケード制御システムは外乱 d2 に対する抑圧性能がより優れており、一方、設定値の追従性能についてはほぼ同等であると結論付けられます。

参考

|

関連するトピック