题目:
假设您正在设计一个电路来控制手机的铃声和振动电机。每当电话需要因来电(输入振铃)而响铃时,您的电路必须打开振铃器(输出振铃器 = 1)或电机(输出电机 = 1),但不能同时打开两者。如果手机处于振动模式(输入 vibrate_mode = 1),则打开电机。否则,请打开振铃器。
尝试仅使用赋值语句,看看是否可以将问题描述转换为逻辑门的集合。
提示:
1.设计电路时,人们常常必须“向后”考虑问题,从输出开始,然后向后推向输入。这通常与人们思考(顺序的、命令式的)编程问题的方式相反,在编程问题中,人们首先查看输入,然后决定操作(或输出)。对于顺序程序,人们通常会想到“如果(输入是 ___ )那么(输出应该是 ___ )”。另一方面,硬件设计者经常认为“当(输入是 ___ )时(输出应该是 ___ )”。
2.上面的问题描述是以适合软件编程的命令式形式编写的(如果是ring,则执行此操作),因此必须将其转换为适合硬件实现的更具声明性的形式(分配ringer = ___)。能够思考并在两种风格之间进行转换是硬件设计所需的最重要的技能之一。
思路:
题目也就是一个简单的逻辑,当来电且振动模式关闭时响铃,当来电且振动模式开启时振动。
用软件思路和硬件思路编写。
1.软件思路就是always块里面作判断,if,case都可以。
2.硬件思路就是用赋值语句进行逻辑门的组合。
解答:
1软件思路,2硬件思路:
总结:
正如提示中说到的,逆向考虑,以及软硬转换都是很重要的思路。
硬件中的逻辑,本人总爱用串联后与二进制数值作判断,不知道是否有什么不好的地方。