CANpack code generation Problem for MCU without floating-point math capabilities
3 views (last 30 days)
Show older comments
real32_T outValue = 0;
{
real32_T result =aa;
result =bb;
outValue = roundf(result);
"This facility may not be available on configurations of the EWL that run on platforms
that do not have floating-point math capabilities. "
--EWL C Reference Manual.pdf
Accepted Answer
Walter Roberson
on 17 Sep 2023
Edited: Walter Roberson
on 17 Sep 2023
roundf has been part of the C standard library since C99. However it expects floating point input and returns floating point output, which is a problem if you are using a system that does not have floating point hardware.
On a system that does not have floating point hardware, you have two choices:
- you can carefully write your code to only operate on the int* and uint* classes; or
- you can convert your code to use fixed-point arithmetic with the Fixed-Point Toolbox. The fixed point toolbox can emulate many floating-point operations in software, including potentially to greater precision than double precision floating point. However, transcendental functions such as trig functions or log generally have to be rewritten; search for CORDIC for those.
More Answers (1)
See Also
Categories
Find more on Trigonometry in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!