はじめに
Simulink/HDL CoderでFPGA実装するようなモデルで、ロジック信号をデバッグしようとすると、特に長い尺の信号を取り扱う場合、色々と問題があり難しいことが多かったので、可視化の代替案を備忘録として残します。
ロジックアナライザー
Simulinkにもロジック波形を表示する機能はあるみたいですが、MATLAB R2023a時点では色々と問題があったので、信号のログはSimulinkで取りつつ、可視化は別の方法でやりました。
信号ログを取る手段としては、HDL VerifierにTo VCD Fileブロックを使いました。
可視化の手段としては、2つ
- VCDファイルに対応したHDLシミュレータを使う
(ModelSim/Questaを使用した) - フリーのビューワーGTK Waveを使う
※GTK Waveはこちらからダウンロードできます。
To VCD Fileブロック
VCDファイルとは
一般的なHDLシミュレータでデータダンプに使われる標準的なファイルフォーマットです。
SimulinkシミュレーションのデータをVCDファイルに保存するブロックは HDL Verifier > To VCD Fileブロック
To VCD Fileブロックの制約
- Simulinkのバス信号に対応していないので、Signal Conversionブロック(出力:バーチャル バス) + Bus to Vectorブロックでベクトル信号に変換する
- 複数階層の信号をまとめてVCDブロックに接続するのにGoto/Fromブロックが便利
- ただし、このブロックはAtomicサブシステムや参照モデルの境界を超えられない。Atomicや参照モデルには、その階層にVCDブロックを置く必要がある。
- 信号名がビューワーの表示名になるので、Simulink信号名をわかりやすく命名する
- Simulinkサンプル時間をキリのいい数字ににする(分解能が1tick未満になるとエラーとなる。詳細は後述)
- アクセラレータに対応している
- 参照モデル内にある場合はアクセラレータが使えない
- 任意の固定小数点, Boolean, double, singleデータ型に対応している。halfは対応していない。
- 右クリックメニューからビューアーに接続した場合は、VCDファイルに信号名が継承されない
- [Nx1], [1xN], [NxM] の行列信号も保存できるが、NxMの行列はベクトル信号として保存される
To VCD Fileブロックのサンプル時間に関して
このブロックに小数点以下の桁数が多いサンプル時間の信号を入力するとエラーが発生します。
例えばFull HD 60fpsの画像処理を行う場合、ピクセルストリームのサンプル時間は以下の通り。
HSize: 1920
VSize: 1080
TotalPixelsPerLine: 2200
TotalVideoLines: 1125
FrameRate: 1/60
PixelSampleTime: 1/60/2200/1125
= 6.734006734006734e-09
HDLシミュレータの1tickは、扱うことのできる時間分解能を1ns, 1ps, 1fsにしても上記のサンプル時間は精度が足りないので、Simulink側のサンプル時間を調整します。
HDLシミュレータの1tick: 1ns
PixelSampleTime: 10nsとなるようにすると
FrameRate = 10e-9 * 2200 * 1125
= 0.02475
フレームサンプル時間を上記設定に設定するとエラーが発生せずにVCDブロックを使用できます。
モデルの設定
To VCD Fileに保存する方法は2つあります。
- ブロックに接続する
- ブロックを置かずに右クリックメニューからビューアーに接続する
1. Goto/Fromブロックで信号を集約して入力
これは信号の取り回しが煩雑になりがちなので、お勧めしません。
2. 信号を右クリックしてビューアーに接続(こちらがお勧め)
信号線を右クリック > ピューアーの作成と接続 > HDL Verifier > To VCD File
をクリックするとブロックを置かずに接続できます。
ビューアーを開いて、信号の数やTimescale設定を行います。
複数信号を接続したい場合は、ビューアーマネージャーを開いて・・・
下図のマネージャ画面で、1つのビューアーに信号を追加していきます。
VCDファイルの表示
HDLシミュレータ(Questa/ModelSim)の場合
HDLシミュレータを起動。Questa/ModelSimは以下のコマンドで起動します。
ModelSim/Questaの場合は以下のコマンドでVCDファイルをWLFファイルに変換。
vcd2wlf test_vcd.vcd test_vcd.wlf
ファイル読み込みと波形の表示は
Fileメニュー>Open
Objects画面で信号名を選択してAdd Waveをクリックすると実行できます。
コマンドだと以下
OpenFile test_vcd.wlf
add wave *
GTK Waveの場合
GTK Waveをインストール、パス設定がされていれば、MATLABからシステムコマンドを実行すればGTK Waveを開くことができます。
それぞれの特長
-
GTK Waveの特長
- 起動までが速い。手軽に使える点が良い。
- カーソルは1つしか置けない。代わりにマーカーを使って時間測定できるがあまり使いやすくはない。
- ビューワーの拡大縮小は[Ctrl+Shift+-], [Ctrl+-]
-
ModelSim/Questaの特長
- 起動には時間がかかる。
- カーソルを複数置けて、各カーソル間の時間測定が容易。
- ビューワーの拡大縮小は [i], [o]キー
- 波形表示フォーマットのオプションが豊富。アナログ波形など。
以上