$monitor和$strobe都看的是啥


注:本文来自硅芯思见


在编写测试平时,经常会用到$monitor和$strobe监测某些信号,并且使用格式上与$display比较类似,但是它们之间还是存在差异的,它们在当前仿真时间槽(time-slot)中被执行的区间是不同的。$display发生在Active区,而$monitor和$strobe发生在当前仿真的最后时刻,即post-pone区,并且一个time-slot是存在很多区域的,因此,它们在观测具体信号值时是存在一定差异的。

【示例】 

图片

【仿真结果】 

图片

出现示例中的结果,是因为非阻塞赋值的LHS更新发生在Non-Active区,而此时的$display已经执行完毕,所以$display观测不到sig更新后的值,但是$monitor发生在Post-pone区,晚于Non-Active区执行,所以可以观测到sig更新后的值。因此,$display和$monitor观测到sig的值不同。在实际使用过程中,具体使用哪一种监测方式则根据两种监测执行的区间特点自行选择,$strobe与$monitor在本例中监测到的结果是一样都发生在Post-pone区,执行类似,在此不赘述。那么既然$strobe和$monitor执行效果一样,都发生在Post-pone区,那么为什么还要同时存在呢?两者之间有些什么差异呢?下面我们就两者之间的一些差异进行示例说明。

1 $strobe的执行

$strobe只有在被调用时才会对其中的参数进行监测,此时的参数所具有的值可以认为是其所在当前时间槽(time-slot)中的最终值。另外,$strobe在设计中可以多次被调用,且多次调用相互之间不产生任何影响。

【示例】 

图片

【仿真结果】 

图片

示例中,在always过程块中,当敏感时间列表中的信号发生一次变化,always过程块中的$strobe就会执行一次,并且输出此次执行时对应参数的稳定值。在initial过程块中,等待4个时间单位后$strobe执行,并且输出此时对应参数的稳定值,而在sig变化的其他时刻,该语句并未执行(因为initial块只执行了一次,并且完成了他的历史使命)。可见$strobe的执行取决于对其的调用,它的执行并不取决于其中参数的变化,同时可见该语句在代码中可以被多次调用,并且多次调用之间不会产生相互影响。

2 $monitor的执行

$monitor和$strobe虽然它们监测的参数都是当前时间槽该参数最后的稳定值,但两者在具体执行上还是有一定差别的,下面通过示例说明$monitor的用法。

【示例】 

图片

【仿真结果】 

图片

示例中,$monitor位于过程块中,sig从0时刻开始,每发生一次变化,$monitor就会执行一次,可见$monitor会持续监测其中参数的变化,只要其中参数发生变化,$monitor就会执行。那么是不是其中的任何参数的变化都会触发$monitor的执行,例如,可不可以使用$monitor监测时间的变化呢?

【示例】 

图片

【仿真结果】 

图片

示例中,随着仿真时间的推进,$monitor仅执行了一次。这主要是因为在$monitor中,如果监测的参数是$time、$stime和$realtime这些系统函数的返回值,$monitor对这些时间参数的变化并不敏感。

另外,当$monitor中具有多个参数同时发生变化时,这是因为这些参数在当前时间槽中调用$monitor时都已经处于稳定状态了,所以此时$monitor只调用一次,如下所示。

【示例】 

图片

【仿真结果】 

图片

那么,我们可不可以使用多个$monitor监测信号的变化呢?此时$monitor会如何执行呢?我们看看下面的示例。

【示例】 

图片

【仿真结果】 

图片

示例中,使用了两个$monitor分别检测sig1和sig2信号的变化,但是仿真结果仅有一个$monitor执行。这主要是因为$monitor执行上的一个特点,在任意仿真时刻,只有一个$monitor系统任务处于激活执行状态,至于多个$monitor执行的顺序,一般则取决于哪一个$monitor最近一次被调用。除此之外,$nonitor还提供了其他的配置系统任务,可以通过这些系统任务实现对于$monitor执行的控制。

【示例】 

