How can I use single float with filtfilt in matlab coder?

3 次查看(过去 30 天)
I use matlab coder (matlab version:R2017a) to compile matlab code to C code .And I want to use single floating-point number.While I have used filtfilt function in matlab code. Then I got an error it said filtfilt only takes double floating-point number.I have tried using single() to convert parameters in filtfilt but still failed.Is there anyone can help me?Thanks.

回答(1 个)

Jan
Jan 2017-6-19
编辑:Jan 2017-6-19
Either convert the signal using double(), or use FEX: FilterM, which accepts single values, but accumulate the internal filter state as doubles to increase the accuracy or the output.
  4 个评论
WillandSmith
WillandSmith 2017-6-22
Thanks Jan.The FilterX.c is indeed a C file, but I still have many other matlab code and I want to complile them all into C code using matlab coder so that I don't have to rewrite all the matlab project to C code. Further more the target platform is ARM. So I have to use single-precision for reducing running time. I read your answer carefully but can't get the point to solve my problem.
Jan
Jan 2017-7-4
While filter works on single also, filtfilt accepts doubles only (at least in some Matlab versions). You can either include the C-Mex FilterX and FiltFiltM.m (see https://www.mathworks.com/matlabcentral/answers/48620-generating-c-c-code-from-m-function-include-mex-file), or modify the builtin filtfilt.m function to accept singles also. I still do not see, where the problem is.

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Statistics and Linear Algebra 的更多信息

标签

Community Treasure Hunt

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

Start Hunting!