HDLBits刷题(3_1_1_13)Ringer

题目:

假设您正在设计一个电路来控制手机的铃声和振动电机。每当电话需要因来电(输入振铃)而响铃时,您的电路必须打开振铃器(输出振铃器 = 1)或电机(输出电机 = 1),但不能同时打开两者。如果手机处于振动模式(输入 vibrate_mode = 1),则打开电机。否则,请打开振铃器。

尝试仅使用赋值语句,看看是否可以将问题描述转换为逻辑门的集合。


提示:

1.设计电路时,人们常常必须“向后”考虑问题,从输出开始,然后向后推向输入。这通常与人们思考(顺序的、命令式的)编程问题的方式相反,在编程问题中,人们首先查看输入,然后决定操作(或输出)。对于顺序程序,人们通常会想到“如果(输入是 ___ )那么(输出应该是 ___ )”。另一方面,硬件设计者经常认为“当(输入是 ___ )时(输出应该是 ___ )”。

2.上面的问题描述是以适合软件编程的命令式形式编写的(如果是ring,则执行此操作),因此必须将其转换为适合硬件实现的更具声明性的形式(分配ringer = ___)。能够思考并在两种风格之间进行转换是硬件设计所需的最重要的技能之一。


思路:

题目也就是一个简单的逻辑,当来电且振动模式关闭时响铃,当来电且振动模式开启时振动。

用软件思路和硬件思路编写。

1.软件思路就是always块里面作判断,if,case都可以。

2.硬件思路就是用赋值语句进行逻辑门的组合。


解答:

1软件思路,2硬件思路:


 总结:

正如提示中说到的,逆向考虑,以及软硬转换都是很重要的思路。

硬件中的逻辑,本人总爱用串联后与二进制数值作判断,不知道是否有什么不好的地方。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值