AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Zeitunterschiede der Befehle, u.a. Case und If
Thema durchsuchen
Ansicht
Themen-Optionen

Zeitunterschiede der Befehle, u.a. Case und If

Ein Thema von LiS · begonnen am 5. Apr 2005 · letzter Beitrag vom 5. Apr 2005
Antwort Antwort
LiS

Registriert seit: 3. Dez 2004
87 Beiträge
 
Turbo Delphi für Win32
 
#1

Zeitunterschiede der Befehle, u.a. Case und If

  Alt 5. Apr 2005, 16:14
hallo!
ich arbeite zur zeit an einem 4Gewinnt-Spiel mit künstlicher Intelligenz, bei der der Computer eine Menge rechnen muss. Deshalb möchte ich die Befehle natürlich möglichst so schreiben, dass der Computer möglichst wenig Zeit braucht. Die Befehle werden nämlich bei der Berechnung bis zu über 100Millionen mal durchgegangen. Deshalb würde mich interessieren, ob es Zeitunterschiede zwischen der If- und der Case-Anweisung oder zwischen der For-, der Repeat-Until- und der While-Schleife gibt, und welche schneller sind. Wer noch andere Befehle kennt, bitte auch rein schreiben, danke!
  Mit Zitat antworten Zitat
Benutzerbild von Binärbaum
Binärbaum

Registriert seit: 19. Jan 2005
Ort: Elstra
764 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: Zeitunterschiede der Befehle, u.a. Case und If

  Alt 5. Apr 2005, 16:24
Also if müsste erstmal schneller sein als case, weil man halt nur zwei Möglichkeiten hat. Aber für solche Fälle lohnt sich auch noch kein case.
Du kannst ja mal zwei Varianten programmieren: eine mit if und die andere mit case.
Dann wird einfach die Zeit gemessen, die jede der beiden Varianten braucht. Aus dem Vergleich der zeiten geht dann hervor, was schneller ist.

MfG
Binärbaum
There are exactly 10 kinds of people: those who understand binary, and those who don't.
---
"Software reift beim Kunden. Bei Hardware ist es anders: Hardware fault beim Kunden." - Rainer G. Spallek
  Mit Zitat antworten Zitat
Muetze1
(Gast)

n/a Beiträge
 
#3

Re: Zeitunterschiede der Befehle, u.a. Case und If

  Alt 5. Apr 2005, 16:26
Moin!

Vor einem If Else If Else If ... Konstrukt ist Case deutlich schneller, da es eine Sprungtabelle aufbaut. Nachteil dabei ist aber, das Case nur mit konstanten Zweigen geht im Gegensatz zu einer If Abfrage...

MfG
Muetze1
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#4

Re: Zeitunterschiede der Befehle, u.a. Case und If

  Alt 5. Apr 2005, 16:46
Zitat von LiS:
ich arbeite zur zeit an einem 4Gewinnt-Spiel mit künstlicher Intelligenz, bei der der Computer eine Menge rechnen muss. Deshalb möchte ich die Befehle natürlich möglichst so schreiben, dass der Computer möglichst wenig Zeit braucht. Die Befehle werden nämlich bei der Berechnung bis zu über 100Millionen mal durchgegangen.
Du würdest viel Zeit sparen, wenn du schlechte Züge frühzeitig eliminierst.
Schau mal ganz unten auf
http://www.enzilex.de/index.php/Alpha-Beta-Suche
das zeigt wieviel Potential in einem besseren Algorythmus steckt.

Zitat von LiS:
Deshalb würde mich interessieren, ob es Zeitunterschiede zwischen der If- und der Case-Anweisung oder zwischen der For-, der Repeat-Until- und der While-Schleife gibt, und welche schneller sind. Wer noch andere Befehle kennt, bitte auch rein schreiben, danke!
For-Schleifen sind am Schnellsten, weil das Decrementieren eines Zähler und Auswerten des Zero-Bits sehr fix geht.
Repeat und While-Schleife sind gleichwertig (bei Repeat-Until wird der Schleifenkörper aber min. einmal ausgeführt)
Case-Anweisungen werden schneller, wenn man die wahrscheinlichsten Werte an den Anfang stellt.
Wenn eine lückenlose Sprungtabelle aufgebaut wird, kann ein geschachtelter Case schneller sein:

Delphi-Quellcode:
case x of
   100..109:

   
   case x of
     100: ;
     101: ;
     102: ;
     ...
     109: ;
   end;

   1000: ;
   1050: ;
end;
Andreas
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:11 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