Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Multimedia (https://www.delphipraxis.net/16-multimedia/)
-   -   Zeitmessung (https://www.delphipraxis.net/160351-zeitmessung.html)

loirad 9. Mai 2011 15:07

Zeitmessung
 
Hallo liebe Delphi-PRAXISler,

ich messe die Zeit, zwischen 2 Zeiten so :arrow:
Code:
start:=now;
Startzeit.Caption:='Startzeit: '+timetostr(start); //(Label Startzeit)
//Prozedure, von der die Zeit gemessen werden soll
ende:=now;
Endzeit.Caption:='Endzeit: '+timetostr(ende); //(Label Endzeit)
Dauer.Caption:='Dauer: '+timetostr(start-ende); //(Label Dauer)
Jetzt ist mein Problem, dass manchmal (nicht immer) einfach 1 Sekunde zu wenig bei dem Label Dauer angezeigt wird. Wo sitzt da der Fehler :?: Hat jemand eine Idee :idea: ?

Mit freundlichen Grüßen
loirad

Satty67 9. Mai 2011 15:12

AW: Zeitmessung
 
Rundungsproblem?

TDateTime ist ja ein Double, der auch Millisekunden beinhaltet.

loirad 9. Mai 2011 15:23

AW: Zeitmessung
 
kann man die Millisekunden auch anzeigen? - wenn ja wie?

DeddyH 9. Mai 2011 15:26

AW: Zeitmessung
 
Delphi-Referenz durchsuchenFormatDateTime

Wolfgang Mix 9. Mai 2011 15:28

AW: Zeitmessung
 
Teile die Nachkommastelle durch 3600 und zeige das dann an

himitsu 9. Mai 2011 15:30

AW: Zeitmessung
 
TimeToStr rundet ab, wobei dann natürlich schnell mal was "fehlen" kann.

Mit einer Sekunde differenz kann man aber eigentlich noch Leben.
Du könntest jetzt auch einfach mal 0.0003472 ('ne halbe Sekunde) zur ausgerechneten Differenz dazuaddieren, dann wird da seltener Abgerundet, aber dafür könnte es ab nun auch mal eine Sekunde zuviel sein.

Wenn du es wirklich genau brauchst, also die Differenz der angezeigten Werte,
dann wirst du ebenfalls jeweils die Anfangs- und Endzeit auf ganze Sekunden abrunden müssen und danach kannst du die gewünschte Differenz ausrechnen.

Wolfgang Mix 9. Mai 2011 15:34

AW: Zeitmessung
 
Der Fehler liegt dann wohl nicht im Sekunden-, sondern im Millisekundenbereich. Auch damit wird man leben können :-)

rollstuhlfahrer 9. Mai 2011 15:43

AW: Zeitmessung
 
Zitat:

Zitat von Wolfgang Mix (Beitrag 1099757)
Teile die Nachkommastelle durch 3600 und zeige das dann an

Sollte das nicht "multipliziere" heißen?

Bernhard

loirad 9. Mai 2011 15:48

AW: Zeitmessung
 
Wenn ich mir da dann Tage, Monate und Jahre anzeige, dann werden mir dort andere Zahlen ausgegeben.
Hier ein Beispiel :arrow: "30 Tage: 12 Monate: 99 Jahre: 0 Stunden: 0 Minuten: 8 Sekunden: 979 Millisekunden"
Code:
showmessage(SysUtils.FormatDateTime('d" Tage":" "m" Monate":" "y" Jahre":" "h" Stunden":" "n" Minuten":" "s" Sekunden ":" "z" Millisekunden"',start-ende));
Das Programm hat aber keinen Tag gedauert.
Woran liegt das?
Liegt das an dem "now"?
Wie kann ich das ändern?

Wolfgang Mix 9. Mai 2011 15:56

AW: Zeitmessung
 
Liste der Anhänge anzeigen (Anzahl: 1)
Schaue dir mal dieses Projekt an (Anhang)

DeddyH 9. Mai 2011 15:57

AW: Zeitmessung
 
Im Format-String von FormatDateTime dürfen nur gültige Format-Bezeichner stehen.

Satty67 9. Mai 2011 16:00

AW: Zeitmessung
 
Zitat:

Zitat von loirad (Beitrag 1099773)
start-ende

Wenn schon so, dann ende-start oder besser als Alternative QueryPerformanceCounter nutzen.

Es schwirren hier auch fertige StoppUhr Beispiele rum bzw. gibt es in neueren Delphi-Versionen evtl. sogar eine?

himitsu 9. Mai 2011 16:09

AW: Zeitmessung
 
Ich würde mal ende-start, anstatt start-ende rechnen ... dann kommen da auch keine negativen Werte raus.
(deine positiven Tage/monate/Jahre sind eigentlich durch einen negativen Bereichsüberlauf entstanden)

[edit]
Tschuldschung, hab Seite 2 übersehn :oops:

loirad 9. Mai 2011 16:28

AW: Zeitmessung
 
Auch wenn ich ende und start vertausche kommen die 30 Tage, 12 Monate und 99 Jahre raus. Wie kann ich das verändern :?::?::?:
@ DeddyH: Was meinst du damit?

DeddyH 9. Mai 2011 16:50

AW: Zeitmessung
 
Damit meine ich, dass z.B. bei dem Wort "Jahre" das "h" als Stunde interpretiert und somit geparst wird. Von daher verbieten sich bei FormatDateTime alle Zeichen oder Wörter, die mit der eigentlichen Formatierung nichts zu tun haben.

loirad 9. Mai 2011 17:43

AW: Zeitmessung
 
@ DeddyH: Ich meine ja immer das vor dem Wort ist der Wert!
@ all: Vorschläge zur Vermeidung, dass 30 Tage, 12 Monate und 99 Jahre ausgegeben werden, wenn nichtmal ein Tag vergangen ist?
Ideen wären sehr hilfreich :thumb::thumb::thumb:!!!

himitsu 9. Mai 2011 19:46

AW: Zeitmessung
 
@DeddyH: rte mal, warum er soviele " in dem Text hat ... alles was damit Maskiert ist, wird nicht als Steuerzeichen geparst ... also macht das h in Jahre keine Probleme. :angle:

Und zu den Werten bei Tag/Monat/Jahr ... welchen Wert haben denn die Variablen?

loirad 9. Mai 2011 20:03

AW: Zeitmessung
 
Ich send einfach mal den wichtigen Teil des Quelltextes:

Code:
procedure TForm1.BerechnenClick(Sender: TObject);
var start,ende:tdatetime;
begin
start:=now;
//Quelltext, dessen Zeit gemessen werden soll
ende:=now;
showmessage(SysUtils.FormatDateTime('d" Tage":" "m" Monate":" "y" Jahre":" "h" Stunden":" "n" Minuten":" "s" Sekunden ":" "z" Millisekunden"',ende-start));
end;
(immernoch 30 Tage, 12 Monate und 99 Jahre ausgegeben)
Ideen?

bernerbaer 9. Mai 2011 20:14

AW: Zeitmessung
 
Geht das nicht einfacher, wenn man direkt in milliseconds arbeitet?

Delphi-Quellcode:
var
   start, ende, dauer : Int64;

   datumswert: TDatetime;
 begin
   start := GetTickCount;
   // hier kommt die ganz lange Funktion
   ende := GetTickCount;
   dauer:= ende - start;
   
   
   // und jetzt noch reine Mathematik oder per Format() ins gewünschte Ausgabeformat bringen zb.:

datumswert:= dauer / MSecsPerSec /  SecsPerDay;

showmessage(FormatDateTime('d" Tage":" "m" Monate":" "y" Jahre":" "h" Stunden":" "n" Minuten":" "s" Sekunden ":" "z" Millisekunden"',datumswert));

Wolfgang Mix 9. Mai 2011 20:17

AW: Zeitmessung
 
Zeitstempel aus Post #10 schon gesichtet?

Thom 9. Mai 2011 22:08

AW: Zeitmessung
 
Zitat:

Zitat von Delphi-Hilfe
Der ganzzahlige Teil eines TDateTime-Wertes entspricht der Anzahl der Tage seit dem 30.12.1899. Der fraktionale Teil TDateTime-Wertes gibt die Tageszeit an.

Probier mal
Delphi-Quellcode:
ShowMessage(FormatDateTime('d:m:yyyy:h:n:s:z',Datumswert));
//...
Dann siehst Du, wieviel Zeit seit dem "Datumsbeginn" vergangen ist. Das ist völlig korrekt... :zwinker:

Die Delphi-Hilfe ist doch eine feine Sache, wenn man mal hineinschaut... :lol:

Laß Dir also nur die Stunden, Minuten, Sekunden und Millisekunden anzeigen und schon sieht das Ganze wesentlich besser aus:
Delphi-Quellcode:
ShowMessage(FormatDateTime('h:n:s:z',Datumswert));
//...
Damit kannst Du jetzt zwar "nur" noch bis 23 Stunden, 59 Minuten, 59 Sekunden und 999 Millisekunden messen - aber ich hoffe, daß Deine Routine nicht sooooooooo lange dauert. :stupid:

loirad 10. Mai 2011 06:25

AW: Zeitmessung
 
Es ist ja Türme von Hanoi (mit Rekursion) - das kann dauern:!:
:lol:


Alle Zeitangaben in WEZ +1. Es ist jetzt 15:50 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz