草庐IT

Verilog的时间系统任务----$time、$stime、$realtime

孤独的单刀 2023-04-07 原文

文章目录

        概述

        $time

        $stime

        $realtime

        总结与参考


概述

        在做仿真的时候,常常需要获取仿真时间以便了解被测模块的测试情况。Verilog语法提供了3个系统任务----$time、$stime、$realtime,这3个系统任务都可以在仿真时(无法综合)获取当前仿真时刻的时间值,但其使用也有一点小小的区别。


$time

        调用系统任务$time,将会获得一个64位的integer型变量,其表示调用该系统任务时的仿真时间。需要注意的是,其值会自动缩放到`timescale任务所定义的时间单位。下面举个例子:

`timescale 10 ns / 1 ns

module tb_time_test;

reg set;
parameter p = 1.55;

initial begin
	$monitor($time,,"set=",set);
	#p set = 0;
	#p set = 1;
end

endmodule

        仿真结果如下: 

  • 在上面的例子中,将仿真时间单位定义成了10ns,而时间精度则定义为1ns。
  • 第1行,set未赋值,所以输出 set = x,此时时间为0
  • 第2行,set赋值为0,所以输出 set = 0,此时时间为1.55*10=15.5ns,由于精度为1ns,所以四舍五入到16ns,同时由于时间单位为10ns,所以不能表示16ns,而是表示四舍五入后的2(单位10ns)
  • 第3行,set赋值为1,所以输出 set = 1,此时时间为16+1.55*10=31.5ns,由于精度为1ns,所以四舍五入到32ns,同时由于时间单位为10ns,所以不能表示32ns,而是表示四舍五入后的3(单位10ns)

        接下来我们把上述代码的仿真时间单位改为1ns,时间精度保留为1ns,这样看起来会好理解一些。

`timescale 1 ns / 1 ns

module tb_time_test;

reg set;
parameter p = 1.55;

initial begin
	$monitor($time,,"set=",set);
	#p set = 0;
	#p set = 1;
end

endmodule

        仿真结果如下:

  • 在上面的例子中,将仿真时间单位定义成了1ns,而时间精度则定义为1ns。
  • 第1行,set未赋值,所以输出 set = x,此时时间为0
  • 第2行,set赋值为0,所以输出 set = 0,此时时间为1.55*1=1.55ns,由于精度为1ns,所以四舍五入到2ns,时间单位为1ns,所以直接显示2(单位1ns)
  • 第3行,set赋值为1,所以输出 set = 1,此时时间为2+1.55*1=3.55ns,由于精度为1ns,所以四舍五入到4ns,时间单位为1ns,所以直接显示4(单位1ns)

$stime

        调用系统任务$stime,将会获得一个32位的无符号integer型变量,其表示调用该系统任务时的仿真时间。需要注意的是,其值同样会自动缩放到`timescale任务所定义的时间单位。

        这个系统任务的用法基本上和 $time是一样的,只不过由于其只有32位,所以表示的时间范围会比较小,使用的时候注意别溢出了。


$realtime

        调用系统任务$realtime,将会获得一个real型变量,其表示调用该系统任务时的仿真时间。需要注意的是,其值会自动缩放到`timescale任务所定义的时间单位。

        由于其返回值为实数real型,所以其可以表示小数时间。同样以上面的代码为例:

`timescale 10 ns / 1 ns

module tb_time_test;

reg set;
parameter p = 1.55;

initial begin
	$monitor($realtime,,"set=",set);
	#p set = 0;
	#p set = 1;
end

endmodule

        仿真结果如下:

  • 在上面的例子中,将仿真时间单位定义成了10ns,而时间精度则定义为1ns。
  • 第1行,set未赋值,所以输出 set = x,此时时间为0
  • 第2行,set赋值为0,所以输出 set = 0,此时时间为1.55*10=15.5ns,由于精度为1ns,所以四舍五入到16ns,同时由于时间单位为10ns,所以不能表示16ns,而是表示1.6(可以表示小数了,单位10ns)
  • 第3行,set赋值为1,所以输出 set = 1,此时时间为16+1.55*10=31.5ns,由于精度为1ns,所以四舍五入到32ns,同时由于时间单位为10ns,所以不能表示32ns,而是表示3.2(可以表示小数了,单位10ns)

总结与参考

  • $time、$stime、$realtime这三个系统任务都可以获取当前仿真时间,区别在于返回的时间值的类型不同,一般的应用使用$time即可
  • 在仿真时获取仿真时间可以观察、监测被测模块的测试情况,有利于提高测试效率

        参考资料1:IEEE Standard for Verilog® Hardware Description Language(IEEE Std 1364™-2005)


  • 📣博客主页:wuzhikai.blog.csdn.net
  • 📣本文由 孤独的单刀 原创,首发于CSDN平台🐵
  • 📣您有任何问题,都可以在评论区和我交流📞!
  • 📣创作不易,您的支持是我持续更新的最大动力!如果本文对您有帮助,还请多多点赞👍、评论💬和收藏⭐!

