15
6

More than 1 year has passed since last update.

MATLAB/Simscape Multibodyでの台車型倒立振子シミュレーション

Last updated at Posted at 2022-12-03

MATLAB/Simulink Advent Calender 2022の4日目になります。
3日目は、@kentaPtさんの「iPhone LiDARで取得した3次元点群を地図上にプロットしてみよう」でした。MATLABで3次元データも扱えるとは、大体の工学分野はMATLABだけでいいのではないか、という気がしてきます。myスマホがiphone SE(第一世代)なので、試せないのが残念です。

背景

MATLABツールボックスの一つであるSimscape Multibodyについて、MathWorksが公開している入門文書は、最終的にリンク機構を例に説明されていました。
しかし、制御工学勢からするとリンク機構はなじみが薄いです。そこで、みんな大好き倒立振子の実装を通して、別視点からの入門記事を提供します。
フライホイール型の倒立振子は、コチラで実装された方がいらっしゃるため、今回は台車型の倒立振子を対象とします。

fig1.png

本記事の対象読者は、MathWorksが公開している次の2つのチュートリアルは実践されたものとしています。

  1. 単純なリンクのモデル化
  2. 単純な振子のモデル化

実装過程

前知識

Simscape MultibodyはZ軸を基準としていることが多いです。例えば、回転接続であるRevolute Jointは、問答無用でZ軸回りの回転となります。そのため、各オブジェクトのどこが何軸かを意識しながら、モデル作成を進めることが上達の近道です。

基本要素への分解

シミュレーション対象を構成要素に分解していきます。オブジェクトは振子と台車になります。また、オブジェクト間はそれぞれ回転軸および直線軸で接続されています。

  • 振子 →台車と回転軸で接続する
  • 台車 →振子と回転軸で接続する、地上と直線軸で接続する
    fig2.png

方針

  • はじめに、振子オブジェクトを作成します。
  • 次に、単純な振子を作成し、重力によって減衰振動することを確認します。
  • 平行して、台車を作成します。
  • 最後に台車と振子を繋げます。

振子を作る

  • smnewコマンドで新しいシミュレーション環境を作成します
    image.png

  • チュートリアルで実施したように、まずは棒を作ります。ここでは、アルミ材料を想定したパラメータ設定をしました。

image.png

  • 今回の振子オブジェクトは、片側しか接続しないため、座標(Rigid Transform)も片端にだけ設定します。
    image.png

  • 位置だけでなく、角度も同じRigid Transformで変換します。Rotatin About設定がFollower Axesの場合は、座標変換前の座標系で3軸を回転します。
    image.png

  • 地面との間を回転軸(Revolute Joint)で接続します。回転軸はZ軸回りでの回転となるので、回転軸と振子の回転とが合うようにRevolute Jointの前後で座標変換②と戻し③をしています。F⇒Bにした場合は、同じブロックでB⇒Fをすれば、結果として元の座標系に戻ります。座標系が見ずらいため、①のブロックで原点からx方向に20mmほどズラしています。

  • 回転軸のダンピング係数(Damping Coefficient)は1e-4 N*m/(deg/s)に設定しました
    image.png
    ※Revolute Jointの向きを逆にしていました。以降のモデルでは修正しています。

image.png

  • この時点でのシミュレーション例
    CartPendforQiita.gif

  • 振子オブジェクトが完成したので、今後のことを考えてサブシステム化します。
    image.png

台車を作る

  • 次は台車単体を実装します。ひとまず振子をコメントアウトします。
    image.png

  • 直線案内(Prismatic Joint)で台車と地面を接続します。Prismatic JointがZ方向のみに移動可能な直線運動を規定するので、Jointの前後に座標変換を加えて、固定座標系のX軸方向の拘束とします。
    image.png
    image.png
    image.png
    image.png
    ※Rigid Transformの設定は、どちらも同じ設定で、方向(接続端子)のみが違います。

  • External Force and Torqueブロックによって、台車に力を加えます。
    ここでは、正弦波状にトルクを加えて、台車が動くことを確認しました。
    image.png
    image.png

CartPendforQiita2.gif

振子と台車をつなげる

台車と振子ができたので、2つを繋げます(実際には振子のコメントアウトを解除します)。正弦波の振幅を大きくしてあげれば、台車の移動に伴って、振子も揺れていることが確認できます。この時に振子の初期角度は0度に設定しておきます。
image.png

制御装置を付与する

  • 制御対象を作れたので、次は状態フィードバック系を実装します。状態量として、台車の位置と速度、振子の角度と角速度をフィードバックします。

  • Prismatic Jointの設定でSensingのPositionとVelocityを有効化します。
    image.png

  • 振子のRevolute Jointも同様にSensing設定でPositionとVelocityを設定します。
    image.png

  • 振子のブロックから、角度と角速度を外部に出力します。
    image.png

  • 状態フィードバック制御器をSimulinkで作ります。振子角度は、鉛直下向きが0radなので、鉛直上向きが0radとなるようにΠ[rad]だけオフセットしています(Revolute Jointの前後の座標変換をうまくやれば不要になる)。
    image.png

制御器を調整する

  • シミュレーション結果やグラフを見ながらゲインを調整します。
  1. 振子角度ゲイン
  2. 振子角速度ゲイン
  3. 台車位置のゲイン
  4. 台車速度のゲイン
  • 調整したゲインの一例と実際の制御の様子は以下の通りです
    image.png

CartPendforQiita3.gif

※ソルバー設定は、チュートリアルを参考に以下の通りに設定
image.png

感想

Simscape Multibodyは座標系の概念に慣れ親しめれば、状態方程式や数式モデルレスでシミュレーション環境を構築できます。さらにシミュレーション結果の動画をすぐに得られる点も素晴らしいです。

当初は、参考文献[2]に記載の資料を読んで、「正統的技術系記事」を書きたいとは思いました。が、残念ながら、ジャンクフード群に分類される記事になってしまいました。

MATLAB/Simulink Advent Calender 2022の25日に、川田先生も倒立振子ネタを投稿されるようで、つよつよな方より先に投稿できて助かりました。

参考文献

[1]Simscape Multibody
[2]テクノロジーマップ、技術カタログの在り方について

15
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
15
6