毛豆仙人 2023-10-02 13:53 采纳率: 75%
浏览 6
已结题

为什么仿真后计数器只在零和一之间跳变


module breath_led(input clk,
input res,
output reg led,
output reg counter1,
output reg counter10);
reg flag=1'b0;
reg c2=5'd1;

always@(posedge clk)
begin
if(!res)
counter1<=0;
else
counter1<=counter1+1;
end

always@(posedge clk)
begin
if(!res)
counter10<=0;
else
counter10<=counter10+1;
end

always@(posedge clk)
begin
if(counter1==4'd9)
counter10<=0;

if(counter10==4'd9&&flag==1'b0)
begin
counter10<=0;
c2<=c2+1;
end
if(counter10==4'd9&&flag==1'b1)
begin
counter10<=0;
c2<=c2-1;
end
if(c2==5'd11||c2==1'd0)
flag<=~flag;
end

always@(posedge clk)
begin
if(counter1<c2)
led<=1'b1;
else
led<=1'b0;
end
endmodule

我想写一个呼吸灯,让灯在每个大周期(10个时钟内)亮起的时间递增,但是这个计数器实在搞不懂。

img

  • 写回答

2条回答 默认 最新

  • 老皮芽子 2023-10-02 17:00
    关注

    你定义的计时器的位宽只有1位,计时器只能在0-1之间变化
    你需要这样,将计时器定义成多位
    output reg [3:0] counter1;
    另外,counter10 你在多个 always 中 赋值,这是不允许的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月11日
  • 已采纳回答 10月3日
  • 创建了问题 10月2日

悬赏问题

  • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
  • ¥15 安装quartus II18.1时弹出此error,怎么解决?
  • ¥15 keil官网下载psn序列号在哪
  • ¥15 想用adb命令做一个通话软件,播放录音
  • ¥30 Pytorch深度学习服务器跑不通问题解决?
  • ¥15 部分客户订单定位有误的问题
  • ¥15 如何在maya程序中利用python编写领子和褶裥的模型的方法
  • ¥15 Bug traq 数据包 大概什么价
  • ¥15 在anaconda上pytorch和paddle paddle下载报错
  • ¥25 自动填写QQ腾讯文档收集表