1

我正在尝试将 Matlab 遗留代码转换为 C 程序。我通过了通常的流程,但遇到了一个我不明白的构建错误:

Nfft = 8;
[~,coh] = size(h); // h = array of 168 elements;
display(coh); // displays 168
if mod(coh,Nfft)~=0,  
    h1 = [h zeros(1,Nfft-mod(coh,Nfft))];
else 
    h1 = h;
end

这在 Matlab 中按预期工作。但是当我通过 codegen 运行它时(删除显示后),我h1 = [h zeros(1,Nfft-mod(coh,Nfft))];在错误消息的行中收到一个错误:

无法从 double 转换为 struct。

我意识到在 matlab 代码中,它没有通过这部分代码。(因为 168%8 == 0)。

任何想法如何解决这一问题?

编辑:经过一番调查,我意识到我正在h从 .mat 文件中读取数据,这可能是原因。从 .mat 文件中读取的数据是否被视为结构?如果是这种情况,那么也许我需要先将每个元素转换为双精度?似乎有点hacky..

4

1 回答 1

2

找到了解决方案!

使用 coder.load 时,.MAT 文件作为数组结构导入。所以,在我的代码中,我试图将一个结构与一个双精度数组连接起来。

解决方案是我加载 .MAT 文件的方式:

老办法:

h = coder.load('my_file.mat', 'my_file_var1');

新的方法:

tmp = coder.load('my_file.mat');
h = tmp.my_file_var1;

然后我可以h用作双打数组。

于 2017-03-08T21:29:51.887 回答