找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5977|回复: 0
打印 上一主题 下一主题
收起左侧

verilog中`timescale的定义与作用

[复制链接]
跳转到指定楼层
楼主
ID:105323 发表于 2016-2-23 17:45 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
`timescale是VerilogHDL 中的一种时间尺度预编译指令,它用来定义模块的仿真时的时间单位和时间精度。格式如下:​
`timescale  仿真时间单位/时间精度​​
​注意:用于说明仿真时间单位和时间精度的数字只能是1、10、100,不能为其它的数字。而且,时间精度要比时间单位小最多两个一样大。比如:下面定义都是对的:
`timescale   1ns/1ps
`timescale   100ns/100ns​
下面的定义是错的:
`timescale  1ps/1ns​

​时间精度就是模块仿真时间和延时的精确程序,比如:定义时间精度为10ns,那么时中所有的延时至多能精确到10ns,而8ns或者18ns是不可能做到的。下面举个简单的例子说明一下:
​`timescale 100ns / 10ns
module muti_delay( din, dout1 );
input           din;
output          dout1;
wire           din;

reg             dout1;
always          @(din)
#3.14       dout1 = din;
endmodule​
​我们可以看到,本意是要延时100*3.14=314ns后将din 的值赋给dout1,但是它在310ns 的时候就赋值了,为什么呢?这就是时间精度的问题了。时间精度定义为10ns,因此不能精确到4ns,经过四舍五入后,“#3.14”变成了“#3.1”。当然就是在310ns的时候赋值了!

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表