1

运行 SPICE 模拟后,我得到一个 .a2d 文件,我正在使用 Matlab 解析该文件。解析文件后,我得到一个包含变量名称的单元格数组 Ex: vars = {'s0';'s1';'s2';'a0';'a1'} 和一个带有信号转换的数据矩阵,其中每行代表每个信号的数据,列代表时间。所有数据都是二进制的,即只有 0 或 1。

我想做的是创建一个算法,根据存储在 vars 中的名称检测“单词”。例如s0、s1、s2组成一个3位字's';a0 和 a1 一个 2 位字“a”。最后,我需要将每个单词的数据矩阵分解为一个数组(从二进制转换为十进制)。

我是手工做的,但我想知道是否有任何方法可以通过脚本来完成。

4

1 回答 1

0

这是一个可能的解决方案,将最终值放入结构的字段中。我使用了一个正则表达式来提取变量名和变化,因为你没有说它们可能有多长。

% fake data
vars = {'sums4', 'sums2', 'sums1', 'a0', 'a5'};
data(1,:) = logical([0 0 1 0 0 0 1]);
data(2,:) = logical([0 1 1 1 1 0 0]);
data(3,:) = logical([1 0 1 1 0 0 1]);
data(4,:) = logical([0 0 1 0 1 1 1]);
data(5,:) = logical([0 1 1 1 0 0 0]);

output = struct();
for i = 1:length(vars) 
    matches = regexp(vars{i}, '(\D+)(\d+)', 'tokens');
    var = matches{1}{1};
    shiftsize = str2num(matches{1}{2});

    % initialise if not already present
    if (~isfield(output, var))
        output.(var) = zeros(1, size(data, 2));
    end

    % add apropriate shifted value to current values
    output.(var) = output.(var) + (bitshift(1, shiftsize) * data(i, :));
end

输出以 vars 的字符串部分命名的字段结束

output = 

    sums: [2 4 22 6 4 0 18]
       a: [0 32 33 32 1 1 1]
于 2012-04-17T05:55:25.447 回答