SV 双向约束与函数应用问题记录

背景:项目要求5G步进增删业务;总时隙640,有160个5G时隙,也就是说在添加小于5G时隙的业务时,占不满5G时隙。如果是满带宽等场景,会导致随机出来的5G步进时隙超过160,不满足要求。

解决方案:

方案1,先随机出160个5G大时隙,再根据每个通道分配的大时隙,随机出真实的时隙业务。在满带宽场景中,无任何问题,但是在总时隙只分配1的情况下,会导致求解过于复杂,导致求解失败。

方案2,先大随机一波,等到随机完成之后,再计算5G大时隙是否满足要求,无法满足要求则继续随机-》由于随机过程中,种子由外部传入,不修改种子,每次随机的值都是一样的,无法解决当前问题。若修改种子,则导致整个验证过程的种子无法复现,不利于定位问题,故摒弃。


方案3,由于无法解决该问题,在咨询大佬之后,给的建议是采用constraint中带函数参数进行5G大时隙限制,最终代码如下,采用函数约束
![image.png](http://image.huawei.com/tiny-lts/v1/images/23053e0e1e93957925e3cc3ef218d6ec_686x411.png@900-0-90-f.png)
在实际回归过程中发现,依然存在问题
![image.png](http://image.huawei.com/tiny-lts/v1/images/fb2554a5464ed83e6657c779c294ed18_1234x615.png@900-0-90-f.png)
报错结果表明,ts_num_map里面的值没有被修改,反而是因为结果不合法而随机失败。查阅网上帖子和资料,找到约束中的函数限制如下
![image.png](http://image.huawei.com/tiny-lts/v1/images/06c80531d17cbcb8ba044bb322305abc_1751x851.png@900-0-90-f.png)
![image.png](http://image.huawei.com/tiny-lts/v1/images/57174e625135c21090f74aa30d304041_1134x660.png@900-0-90-f.png)
约束中的函数只能使用局部变量而无法修改类变量,使得函数约束是单向约束,不会因为5G时隙数大于设定时隙数而修改ts_num_map的值,故导致问题依然出现。

方案4,由于语法手册中描述到C2约束是一种双向约束,于是想到,通过双向约束是否可以使得5G大时隙不符合要求而改变ts_num_map呢,应该是可以的,这里就有个选择,到底是手写80个通道的ts_num_map[i]还是用脚写的问题。最终我们选择了通过sum函数来实现该方案。
![image.png](http://image.huawei.com/tiny-lts/v1/images/06c80531d17cbcb8ba044bb322305abc_1751x851.png@900-0-90-f.png)
通过定义临时变量,让临时变量传递这种双向约束的方式,我们间接的修改了ts_num_map,使得完全随机且满足5G步进的约束,大功告成。
![image.png](http://image.huawei.com/tiny-lts/v1/images/ab6667246cb5b0eccfb7a0f8f5ceb623_965x673.png@900-0-90-f.png)


 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值