Verilog HDL仿真激励的产生
来源:互联网 发布:天空左岸java 编辑:程序博客网 时间:2024/05/08 17:37
一、变量初始化
变量初始化的基本原则为:可综合代码中完成内部变量的初始化,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语句块中完成。前者符合不规则数据序列,并且要求长度较短;后者适合具有一定规律的数据序列。
- Verilog HDL仿真激励的产生
- Verilog HDL仿真激励的产生
- verilog HDL 仿真错误
- FPGA Verilog HDL格雷码的产生
- (Verilog HDL)如何提高代码的仿真效率
- Verilog HDL常用的行为仿真描述语句(一)
- Verilog HDL常用的行为仿真描述语句(二)
- Verilog HDL常用的行为仿真描述语句(三)
- Verilog HDL常用的行为仿真描述语句(四)
- Verilog HDL常用的行为仿真描述语句(五)
- Verilog HDL常用的行为仿真描述语句(六)
- Verilog HDL常用的行为仿真描述语句
- modelsim仿真verilog HDL 简单命令使用
- Verilog-HDL 的基本概念
- Verilog HDL的建模
- Verilog HDL的Testbench简介
- 关于Verilog HDL的学习
- 基于Verilog HDL的有限状态机
- Spring@Autowired注解与自动装配
- SQL语言艺术(笔记)
- C++多线程(五)
- python os模块
- Android APK反编译详解(附图)
- Verilog HDL仿真激励的产生
- IE6:防止Select等元素遮挡弹出Div层
- Android如何防止apk程序被反编译
- 四大安全会议
- Android学习系列(2)--App自动更新之通知栏下载
- 第17周报告2
- java web应用性能调优
- HUSTOJ随笔
- 实战:sqlserver 日常检查脚本