Gra polegająca na dopasowaniu liczby binarnej do dziesiętnej: 10 kroków
Gra polegająca na dopasowaniu liczby binarnej do dziesiętnej: 10 kroków
Anonim
Image
Image
Konfigurowanie dzielnika zegara
Konfigurowanie dzielnika zegara

Ta instrukcja pokaże proces i moduły wymagane do stworzenia naszej gry dopasowywania binarnego do dziesiętnego. W ciągu 60 sekund użytkownicy przetłumaczą i wprowadzą jak najwięcej losowo wygenerowanych liczb dziesiętnych na siedmiosegmentowym wyświetlaczu na binarne, przełączając przełączniki i przesyłając za pomocą przycisku zgadywania. Po zakończeniu zostanie wyświetlony końcowy wynik, a następnie zresetowany, aby zagrać ponownie.

Zrozumienie odruchów binarnych i szybkich jest korzystne, ale przycisk resetowania jest dostępny na wypadek, gdyby ktoś chciał natychmiast spróbować ponownie.

Krok 1: Konfiguracja dzielnika zegara

Podstawą całego projektu jest poprawna synchronizacja wszystkich części tego gadżetu. Nasz automat skończony korzysta z wewnętrznego zegara, ale siedmiosegmentowy wyświetlacz i timer muszą używać zmienionej wersji zegara.

Ten „nowy zegar” pochodzi z podzielenia wewnętrznego zegara przez pożądany okres, aby osiągnąć określoną częstotliwość potrzebną dla każdego konkretnego komponentu. Zostało to zrobione w poprzednich laboratoriach i z doświadczenia wiemy, że zegar ma cyfrę „jedną” ustawioną na 0,1 Hz, a cyfra „dziesiątek” to 1 Hz

Wejścia: ClkIn, dzielnik (32 bity)

Wyjścia: ClkOut

Krok 2: Tworzenie maszyny skończonej (FSM)

Tworzenie maszyny skończonej (FSM)
Tworzenie maszyny skończonej (FSM)
Tworzenie maszyny skończonej (FSM)
Tworzenie maszyny skończonej (FSM)
Tworzenie maszyny skończonej (FSM)
Tworzenie maszyny skończonej (FSM)

W naszej maszynie skończonej zdecydowaliśmy, że pięć stanów (Start, Display, Check, Score i End) będzie potrzebnych z pięcioma wejściami (start, reset, odgadnięcie, równy, limit czasu). Jedynym wyjściem w naszym Maszynie Stanu jest 3-bitowa liczba, która reprezentuje stan użytkownika (000, 001, 011, 101, 100) w odniesieniu do poniższych stanów.

Pamiętaj, że Automat skończony w rzeczywistości nie wykonuje poniższych funkcji, zamiast tego po prostu mówi, w jakim stanie znajduje się program i jaki. O tym, co się faktycznie dzieje, decyduje górny moduł wyjaśniony poniżej.

Stan początkowy (000)

Stan początkowy to stan, w którym użytkownik rozpocznie pracę, dopóki wejście startowe nie będzie wysokie, jest to również stan, który zostanie osiągnięty po naciśnięciu przycisku resetowania.

Stan gry (001)

Stan gry to początek gry, w której generowana jest liczba losowa, a użytkownik przełącza przełączniki, aby utworzyć dane wejściowe. Po naciśnięciu przycisku zgadywania gra przechodzi w stan sprawdzania.

Sprawdź stan (011)

W tym stanie używany jest komparator, który porównuje wartości danych wejściowych użytkownika i losowo wygenerowaną liczbę. Jeśli zgłoszenie jest poprawne, równa wartość jest wysoka i FSM przechodzi do stanu punktacji; jeśli jednak zgłoszenie jest nieprawidłowe, FSM powraca do stanu wyświetlania, dopóki zgłoszenie nie będzie poprawne.

Ten stan sprawdzania zachodzi stosunkowo szybko w porównaniu z innymi, ponieważ występuje tylko tak długo, jak przycisk sprawdzania jest wciśnięty

Stan wyniku (101)

