mikrocontroller.net

Forum: FPGA, VHDL & Co. VHDL Type conversion Time -> Real


Autor: Flo (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hey,

ich will ein Datum vom Typ time in real konvertieren. Folgende Anweisung 
hab ich dafür testweise geschrieben:
constant ClkPeriod : time := 10 ns;
...

process(...)
variable check : real;
begin

check := real(ClkPeriod/10 us);
end process;

Mein Problem ist, dass check immer den Wert 0 hat. Irgendwie 
funktioniert das nicht, aber ich seh den Fehler nicht.

check soll einfach den reinen Zahlenwert der ClkPeriod halten, und zwar 
konvertiert in Microsekunden.

Autor: Lothar Miller (lkmiller) (Moderator) Benutzerseite
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Ist ja klar, was (10 ns / 10 us) in Integer gibt: 0

Du solltest das etwas weiter greifen und erst mal die Zeit in eine Zahl 
umwandeln, und danach erst teilen, nicht ohne zuvor das Ganze nach real 
gecastet zu haben:
   signal timeinus : real := 0.0;
   :
   timeinus <= real(ClkPeriod/1 ps) / real(1 us/1 ps);

BTW:
> und zwar konvertiert in Microsekunden.
Dann ist es ungeschickt, durch 10 us zu teilen...  :-o

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.