system verilog随机函数_总结verilog产生随机数的$random和seed

$random函数在System Verilog中用于生成随机数,本文详细介绍了其三种使用方式及seed的设定方法,包括直接赋值和利用$get_initial_random_seed()。通过deposit命令在仿真时动态改变seed值,以实现不同随机数序列的生成。
摘要由CSDN通过智能技术生成

$random(seed)是verilog中最简单的产生随机数的系统函数。

在调用系统函数$random(seed)时,可以写成三种样式:1)$random,2)$random(),3)$random(seed)。下面分别说明:

1)$random

这是最简单的一种写法,略去了seed这个传入参数,$random会使用一个默认的seed(这个默认值为0?)。也正因此,每次进行仿真时,$random产生的随机数序列都是相同的。

2)$random()

这种写法和写法1)的作用是相同的,同样是没有给$random传入seed。

3)$random(seed)

这种写法与上面两种不同,给$random传入了参数seed,因此$random根据seed来产生随机数。seed不同,产生的随机数的序列也不同。而且,每执行一次$random(seed)产生一个随机数,seed也自动更新一次。

下面讨论seed的产生。

据我有限的知识,seed有两种产生方式:4)直接赋值为一个确定数,5)利用系统函数$get_initial_random_seed获得值。下面分别讨论:

4)直接赋值

在一个initial块中直接将seed变量写成某值,如下面代码:

integer seed;

reg [7:0] rand_num;

initial begin seed = 0; end

always @(posedge clk) begin rand_num <= $random(seed);

end

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值