Intro to Computer Engineering

Studio 5 - Digital Inputs and More Practice with Delta Timing

========

Introduction

Click here to access the Canvas page with the repository for this studio.

Objectives

By the end of this studio, you should know:

========

Push-button inputs

The first thing we’ll do today is explore push-button inputs in more detail. This includes investigating the bouncing properties of the buttons themselves.

Mirror

Complete the sketch called mirror so that it reads the state of the push-button input and sends it to an LED digital output (i.e., flash an LED on when the button is pressed). The program should repeat this operation continuously.

Extend this program to count the number of times the push-button has been pressed. For example, if the button is pressed and released three times it should count to three. You can detect a press either as the input changes from 0 to 1 or as it changes from 1 to 0. Each time the count increases, display the current value of the count in the Serial Monitor.

Does the count always accurately reflect the number of times the button has been pressed?

Debounce

Complete the sketch called debounce so that it reads the state of the push-button using a proper debouncing technique, like the one covered is in this tutorial from Arduino. (This example uses an external resistor as a pull-down. We have been using an internal pull-up, which requires different logic!) In your opinion, does the tutorial use proper delta-time techniques?

Check that your push-button is appropriately debounced by repeating the counting experiment above. What debounce delay is necessary for your push-button to be reliably debounced?

========

Handling More Traffic

The rest of his module’s studio will be a continuation of the Stoplight Delta Timing Studio from Module 3. Replace the stub stoplight.ino with yours from Module 3. Then wire your Arduino to once again have the red, yellow, and green traffic lights, the “walk” light, and the “don’t walk” light as in Module 3’s Studio.

Now update your sketch to include a two-way intersection, like:

image3

It should fairly switch between:

  1. Allowing traffic to go north/south
  2. Allowing traffic to go east/west
  3. Stopping all traffic and allowing pedestrians to cross in either direction

You will need to:

How many states did you include in your new FSM? Draw the FSM you have designed on the FSM designer.

========

Studio Demo 2

The full, two-way stop light with a crossing should work something like this (Again, WALK is Blue, but this time DONT WALK is Yellow):

========

Finish up

  1. Commit your code and verify in your web browser that it is all there.
  2. Get checked out by a TA.

Things that should be present in your repo structure:

========

Key Concepts

Generated at 2025-01-27 03:39:43 +0000.
Page written by Ben Stolovitz and Shuya Ma; Revisions by Bill Siever, Roger Chamberlain, James Orr.