CAN

事例

【XCP】最小構成のMBD事例 第2章 その222【仮想HILS⑤】

構成がややこしいことになってきたので仮想ECUと仮想HILSの実験構成を再確認。ネットワーク構成と論理的構成を確認。論理的構成はModelicaモデルベースでシンプルだが、ネットワーク構成は各信号をCANやXCPに変えてるため複雑化。このようにノードを分割しておくと部分的に実物に差し替えるなどがし易くなる。
事例

【XCP】最小構成のMBD事例 第2章 その221【仮想HILS④】

ついに仮想HILSのPythonコード完成。基本的には前回までの修正内容を盛り込んだだけ。指令値取得用のCANバス初期化の位置を先頭から実処理の前に移動。XCP関連のCANフレームがFIFOに詰まれてしまうため、それを避ける目的で移動。使用する前にFIFOクリアしてもOK。
事例

【XCP】最小構成のMBD事例 第2章 その220【仮想HILS③】

XCP関連の処理を追加。基本xcp_canクラスを呼び出すだけ。DAQ受信とSTIM送信はFMU処理が実装してあるFMU_handler内で呼び出す。DAQ受信はFMU処理直前。STIM送信はFMU処理直後。これにより、仮想ECU側の変数と仮想HILS側のシグナルの同期が取れる。
事例

【XCP】最小構成のMBD事例 第2章 その219【仮想HILS②】

DummyFMU化したPID制御の辻褄合わせを実施。Dummy_FMUModelCS2のdo_stepメソッドをオーバーライドすればOK。do_stepをdp_pidとして実装。do_pid関数内部でPID.fmuの変わりに出力を決定する仕掛け。このように入出力の辻褄合わせをすればOK。
事例

【XCP】最小構成のMBD事例 第2章 その218【仮想HILS①】

再びPyFMIを使うということでPyFMI関連の復習。過去記事のリンクを貼っておいた。PIDのFMUをDummy_FMUModel化実施。FMUModelCS2でロードしていたものをDummy_FMUModelCS2でロードするに変えるだけ。当然、これに伴う変更もあるが。
事例

【仮想ECU】最小構成のMBD事例 第2章 その217【PID制御⑧】

DAQリスナーの動作確認実施。問題無く動作した。やや表示範囲が有ってないが次に作る「HILSもどき」向けの設定になってる。「HILSもどき」改め「仮想HILS」と命名変更。仮想HILS作成に向けてのロードマップ確認。下位レイヤの動作が先に保証済みになっていると計画が立てやすい。
事例

【仮想ECU】最小構成のMBD事例 第2章 その216【PID制御⑦】

DAQリスナーのPythonコードを開示。基本的にはPython-canで受信。DAQパケットならば取り込む。上記を元にmatplotlibで描画。波形表示はリアルタイムではあるが負荷低減のため0.2秒周期。ここらへんの描画負荷の事情はHILSもどきの時と一緒。
事例

【仮想ECU】最小構成のMBD事例 第2章 その215【PID制御⑥】

HILSもどきの前にDAQパケットを取得して波形表示する機能が必要。仮想ECU側の内部変数を表示することが目的。DAQパケットはECU側の計測値なので、内部変数と解釈しても差し支えない。上記機能はDAQリスナと命名。DAQリスナの実験構成を図示した。横からCANを覗き見るだけのシンプルな機能。
事例

【仮想ECU】最小構成のMBD事例 第2章 その214【PID制御⑤】

仮想ECU側のPID制御器の入出力する信号の種類を確認。実際にXCPのDAQ、STIMを実施して制御状態を計測。想定通りの挙動になっていた。CAN回線モニタを確認。DAQとSTIMの目標値、実施のレイアウトを合わせていたので、縦に慣れべることで挙動が推測できる。
事例

【仮想ECU】最小構成のMBD事例 第2章 その213【PID制御④】

PID制御器動作確認用Pythonコードを開示。コンフィグレーション、XCPマスター生成、DAQ起動、計測、書き換えを隠蔽している。エントリポイントとして起動した際は簡単なXCP通信をしてXCPスレーブの挙動が見れる。ライブラリとして呼び出すことも可能。こんな感じのちょっとずづの積み上げが割と重要。