首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >verilog中模算子的范围

verilog中模算子的范围
EN

Stack Overflow用户
提问于 2017-02-27 01:42:06
回答 1查看 4.7K关注 0票数 0

在Verilog中%操作符的范围是多少?在C中,我知道如果我写数字%10,那么输出在0到9之间。但是我尝试了Verilog,结果是-9到9之间?为什么会这样呢?

代码语言:javascript
复制
enter code here
module testbench;
integer i;
reg signed [15:0] a,b;
initial
begin
for(i = 0; i < 9; i = i + 1)
begin
    a= $random%10;
    b= $random%20;  
    $display("A: %d and B : %d",a,b);
end
end
endmodule
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-02-27 02:49:05

模可以返回负数,如Verilog的IEEE 1364-2001§4.1.5算术运算符和SystemVerilog的IEEE Std 1800-2012§11.4.3算术运算符中所明确表示的那样。

模数运算的结果应采用第一个操作数的符号。

LRMs (语文参考手册)也列举了一些例子。

要保证一个正数,可以使用$unsigned()。示例:

代码语言:javascript
复制
a = $unsigned($random) % 10;

如果启用SystemVerilog,则可以用$urandom替换$unsigned($random),也可以用$urandom_range(9, 0)替换$unsigned($random) % 10;参见IEEE Std 1800-2012§18.13随机数系统函数和方法

FYI : C/C++对负数也是如此。请参阅先前回答的问题:带负数的模运算带负值的模算子

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42476537

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档