This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
labs:sp20_debounce [2020/05/28 10:34] nelson [Final Questions] |
labs:sp20_debounce [2020/05/28 18:42] (current) nelson [Debounce State Machine] |
||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== Debounce State Machine ====== | + | ====== Sp20 Debounce State Machine ====== |
You will create a debounce state machine and use this state machine to debounce the button on the NEXYS4 board to reliably count the number of times the button is pressed. | You will create a debounce state machine and use this state machine to debounce the button on the NEXYS4 board to reliably count the number of times the button is pressed. | ||
Line 121: | Line 121: | ||
{{ :labs:tb_debounce.v |}} | {{ :labs:tb_debounce.v |}} | ||
- | <color red>Include a copy of your testbench output in your lab report</color> | + | <color red>Include a copy of your testbench output that shows you had 0 errors.</color> |
**Exercise 2 Pass-off:** No passoff, just make sure that you passed the testbench with zero errors.\\ \\ | **Exercise 2 Pass-off:** No passoff, just make sure that you passed the testbench with zero errors.\\ \\ | ||
Line 180: | Line 180: | ||
After completing your top-level module, create a TCL script to simulate at least three "noisy" button presses on your top-level design. Verify that your design counts properly in these noisy button press situations. | After completing your top-level module, create a TCL script to simulate at least three "noisy" button presses on your top-level design. Verify that your design counts properly in these noisy button press situations. | ||
- | <color red>Attach your code and your Tcl script to the Lab Writeup page (there are locations to do so). Your simulation must show the expected behavior of your debounce module. | + | <color red>Attach your Tcl script to the Lab Writeup page. Your simulation must show the expected behavior of your debounce module. |
</color> | </color> | ||
+ | |||
+ | <color red>Attach PDF of your **debounce** SystemVerilog module. </color> | ||
+ | |||
+ | <color red>Attach PDF of your **debounce_top** SystemVerilog module. </color> | ||
**Exercise #3 Pass-Off:** Nothing to be passed off in person. \\ \\ | **Exercise #3 Pass-Off:** Nothing to be passed off in person. \\ \\ | ||
Line 206: | Line 210: | ||
===== Final Pass Off ===== | ===== Final Pass Off ===== | ||
<color green> | <color green> | ||
- | Demonstrate your circuit operating on the FPGA board to the TA. Carefully read through the entire lab and then describe and demonstrates how it meets all requirements you were given. | + | Attach a link to a video demonstrating your circuit operating on the FPGA board. Carefully read through the entire lab and then describe and demonstrates how it meets all requirements you were given. |
- | </color> | + | Be sure to include a demonstration of your characterizing just how bouncy your button is in terms of the % of button pushes that bounce. |
- | + | ||
- | <color green> | + | |
- | Characterize just how bouncy your button is in terms of the % of button pushes that bounce. Use a large enough trials to make your analysis meaningful. Also, create a histogram on paper and show in your video how often, when it bounces, it bounces just twice, three times, etc. What is the largest number of bounces? What is the average? What is the median? | + | |
</color> | </color> | ||