当前位置: 首页 > news >正文

建设网站需要多少钱济南兴田德润地址各种手艺培训班

建设网站需要多少钱济南兴田德润地址,各种手艺培训班,wordpress点击图片缩放,律所网站建设要求书文章目录 参数方式定义参数的优势rtl模块中的参数定义模块名后定义参数parameter定义参数 仿真模块中的参数修改例化时修改defparam修改 总结与说明附录:测试代码 参数方式定义参数的优势 当一个模块被另一个模块引用例化时,高层模块可以对低层模块的参…

文章目录

  • 参数方式定义参数的优势
  • rtl模块中的参数定义
    • 模块名后定义参数
    • parameter定义参数
  • 仿真模块中的参数修改
    • 例化时修改
    • defparam修改
  • 总结与说明
  • 附录:测试代码

参数方式定义参数的优势

当一个模块被另一个模块引用例化时,高层模块可以对低层模块的参数值进行改写。这样就允许在编译时将不同的参数传递给多个相同名字的模块,而不用单独为只有参数不同的多个模块再新建文件。

参数覆盖有 2 种方式:1)使用关键字 defparam,2)例化时修改:带参数值模块例化。

使用参数的方式定义常量有很多好处,如:

  1. 我们在RTL代码中实例化该模块时,如果需要两个不同计数值的计数器我们不必设计两个模块,而是直接修改参数的值即可

  2. 另一个好处是在编写Testbench进行仿真时我们也需要实例化该模块,但是我们需要仿真至少0.5s的时间才能够看出到led_out效果,这会让仿真时间很长,也会导致产生的仿真文件很大,所以我们可以通过直接修改参数的方式来缩短仿真的时间而看到相同的效果,且不会影响到RTL代码模块中的实际值,因为parameter定义的是局部参数,所以只在本模块中有效。

为了更好的区分,参数名我们习惯上都是大写。

rtl模块中的参数定义

模块名后定义参数

格式:

#(
parameter CNT_MAX = 25’d100,
parameter CNT_MAX_5 = CNT_MAX - 5
)


#+()
()内用parameter 参数名 = XX
()内的参数间用逗号分隔,最后一个参数后没有逗号

举例:

module test
#(
parameter CNT_MAX = 25'd100,
parameter CNT_MAX_5 = CNT_MAX - 5)(input wire sys_clk , //系统时钟50MHzinput wire sys_rst_n , //全局复位output reg led_out //输出控制led灯);

parameter定义参数

格式:

parameter 参数名 = XX;

不同参数定义用分号结束语句

举例:

//=========================< Parameter >==============================parameter 				CNT_MAX		=	25'd100		    	;parameter 				CNT_MAX_5 	= 	CNT_MAX - 5			;

仿真模块中的参数修改

例化时修改

格式:

#(
.CNT_MAX (25’d24 ),
.CNT_MAX_5(25’d19)
)


#+()
()内用 .参数名(修改后的数值)
()内的参数间用逗号分隔,最后一个参数后没有逗号

举例:

test#(.CNT_MAX (25'd24 ),.CNT_MAX_5(25'd19))counter_inst(.sys_clk (sys_clk ), //input sys_clk.sys_rst_n (sys_rst_n ), //input sys_rst_n.led_out (led_out ) //output led_out);

也可以去掉参数名,按顺序进行参数例化(但是不建议哦,不方便阅读):

#(25'd24,25'd19)

defparam修改

格式:

defparam counter_inst.CNT_MAX = 25’d24 ;
defparam counter_inst.CNT_MAX_5 = 25’d19 ;


defparam 模块例化的参数名.模块中的参数 = 数值;
不同修改参数用分号结束语句

举例:

//=========================< Parameter >==============================
defparam 			counter_inst.CNT_MAX	=		25'd24	    	;
defparam 			counter_inst.CNT_MAX_5	=		25'd19			;test counter_inst(.sys_clk 	(sys_clk 	), //input sys_clk.sys_rst_n 	(sys_rst_n 	), //input sys_rst_n.led_out 	(led_out 	) //output led_out);

总结与说明

  1. 参数定义(两种方法)和仿真模块中的参数修改(两种方法)可以选择使用,共四种对应写法。
参数定义参数修改
模块名后定义参数例化时修改
模块名后定义参数defparam修改
parameter定义参数例化时修改
parameter定义参数defparam修改
  1. 如果rtl模块中既有模块名后定义参数又有parameter定义参数,用defparam修改会报错,用例化时修改不报错。具体看建议与区别部分(4)

  2. 使用建议用模块名后定义参数例化时修改这一对应方案。

rtl中:

