Labfans是一个针对大学生、工程师和科研工作者的技术社区。 论坛首页 | 联系我们(Contact Us)
MATLAB爱好者论坛-LabFans.com
返回   MATLAB爱好者论坛-LabFans.com > 其它 > 资料存档
资料存档 资料存档
回复
 
主题工具 显示模式
旧 2019-12-10, 16:49   #1
poster
高级会员
 
注册日期: 2019-11-21
帖子: 3,006
声望力: 66
poster 正向着好的方向发展
帖子 MATLAB Embedded Coder:uint8的fft2操作?

我想使用MATLAB Embedded Coder生成一些代码,该代码在uint8数据类型上运行fft2操作。最终的应用程序将通过4096上的图像进行操作高达4096,所以我想不必使用double (双〜数据对比的134MB〜16MB)所需的输入来获得emlc现在编译我的代码。

这是我正在运行的示例:

%#eml function bar = emlc_test(foo) bar = fft2(foo); end 使用编译器命令:

emlc -T rtw emlc_test -c -report -v -eg { zeros(32,32,'uint8') } 这引发错误:

??? Function 'fft' is not defined for values of class 'uint8'. 将'uint8'更改为'double'时,相同的代码/编译命令可以正常工作

但是,查看生成的代码,似乎处理应该能够在uint8空间中运行。是否缺少我允许fft2操作处理uint8数据而不是double数据的标志?


回答:
MATLAB fft2参考文档对double或single类型的要求是明确的。

似乎您可能甚至必须为输入使用基于单打的“怪物”(*)矩阵。我认为这样做的原因是MATLAB无法确定输出中所需的类型,而与输入相同。
(**)实际上不是那么大:单一类型仅是您预期的4倍。



更多&回答...
poster 当前离线   回复时引用此帖
回复


发帖规则
不可以发表新主题
不可以发表回复
不可以上传附件
不可以编辑自己的帖子

启用 BB 代码
论坛禁用 表情符号
论坛启用 [IMG] 代码
论坛启用 HTML 代码



所有时间均为北京时间。现在的时间是 22:17


Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.