AHB-sram关于受约束的随机化(sv项目笔记之3)

在这一部分中,了解随机化验证策略的重要性,为什么要使用随机化的验证策略?

基于对象的随机包括哪三个步骤?

  1. 定义随机变量rand、randc。
  2. 指定约束条件constraint range{[][]}
  3. 调用randomize()方法

若没有定义rand,编译不会报错,但仿真会报错。

这一部分由于只是在generator中做出修改,所以我们需要针对generator进行修改,新定义一个产生随机变量的方法。

 

在env_top中进行调用时调用随机化的方法即可:

 

在trans中还要指定需要被rand的数据,并用constraint关键字声明随机化的范围。

我们也可以在使用randomize的同时使用关键字with 对随机化范围进行进一步界定。需要注意的是,该方法在日后的项目中会经常用到。

也可以在constaint内做条件约束,此时不应该有begin和end,符号应该用==。

之后可以更改条件实现不同size的传输。

对比地址位是否符合变化情况。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值