17_随机约束和分布

1. 为什么需要随机约束?

在这里插入图片描述

  • 减少了代码量实际上是减少了测试用例的代码(test()中的代码)。
    在这里插入图片描述
  • 约束变形:前期约束窄中期宽后期窄
    在这里插入图片描述
    在这里插入图片描述
  • AC。验证环境结构可以随机

2. 随机化

在这里插入图片描述

  • 随机变量只能是class中的成员变量
    在这里插入图片描述
  • new只是创建了变量,但是还没有随机化。必须调用randomize(),成功随机化返回1.
  • 本例子中的constraint中只约束了src,所以只随机了src。
  • 若constraint中有一个约束不合适导致随机失败,那么constraint中的所有变量都会随机失败。
  • 有一副扑克牌,rand的意思是每次随机抽出一张牌的概率永远是1/54,randc的意思是一直抽一副牌抽完一副牌之后重新换一副。(c代表cycle,即周期随机)。一般rand用的多,randc常用于周期遍历。

3. 约束

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • AB。month的位宽限制其值只能是0~7.
    在这里插入图片描述
  • const只能在初始化赋初值。
    *
    在这里插入图片描述
  • 0:=40意味着0被选中的可能是40个单位,[1:3]:=意味着123被选中的可能是60个单位
  • [0:3]:/60表示123权重之和是60,每个都是20个单位
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  • constraint中所有的约束是并行执行的,并行约束,与谁先谁后没有关系
  • 约束之间也可以嵌套,在一个constraint中也可以再有一个constraint,二者是平级的。
  • 约束之间可以继承,父子约束不可以有冲突。对子类中的成员进行随机化时,两重约束都会生效
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值