Forum: FPGA, VHDL & Co. WHEN - ELSE - Reihenfolge wichtig?


von unknown (Gast)


Lesenswert?

Hallo zuammen,

ich habe folgenden Code:
1
c <= '0' WHEN a = "00" AND b = "00" ELSE
2
       '1' WHEN a = "00"                     ELSE 
3
       '0';

Wenn ich das (freilich etwas anders) in einem Prozess beschreiben würde, 
wird ja bei IF-ELSE immer die erste zutreffende Bedingung gewählt. Alles 
was dahinter kommt ist egal. Wenn also a=00 und b=00 sind, dann ist c=0. 
Wenn aber b irgendwas außer 00 ist, dann ist c=1.

Aber wie sieht es in diesem Beispiel aus?
Ist hier c immer 1, solange a=00 ist, oder ist es auch abhängig von b?

Vielen Dank!

von unknown (Gast)


Lesenswert?

Mir ist bewusst, dass ich es auch so umschreiben könnte.
1
c <= '1' WHEN a = "00" AND b /= "00" ELSE '0';

Mir geht es nicht um die Funktion, sondern rein um die 
Interpretationsreihenfolge von WHEN-ELSE.

von ... (Gast)


Lesenswert?

Wenn Du das vereinfachen kannst, kann der Synthesizer das auch.

Das die 2. Bedingung sequentiell dahinter steht, wird
nicht dazu führen das daraus extra Logik ensteht.

Das müsste dann schon ein anderes Signal oder Variable sein.

Das würde dann in der Tat mit weiterer Logik in die Auswertung
einbezogen.

von Lothar M. (Firma: Titel) (lkmiller) (Moderator) Benutzerseite


Lesenswert?

unknown schrieb:
> Ist hier c immer 1, solange a=00 ist, oder ist es auch abhängig von b?
Lies einfach mal das WHEN-ELSE ganz natürlichsprachig, dann steht da:
"c wird 0 wenn a gleich 00 und b gleich 00 sonst ... "
Und wenn jetzt also  diese erste Bedingung zutrisst, ist eine Auswertung 
von "..." ncht mehr nötig.

Das ist wie wenn du sagst:
"Wir gehen zum Schwimmen wenn Peter kommt und Klaus kommt, sonst ..."
Da ist es auch klar, dass man zum Schwimmen geht, wenn die beiden 
kommen. Eine weitere Auswertung hinter dem "sonst" ist unnötig.

> Ist hier c immer 1, solange a=00 ist, oder ist es auch abhängig von b?
Lösung: natürlich ist es abhängig von b.

: Bearbeitet durch Moderator
von berndl (Gast)


Lesenswert?

Lothar M. schrieb:
> Das ist wie wenn du sagst:
> "Wir gehen zum Schwimmen wenn Peter kommt und Klaus kommt, sonst ..."

Vorsicht!
Frau schickt Gatten zum einkaufen: Hol bitte ein Brot und wenn sie Eier 
haben, nimm 6 Stueck.
Gatte kommt zurueck, sie ganz entgeistert: Wieso bringst du 6 Brote mit?
Er: Sie hatten Eier!

:o)

von Lothar M. (Firma: Titel) (lkmiller) (Moderator) Benutzerseite


Lesenswert?

berndl schrieb:
> Er: Sie hatten Eier!
:-D
Geht das auch auf VHDL?

von berndl (Gast)


Lesenswert?

Klaro!
1
num_brote_u <= x"1" when eier_b = false else x"6";
Annahme: Kleinfamilie bis maximal 15 'brote'...

von Lothar M. (Firma: Titel) (lkmiller) (Moderator) Benutzerseite


Lesenswert?

berndl schrieb:
> Annahme: Kleinfamilie bis maximal 15 'brote'...
Und zusätzliche Annahme: Interpretation des Mannes...

von berndl (Gast)


Lesenswert?

Noch schoener waere in diesem Fall ja:
1
num_brote_u <= x"1" butwhen eier_b = true then x"6";
Naja, vielleicht bei VHDL2050... 'comefrom' gibt es ja auch anstatt 
'goto'

von berndl (Gast)


Lesenswert?

Lothar M. schrieb:
> Und zusätzliche Annahme: Interpretation des Mannes...

Ingenieur halt...

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.