gpt4 book ai didi

Verilog:如何取绝对值

转载 作者:行者123 更新时间:2023-12-01 23:14:38 43 4
gpt4 key购买 nike

在 verilog 中,我有一个二进制值数组。如何取减去值的绝对值?

Verilog代码:

module aaa(clk);
input clk;

reg [7:0] a [1:9];
reg [7:0] s [1:9];

always@(posedge clk)
begin
s[1] = a[1] - a[2];
s[2] = a[2] - a[3];
s[3] = a[1] + a[3];
end
endmodule

我希望我的 s[1]s[2] 值始终为正。我怎样才能在可综合的verilog中做到这一点?

我尝试使用signed reg,但它显示错误。

最佳答案

无论号码是否signed or not 仍然使用二进制补码,可以在位级别正确执行加法和减法。

如果要将数字解释为带符号的,则可以使用 MSB 来判断它是正数 (0) 还是负数 (1)

要绝对数字,只需根据 MSB 反转即可:

reg [31:0] ans    ; // Something else drives this value
reg [31:0] abs_ans; // Absolute version of ans
// invert (absolute value)
always @* begin
if (ans[31] == 1'b1) begin
abs_ans = -ans;
end
else begin
abs_ans = ans;
end
end

注意:使用 =因为它是一个组合 block ,如果使用触发器(边沿触发),请使用 <=正如@TzachiNoy 所提到的。

关于Verilog:如何取绝对值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19423792/

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