メインコンテンツ

pid

並列形式 PID コントローラー

    説明

    並列形式の比例-積分-微分 (PID) コントローラー モデル オブジェクトを作成したり、動的システム モデルを並列 PID コントローラー形式に変換するには、pid を使用します。

    pid コントローラー モデル オブジェクトは、並列形式 PID コントローラーを連続時間または離散時間で表現できます。

    • 連続時間 — C=Kp+Kis+KdsTfs+1

    • 離散時間 — C=Kp+KiIF(z)+KdTf+DF(z)

    ここで、以下となります。

    • Kp は比例ゲインです。

    • Ki は積分ゲインです。

    • Kd は微分ゲインです。

    • Tf は 1 次微分フィルター時定数です。

    • IF(z) は離散時間コントローラーで積分を計算するための積分手法です。

    • DF(z) は離散時間コントローラーで微分フィルターを計算するための積分手法です。

    このオブジェクトを、制御アーキテクチャのプラント、アクチュエータ、センサーなど、他のコンポーネントと組み合わせて、制御システムを表すことができます。詳細については、モデル オブジェクトでの制御システム モデリングを参照してください。

    コントローラーのパラメーターを直接指定するか、別のタイプのモデル (伝達関数モデル tf など) を PID コントローラー形式に変換して、PID コントローラー モデル オブジェクトを作成できます。

    pid を使用して、一般化状態空間 (genss) モデルや不確かさをもつ状態空間 (uss (Robust Control Toolbox)) モデルを作成することもできます。

    作成

    pid コントローラー モデルは次のいずれかの方法で取得できます。

    • 関数 pid を使用してモデルを作成する。

    • 関数 pidtune を使用して、プラント モデル用に PID コントローラーを調整する。関数 pidtune の引数 type で 1-DOF PID コントローラー タイプを指定して、並列形式 PID コントローラーを取得する。以下に例を示します。

      sys = zpk([],[-1 -1 -1],1);
      C = pidtune(sys,'PID');
    • 以下を使用して、プラント モデル用に PID コントローラーを対話的に調整する:

    説明

    C = pid(Kp,Ki,Kd,Tf) は、連続時間並列形式 PID コントローラー モデルを作成し、KpKiKdTf の各プロパティを設定します。残りのプロパティは既定値をもちます。

    C = pid(Kp,Ki,Kd,Tf,Ts) は、サンプル時間 Ts をもつ離散時間 PID コントローラー モデルを作成します。

    C = pid(Kp) は、連続時間の比例 (P) コントローラーを作成します。

    C = pid(Kp,Ki) は、比例および積分 (PI) コントローラーを作成します。

    C = pid(Kp,Ki,Kd) は、比例、積分、および微分 (PID) コントローラーを作成します。

    C = pid(___,Name,Value) は、前述の入力引数の任意の組み合わせについて引数 Name,Value を 1 つ以上使用して指定される、pid コントローラー オブジェクトのプロパティを設定します。

    C = pid は、既定のプロパティ値をもつコントローラー オブジェクトを作成します。コントローラー モデルのプロパティを変更するには、ドット表記を使用します。

    C = pid(sys) は、動的システム モデル sys を並列形式 pid コントローラー オブジェクトに変換します。

    入力引数

    すべて展開する

    比例ゲイン。有限の実数値または調整可能なオブジェクトとして指定します。

    • pid コントローラー オブジェクトを作成するには、有限の実数スカラー値を使用します。

    • pid コントローラー オブジェクトの配列を作成するには、有限の実数値の配列を使用します。

    • 調整可能なコントローラー モデルを作成するには、調整可能なパラメーター (realp) または一般化行列 (genmat) を使用します。

    • 調整可能なゲインスケジュール コントローラー モデルを作成するには、tunableSurface を使用して作成された調整可能な曲面を使用します。

    積分ゲイン。有限の実数値または調整可能なオブジェクトとして指定します。

    • pid コントローラー オブジェクトを作成するには、有限の実数スカラー値を使用します。

    • pid コントローラー オブジェクトの配列を作成するには、有限の実数値の配列を使用します。

    • 調整可能なコントローラー モデルを作成するには、調整可能なパラメーター (realp) または一般化行列 (genmat) を使用します。

    • 調整可能なゲインスケジュール コントローラー モデルを作成するには、tunableSurface を使用して作成された調整可能な曲面を使用します。

    微分ゲイン。有限の実数値または調整可能なオブジェクトとして指定します。

    • pid コントローラー オブジェクトを作成するには、有限の実数スカラー値を使用します。

    • pid コントローラー オブジェクトの配列を作成するには、有限の実数値の配列を使用します。

    • 調整可能なコントローラー モデルを作成するには、調整可能なパラメーター (realp) または一般化行列 (genmat) を使用します。

    • 調整可能なゲインスケジュール コントローラー モデルを作成するには、tunableSurface を使用して作成された調整可能な曲面を使用します。

    1 次微分フィルターの時定数。有限の実数値または調整可能なオブジェクトとして指定します。

    • pid コントローラー オブジェクトを作成するには、有限の実数スカラー値を使用します。

    • pid コントローラー オブジェクトの配列を作成するには、有限の実数値の配列を使用します。

    • 調整可能なコントローラー モデルを作成するには、調整可能なパラメーター (realp) または一般化行列 (genmat) を使用します。

    • 調整可能なゲインスケジュール コントローラー モデルを作成するには、tunableSurface を使用して作成された調整可能な曲面を使用します。

    サンプル時間。以下として指定します。

    • 0 (連続時間システムの場合)。

    • 離散時間システムのサンプリング周期を表す正のスカラー。TsTimeUnit プロパティによって指定される時間単位で指定します。

    pid コントローラーの配列では、すべてのコントローラーに同じ Ts が適用されます。

    PID コントローラー モデルは未指定のサンプル時間 (Ts = -1) をサポートしません。

    メモ

    Ts を変更してもモデルの離散化やリサンプリングは行われません。連続時間表現と離散時間表現の間の変換を行うには、c2dd2c を使用します。離散時間システムのサンプル時間を変更するには、d2d を使用します。

    離散化されたコントローラーの離散積分器の式は、次の表に示すように、使用する c2d 離散化手法に依存します。

    c2d 離散化手法IFormulaDFormula
    'zoh'ForwardEulerForwardEuler
    'foh'TrapezoidalTrapezoidal
    'tustin'TrapezoidalTrapezoidal
    'impulse'ForwardEulerForwardEuler
    'matched'ForwardEulerForwardEuler

    c2d 離散化手法の詳細については、c2d を参照してください。

    他の離散積分器の式が必要な場合は、TsIFormula、および DFormula を目標値に直接設定してコントローラーを離散化することができます。ただし、この方法では離散化されたコントローラーの新しいゲインとフィルター定数値は計算されません。したがって、この方法で得られる連続時間 PID コントローラーと離散時間 PID コントローラー間の一致は、c2d を使用する場合より劣っている可能性があります。

    動的システム。SISO 動的システム モデル、または SISO 動的システム モデルの配列として指定します。使用できる動的システムには次のようなものがあります。

    • tf モデル、zpk モデル、ss モデル、pidstd モデルなどの連続時間または離散時間の数値 LTI モデル。

    • genssuss (Robust Control Toolbox) モデルなどの一般化された、あるいは不確かさをもつ LTI モデル。

      結果の PID コントローラーでは以下が想定されます。

      • 調整可能な制御設計ブロックについては調整可能なコンポーネントの現在値。

      • 不確かさをもつ制御設計ブロックについてはモデルのノミナル値。

    • idtf (System Identification Toolbox)idss (System Identification Toolbox)idproc (System Identification Toolbox)idpoly (System Identification Toolbox)idgrey (System Identification Toolbox) モデルなどの、同定された LTI モデル。

    出力引数

    すべて展開する

    PID コントローラー モデル。以下として返されます。

    • すべてのゲインが数値をもつ場合は、並列形式 PID コントローラー (pid) モデル オブジェクト。ゲインが数値配列の場合、Cpid コントローラー オブジェクトの配列です。

    • 入力引数 numerator または denominatorrealp パラメーターまたは一般化行列 (genmat) などの調整可能なパラメーターが含まれる場合は、一般化状態空間モデル (genss) オブジェクト。

    • 入力引数 numerator または denominator に不確かさをもつパラメーターが含まれる場合は、不確かさをもつ状態空間モデル (uss) オブジェクト。不確かさをもつモデルを使用するには Robust Control Toolbox™ ソフトウェアが必要です。

    プロパティ

    すべて展開する

    PID コントローラーの係数。スカラーとして指定します。pid コントローラー オブジェクトまたはオブジェクトの配列を作成するときは、これらの係数を入力引数 KpKiKd、および Tf で指定します。

    離散時間 pid コントローラーの積分器に使用する離散積分器の式 IF(z):

    C=Kp+KiIF(z)+KdTf+DF(z).

    IFormula を以下のいずれかとして指定します。

    • 'ForwardEuler'IF(z) = Tsz1.

      この方程式は、コントローラーの帯域幅と比較してナイキスト制限が大きくなるような、小さいサンプル時間に最適です。大きいサンプル時間で ForwardEuler 式を使用すると、連続時間で安定しているシステムを離散化する場合でも不安定となることがあります。

    • 'BackwardEuler'IF(z) = Tszz1.

      BackwardEuler 式の利点は、この式を使用して安定した連続時間システムを離散化すると、常に安定した離散時間結果が得られることです。

    • 'Trapezoidal'IF(z) = Ts2z+1z1.

      Trapezoidal 式の利点は、この式を使用して安定した連続時間システムを離散化すると、常に安定した離散時間結果が得られることです。使用可能なすべての積分式の中で、離散システムと対応する連続時間システムの周波数領域プロパティが最も近くなるのは Trapezoidal 式です。

    C が連続時間コントローラーの場合、IFormula'' です。

    離散時間 pid コントローラーの微分フィルターに使用する離散積分器の式 DF(z):

    C=Kp+KiIF(z)+KdTf+DF(z).

    DFormula を以下のいずれかとして指定します。

    • 'ForwardEuler'DF(z) = Tsz1.

      この方程式は、コントローラーの帯域幅と比較してナイキスト制限が大きくなるような、小さいサンプル時間に最適です。大きいサンプル時間で ForwardEuler 式を使用すると、連続時間で安定しているシステムを離散化する場合でも不安定となることがあります。

    • 'BackwardEuler'DF(z) = Tszz1.

      BackwardEuler 式の利点は、この式を使用して安定した連続時間システムを離散化すると、常に安定した離散時間結果が得られることです。

    • 'Trapezoidal'DF(z) = Ts2z+1z1.

      Trapezoidal 式の利点は、この式を使用して安定した連続時間システムを離散化すると、常に安定した離散時間結果が得られることです。使用可能なすべての積分式の中で、離散システムと対応する連続時間システムの周波数領域プロパティが最も近くなるのは Trapezoidal 式です。

    DFormulaTrapezoidal 値は、微分フィルターのない pid コントローラー (Tf = 0) には利用できません。

    C が連続時間コントローラーの場合、DFormula'' です。

    この プロパティ は読み取り専用です。

    システム入力のむだ時間。InputDelaypid コントローラー オブジェクトに対しては常に 0 です。

    この プロパティ は読み取り専用です。

    システム出力のむだ時間。OutputDelaypid コントローラー オブジェクトに対しては常に 0 です。

    サンプル時間。以下として指定します。

    • 0 (連続時間システムの場合)。

    • 離散時間システムのサンプリング周期を表す正のスカラー。TsTimeUnit プロパティで指定された時間単位で指定します。

    pid が PID コントローラーの配列である場合、すべてのコントローラーに同じ Ts が適用されます。

    時間変数の単位。次のいずれかとして指定します。

    • 'nanoseconds'

    • 'microseconds'

    • 'milliseconds'

    • 'seconds'

    • 'minutes'

    • 'hours'

    • 'days'

    • 'weeks'

    • 'months'

    • 'years'

    TimeUnit の変更は他のプロパティには影響しませんが、システム全体の動作が変わります。chgTimeUnit を使用して、システム動作を変更せずに時間単位を変換します。

    入力チャネル名。次のいずれかとして指定します。

    • 文字ベクトル

    • '' (名前を指定しない)

    あるいは、次のようにして、コントローラー モデル C の入力に名前 error を割り当てます。

    C.InputName = 'error';

    省略形表記 u を使用して、InputName プロパティを参照できます。たとえば、C.uC.InputName と同じです。

    InputName の使用目的は次のとおりです。

    • モデル表示とプロット上のチャネルの識別

    • モデル相互接続時における接続点の指定

    入力チャネル単位。以下のいずれかとして指定します。

    • 文字ベクトル。

    • '' (単位を指定しない)。

    InputUnit を使用して入力信号の単位を指定します。InputUnit はシステムの動作に影響しません。

    たとえば、次のようにして、濃度単位 'mol/m^3' をコントローラー モデル C の入力に割り当てます。

    C.InputUnit = 'mol/m^3';

    入力チャネル グループ。このプロパティは PID コントローラー モデルには必要ありません。

    既定では、InputGroup はフィールドのない構造体です。

    出力チャネル名。次のいずれかとして指定します。

    • 文字ベクトル。

    • '' (名前を指定しない)。

    たとえば、次のようにして、名前 'control' をコントローラー モデル C の出力に割り当てます。

    C.OutputName = 'control';

    省略形表記 y を使用して OutputName プロパティを参照することもできます。たとえば、C.yC.OutputName と同じです。

    OutputName の使用目的は次のとおりです。

    • モデル表示とプロット上のチャネルの識別

    • モデル相互接続時における接続点の指定

    出力チャネル単位。次のいずれかとして指定されます。

    • 文字ベクトル。

    • '' (単位を指定しない)。

    OutputUnit を使用して出力信号の単位を指定します。OutputUnit はシステムの動作に影響しません。

    たとえば、次のようにして、単位 'volts' をコントローラー モデル C の出力に割り当てます。

    C.OutputUnit = 'volts';

    出力チャネル グループ。このプロパティは PID コントローラー モデルには必要ありません。

    既定では、OutputGroup はフィールドのない構造体です。

    システムに関連付けるユーザー指定のテキスト。文字ベクトルまたは文字ベクトルの cell 配列として指定します。たとえば、'System is MIMO' とします。

    システムに関連付けるユーザー指定のデータ。任意の MATLAB データ型として指定します。

    システム名。文字ベクトルとして指定します。たとえば、'system_1' とします。

    モデル配列のサンプリング グリッド。構造体配列として指定します。

    SamplingGrid を使用して、モデル配列の各モデルに関連付けられている変数値を追跡します。これには同定された線形時不変 (IDLTI) モデル配列も含まれます。

    構造体のフィールド名をサンプリング変数の名前に設定します。フィールドの値を、配列内の各モデルに関連付けられているサンプリングされた変数の値に設定します。すべてのサンプリング変数は数値スカラーでなければならず、サンプル値のすべての配列はモデル配列の次元と一致しなければなりません。

    たとえば、t = 0:10 の各時点で線形時変システムのスナップショットを記録することにより、線形モデルの 11 行 1 列の配列 sysarr を作成することができます。次のコードは線形モデルでの時間サンプルを格納します。

     sysarr.SamplingGrid = struct('time',0:10)

    同様に、2 つの変数 zetaw を個別にサンプリングすることにより、6 行 9 列のモデル配列 M を作成できます。次のコードは (zeta,w) の値を M にマッピングします。

    [zeta,w] = ndgrid(<6 values of zeta>,<9 values of w>)
    M.SamplingGrid = struct('zeta',zeta,'w',w)

    M を表示する際、配列の各エントリは対応する zetaw の値を取り込みます。

    M
    M(:,:,1,1) [zeta=0.3, w=5] =
     
            25
      --------------
      s^2 + 3 s + 25
     
    
    M(:,:,2,1) [zeta=0.35, w=5] =
     
             25
      ----------------
      s^2 + 3.5 s + 25
     
    ...

    複数のパラメーター値または操作点で Simulink® モデルを線形化することにより生成されたモデル配列の場合、SamplingGrid には配列の各エントリに対応する変数値が自動的に入力されます。たとえば、Simulink Control Design™ のコマンド linearize (Simulink Control Design) および slLinearizer (Simulink Control Design) により、SamplingGrid が自動的に入力されます。

    既定では、SamplingGrid はフィールドのない構造体です。

    オブジェクト関数

    以下のリストには、pid モデルで使用できる関数の代表的なサブセットが含まれています。一般に、動的システム モデルに適用できる関数はすべて、pid オブジェクトに適用できます。

    すべて展開する

    step動的システムのステップ応答
    impulse動的システムのインパルス応答プロット、インパルス応答データ
    lsim任意の入力に対する動的システムの時間応答シミュレーション データを計算
    bode動的システムのボード周波数応答
    nyquist動的システムのナイキスト応答
    nichols動的システムのニコルス応答
    bandwidth周波数応答帯域幅
    pole動的システムの極
    zeroSISO 動的システムの零点とゲイン
    pzplot動的システムの極-零点配置図のプロット
    marginゲイン余裕、位相余裕、および交差周波数
    zpk零点-極-ゲイン モデル
    ss状態空間モデル
    c2d連続時間から離散時間へモデルを変換
    d2c離散時間から連続時間へモデルを変換
    d2d離散時間モデルのリサンプリング
    feedback複数のモデルのフィードバック接続
    connect動的システムのブロック線図相互接続
    series2 つのモデルの直列接続
    parallel2 つのモデルの並列接続
    pidtune線形プラント モデルのための PID 調整アルゴリズム
    rlocus動的システムの根軌跡
    piddata並列形式 PID コントローラーのアクセス係数
    make2DOF1-DOF PID コントローラーの 2-DOF コントローラーへの変換
    pidTunerPID 調整のための PID 調整器を開く
    tunablePID調整可能な PID コントローラー

    すべて折りたたむ

    比例ゲインと積分ゲイン、および微分項のフィルターをもつ連続時間コントローラーを作成します。これを行うには、積分ゲインを 0 に設定します。他のゲインとフィルター時定数を望ましい値に設定します。

    Kp = 1;
    Ki = 0;   % No integrator
    Kd = 3;
    Tf = 0.5;
    C = pid(Kp,Ki,Kd,Tf)
    C =
     
                   s    
      Kp + Kd * --------
                 Tf*s+1 
    
      with Kp = 1, Kd = 3, Tf = 0.5
     
    Continuous-time PDF controller in parallel form.
    Model Properties
    

    表示では、コントローラー タイプ、式およびパラメーター値が示され、コントローラーに積分項のないことが確認されます。

    台形則による離散化式を使用し、離散時間 PI コントローラーを作成します。

    離散時間 PI コントローラーを作成するには、Name,Value 構文を使用して Ts の値と離散化式を設定します。

    C1 = pid(5,2.4,'Ts',0.1,'IFormula','Trapezoidal')    % Ts = 0.1s
    C1 =
     
                Ts*(z+1)
      Kp + Ki * --------
                2*(z-1) 
    
      with Kp = 5, Ki = 2.4, Ts = 0.1
     
    Sample time: 0.1 seconds
    Discrete-time PI controller in parallel form.
    Model Properties
    

    あるいは、4 つの PID パラメーター KpKiKdTf すべての後に 5 番目の入力引数として Ts を指定することで、同じ離散時間コントローラーを作成できます。必要なのは PI コントローラーのみであるため、KdTf を 0 に設定します。

    C2 = pid(5,2.4,0,0,0.1,'IFormula','Trapezoidal')
    C2 =
     
                Ts*(z+1)
      Kp + Ki * --------
                2*(z-1) 
    
      with Kp = 5, Ki = 2.4, Ts = 0.1
     
    Sample time: 0.1 seconds
    Discrete-time PI controller in parallel form.
    Model Properties
    

    表示には、C1C2 が同じであることが示されます。

    PID コントローラーを作成する場合は、動的システムのプロパティ InputName および OutputName を設定します。これが有用なのは、たとえば、PID コントローラーを他の動的システム モデルと connect コマンドを使用して相互接続する場合などです。

    C = pid(1,2,3,'InputName','e','OutputName','u')
    C =
     
                 1          
      Kp + Ki * --- + Kd * s
                 s          
    
      with Kp = 1, Ki = 2, Kd = 3
     
    Continuous-time PID controller in parallel form.
    Model Properties
    

    表示に PID コントローラーの入力名と出力名は示されませんが、プロパティ値を調べることはできます。たとえば、コントローラーの入力名を確認します。

    C.InputName
    ans = 1×1 cell array
        {'e'}
    
    

    配列の行については 1 ~ 2 の範囲の比例ゲインをもち、列については 5 ~ 9 の範囲の積分ゲインをもつ PI コントローラーの 2 行 3 列のグリッドを作成します。

    PID コントローラーの配列を作成するには、ゲインを表す配列から開始します。

    Kp = [1 1 1;2 2 2];
    Ki = [5:2:9;5:2:9];

    これらの配列を pid コマンドに渡すと、コマンドはその配列を返します。

    pi_array = pid(Kp,Ki,'Ts',0.1,'IFormula','BackwardEuler');
    size(pi_array)
    2x3 array of PID controller.
    Each PID has 1 output and 1 input.
    

    あるいは、stack コマンドを使用して PID コントローラーの配列を作成します。

    C = pid(1,5,0.1)           % PID controller
    C =
     
                 1          
      Kp + Ki * --- + Kd * s
                 s          
    
      with Kp = 1, Ki = 5, Kd = 0.1
     
    Continuous-time PID controller in parallel form.
    Model Properties
    
    Cf = pid(1,5,0.1,0.5)      % PID controller with filter
    Cf =
     
                 1            s    
      Kp + Ki * --- + Kd * --------
                 s          Tf*s+1 
    
      with Kp = 1, Ki = 5, Kd = 0.1, Tf = 0.5
     
    Continuous-time PIDF controller in parallel form.
    Model Properties
    
    pid_array = stack(2,C,Cf); % stack along 2nd array dimension

    これらのコマンドは、コントローラーの 1 行 2 列の配列を返します。

    size(pid_array)
    1x2 array of PID controller.
    Each PID has 1 output and 1 input.
    

    配列内の PID コントローラーはすべて、同じサンプル時間、離散積分器の式、および動的システムのプロパティ (InputNameOutputName など) をもっていなければなりません。

    標準形式の pidstd コントローラーを並列形式に変換します。

    標準 PID 形式では、コントローラーの動作は全体的な比例ゲイン Kp、積分時定数 Ti と微分時定数 Td、そしてフィルター除数 N によって表現されます。pid コマンドを使用して、任意の標準形式コントローラーを並列形式に変換できます。たとえば、次の標準形式コントローラーを考えます。

    Kp = 2;
    Ti = 3;
    Td = 4;
    N = 50;
    C_std = pidstd(Kp,Ti,Td,N)
    C_std =
     
                 1      1              s      
      Kp * (1 + ---- * --- + Td * ------------)
                 Ti     s          (Td/N)*s+1 
    
      with Kp = 2, Ti = 3, Td = 4, N = 50
     
    Continuous-time PIDF controller in standard form
    Model Properties
    

    pid を使用してこのコントローラーを並列形式に変換します。

    C_par = pid(C_std)
    C_par =
     
                 1            s    
      Kp + Ki * --- + Kd * --------
                 s          Tf*s+1 
    
      with Kp = 2, Ki = 0.667, Kd = 8, Tf = 0.08
     
    Continuous-time PIDF controller in parallel form.
    Model Properties
    

    PID コントローラーを表す連続時間動的システムを、並列 pid 形式に変換します。

    次の動的システムには積分器と 2 つの 0 があり、PID コントローラーと等価です。

    H(s)=3(s+1)(s+2)s.

    Hzpk モデルを作成します。次に pid コマンドを使用して、PID ゲイン KpKiKd によって H を取得します。

    H = zpk([-1,-2],0,3);
    C = pid(H)
    C =
     
                 1          
      Kp + Ki * --- + Kd * s
                 s          
    
      with Kp = 9, Ki = 6, Kd = 3
     
    Continuous-time PID controller in parallel form.
    Model Properties
    

    微分フィルターをもつ PID コントローラーを表す離散時間動的システムを、並列 pid 形式に変換します。

    PIDF コントローラーを表す離散時間 zpk モデル (2 つの零点と、z = 1 の積分器極を含む 2 つの極) を作成します。

    sys = zpk([-0.5,-0.6],[1 -0.2],3,'Ts',0.1);

    sys を PID 形式に変換する際の結果は、変換でどの離散積分器の式を指定するかに依存します。たとえば、既定の ForwardEuler を積分器と微分の両方で使用したとします。

    Cfe = pid(sys)
    Cfe =
     
                  Ts               1     
      Kp + Ki * ------ + Kd * -----------
                  z-1         Tf+Ts/(z-1)
    
      with Kp = 2.75, Ki = 60, Kd = 0.0208, Tf = 0.0833, Ts = 0.1
     
    Sample time: 0.1 seconds
    Discrete-time PIDF controller in parallel form.
    Model Properties
    

    ここで、Trapezoidal 式を使用して変換を行います。

    Ctrap = pid(sys,'IFormula','Trapezoidal','DFormula','Trapezoidal')
    Ctrap =
     
                Ts*(z+1)                 1         
      Kp + Ki * -------- + Kd * -------------------
                2*(z-1)         Tf+Ts/2*(z+1)/(z-1)
    
      with Kp = -0.25, Ki = 60, Kd = 0.0208, Tf = 0.0333, Ts = 0.1
     
    Sample time: 0.1 seconds
    Discrete-time PIDF controller in parallel form.
    Model Properties
    

    表示には、結果として得られる係数値と関数形式に相違があることが示されます。

    この特定の動的システムでは、微分フィルターに BackwardEuler 式を使用して sys を並列 PID 形式で書き込むことはできません。これを行うと Tf < 0 になりますが、これは許可されません。この場合、pid はエラーを返します。

    連続時間 PID コントローラーを離散化し、積分フィルター式と微分フィルター式を設定します。

    連続時間コントローラーを作成し、c2d コマンドのゼロ次ホールド メソッドを使用してこれを離散化します。

    Ccon = pid(1,2,3,4);  % continuous-time PIDF controller
    Cdis1 = c2d(Ccon,0.1,'zoh')
    Cdis1 =
     
                  Ts               1     
      Kp + Ki * ------ + Kd * -----------
                  z-1         Tf+Ts/(z-1)
    
      with Kp = 1, Ki = 2, Kd = 3.04, Tf = 4.05, Ts = 0.1
     
    Sample time: 0.1 seconds
    Discrete-time PIDF controller in parallel form.
    Model Properties
    

    表示には、c2d が離散時間コントローラーの新しい PID ゲインを計算することが示されます。

    離散化されたコントローラーの離散積分器の式は、c2d 離散化手法に依存します。zoh メソッドでは、IFormulaDFormula のどちらも ForwardEuler です。

    Cdis1.IFormula
    ans = 
    'ForwardEuler'
    
    Cdis1.DFormula
    ans = 
    'ForwardEuler'
    

    c2d によって返された式の中から異なるものを複数使用する場合、コントローラーの TsIFormula、および DFormula プロパティを望ましい値に直接設定できます。

    Cdis2 = Ccon;
    Cdis2.Ts = 0.1; 
    Cdis2.IFormula = 'BackwardEuler';
    Cdis2.DFormula = 'BackwardEuler';

    ただし、これらのコマンドは、離散化されたコントローラーの新しい PID ゲインは計算しません。これを確認するには、Cdis2 を調べ、その係数を Ccon および Cdis1 と比較します。

    Cdis2
    Cdis2 =
     
                 Ts*z               1      
      Kp + Ki * ------ + Kd * -------------
                  z-1         Tf+Ts*z/(z-1)
    
      with Kp = 1, Ki = 2, Kd = 3, Tf = 4, Ts = 0.1
     
    Sample time: 0.1 seconds
    Discrete-time PIDF controller in parallel form.
    Model Properties
    

    バージョン履歴

    R2010b で導入