Ponieważ równa wartość jest wysoka, zgłoszenie było prawidłowe. W tym stanie wartość wyniku wzrośnie o jeden i zostanie wygenerowana nowa liczba do wprowadzenia przez użytkownika. Ten nowy numer przenosi nas z powrotem do stanu początkowego, w którym użytkownik ponownie przełącza przełączniki.

Stan końcowy (100)

Po upływie 60-sekundowego odliczania limit czasu będzie wysoki, a użytkownik osiągnie stan końcowy, w którym wyświetlany jest końcowy wynik. Wejście resetowania zostanie następnie wciśnięte i FSM ponownie uruchomi się w stanie startu.

Wejścia: Clk, rst, start, zgadnij, równe, limit czasu

Wyjście: stan (3 bity)

Krok 3: Mapowanie wyświetlacza siedmiosegmentowego

Mapowanie wyświetlacza siedmiosegmentowego
Mapowanie wyświetlacza siedmiosegmentowego
Mapowanie wyświetlacza siedmiosegmentowego
Mapowanie wyświetlacza siedmiosegmentowego
Mapowanie wyświetlacza siedmiosegmentowego
Mapowanie wyświetlacza siedmiosegmentowego

Wyświetlacz siedmiosegmentowy jest kluczową częścią całego projektu, ponieważ dwie pierwsze cyfry na ekranie są używane jako wyjście generatora liczb losowych, a dwie ostatnie cyfry to licznik czasu. Chociaż zaimplementowaliśmy przykład tego w ostatnim laboratorium pod względem wyświetlania cyfr na ekranie, był on wyświetlany w systemie szesnastkowym. Aby rozwiązać ten problem, użyliśmy konwertera i dzielnika zegara, co zostało dokładniej wyjaśnione poniżej.

Wyświetlacz pokazuje wszystkie zera, dopóki FSM nie wejdzie w stan gry; jednak w stanie końcowym wyświetlacz powinien pokazywać tylko wynik użytkownika.

Ponieważ używamy wszystkich czterech cyfr na siedmiosegmentowym wyświetlaczu, musimy przechodzić przez każdą anodę wystarczająco szybko przy 300 Hz, aby być postrzeganym jako zawsze podświetlony.

Wejścia: Clk, siedmiosegmentowe

Wyjścia: katody (7 bitów), anody (4 bity)

Krok 4: Tworzenie komparatora

Tworzenie komparatora
Tworzenie komparatora

Ten submoduł jest używany w stanie kontrolnym w zakresie porównywania 7-bitowego zgadywania wprowadzonego binarnie z rzeczywistą wartością dziesiętną.

Mieliśmy stwierdzenie if, które oceniało zarówno dane wejściowe, jak i dwa wyniki w zależności od tego, czy równa wartość była wysoka, czy niska. Równie ważny jak ten moduł, jest zdecydowanie jednym z prostszych programów do zaprojektowania w tym projekcie.

Wejścia: przełączniki (8 bitów), numer (8 bitów)

Wyjście: EQ

Krok 5: Konfigurowanie timera

Konfigurowanie timera
Konfigurowanie timera
Konfigurowanie timera
Konfigurowanie timera

Nasz zegar to zasadniczo dwa różne liczniki, które rosną w różnym tempie. Jeden licznik wartości „jedynki” (pierwszy wyświetlacz siedmiosegmentowy) i jeden licznik wartości „dziesiątki” (druga cyfra na wyświetlaczu siedmiosegmentowym). Każda cyfra jest oparta na rosnącej krawędzi zegara, a gdy licznik osiągnie 60 sekund, time_out będzie wysoki, a gra zakończy się i powróci do stanu początkowego.

Wejścia: Clk, state (3 bity), start

Wyjścia: prądowe (8 bitów), limit czasu

Krok 6: Projektowanie generatora pseudolosowych liczb

Projektowanie generatora pseudolosowych liczb
Projektowanie generatora pseudolosowych liczb

Inną alternatywną metodą generatora liczb specjalnie dla tego przypadku jest posiadanie powtarzającego się licznika od 0-99 (w postaci binarnej), który wyprowadza zliczoną liczbę, gdy wejście jest wysokie, ponieważ wyeliminowałoby to potrzebę korzystania z LFSR.

