Forum: FPGA, VHDL & Co. VHDL Beginner 7-Segment


von manuel1139 (Gast)


Lesenswert?

Hallo!

Bin gerade dabei mich in VHDL einzuarbeiten. Nach dem ich schon einige 
Hürden genommen habe steh ich jetzt vor dem Problem das ich mir ein 
Modul bauen will das als Input einen Integer (von 0-9999) und als Output 
diesen Integer auf dem 7-Segment Display meines Digilent Starter Kit 
anzeigt.

Jetzt muss ich ja die einzelnen Ziffern des Integer auf die 7-Segment 
anzeigen verteilen.

Was ich mir überlegt habe ist

1. z.B. 3212 ->


3212 / 1000 -> 3 rest 212
 212 / 100  -> 2 rest 2
  12 / 10   -> 1 rest 2
            -> 2


2. Konvertieren in einen String und
dann das Array(n) wieder zurückkonvertieren.

Beide Lösungen scheinen mit reichlich Overhead verbunden  zu sein... Was 
ist die praktikabelste Lösung? Ich habe gehört Modulo/Rest kann genauso 
wie Stringverarbeitung nicht unbedingt? synthetisiert werden?

Oder steh ich vielleicht auf dem Schlauch?

Vielen Dank für eure Antworten!

Gruß,

   Manuel

von Joerg W. (joergwolfram)


Lesenswert?

Hmmm, da fällt mir jetzt folgende Lösung ein, auch wenn sie vielleicht 
nict besonders elegant ist.

- Zähler mit Wert laden und 4-Dekadenzähler mit 0 laden
- Wenn Zähler ungleich Null, dann Zähler-1 und Dekadenzähler+1
- Wenn Zähler ungleich Null ist, die Anzeige dunkelschalten

Bei einer Taktfrequenz von z.B. 10MHz ist die Wandlungszeit max. 1ms, 
was bei 7-Segmentanzeigen nicht auffalllen sollte.

Gruß Jörg

von Mike (Gast)


Lesenswert?

Du könntest die Variante von Jörg noch etwas erweitern indem du für jede 
Stelle einen Wert abziehst:

Also:

Wert:   Anzeige:
 3212   0xxx
-1000   1xxx
-1000   2xxx
-1000   3xxx      (nächste Subtraktion ergibt Wert <0 -> auf 100
                   umstellen)

- 100   31xx
- 100   32xx      (nächste Subtraktion ergibt Wert <0 -> auf 10
                   umstellen)

-  10   321x      (Wert kleiner 10 nun den Rest einfach anzeigen)

=>      3212

Die Rechnung findet natürlich mit Binärzahlen statt. Für die Umsetzung 
brauchst du auch nur Subtraktion und 4 Zähler.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.