标签:文件 技术分享 分配 iss -o 需要 循环 调整 返回
我们在调用randomize()函数之前或者之后要立即执行一些操作。比如,在随机化之前可能要设置类里的一些非随机变量(上下限、权重),或者随机化之后需要计算随机数据的误差矫正位。
SystemVerilog中可以使用void类型的pre_randomize和post_randomize函数来完成这些功能。void类型的函数并没有返回值,与任务不同,并不会消耗时间。
我们在实际的应用中,通常要用到一些非线性的随机分布,这时候我们希望能够有一种浴缸型的分布,在两端的概率大,中间的概率小。
可以通过详细描述dist约束构造浴缸型的分布,但是需要多次调整才能获得需要的形状。
在Verilog中,我们已经提供了很多非线性函数,例如:$dist函数,但是并没有浴缸型函数,这时我们可以通过两条指数曲线去构造我们想要的函数。
常用的函数:
$dist_uniform() ——平均分布;
值得一提的是由于变量value是由function计算得到的,而不是随机约束求解器得到的,所以并不需要rand修饰符定义。
我们怎样才能写出便于维护和修改的CRT?通常是有一些小技巧的。下面我们就这些技巧做一下介绍。
通常一些上下限还有一些权重值,可以通过设置一个变量来维护。
可以通过改变read8_wt=0,来禁止这项命令生效。缺省情况下,read8_wt,read16_wt,read32_wt是1,1,1.
调用handle.randomize()函数的同时,SystemVerilog会检查这些变量是否满足约束条件。
在随机化的过程中,为了输出随机化的结果,我们通常会设置function void display()函数来进行可视化输出。
如果一套的随机约束已经产生了大部分你想要的激励向量,只有少数几个向量需要修改,那么你可以使用rand_mode()函数把这些变量设置成非随机变量。
利用调试函数得出结果
对length变量进行rand_mode()设置以后,约束丧失了对length的约束能力。
上一小节,我们讲了从一个大的约束里面除去对某个变量的约束,那么这一小节我们来讲,只对某一个或者某几个变量进行约束。
在调用randomize()函数时只传递变量的一个子集,这样的话就只会随机化类里面的几个变量。只有参数列表里面的变量才会被随机化。所有的约束仍然保持有效。
low是一个非随机变量,却被随机化赋于了一个随机值,并且满足约束条件。
如果利用if-else语句声明的约束显得很复杂,可读性不是很强的情况下,可以采用打开或关闭进行约束。
使用random()with{}内嵌约束语句使约束的作用范围局部化,作为对约束的补充是一种很好的做法。但是与之而来的问题是约束代码位于代码不同的位置,还难维护;其次很难在不同的测试里复用这些内嵌约束。
外部约束对类的所有实例都起作用,而内嵌约束仅仅影响一次randomize()调用。
在使用无符号的数时,一定要注意是否溢出,这个问题可以通过限制位宽来解决。
以上篇幅我们都只对标量类型的变量进行约束,现在思考如何在随机化数组时进行约束?
利用foreach约束和一些数组函数可以改变值的分布性状。
利用foreach会影响仿真器的运行速度,特别是遇到foreach嵌套的时候,这个时候我们可以通过使用randc变量来代替foreach的嵌套。
size()函数可以用来约束动态数组或队列里的元素个数。
一定要设置数组的上限,否则会产生成千上万个元素。
注意溢出问题
foreach能够对数组里的每一个元素进行约束。
foreach约束只能有一个数组名,不允许使用层次化的引用。
display函数用于调试输出。
标签:文件 技术分享 分配 iss -o 需要 循环 调整 返回
原文地址:https://www.cnblogs.com/xuqing125/p/9550580.html