Liczba zmienia się przy każdym rosnącym zboczu wewnętrznego zegara (10 nanosekund) i przechodzi przez wszystkie 100 liczb w ciągu jednej mikrosekundy. Za każdym razem, gdy użytkownik chce nowego numeru z generatora liczb, wyświetla numer, na którym był, Chociaż proces ten nie jest całkowicie losowy, prawdopodobieństwo znalezienia powiązanych wyników tego procesu jest na tyle niskie, że jest pseudolosowe.

Wejścia: Clk, changenum, równe

Wyjścia: liczba (8 bitów)

Krok 7: Tworzenie konwertera

Tworzenie konwertera
Tworzenie konwertera

Niezbędnym komponentem jest Konwerter, którego użyliśmy do wyświetlania liczb dziesiętnych na wyświetlaczu siedmiosegmentowym zamiast oryginalnego szesnastkowego. Chociaż obie liczby są oparte na 7-bitowej liczbie binarnej, stworzyliśmy cały moduł przeznaczony do konwersji liczb szesnastkowych na dziesiętne.

Na przykład, jeśli naszym ostatecznym wynikiem dla wyniku będzie 0010001 (siedemnaście), wyświetlacz siedmiosegmentowy pokaże wartość szesnastkową 11 zamiast liczby dziesiętnej 17.

Wejście: Numin (8 bitów)

Wyjście: Numout (8 bitów)

Krok 8: Składanie wszystkiego razem w module gry

Składanie wszystkiego razem w module gry
Składanie wszystkiego razem w module gry
Składanie wszystkiego razem w module gry
Składanie wszystkiego razem w module gry
Składanie wszystkiego razem w module gry
Składanie wszystkiego razem w module gry
Składanie wszystkiego razem w module gry
Składanie wszystkiego razem w module gry

W przypadku naszych komponentów użyliśmy niezbędnych przełączników 0–6, które użytkownik może przełączać, a trzy przyciski działają jako wejścia użytkownika do uruchamiania, resetowania i zgadywania. Siedmiosegmentowy wyświetlacz i komponenty zegara są również komponentami, które zrobiliśmy z poprzednich laboratoriów, ale musieliśmy je zmienić, aby pasowały do tego projektu.

Podzieliliśmy ten projekt na sześć modułów pokazanych powyżej, aby rozbić cały gadżet na wiele działających części, jednak sposób ich połączenia jest dość skomplikowany i jest pokazany na załączonym obrazku czarnej skrzynki.

Podczas gry świeci się 7 diod LED, aby powiadomić użytkownika, którego przełącznika użyć, a gdy gra się kończy, zaprogramowaliśmy również miganie diod LED

Wejścia: przełączniki (8 bitów), Clk, reset, start, zgadywanie

Wyjścia: katody (7 bitów), anody (4 bity), diody LED (7 bitów)

Krok 9: Napotkane dodatkowe problemy

Chociaż w tej grze używanych jest tylko siedem przełączników, w kodzie jest to liczba 8-bitowa. Zrobiliśmy to, aby mieć wygodniejszy komparator, który porównywałby te 8 bitów z 8-bitową liczbą, którą wygenerowaliśmy z generatora liczb losowych.

Na początku wynik przysporzył nam również trochę kłopotów, ponieważ ustawiliśmy go na zwiększenie o jeden punkt, gdy FSM był w stanie wyniku; Jednak zamiast tego wynik rósł tak długo, jak stan był włączony, co dało nam nieracjonalnie wysoki wynik, z którym nie mogliśmy sobie poradzić. Naprawiliśmy to, dodając sygnał impulsowy, który był zsynchronizowany z narastającym zboczem zegara, jak widać w kodzie w kroku 8.

Wreszcie, debugowanie timera zajęło dużo czasu, ponieważ zniekształcało nasz siedmiosegmentowy wyświetlacz podczas odliczania, więc musieliśmy zmienić go z odliczania od 60 na odliczanie od 0.

Krok 10: Pliki źródłowe i ograniczenia

Jeśli wolisz pobierać z naszych plików źródłowych zamiast tworzyć własne, oto one. Dołączony jest również plik ograniczenia.

Zalecana: