找回密码
 注册
关于网站域名变更的通知
查看: 430|回复: 1
打印 上一主题 下一主题

[仿真讨论] Verilog HDL仿真激励的产生介绍

[复制链接]
  • TA的每日心情
    开心
    2020-9-2 15:04
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    跳转到指定楼层
    1#
    发表于 2020-12-8 10:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x

    一、变量初始化

    变量初始化的基本原则为:可综合代码中完成内部变量的初始化,Testbench中完成可综合代码所需的各类接口信号的初始化。

    初始化的方法有两种:一种是通过initial语句块初始化;另一种是在定义时直接初始化。

    当initial语句块中有多条语句时,需要用begin…end或者fork…join语句。

    直接初始化,如:reg [7:0] cnt = 8'b00000000;

    二、时钟信号的产生

    1、普通时钟信号:

    a. 基于initial语句的方法:

    parameter clk_period = 10; reg clk; initial begin clk = 0; forever #(clk_period/2) clk = ~clk; end

    b. 基于always语句的方法:

    parameter clk_period = 10; reg clk; initial clk = 0; always #(clk_period/2) clk = ~clk;

    2、自定义占空比的时钟信号:

    parameter High_time = 5,Low_time = 20; // 占空比为High_time/(High_time+Low_time) reg clk; always begin clk = 1; #High_time; clk = 0; #Low_time; end

    3、相位偏移的时钟信号:

    parameter High_time = 5,Low_time = 20,pshift_time = 2; // 相位偏移为360*pshift_time/(High_time+Low_time) reg clk_a; wire clk_b; always begin clk_a = 1; #High_time; clk_a = 0; #Low_time; end assign #pshift_time clk_b = clk_a;

    4、固定数目的时钟信号:

    parameter clk_cnt = 5, clk_period = 2; reg clk; initial begin clk = 0; repeat(clk_cnt) #(clk_period/2) clk = ~clk; end

    三、复位信号的产生

    1、异步复位信号:

    parameter rst_repiod = 100; reg rst_n; initial begin rst_n = 0; #rst_repiod; rst_n = 1; end

    2、同步复位信号:

    parameter rst_repiod = 100; reg rst_n; initial begin rst_n = 1; @(posedge clk) rst_n = 0; #rst_repiod; rst_n = 1; end

    四、数据信号的产生

    数据信号的产生主要有两种形式:一、初始化和产生都是在initial块中进行;二、初始化在initial语句中完成,而产生却在always语句块中完成。前者符合不规则数据序列,并且要求长度较短;后者适合具有一定规律的数据序列。


    * b3 |+ ~9 W8 y/ d* e/ k3 H; y

    该用户从未签到

    2#
    发表于 2020-12-8 13:11 | 只看该作者
    数据信号的产生主要有两种形式
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-7-7 13:34 , Processed in 0.109375 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

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