mikrocontroller.net

Forum: FPGA, VHDL & Co. Rechtsrotation ror mit STD_LOGIC_VECTOR


Autor: Dari (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo.

Ich habe in meinem Beleg folgende Aufgabe:
Ich soll 4 Dezimalzahlen einlesen, die ich zyklisch rotieren lassen soll 
und auf eine 4 * 7-Segment-Anzeige anzeigen lassen soll. Das Problem 
besteht hierbei in der Rotation der 4 Zahlen.
Zahl 1 soll in Segment 1 angezeigt werden,
Zahl 2 in Segment 2,
Zahl 3 in Segment 3 und
Zahl 4 in Segment 4.

Mit Hilfe eines Bits sollen dann die 4 Zahlen auf der Anzeige zum 
Rotieren gebracht werden.

Wie kann ich diese Rotation realisieren?

Danke für Hilfe.

Dari.

Autor: Rick Dangerus (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Vielleicht in einer State Machine? Schreib Dir mal alle Eingänge und 
alle Ausgänge auf. Dann überlegst Du Dir, welche/wieviele Zustände die 
Ausgänge einnehmen sollen. Und im letzten Schritt fällt Dir ein, welcher 
Eingang, welchen Zustandswechsel verursacht.

Rick

Autor: Thomas Hertwig (mac4ever)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Geht noch viel einfacher ... muss nicht zwingend eine FSM werden.
signal z1,z2,z3,z4 : std_logic_vector(3 downto 0);
signal rotation_vec: std_logic_vector(15 downto 0);

process(clk)
begin
 if rising_edge(clk)
  rotation_vec<=rotation_vec(3 downto 0) & rotation_vec(15 downto 4);
 end if;
end process;

z1<=rotation_vec(15 downto 12);
z2<=rotation_vec(11 downto  8);
z3<=rotation_vec( 7 downto  4);
z4<=rotation_vec( 3 downto  0);

Im Prinzip einfach alle 4 Zahlen in einen großen Vector legen und dann 
um die Bitbreite ( hier 4 ) nach rechts shiften .... fertig

Autor: Martin (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
hi,

eine Idee wäre auch noch bei Multiplex-Betrieb der 4 ziffern einfach die 
Ansteuerung der 4 Stellen so ändern, dass sich ein Rotationseffekt 
ergibt.

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [vhdl]VHDL-Code[/vhdl]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.