图片

【仿真结果】 

图片

示例中,$monitoroff和$monitoron之间sig的变化并没有触发$monitor系统任务的执行。这主要是因为$monitoroff会不使能当前所有激活的$monitor任务对于其中参数的监测,所以在$monitoroff之后,$monitor监测的参数如果发生变化,将不会触发$monitor的执行。$monitoron的效果与$monitoroff刚好相反,主要用于再次启动激活$monitor任务,在$monitoron执行后,如果$monitor监测的参数发生变化,则会触发$monitor的执行。

综上所述,$strobe和$monitor执行的主要特定如下:

Ø$strobe和$monitor监测的相关变量的值,都是这些变量在当前时间槽中的最终稳定值;

Ø$strobe只有在被调用时才会对其中的参数进行监测,而$monitor只要监测的参数发生变化,$monitor就会执行;

Ø代码中可以存在多个$strobe,并且多个$strobe的调用相互之间不影响;

Ø在$strobe和$monitorr中,如果监测的参数是$time、$stime和$realtime这些系统函数的返回值,$strobe和$monitor对这些时间参数的变化并不敏感

Ø在任意仿真时刻,只有一个$monitor系统任务处于激活执行状态,至于多个$monitor执行的顺序,一般则取决于哪一个$monitor最近一次被调用;

Ø可以通过$monitoroff和$monitoron对$monitor的执行进行监测;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/651149.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

字符串函数strncpy、strncat、strncmp的功能(3)

目录 引言: 一、strncpy函数介绍: 1.声明: 2.功能: 3.底层代码: 二、strnact函数介绍: 1.声明: 2.功能: 3.底层代码: 三、strncmp函数介绍: 1.声…

常见电源电路(LDO、非隔离拓扑和隔离拓扑结构)

一、常见电路元件和符号 二、DC-DC转换器 DC-DC转换器:即直流-直流转换器,分为三类:①线性调节器;②电容性开关解调器;③电感性开关调节器; 2.1线性稳压器(LDO) 2.1.1 NMOS LDO…

如何将前后端分离(vue2+SpringBoot)项目部署到腾讯云服务器

如何将前后端分离(vue2SpringBoot)项目部署到腾讯云服务器 目录 如何将前后端分离(vue2SpringBoot)项目部署到腾讯云服务器 1、在选中目录地下新建2个文件夹 2、将打包好的前端项目和后端jar包上传到相应的目录下 3、将路径切…

Gin 应用多实例部署session问题、session参数与刷新

文章目录 一、Gin Session 存储的实现方案二、memstore:基于内存的实现2.1 基本使用2.2 关键参数 三、使用redis:多实例部署3.1 使用redis优势3.2 基本使用 四、信息安全的三个核心概念五、Gin Session 参数5.1 参数介绍 六、Session 自动刷新 一、Gin S…

语图奇缘:林浩然与杨凌芸的哲学漫画大冒险

语图奇缘:林浩然与杨凌芸的哲学漫画大冒险 Language Odyssey: The Philosophical Comic Adventure of Lin Haoran and Yang Lingyun 在一个充满逻辑谜题和言语陷阱的城市——逻言市,住着两位热衷于探索语言奥秘的年轻人,林浩然和杨凌芸。林浩…

Qt的绘制是如何发生的