有关Verilog的时间系统任务----$time、$stime、$realtime的更多相关文章

  1. ruby - 其他文件中的 Rake 任务 - 2

    我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时

  2. ruby - 如何使用 RSpec::Core::RakeTask 创建 RSpec Rake 任务? - 2

    如何使用RSpec::Core::RakeTask初始化RSpecRake任务?require'rspec/core/rake_task'RSpec::Core::RakeTask.newdo|t|#whatdoIputinhere?endInitialize函数记录在http://rubydoc.info/github/rspec/rspec-core/RSpec/Core/RakeTask#initialize-instance_method没有很好的记录;它只是说:-(RakeTask)initialize(*args,&task_block)AnewinstanceofRake

  3. ruby-on-rails - Ruby 检查日期时间是否为 iso8601 并保存 - 2

    我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby​​是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查

  4. ruby-on-rails - 将 Ruby 中的日期/时间格式化为 YYYY-MM-DD HH :MM:SS - 2

    这个问题在这里已经有了答案:Railsformattingdate(4个答案)关闭4年前。我想格式化Time.Now函数以显示YYYY-MM-DDHH:MM:SS而不是:“2018-03-0909:47:19+0000”该函数需要放在时间中.现在功能。require‘roo’require‘roo-xls’require‘byebug’file_name=ARGV.first||“Template.xlsx”excel_file=Roo::Spreadsheet.open(“./#{file_name}“,extension::xlsx)xml=Nokogiri::XML::Build

  5. ruby - 查找字符串中的内容类型(数字、日期、时间、字符串等) - 2

    我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s

  6. 电脑0x0000001A蓝屏错误怎么U盘重装系统教学 - 2

      电脑0x0000001A蓝屏错误怎么U盘重装系统教学分享。有用户电脑开机之后遇到了系统蓝屏的情况。系统蓝屏问题很多时候都是系统bug,只有通过重装系统来进行解决。那么蓝屏问题如何通过U盘重装新系统来解决呢?来看看以下的详细操作方法教学吧。  准备工作:  1、U盘一个(尽量使用8G以上的U盘)。  2、一台正常联网可使用的电脑。  3、ghost或ISO系统镜像文件(Win10系统下载_Win10专业版_windows10正式版下载-系统之家)。  4、在本页面下载U盘启动盘制作工具:系统之家U盘启动工具。  U盘启动盘制作步骤:  注意:制作期间,U盘会被格式化,因此U盘中的重要文件请注

  7. 【鸿蒙应用开发系列】- 获取系统设备信息以及版本API兼容调用方式 - 2

    在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList​()Obt

  8. kvm虚拟机安装centos7基于ubuntu20.04系统 - 2

    需求:要创建虚拟机,就需要给他提供一个虚拟的磁盘,我们就在/opt目录下创建一个10G大小的raw格式的虚拟磁盘CentOS-7-x86_64.raw命令格式:qemu-imgcreate-f磁盘格式磁盘名称磁盘大小qemu-imgcreate-f磁盘格式-o?1.创建磁盘qemu-imgcreate-fraw/opt/CentOS-7-x86_64.raw10G执行效果#ls/opt/CentOS-7-x86_64.raw2.安装虚拟机使用virt-install命令,基于我们提供的系统镜像和虚拟磁盘来创建一个虚拟机,另外在创建虚拟机之前,提前打开vnc客户端,在创建虚拟机的时候,通过vnc

  9. sql - 查询忽略时间戳日期的时间范围 - 2

    我正在尝试查询我的Rails数据库(Postgres)中的购买表,我想查询时间范围。例如,我想知道在所有日期的下午2点到3点之间进行了多少次购买。此表中有一个created_at列,但我不知道如何在不搜索特定日期的情况下完成此操作。我试过:Purchases.where("created_atBETWEEN?and?",Time.now-1.hour,Time.now)但这最终只会搜索今天与那些时间的日期。 最佳答案 您需要使用PostgreSQL'sdate_part/extractfunction从created_at中提取小时

  10. ruby-on-rails - Rake 任务仅调用一次时执行两次 - 2

    我写了一个非常简单的rake任务来尝试找到这个问题的根源。namespace:foodotaskbar::environmentdoputs'RUNNING'endend当在控制台中执行rakefoo:bar时,输出为:RUNNINGRUNNING当我执行任何rake任务时会发生这种情况。有没有人遇到过这样的事情?编辑上面的rake任务就是写在那个.rake文件中的所有内容。这是当前正在使用的Rakefile。requireFile.expand_path('../config/application',__FILE__)OurApp::Application.load_tasks这里

随机推荐