HDL Coder generated Verilog code for 2-D LUT block propogates X in Vivado Simulator
62 views (last 30 days)
Show older comments
When generating HDL code with HDL Coder for a 2-D Look Up Table block, I observed different behavior between VHDL and Verilog for the same lookup table access:
- In VHDL, the generated code uses
to_integer(add_cast + resize(mul_temp, 32))
which ensures that everything is resized into a 32-bit signed domain, producing a deterministic index.
- In Verilog, however, the generated code was:
$signed({1'b0, prelookup_idx}) + alpha2_D_Lookup_Table_mul_temp_2
Here, prelookup_idx is only 2 bits, while mul_temp_2 is 35 bits signed. The result is a 35-bit signed expression, and if any bit in the operands propagates X, the whole lookup table output becomes X in Vivado simulator.
Solution
To mimic the VHDL resize behavior, the Verilog code needs explicit truncation and casting:
wire signed [31:0] add_cast_2 = $signed({{30{1'b0}}, prelookup_idx});
wire signed [31:0] mul_temp_2_resized = alpha2_D_Lookup_Table_mul_temp_2[31:0];
wire signed [31:0] idx2 = add_cast_2 + mul_temp_2_resized;
assign alpha2_D_Lookup_Table_tableout3 = alpha2_D_Lookup_Table_7[idx2[5:0]];
With this change:
- The 35-bit value is truncated to 32 bits (matching the VHDL resize).
- The addition is performed in a 32-bit signed domain.
- The X propagation issue in Verilog simulation disappears.
Conclusion
There is a subtle difference between HDL Coder’s VHDL and Verilog backends regarding resize handling.
- VHDL always produces a deterministic integer with resize + to_integer.
- Verilog can leave the expression at a wider signed width, which increases the chance of X propagation.
Explicit truncation/casting in Verilog aligns its behavior with VHDL and resolves the simulation mismatch.
HDL Coder version is 25.1.

0 Comments
Answers (2)
Kiran Kintali
on 12 Sep 2025
Could you please share the sample model?
The input types and block parameters are essential for generating HDL code.
Additionally, the testbench surrounding the subsystem shown in the image helps reproduce the simulation behavior, making it easier to validate the design.
Kiran Kintali
on 18 Oct 2025 at 16:17

Could you please share your test model along with the version of MATLAB you are using?
We tested with R2025b using the attached model (types selected based on your HDL code), but we did not observe any 'X' propagation in the generated code or testbench using HDL Coder.
2 Comments
Kiran Kintali
on 21 Oct 2025 at 12:39
Edited: Kiran Kintali
on 21 Oct 2025 at 13:45
We have used QuestaSim/ModelSim to verify the standalone functionality of the 2D LUT block. The generated HDL code and testbench from HDL Coder are consistent and behave as expected. Next, we will evaluate the design using Vivado Simulator and share our findings if we find any issues.
See Also
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!