Please help me fix Digital Upconverter filter problem
Show older comments
I'm working on this example:
Implement Digital Upconverter for FPGA
It works fine when I leave the Matlab parameters as they are (the output is an 18 bit number), however I want to convert the output to a 14 bit fixed-point number then the output signal immediately outputs show problems. I tried to change the output bits of the filter and use the "data type converter" block but the output signal is not as nice as the Matlab sample signal. Can someone help me to solve this problem. It is really important to me. Thank you very much.
This is the original signal at the output of Matlab's filter when the output is fixeddt(1,18,16)

And here is the signal after I try to convert the output bits to 14 bits

Answers (2)
Ho
on 16 Jul 2023
0 votes
Bharath Venkataraman
on 16 Jul 2023
0 votes
I was able to update the MATLAB script and model to reduce the wordlength and fraction length by 2 bits (keeping the same headroom for integer values and reducing the fractional bits). Attached are the 14 bit input model and script.
The output of the HDL and the Simulink model are 14-bit numbers, but to accommodate the throughput, a frame of 4 values is sent out at a time. The setting outputFrame on line 366 in the MATLAB file decides the size of the output. Setting outputFrame to 1 will give you scalar 14-bit output. This comes at the expense of being able to send in data once every 64 cycles (instead of once every 16 cycles) to accommodate the interpolation in the model.
8 Comments
Ho
on 18 Jul 2023
Ho
on 19 Jul 2023
Bharath Venkataraman
on 21 Jul 2023
This change is built on the example, so please copy all the files that were part of the example into the same directory.
Ho
on 21 Jul 2023
Bharath Venkataraman
on 21 Jul 2023
My earlier model was 16 bits. I have now changed it to 14 bits - model and script are attached (and require the other files from the example).
Ho
on 22 Jul 2023
Ho
on 24 Jul 2023
Bharath Venkataraman
on 27 Jul 2023
I think this error is a duplicate of another post. Please contact MathWorks support with this issue. We will try to provide a workaround while we debug and fix the problem.
Categories
Find more on HDL Code Generation 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!



