1
SPICEシミュレーションを実行した後、私はMatlabで解析している.a2dファイルを取得します。ファイルを解析すると、変数の名前を持つセル配列が得られます 例:vars = {'s0'; 's1'; 's2'; 'a0'; 'a1'} と信号遷移を持つデータ行列各行は各信号のデータを表し、列は時間を表す。すべてのデータはバイナリです。すなわち、0または1だけです。部分文字列を一致させて文字列をグループ化する
私がしたいことは、varsに保存されている名前に基づいて「単語」を検出するアルゴリズムを作成することです。たとえば、s0、s1、およびs2は3ビットのワード 's'を形成します。 a0、a1は2ビットの語aである。 最後に、データ行列を単語ごとに1つの配列に分割する(2進数から10進数に変換する)必要があります。
私は手でそれをやっていますが、スクリプトでそれを行う方法があるかどうかを知りたいと思います。
こんにちは@Alex、コードのthaksの文字列の一部にちなんで名付けられたフィールドで終わり、それは素晴らしい作品! おそらく私はそれを明確にしていないかもしれないちょっとした小さな修正です。 varsに数値で仕上げることなくいくつかのフィールドが含まれていると、コードにエラーが発生します(通常は1ビット信号の場合です)。 とにかくif文を追加してコードにこの変更を加えました。 'if(〜isempty(マッチ))' 'var = vars {i};' 'shifttsize = 0' 'else' 'var = 1と一致{1}' 'shifttsize = str2num({1} {2}と一致);' 'end' –