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

1 visualización (últimos 30 días)
wang
wang el 14 de Feb. de 2023
Comentada: wang el 20 de Feb. de 2023
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

Respuestas (2)

Fangjun Jiang
Fangjun Jiang el 15 de Feb. de 2023
Editada: Fangjun Jiang el 15 de Feb. de 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 comentario
wang
wang el 20 de Feb. de 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?

Iniciar sesión para comentar.


Bharath Venkataraman
Bharath Venkataraman el 15 de Feb. de 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.

Productos


Versión

R2021b

Community Treasure Hunt

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

Start Hunting!

Translated by