[吾题有解] HDLBits : Lemmings2

张开发
2026/4/19 18:32:53 15 分钟阅读

分享文章

[吾题有解] HDLBits : Lemmings2
旅鼠四题中的第二题直接说关键点。首先是要搞清楚有几个状态它们分别是向左LEFT、向右RIGHT、下落中保持向左FALL_L和下落中保持向右FALL_R四个状态。接下来是明白输入如何影响次态处于地面状态LEFT、RIGHT时当ground 0下一个状态进入保持当前方向的下落状态分别对应FALL_L、FALL_R处于下落状态时当ground 1下一个状态进入保持当前方向的地面状态。其中的关键是旅鼠进入、脱离下落状态以及处于下落状态中时不受碰撞信号的影响。所以判断次态要首先确定ground信号值在现态为地面状态时若为1则正常碰撞判定/次态为下落状态若为0进入下落状态在现态为下落状态时只考虑ground若为1则回到当前方向地面状态若为0不受其他信号影响保持当前方向下落状态。Being bumped while falling does not affect the walking direction, and being bumped in the same cycle as ground disappears (but not yet falling), or when the ground reappears while still falling, also does not affect the walking direction.最后是输出采用组合逻辑连续赋值语句描述相比于前一题添加了一个下落时输出“aaah”这里唯一要注意的是无论下落中保持向左还是向右均要输出“aaah”。最后给出本题的Veirlog HDLmoduletop_module(input clk,input areset,// Freshly brainwashed Lemmings walk left.input bump_left,input bump_right,input ground,output walk_left,output walk_right,output aaah);localparam LEFT4b0001,// One-HotRIGHT4b0010,FALL_L4b0100,FALL_R4b1000;reg[3:0]state;reg[3:0]next_state;// 时序逻辑描述状态切换always (posedge clk or posedge areset)if(areset)stateLEFT;elsestatenext_state;// 组合逻辑描述次态判断always (*)begincase(state)LEFT:next_state~ground?FALL_L:(bump_left?RIGHT:LEFT);RIGHT:next_state~ground?FALL_R:(bump_right?LEFT:RIGHT);FALL_L:next_stateground?LEFT:FALL_L;FALL_R:next_stateground?RIGHT:FALL_R;endcase end// 组合逻辑描述输出信号assign walk_left(stateLEFT);assign walk_right(stateRIGHT);assign aaah(stateFALL_L)||(stateFALL_R);endmodule总结其实组合逻辑次态判断部分也不是一开始就想出来的最开始是使用case语句对输入集合{bump_left, bump_right, ground}的8种情况从3’b000~3’b111逐个确定输出写了两个状态之后才发现可以精简为上述代码逻辑也变得更加清晰。启发是在解决问题的时候可以不必一开始就追求最优解法而是尝试先写出一个解明白了其中蕴含的逻辑后再视情况进行优化。

更多文章