The Simulink model is fixed-point based on floating-point numbers

1 view (last 30 days)
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

Answers (2)

Fangjun Jiang
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.
  1 Comment
wang
wang on 20 Feb 2023
I changed the data type of X to unit8. When running the error, Simulink was displayed and the output was judged to be double. Maybe there is something wrong with my explanation. Could you please have a look at my latest question?

Sign in to comment.


Bharath Venkataraman
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.

Products


Release

R2021b

Community Treasure Hunt

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

Start Hunting!