当前位置: 首页 > news >正文

SystemVerilog Assertions应用指南 第一章(1.27章节 “within”运算符)

        “ within”构造允许在一个序列中定义另一个序列。

  seq1 within seq2

        这表示seq1在seq2的开始到结束的范围内发生,且序列seq2的开始匹配点必须在seq1的开始匹配点之前发生,序列seq1的结束匹配点必须在seq2的结束匹配点之前结束。属性p32检查序列s32a在信号“ start”的上升沿和下降沿之间发生。信号“ start”的上升和下降由序列s32b定义。

sequence s32b;@(posedge clk)$fell(start) ##[5:10] $rose(start);
endsequencesequence s32;@(posedge clk) s32 within s32b;
endsequenceproperty p32;@(posedge clk) $fell (start) |-> s32;
endpropertya32: assert property(p32);

        图1-34使用了与 throughout运算符用的例子相同的设计条件来显示属性p32在模拟中的响应。检验有两个有效的开始:一个在时钟周期3,另一个在时钟周期16。在这两个点,检测到信号“ start”的下降沿。

        成功1——从时钟周期3开始的检验成功了。信号“ start”的下降沿在时钟周期3,上升沿在时钟周期13。在这两个时钟周期间,信号“c”分别在时钟周期6,9,11被检测到三次高电平。因此检验成功。        
        未完成1—从时钟周期16开始的检验未能完成。信号“ start的下降沿在时钟周期16,上升沿在时钟周期21。在这两个时钟周期间,信号“c”分别在时钟周期18和20被检测到两次高电平信号“c”的第三次重复出现在时钟周期22,但是在时钟周期21检测到信号“ start”为高。这是一个失败,但是由于信号“c”使用的是跟随重复(“goto” repetition运算符,它按照阻塞序列的规则来执行。这使得检查失败并且在模拟中发出了一个未完成的信息。

http://www.lryc.cn/news/192498.html

相关文章:

  • 2023年09月 C/C++(七级)真题解析#中国电子学会#全国青少年软件编程等级考试
  • [Mono Depth/3DOD]单目3D检测基础
  • 【Docker 内核详解】namespace 资源隔离(三):PID namespace
  • 1600*C. Game On Leaves(博弈游戏树)
  • Apache Ant的安装
  • 考研:数学二例题--∞−∞和0⋅∞型极限
  • C++算法:图中的最短环
  • C++学习——类其实也是一种作用域
  • Seata入门系列【4】undo_log、global_table、branch_table、lock_table字段及作用详解
  • 虚幻引擎:数据表格的C++常用API
  • Java日期格式化(DateFormat类和SimpleDateFormat类)
  • centos 7 lamp owncloud
  • 屏幕亮度调节保护您的眼睛
  • CentOS Linux下CMake二进制文件安装并使用Visual Studio调试
  • ASP.net相关目录,相关配置文件和.后缀名解释
  • 一键批量转换,轻松将TS视频转为MP4视频,实现更广泛的播放和分享!
  • 【Redis】使用Java客户端操作Redis
  • BSPHP 未授权访问 信息泄露
  • Learning Sample Relationship for Exposure Correction 论文阅读笔记
  • Vue项目 -- 解决Eslint导致的console报错问题
  • uni-app 在已有的数据对象中动态添加更多的数据对象
  • 【LeetCode】17. 电话号码的字母组合
  • 使用 Apache Kafka 进行发布-订阅通信中的微服务
  • valarray 包含对象成员的类(cpp14章)
  • 2023双11笔记本电脑候选名单(截止2023.10.13的价格,双十一活动可能会更便宜一点)
  • Springcloud笔记(4)-客户端负载均衡Ribbon
  • MediaRecorder媒体录音机
  • 短视频如何批量添加水印
  • RT-Thread MQTT(学习)
  • Vue_Bug VUE-ELEMENT-ADMIN默认是英文模式