QEvent::WindowDeactivate 当用户鼠标在应用之外时,会触发QEvent::WindowDeactivate事件, Qt5Widgetsd.dll!QApplication::setActiveWindow(QWidget * act) Line 2072 C Qt5Widgetsd.dll!QApplicationPrivate::notifyActiveWindowChange(QWindo…

一篇文章带你了解C++中隐含的this指针

文章目录 一、this指针的引出二、this指针的特性【面试题】 一、this指针的引出 我们先来定义一个日期类Date,下面这段代码执行的结果是什么呢? class Date { public:void Init(int year, int month, int day){_year year;_month month;_day day;}v…

2024新版68套Axure RP大数据可视化大屏模板及通用组件+PSD源文件

Axure RP数据可视化大屏模板及通用组件库2024新版重新制作了这套新的数据可视化大屏模板及通用组件库V2版。新版本相比于V1版内容更加丰富和全面,但依然秉承“敏捷易用”的制作理念,这套作品也同样延续着我们对细节的完美追求,整个设计制作过…

【PythonRS】Rasterio库安装+基础函数使用教程

Rasterio是一个Python库,专门用于栅格数据的读写操作。它支持多种栅格数据格式,如GeoTIFF、ENVI和HDF5,为处理和分析栅格数据提供了强大的工具。RasterIO适用于各种栅格数据应用,如卫星遥感、地图制作等。通过RasterIO&#xff0c…

Two-factor authentication (2FA) is required for your GitHub account解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

SkyWalking介绍与使用docker-compose部署服务

一、Skywalking概述 1、Skywalking介绍 Skywalking是分布式系统的应用程序性能监视工具,专为微服务,云原生架构和基于容器(Docker,K8S,Mesos)架构而设计,它是一款优秀的APM(Application Performance Management)工具,包括了分布式追踪,性能指标分析和服务依赖分析等…

gitee仓库使用中的警告

当 Git 执行 git pull 命令时,有时候会出现类似下面的警告信息: warning: ----------------- SECURITY WARNING ---------------- warning: | TLS certificate verification has been disabled! | warning: ------------------------------------------…

Python退出主程序

import sys sys.exit(1) exit函数的使用方法 Exit the interpreter by raising SystemExit(status).If the status is omitted or None, it defaults to zero (i.e., success). If the status is an integer, it will be used as the system exit status. If it is another kin…

网络安全03---Nginx 解析漏洞复现

目录 一、准备环境 二、实验开始 2.1上传压缩包并解压 2.2进入目录,开始制作镜像 2.3可能会受之前环境影响,删除即可 ​编辑 2.4制作成功结果 2.5我们的环境一个nginx一个php 2.6访问漏洞 2.7漏洞触发结果 2.8上传代码不存在漏洞 2.9补充&#…

ubuntu 编译使用 liblas 读取点云

在ubuntu上使用las读取点云 1、环境配置 1.1、安装libgeotiff 下载依赖 sudo apt-get install libtiff-dev //安装libtiff sudo apt-get install libproj-dev //安装libproj下载源码,编译 如下该是libgeotiff-1.3.0版本安装包 wget https://download.osgeo.o…

【蓝桥杯冲冲冲】旅行计划

蓝桥杯备赛 | 洛谷做题打卡day18 文章目录 蓝桥杯备赛 | 洛谷做题打卡day18旅行计划题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示题解代码我的一些话 旅行计划 题目描述 Kira酱要去一个国家旅游。这个国家有 N N N 个城市,编号为 1 1 1 至 N N…

计算机网络(第六版)复习提纲11

二、CSMA/CD协议 1.广播信道上的一对一通信 2.以太网的两个措施 a)采用无连接的方法,不可靠 b)发送的数据都是用曼彻斯特编码 3.CSMA/CD协议(先听后说,边听边说) a)前身是ALOHA协议,想发就发,冲突时随机等待…

SpringSecurity(16)——OAuth2客户端授权模式

工作流程 基本使用 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId><version>2.3.12.RELEASE</version> </dependency> <dependency><groupId>…

大数据Doris(五十九):SQL函数之字符串函数(三)

文章目录 SQL函数之字符串函数(三) 一、​​​​​​​NULL_OR_EMPTY (VARCHAR str)

力扣1312. 让字符串成为回文串的最少插入次数

动态规划 思路&#xff1a; 通过插入字符构造回文串&#xff0c;要想插入次数最少&#xff0c;可以将字符串 s 的逆序 s 进行比较找出最长公共子序列&#xff1b;可以先分析&#xff0c;字符串 s 通过插入得到回文串 ps&#xff0c;其中间的字符应该不会变化&#xff1a; 若 s…