用Verilog HDL语言设计一个模值可变的计数器?怎样做? 10

 我来答
温文2尔雅
2013-09-30 · TA获得超过476个赞
知道小有建树答主
回答量:119
采纳率:0%
帮助的人:115万
展开全部
其实很简单的,这个和可以设置初始值的计数器实现方法是一样的。如果你能看懂下面这段代码,相信你肯定能写出一个模值可变的计数器了。
module counter7(clk,rst,load,data,cout);
input clk,rst,load;
input [2:0] data;
output reg [2:0] cout;

always@(posedge clk)
begin
if(!rst)
cout<=3’d0;
else if(load)
cout<=data;
else if(cout>=3’d6)
cout<=3’d0;
else
cout<=cout+3’d1;
end
endmodule
这段代码是设计一个可预置初值的7进制循环计数器。按照你的需要,稍微改一下就可以了,这下你应该会了吧?
001号种子
2015-07-27 · 超过39用户采纳过TA的回答
知道小有建树答主
回答量:92
采纳率:0%
帮助的人:75.2万
展开全部
module param_counter(
clk_in, reset, cnt_out
);
input clk_in;
input reset;
output [15:0] cnt_out;
//参数化调用,利用#符号将计数器的模值 10 传入被调用模块
cnt #(10) inst_cnt(
.clk_in(clk_in),
.reset(reset),
83
.cnt_out(cnt_out)
);
endmodule
被例化的参数化计数器的代码如下:
module cnt(
clk_in, reset, cnt_out
);
//定义参数化变量
parameter [15:0]Cmax = 1024;
input clk_in;
input reset;
output [15:0] cnt_out;
reg [15:0] cnt_out;
//完成模值可控的计数器
always @(posedge clk_in) begin
if(!reset)
cnt_out <= 0;
else
if(cnt_out == Cmax)
cnt_out <= 0;
else
cnt_out <= cnt_out + 1;
end
endmodule
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式