gpt4 book ai didi

verilog - 如何使用 ModelSim 查看波形中定点数的实际值? (系统Verilog)

转载 作者:行者123 更新时间:2023-12-05 05:24:16 27 4
gpt4 key购买 nike

我在代码中使用带符号的定点数。为了更容易验证这些值,我想看看它们在波形中代表的实数。例如,假设:

    // 1bit signal, 4bits integer, 4bits fraction
wire [8:0] my_number1 = 9'b1_1111_1000; // -0.5
wire [8:0] my_number2 = 9'b0_0000_1000; // 0.5

我希望 my_number1 和 my_number2 分别为 -0.5 和 0.5。当我使用 Cadence 工具时,我可以单击信号波形并选择“创建表达式”并简单地创建一个新信号:

    (my_number1*(2.0**-4))

ModelSim Altera 入门版在其 GUI 上没有这个选项,所以我想我可以在我的测试台中创建一个与定点相关的真实信号,然后跟踪这个数字。

我试图在我的测试台中创建一个真实的信号:

    real my_number1_real = (my_number1*(2.0**-4));

但我只能看到 -0。我也试过 $bitstoreal 但我必须将它转换为 64 位数字并考虑指数等 ( see wikipedia ),所以这绝对不是一个简单的方法。

知道我该怎么做吗?

最佳答案

real my_number1_real = (my_number1*(2.0**-4));

是在时间 0 求值的常量表达式。像下面这样的东西会更好。

real my_number1_real;
always @*
my_number1_real = (my_number1*(2.0**-4));

我相信 always @* 在触发实数时可能会遇到问题,所以如果您可以使用系统 verilog,那么 always_comb 会更好。

关于verilog - 如何使用 ModelSim 查看波形中定点数的实际值? (系统Verilog),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35341963/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com