![]() |
Zeitmessung für Programmroutinen
Hallo,
ich, vermutlich auch viele andere, benötige immer wieder zu Testzwecken Zeitmessungen für Codeteile in eigenen Programmen (Delphi 2007). Bei Single Core Prozessoren habe ich früher das RDTSC von Hagen/Luckie verwendet und war damit auch sehr zufrieden, da es auch eine viel höhere Auflösung als Gettickcount besitzt. Dies sollte ja bei Multicore Prozessoren nicht mehr richtig funktionieren. Ich habe gestern mal wieder alte Beiträge zu diesem Thema durchgestöbert. Was ist eigentlich der aktuelle Stand der Dinge. Soll man jetzt nun doch QueryPerformanceCounter verwenden? Dieser sollte ja laut einigen Beiträge auch nicht richtig funktionieren, ist der QueryPerformanceCounter durch ServicePacks wieder gefixt? Lg, jus |
AW: Zeitmessung für Programmroutinen
Ich hoffe mal, daß QueryPerformanceCounter läuft, denn dieses nutzte ich erfolgreich.
RDTSC soll angeblich auch mit Multicore funktionieren, da inzwischen alle Cores den selben Counter nutzen. Es wurde (hier in irgendeinem Thread) sogar mal behauptet, daß dieser selbst bei dynamisch getakteten CPUs gleichmäßige Werte liefert. (das könnte stimmen, da ein aktuelles Programm immer den maxiamalen CPU-Takt anzeigt und keinen veränderlichen :gruebel:) Das könnte man aber "leicht" ausprobieren, indem man es einfach mal mißt und auf verschiedenen Kernen die Werte vergleicht, indem man den Thread an unterschiedliche Kerne bindet. |
AW: Zeitmessung für Programmroutinen
Hallo Himitsu,
wenn du den QueryPerformanceCounter auch verwendest, dann bin ich schon beruhigt. :-D Auf der anderen Seite wäre der RDTSC wirklich mal einen Test wert. Lg, jus |
AW: Zeitmessung für Programmroutinen
Nur noch ein Hinweis am Rande: ab Delphi 2010 gibts die Unit Diagnostics, in der eine passende Klasse zur Zeitmessung enthalten ist.
|
AW: Zeitmessung für Programmroutinen
|
AW: Zeitmessung für Programmroutinen
Hallo,
ich habe vor einiger Zeit mich mal wieder kurz mit dem Thema RDTSC auseinandergesetzt und möchte kurz die Info teilen. Vielleicht kann es jemand auch mal gebrauchen. Es wurde häufig in den Beiträgen die Info gebracht, dass RDTSC bei neueren Intel Prozessoren wieder mit konstanter Rate läuft. Zitat:
![]() Ob ein Prozessor invariant TSC unterstützt kann man mit CPUID 80000007H:EDX[8] abfragen. Dies kann man in der aktuellen " ![]() Da die aktuelle Jedi Bibliothek sehr viel von CPUID ausliest, habe ich diese verwendet um dieses Bit auszulesen. Falls jemand interessiert könnte ich auch die minimalen Modifikationen der JclSysInfo.pas posten. Das coole bei invariant TSC ist, dass das ![]() Lg, jus |
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:30 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz