The next natural task
would be a Stopwatch with Lap-time (mellemtid på dansk) - Please
try my solution and make your own adjustment if you like. For
instance could "Hours" be included in the time as well - but
this call for some adjustment at the Display driver in order to
select between Hours: Minutes: Seconds.
A more advanced (and
harder task) could be a combined Watch + Stopwatch with the
ability to set the Time of the Watch.
If you try to solve this
problem with ONE HUGE State Machine are you bound to fail -
(Don't even try) - However could the control-part of the watch
be formed with a State Machine (An exercise to come)
Instead must you try to decompose the Problem into natural
elements which each solves a part of the problem and are able to
interact with each others.
The Schematic of my
solution shown beneath and could act as inspiration.
|
|
|
|
The VHDL source code
for Muxdisplay_ver3 can be found here:
Muxdisplay_ver3.vhd
|
|
|
data:image/s3,"s3://crabby-images/a69c5/a69c526bd21addf51d7722844d9d14eb75ccaff6" alt="" |
The Toggle_Button3 a State
Machine which controlled by the "Button" input and
removes eventually bouncing from the contact with a
4-bit shiftregister (not part of the State Machine).
The six internal states
produces three outputs:
Toggle: Changes state for each press
of the button.
Deboun: Will be "1" when the button
pressed or else "0" (Debouched button)
Pulse: Like
Deboun but will only be "1" for one Clk period after
a press.
|
|
|
data:image/s3,"s3://crabby-images/5e538/5e5383c5746ddb3dd048967a4b47bfe59ee5435a" alt=""
|
In order to
use the 1 kHz frequency from the MuxDisplay and
produce a 4-bit Bcd output with 1/10 of second
resolution will this be a good component to have.
The "En" input
controls the counter and Clear works asynchronous
(hence the name). Rco will be "1" when the counter
reaches 999 and En='1'
|
|
|
data:image/s3,"s3://crabby-images/b0f24/b0f2462bc3cf362e733ef6800b5bd78e80fc7cda" alt="" |
As the En input only will
be high for one Clock pulse each second will this
counter accumulate the Second-part of the time.
The same component used for the Minutes-part as
well.
Rco will be "1" when the
counter reaches 59 and En='1' otherwise "0"
|
|
|
data:image/s3,"s3://crabby-images/8ba70/8ba70280efcec659ad56476a658ae45447a11b5f" alt="" |
This component produces a
"Running light" at the leds in order to present the
1/10 of seconds.
Consider if this
functionality should be placed elsewhere in the
diagram.
|
|
|
data:image/s3,"s3://crabby-images/829b9/829b9ada37ec9e084cd64f34260ee88403d9cc04" alt="" |
In order to "freeze" the
display for presentation of a Lap-time will the best
solution properly be a x-bit Latch which allows the
time-data to pass by under normal condition and hold
the display each time the Latch high.
|
|
|
data:image/s3,"s3://crabby-images/484a2/484a292bdeafd036d60fc8b81c7bf7552418e17d" alt="" |
Just as an extra feature
would it be nice to have the display-dots perform
some kind of blinking in order to indicate the
different states of the Watch.
|
|
|