VHDL En minuts stoppur: 5 steg
VHDL En minuts stoppur: 5 steg
Anonim
Image
Image

Det här är en handledning om hur du bygger ett stoppur på en minut med VHDL och ett Basys 3 -kort. En sådan enhet är idealisk för spel där varje spelare har högst en minut på sig att göra sitt drag. Stoppuret visar exakt sekunder och millisekunder på sjusegmentsdisplayen, från 0 sekunder och 0 millisekunder, upp till 60 sekunder och 0 millisekunder. Två knappar används också: den centrala knappen, som används för att starta, stoppa och fortsätta timern, och den högra knappen, som används för att starta om timern. När enheten jämförs sida vid sida med den inbyggda stoppuret på en smart telefon märks klockans noggrannhet.

Steg 1: Skaffa hårdvara/programvara

Blockdiagram
Blockdiagram

1. Basys 3 Artix-7 FPGA Trainer Board från Digilent med Micro-USB till USB-kabel

2. Vivado 2016.2 Design Suite från Xilinx

Steg 2: Block Diagram

Denna krets är konstruerad beteendemässigt och använder inbyggda Xilinx-komponenter, men kan också beskrivas strukturellt, vilket framgår av det allmänna strukturdiagrammet ovan. Av diagrammet kan man se att kretsen drivs av två frekvensdelare. En av frekvensdelarna körs på 1 centisekund och driver katodräknaren som används som siffrorna som visas på sjusegmentsdisplayen. Den andra frekvensdelaren körs på 240Hz och används för att driva anodräknaren som roterar genom anoderna så att alla siffror visas korrekt på sjusegmentsdisplayen. Kodaren tar katodlogiken från katodräknaren och anodlogiken från anodräknaren och kodar den till utgångens katod och anod som kör sjusegmentsdisplayen. Funktionen för denna kodare är att katodutgången ändras varje gång anodutgången ändras. Katodutgången kan inte köras oberoende av räknaren eftersom anoderna måste rotera genom de fyra separata siffrorna.

Steg 3: Projektmodul

För det första görs ett processblock för CEN så att när en knapptryckning upptäcks växlar ENABLE. Detta fungerar som stopp/start av katodräknaren.

I nästa processblock ställs centisekund- och 240Hz -klocksignalerna så att deras respektive räknare ökar med 1 varje gång den interna 100mHz -klockan når en stigande kant. När centisekundräknaren når 500000, återställs den till 0. Samtidigt skulle 240Hz -räknaren återställas när räkningen når 41667.

För katodsektionen i koden, om ENABLE är '0', kommer katodräkningen att pausas. Om återställningsknappen trycks in under denna tid återställs alla räkningar till "0000". Samtidigt, om ENABLE är '1', fortsätter katodräkningen tills katodräkningen når 60,00, där den utlöser stoppsignalen till '1'. Stoppsignalen leder tillbaka till CEN -processblocket och gör att ENABLE är '0' medan stoppsignalen är '1' och ändras inte förrän återställningsknappen trycks in.

Slutligen konfigureras sju segmentdisplayen genom att ha de 4 anoderna korrekt anslutna till var och en av deras 8 katoder för att visa sina respektive siffror 0-9 samtidigt.

Steg 4: Begränsningar

Begränsningar
Begränsningar

Denna begränsningsfil ansluter de angivna in- och utgångarna från VHDL till de nödvändiga, fysiska delarna av Basys -kortet. För detta projekt innehåller komponenterna de fyra anoderna och var och en av deras åtta katoder för displayen med sju segment, den interna 100 mHz -klockan, mittknappen och den högra knappen.

Steg 5: Testa

När du har fyllt i koden kan du nu programmera FPGA via USB -kabeln. Displayen med sju segment ska visa 0,00. Testa om knapparna fungerar genom att trycka på mittknappen för att starta timern tills den når 60,00 och stannar; när som helst däremellan kan du trycka på den centrala knappen igen för att pausa den. När den har pausats kan du trycka på höger knapp för att återställa timern till 0,00. Om allt fungerar korrekt, grattis till att du precis har byggt en minuts timer!