AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

schnellere Ausgabe

Ein Thema von axesy · begonnen am 9. Apr 2006 · letzter Beitrag vom 10. Apr 2006
Antwort Antwort
axesy

Registriert seit: 9. Apr 2006
2 Beiträge
 
#1

schnellere Ausgabe

  Alt 9. Apr 2006, 23:01
ich habe ein Problem:
Ich muss eine Simulation über das Verhalten von (Langton-)Ameisen halten und dazu zunächst ein Programm schreiben. Die Implementierung ist auch soweit fertig. Mein Problem ist die Geschwindigkeit (des Zeichnens). Das Programm zeichnet ungefähr nur 100 Schritte der Ameise pro Sekunde, es sollten aber bis zu 50 000 Schritte in absehbarer Zeit gezeichnet werden können (das wären knapp 10 Minuten).
nun habe ich festgestellt:
1. Am Algorithmus liegt das nicht (ohne das Ergebnis zu zeichnen kann der Algorithmus in einer Sekunde 350 000 Schritte der Ameise durchführen)
2. Am Zeichnen liegt das auch nicht:
ich lasse das Zeichnen ganz weg (und auch den Ameisen-Algorithmus) und lasse nur eine Variabel von 0 bis ... hochzählen und nach jedem Schritt ausgeben (in einem label oder edit). Das dauert genauso lange, wie das Zeichnen!
Ich verwende entweder einen Timer (Zeit: 1) oder einen Button (und lasse ENTER gedrückt), beides ist gleich schnell. Mache ich es mit einer Schleife (oder auch rekursiv) also ohne Timer/Button dann geht es natürlich viel schneller, es wird aber nur der Anfangs- und Endzustand ausgegeben. Gerade bei dem Ameisenproblem sind aber die Zwischenzustände wichtiger als der Endzustand.
Wie kann man also SCHNELLER zählen (oder allg. etwas ausgeben), wobei jeder Zählzustand ausgegeben werden muss???
Dank im Voraus
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2

Re: schnellere Ausgabe

  Alt 9. Apr 2006, 23:05
Grafische Ausgaben sind generell sehr langsam. Es wäre zu überlegen, ob man nur jeden hundersten Schritt oder so ausgibt. Mehr macht auch kaum Sinn denke ich.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
ichbins

Registriert seit: 9. Jul 2005
Ort: Hohenaltheim
1.001 Beiträge
 
Delphi 2005 Personal
 
#3

Re: schnellere Ausgabe

  Alt 10. Apr 2006, 03:52
Zitat:
Ich verwende entweder einen Timer (Zeit: 1) oder einen Button (und lasse ENTER gedrückt), beides ist gleich schnell. Mache ich es mit einer Schleife (oder auch rekursiv) also ohne Timer/Button dann geht es natürlich viel schneller, es wird aber nur der Anfangs- und Endzustand ausgegeben. Gerade bei dem Ameisenproblem sind aber die Zwischenzustände wichtiger als der Endzustand.
Wenn du einen Timer möglichst schnell haben willst, dann mach die Zeit immer auf 0.
Das Problem mit der Schleife kannst du auch beheben: Du musst einfach nur ein application.processmessages einfügen, wenn das Fenster aktualisiert werden soll.

Normalerweise wird das Programmfenster nur aktualisiert, solange "das Programm nichts zu tun hat" und sich ein Beweggrund für eine Änderung (anderes Fenster vor eigenes geschoben oder Eigenschaften verändert) ergeben hat, also z.B: in den Wartezeiten zwischen den Timern, wenn sich dein Label geändert hat.


Ansonsten einfach Luckies Tipp befolgen. In der Schleife dürfte es auch kein Problem sein, einfach mit
if i mod 100=0 überprüfen, ob die Zählervariable durch hundert teilbar ist, das wird ja automatisch jedes hundertste Mal passieren.
Michael Enßlin
Ich, der ich weiß, mir einzubilden, dass ich weiß, nichts zu wissen, weiß, dass ich nichts weiß.
Sokrates
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#4

Re: schnellere Ausgabe

  Alt 10. Apr 2006, 07:44
Timer sind wirklich kritisch. Ich würde folgendes vorschlagen:
Ein Thread simuliert die Ameisen. Das geht, wie Du gesehen hast, ordendlich schnell, sodaß Du vielleicht sogar eine Verzögerung einbauen musst.
Das Zeichnen selbst würde ich über einen Timer (25x pro Sekunde max) realisieren.

Mit anderen Worten: Deine Simulation läuft in Echtzeit, aber die Refresh-Rate der Visualisierung kann deutlich darunter liegen. Eine schwachbrüstige CPU, oder eine ältere Grafikkarte führen nur dazu, dass das Timerinterval hochgesetzt wird, am Simulationsverhalten selbst ändert es nichts.
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
axesy

Registriert seit: 9. Apr 2006
2 Beiträge
 
#5

Re: schnellere Ausgabe

  Alt 10. Apr 2006, 13:18
Danke für eure Hilfe! ich habs jetzt erst mal mit Schleife und application.processmessages gemacht, mit threads muss ich mich noch ml auseinandersetzen.
  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 07:35 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