Cronòmetre bàsic amb VHDL i Basys3 Board: 9 passos
Cronòmetre bàsic amb VHDL i Basys3 Board: 9 passos
Anonim
Image
Image

Benvingut a l'informable sobre com construir un cronòmetre mitjançant la placa bàsica VHDL i Basys 3. Estem encantats de compartir el vostre projecte amb vosaltres! Aquest va ser un projecte final del curs CPE 133 (Disseny digital) a Cal Poly, SLO a la tardor del 2016. El projecte que vam construir és un cronòmetre senzill que arrenca, restableix i posa en pausa el temps. Presa tres botons polsadors a la placa Basys3 com a entrades i l’hora es mostra a la pantalla de set segments de quatre dígits de la placa. El temps transcorregut es mostra en un format de segons: centisegons. Utilitza el rellotge del sistema del tauler com a entrada per fer un seguiment del temps transcorregut i transmet el temps als quatre dígits de la pantalla de set segments.

Pas 1: materials

Configuració d'entrades i sortides
Configuració d'entrades i sortides

Els materials que necessiteu per a aquest projecte:

  • 1 ordinador amb Vivado Design Suite WebPack instal·lat des de Xilinx (preferiu la versió 2016.2)
  • 1 placa Digilent Basys3 Xilinx Artix-7 FPGA
  • 1 cable de port USB

Pas 2: Configuració d'entrades i sortides

La figura anterior mostra un diagrama de blocs de nivell superior del mòdul de cronòmetre principal. El cronòmetre pren les entrades "CLK" (rellotge), "S1" (botó d'inici), "S2" (botó de pausa) i "RST" (restabliment) i té una sortida de 4 bits "Ànodes", un de 7 bits "segment" de sortida i una sortida "DP" d'un sol bit (punt decimal). Quan l'entrada "S1" és alta, el cronòmetre comença a comptar el temps. Quan "S2" és baix, el cronòmetre posa en pausa l'hora. Quan "RST" és alt, el cronòmetre s'atura i restableix l'hora. Hi ha quatre submòduls dins del circuit: el divisor de rellotge, el comptador de dígits, el controlador de pantalla de set segments i el codificador de pantalla de set segments. El mòdul principal del cronòmetre enllaça tots els submòduls i les entrades i sortides.

Pas 3: fabricació de rellotges

Fer rellotges
Fer rellotges

El mòdul divisor de rellotge pren un rellotge del sistema i utilitza una entrada divisora per crear un rellotge de qualsevol velocitat no superior a la del rellotge del sistema. El cronòmetre utilitza dos mòduls de rellotge diferents, un que crea un rellotge de 500 Hz i un altre que crea un rellotge de 100 Hz. L'esquema del divisor de rellotge es mostra a la figura anterior. El divisor de rellotge inclou una entrada de "bit CLK" d'un sol bit, i una entrada de 32 bits "Divisor" i la sortida d'un bit de bit "CLKOUT". "CLK" és el rellotge del sistema i "CLKOUT" és el rellotge resultant. El mòdul també inclou una porta NOT, que commuta el senyal "CLKTOG" quan el recompte arriba al valor del divisor.

Pas 4: Compte fins a deu

Comptant fins a deu
Comptant fins a deu

El comptador de dígits compta cada dígit del 0 al 10 i crea un altre rellotge per al següent dígit que funcioni fora que oscil·la quan el recompte arriba a 10. El mòdul inclou 3 entrades d'un sol bit "S", "RST" i "CLK "i dóna com a resultat una sortida de" bit "d'un sol bit i una sortida de" D "de 4 bits. L'entrada "S" és l'habilitació de l'entrada. El rellotge s'activa quan "S" és alt i s'apaga quan "S" és baix. "RST" és l'entrada de restabliment, de manera que el rellotge es reinicia quan "RST" és alt. "CLK" és l'entrada de rellotge del comptador de dígits. "N" és la sortida del rellotge que es converteix en el rellotge d'entrada del següent dígit. La sortida "D" presenta el valor binari del dígit en què es troba el comptador.

Pas 5: mostrar números

Visualització de números
Visualització de números

El codificador de pantalla de set segments codificarà el número binari rebut del mòdul del controlador de pantalla de set segments i el convertirà en un flux de bits que s’interpretaran com a valors “1” o “0” per a cada segment de la pantalla. El mòdul rep el número binari com a "dígit" d'entrada de 4 bits i dóna lloc als "segments" de sortida de 7 bits. El mòdul consta d’un bloc de procés de majúscules i minúscules que assigna un flux de 7 bits específic per a cada valor d’entrada possible de 0 a 9. Cada bit dels fluxos de set bits representa un dels set segments dels dígits de la pantalla. L'ordre dels segments del tauler d'activitat és "abcdefg" i el "0" representa els segments que s'encenen per al nombre donat.

Pas 6: Com es mostra el cronòmetre

Com es mostra el cronòmetre
Com es mostra el cronòmetre

Al mòdul del controlador de pantalla de set segments, hi ha quatre entrades de 4 bits "D0", "D1", "D2" i "D3", que representen cadascun els quatre dígits que es mostraran. L'entrada "CLK" és l'entrada de rellotge del sistema. La sortida d'un bit "DP" representa el punt decimal a la pantalla de set segments. La sortida de 4 bits "Ànodes" determina quin dígit de la pantalla de set segments es mostra i la sortida de 4 bits "temp" depèn de l'estat de l'entrada de control de 2 bits "SEL". El mòdul utilitza 4 multiplexors per a l'entrada de control "SEL" i les tres sortides; "Ànodes", "temp" i "DP".

Pas 7: Unir-ho tot

Per crear els botons d’inici i pausa s’utilitza un bloc de procés “si” que s’executa al rellotge de 500Hz. A continuació, enllaceu tots els submòduls al mòdul principal del cronòmetre declarant els components de cada submòdul individual i utilitzant diversos senyals. Els submòduls de dígits prenen la sortida del rellotge del submòdul de dígits anterior i el primer pren el rellotge de 100Hz. Les sortides "D" dels submòduls de dígits es converteixen en les entrades "D" del mòdul de control de visualització de set segments. I, finalment, la sortida "temporal" del mòdul del controlador de pantalla de set segments es converteix en l'entrada "temporal" del mòdul codificador de set segments.

Pas 8: restriccions

Restriccions
Restriccions

Utilitzeu 3 polsadors (W19, T17 i U18) per a les entrades "RST", "S1" i "S2". W19 és el botó de restabliment, T17 és el botó d’inici (S1) i U18 és el botó de pausa (S2). També es requereix una restricció per a l'entrada d'entrada de rellotge mitjançant el port W5. A més, recordeu afegir aquesta línia a la restricció del rellotge:

create_clock -add -name sys_clk_pin -period 10.00 -waveform {0 5} [get_ports {CLK}]

També enllaceu els ànodes i els segments amb el tauler perquè el cronòmetre es mostri a la pantalla de set segments tal com es veu al fitxer de restriccions.

Pas 9: proves

Proves
Proves

Assegureu-vos que el dispositiu funcioni jugant amb els tres botons: premeu-los i manteniu-los premuts en tot ordre possible per trobar possibles problemes amb el vostre codi.

Recomanat: