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
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
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.