CompiledPo​rtWidthsプロ​パティとCompil​edPortDime​nsionsプロパテ​ィの使用方法、制限事​項、出力形式を教えて​ください。

7 Ansichten (letzte 30 Tage)
CompiledPortWidthsプロパティとCompiledPortDimensionsプロパティの使用方法、制限事項、出力形式を教えてください。

Akzeptierte Antwort

MathWorks Support Team
MathWorks Support Team am 15 Sep. 2021
CompiledPortWidths と CompiledPortDimensions は、コマンドラインからモデル内の信号のサイズと次元を取得するために用います。
これらの情報は次のようにして取得します。
>> mymodel([],[],[],'compile');
>> s = get_param(gcb,'CompiledPortWidths');
>> mymodel([],[],[],'term');
CompiledPortWidths と CompiledPortDimensions はほとんど同じですが、CompiledPortDimensions は信号のサイズ(整数値)ではなく、次元を示す一連の数値を出力します(詳細は後述します)。CompiledPortWidths の場合、上記の get_param でえられた構造体 s は以下の形式になります。
s.Input = [各入力ポートに対応する信号サイズ(整数値)のベクトル]
s.Output = [各出力ポートに対応する信号サイズ(整数値)のベクトル]
s.State = [信号サイズ(整数値)のスカラー(State のポートは1つしかないためです)]
s.Enable = [信号サイズ(整数値)のスカラー]
s.Trigger= [信号サイズ(整数値)のスカラー]
追加の注意事項
(1) get_param(gcb,'CompiledPortWidths')は、ポートブロック、仮想ブロック(Mux, Demux, ...)など、あらゆるブロックに対して呼び出すことができます。
(2) gcbが出力ポートを持つトリガ(イネーブル)ブロックの場合、s のOutputフィールド(s.Output)にはトリガ(イネーブル)ブロックの出力ポートの信号サイズが格納されます。
(3) gcbが出力ポートを持たないトリガ(イネーブル)ブロックの場合、s は空になります。
(4) gcbがトリガ(イネーブル)ブロックを含むサブシステム(出力ポートの有無は問わない)である場合、's'のトリガ(イネーブル)フィールド、すなわちs.Trigger(s.Enable)には、トリガ(イネーブル)ポートの端子幅が入ります。
(5)
(i)ブロックダイアグラムをコンパイルする前、または
(ii)シミュレーションが完了した後に実行された場合、
get_paramを実行すると、sは空の構造体(0x0)となります。
(6)gcbのInitFcnとStartFcnがこのパラメータを取得するように設定されている場合、
(i)InitFcn は空の構造体を返します。
(ii) StartFcn は空でない構造体を返します。
(7) CompiledPortWidthsを持つバス信号の場合、
(i) 非バーチャルバスは1x1信号として扱われます。
(ii) バーチャルバスは、それらの合成信号のサイズの合計としてカウントされます。
(8) CompiledPortDimensions
(i) 各信号が一次元の場合は、その信号の値のペアを与える。多次元の場合は、次元数とその次元の値を記載します。例えば、1x1の信号は[1 1]と記載されますが、2x4x5の信号は[3 2 4 5]と記載されます。
(ii) バーチャルバスは、[-2 n s1 s2 s3 ...]の形式で記載されます。ここで、nは仮想バス内の信号の数、sは信号です。例えば、1x1と2x2x2の2つの信号を持つ仮想バスは、[-2 2 1 1 3 2 2 2]のように記載されます。
(iii) 非バーチャルバスは、[1 1]が返ります。

Weitere Antworten (0)

Tags

Noch keine Tags eingegeben.

Produkte


Version

R2015a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!