数电实验 可逆计数器设计

数电实验 可逆计数器设计

在这里插入图片描述

module yyc2018113559_3(clk,clr,x,Q,co,codeout);
input clk,clr,x;  //clk时钟,clr低电平Q清零,x转换加计数与减计数
output reg[6:0] codeout;
output co;  //进位信号
output reg[3:0] Q;

always @(posedge clk,negedge clr)  //敏感信号为clk上升沿,clr下降沿
	if(!clr)  //如果clk为低电平,Q清零
		Q<=4'd0;
	else if(x) // 如果x为高电平,加计数
	begin
		if(Q==4'd9) //Q为9则清零
			Q<=4'd0;
		else
			Q<=Q+4'd1;
	end
	else    //如果x为低电平,减计数
	begin
		if(Q==4'd0) //Q为0则变为9重新开始减计数
			Q<=4'd9;
		else
			Q<=Q-4'd1;
	end

	assign co=(clr & ~x &Q==4'd0)|(x & Q==4'd9); //实现进位

always @(clk) //译码器
begin 
	case(Q)
	4'b0000:codeout=7'b1111110;
	4'b0001:codeout=7'b0110000;
	4'b0010:codeout=7'b1101101;
	4'b0011:codeout=7'b1111001;
	4'b0100:codeout=7'b0110011;
	4'b0101:codeout=7'b1011011;
	4'b0110:codeout=7'b1011111;
	4'b0111:codeout=7'b1110000;
	4'b1000:codeout=7'b1111111;
	4'b1001:codeout=7'b1111011;
	endcase
end


endmodule
  • 6
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

rgb2gray

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值