バックナンバーはこちら。
https://www.simulationroom999.com/blog/model-based-of-minimum-2-backnumber/
はじめに
前回は、時間軸、Ramp関数、入力用行列、入力オブジェクトの生成まで実施。
シミュレーションを実施する上での必要な準備が整った状態。
今回は実施にFMUを駆動させてシミュレーションを実施するところ。
登場人物
博識フクロウのフクさん
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="指差しフクロウ"
イラストACにて公開の「kino_k」さんのイラストを使用しています。
https://www.ac-illust.com/main/profile.php?id=iKciwKA9&area=1
エンジニア歴8年の太郎くん
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="技術者太郎"
イラストACにて公開の「しのみ」さんのイラストを使用しています。
https://www.ac-illust.com/main/profile.php?id=uCKphAW2&area=1
シミュレーション
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
前回のでシミュレーションの前準備が揃ったから
今回はついにシミュレーション実施だね。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
そうだね。
まぁやることはシミュレーション用の関数を呼び出すだけだ。
res = model.simulate(start_time=0.0,final_time=2.0, input=input_object)
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
前回作った、入力オブジェクトをここで渡すんだね。
シミュレーション時間も開始を0秒、終了を2秒か。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
そうそう。
これでシミュレーションとしては完了だ。
シミュレーション結果の取得
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
で、シミュレーションの結果はどう取得するの?
戻り値でresってのは受け取ってるけど?
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
そのresの中に連想配列で格納されてる。
取得方法としては以下になる。
voltage = res['voltage']
current = res['current']
speed = res['speed']
loadTorqueStep_tau = res['loadTorqueStep.tau']
t = res['time']
data:image/s3,"s3://crabby-images/0f4a3/0f4a3412b4e6b4c485d018cd2f8825371049af7c" alt="太郎くん"
ほう。
パラメータ名をそのまま指定すれば取得できるのか!
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
FMILibraryの時は一旦変数オブジェクトを取得して、
そこからvalueReferenceがどうのってあったけど、
そこらへんは要らないんだね。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
そうだね。
そこら辺はかなり扱いが楽になっていると言える。
シミュレーション結果の表示
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
次はグラフにするんだろうけど、
これは普通にmatplotlibを使えばいいんだろうね。
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
こんな感じかな。
plt.plot(t, voltage, label="voltage")
plt.plot(t, current, label="current")
plt.plot(t, speed, label="speed")
plt.plot(t, loadTorqueStep_tau, label="loadTorqueStep.tau")
plt.legend(loc='best')
plt.xlabel('time [sec]')
plt.grid(which='both')
plt.show()
data:image/s3,"s3://crabby-images/2e5ef/2e5ef1a2a154cdb66566de4434a08eca0b5a22e7" alt="フクさん"
うん。
それでOKだろう。
まとめ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まとめだよ。
- シミュレーション実施。
- 開始時刻、終了時刻、入力オブジェクトを渡すことで実施可能。
- シミュレーション結果取得。
- simulate関数の戻り値が連想配列になっている。
- voltage = res[‘voltage’]のような指定方法。
- シミュレーション結果のグラフ表示。
- matplotlibでプロットするのみ。
バックナンバーはこちら。
コメント