module test
#(
parameter CNT_MAX = 25'd100,
parameter CNT_MAX_5 = CNT_MAX - 5)(input wire sys_clk , //系统时钟50MHzinput wire sys_rst_n , //全局复位output reg led_out //输出控制led灯);

仿真代码中:

test#(.CNT_MAX (25'd24 ),.CNT_MAX_5(25'd19))counter_inst(.sys_clk (sys_clk ), //input sys_clk.sys_rst_n (sys_rst_n ), //input sys_rst_n.led_out (led_out ) //output led_out);

附录:测试代码

rtl部分:

module test
#(
parameter CNT_MAX = 25'd100,
parameter CNT_MAX_5 = CNT_MAX - 5)(input wire sys_clk , //系统时钟50MHzinput wire sys_rst_n , //全局复位output reg led_out //输出控制led灯);/* 	//=========================< Parameter >==============================parameter 				CNT_MAX		=	25'd100		    	;parameter 				CNT_MAX_5 	= 	CNT_MAX - 5			;*/reg [24:0] cnt; //cnt:计数器计数,当计数到CNT_MAX的值时清零always@(posedge sys_clk or negedge sys_rst_n)if(sys_rst_n == 1'b0)cnt <= 25'b0;else if(cnt == CNT_MAX)cnt <= 25'b0;elsecnt <= cnt + 1'b1;//led_out:输出控制一个LED灯,每当计数满标志信号有效时取反always@(posedge sys_clk or negedge sys_rst_n)if(sys_rst_n == 1'b0)led_out <= 1'b0;else if(cnt == CNT_MAX_5)led_out <= ~led_out;endmodule

仿真部分:

`timescale 1ns/1ns
module tb_test();//reg define
reg sys_clk;
reg sys_rst_n;//wire define
wire led_out;//初始化输入信号initial beginsys_clk = 1'b1;sys_rst_n <= 1'b0;#20sys_rst_n <= 1'b1;end//sys_clk:每10ns电平翻转一次,产生一个50MHz的时钟信号always #10 sys_clk = ~sys_clk;/* 	//=========================< Parameter >==============================defparam 			counter_inst.CNT_MAX	=		25'd25	    	;defparam 			counter_inst.CNT_MAX_5	=		25'd20			;*///---------------------flip_flop_inst----------------------test
/*  #(25'd24,25'd19)*/#(.CNT_MAX (25'd23 ),.CNT_MAX_5(25'd20)//实例化带参数的模块时要注意格式,当我们想要修改常数在//当前模块的值时,直接在实例化参数名后面的括号内修改即可)counter_inst(.sys_clk 	(sys_clk 	), //input sys_clk.sys_rst_n 	(sys_rst_n 	), //input sys_rst_n.led_out 	(led_out 	) //output led_out);endmodule
http://www.khdw.cn/news/19879.html

相关文章:

  • 滕州网站制作seo模拟点击算法
  • 全网营销的概念和特点优化关键词首页排行榜
  • 上海建设官方网站营销技巧第三季
  • 二手房简单翻新装修要多少钱网站排名seo培训
  • 网站开发优秀论文百度基木鱼建站
  • 用源代码做网站seo高端培训
  • 寒亭区住房和城乡建设局网站安徽网站关键词优化
  • 免费小说网站怎么做促销活动推广方案
  • Python爬取wordpress青岛网站seo优化
  • 怎么建设一个人自己网站郑州网站制作选择乐云seo
  • 优秀品牌策划方案360手机优化大师安卓版
  • 制作钓鱼网站属于什么罪河源网站seo
  • 网站 手机版 电脑版 怎么做网站竞价推广
  • 郑州英语网站建设单页网站制作教程
  • 网页设计师招聘条件沙坪坝区优化关键词软件
  • 做360网站快速排名软件台州网站seo
  • 城乡和住房建设厅网站首页深圳网络推广营销公司
  • 网站模版建站百度搜索排行榜
  • 定制网站建设简介天津优化代理
  • 东营建设网站公司电话号码seo搜索引擎优化方法
  • 快速搭建外贸网站永久免费国外域名注册
  • 个人做网站法律风险优化是什么意思
  • 公司网站建设服务费计入什么科目武汉seo 网络推广
  • 杭州做网站的谷歌竞价推广教程
  • 网站建设的前期工作基础买淘宝店铺多少钱一个
  • 怎么选择一家好的网站建设公司ui设计培训班哪家好
  • 网站数据库备份还原太原seo自媒体
  • 长春建站企业产品宣传推广方案
  • 巴中市建设局网站怎么在百度发布免费广告
  • 优服优科网站建设公司自己建网站要多少钱