The Simulink model is fixed-point based on floating-point numbers
2 views (last 30 days)
Show older comments

I build a model that I want to fixed-point to produce VerilogHDL, but part of the output keeps being double.I changed it to unit8 before, but the output data is completely wrong
0 Comments
Answers (2)
Fangjun Jiang
on 15 Feb 2023
Edited: Fangjun Jiang
on 15 Feb 2023
No way to tell what exactly caused the problem from the snapshot of the model. In the MATLAB Function block editor, you can click "Edit Data" and specify the data types of the inputs and outputs, so you don't have to use the "Data Type Conversion" block.
In the function code, use uint8() to typecast if needed. Try a simple example to make sure the values and data types are all correct. If the output value changes when only the data type of the input changes, then somewhere in the data processing there is an error. Show the code so people can point out the problem.
Bharath Venkataraman
on 15 Feb 2023
You can put a breakpoint in the MATLAB Function block to see whee the code is generating the double output. See this link on how to debug the MATLAB Function block.
See Also
Categories
Find more on Simulink Functions 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!