AGB  ·  Datenschutz  ·  Impressum  







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

Wator - Problem mit Arrayberechnung

Ein Thema von monta · begonnen am 4. Mär 2006 · letzter Beitrag vom 11. Mär 2006
Antwort Antwort
monta

Registriert seit: 18. Okt 2004
Ort: Dresden
141 Beiträge
 
#1

Wator - Problem mit Arrayberechnung

  Alt 4. Mär 2006, 15:57
Ich versuche gerade eine einfache Wator - Simulation (Räuber-Beute-Modell) zu programmieren. Alle denen WATOR nichts sagt, können hier nachlesen Wikipedia - Wator.

Jedoch hab ich bei der Berechnung der nächsten Generation das Problem, das das Programm nach einigen neuen Generationen sich komplett aufhängt. Je mehr Individuen ich dabei zu Begin setze, desto eher hängt sich das Programm auf. Irgendetwas in meiner Prozedure sogrt vermutlich für einen Speicherüberlauf oder eine entlosschleife, jedoch habe ich keine Ahnung, wo der Fehler liegt.

Hier nun mal mein Code:

Delphi-Quellcode:
procedure TForm1.StartClick(Sender: TObject);
var x, y: integer;
    x2, y2: integer;
    Nachbarn: integer;
    tempWator: TWator; //Array [0..124, 0..124] of Record aus Gattung, Fasten, Alter: jeweils integer
begin
  randomize;
  for x := 1 to 123 do
  begin
    for y := 1 to 123 do
    begin

      x2 := x;
      y2 := y;
      if Wator[x, y].Gattung <> 0 then //0 markiert leere Felder
      begin
        Nachbarn := Nachbarschaft(x, y); //Nachbarschaft ermittel ob ein Feld in der Umgebung frei ist bzw. ein Hai einen Fisch finden kann
        if Nachbarn in [1, 2] then
        begin
          repeat //ermittelt freies Nachbarfeld
            x2 := x;
            y2 := y;
            case Random(4) of
              1: inc(x2);
              2: dec(x2);
              3: inc(y2);
              4: dec(y2);
            end;
          until ((Wator[x2, y2].Gattung = 0) and (Nachbarn = 1)) or //Abbruch bei Fischen sobald ein freies Nachbarfeld gefunden wurde
            ((Wator[x2, y2].Gattung = 2) and (Nachbarn = 2)); //bei Haien, wenn sie einen Fisch gefunden haben (falls überhaupt verfügbar)
        end;
      end;

      tempWator[x2, y2].Gattung := Wator[x, y].Gattung; //tempWator dient als Zwischenspeicher für für
      tempWator[x2, y2].Alter := Wator[x, y].Alter + 1; //nächste Generation
      tempWator[x2, y2].Gattung := Wator[x, y].Fasten + 1;

    end;
  end;
    Wator := tempWator; //geändert
    PaintWator; //gibt Array grafisch aus
    ShowMessage('Ende'); //als Test, ob durchlauf abgeschlossen
end;

sämtliche speziellen Routinen wie Vermehrung fehlen natürlich noch.

Vielleicht sieht jemand die Stelle, wo der Overhead - oder sonstwas - entsteht.
Johannes M.
  Mit Zitat antworten Zitat
ConstantGardener

Registriert seit: 24. Jan 2006
Ort: Halberstadt
376 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: Wator - Problem mit Arrayberechnung

  Alt 5. Mär 2006, 11:26
Hallo monta,

ich sehe bei dir kein Application.ProcessMessages in der Schleife. Die Anwendung gibt keinem anderen Programmteil bzw. der VCL Gelegenheit Ausgaben/Eigaben usw. zu ermöglichen. Ruf die Methode mal mit auf, vielleicht hilfts...

Oder du lagerst die Sache in nen eigenen Thread aus !?
Andreas Schachtner
  Mit Zitat antworten Zitat
monta

Registriert seit: 18. Okt 2004
Ort: Dresden
141 Beiträge
 
#3

Re: Wator - Problem mit Arrayberechnung

  Alt 5. Mär 2006, 13:06
Danke für die Hilfe, aber ein Aufruf von Processmessage ändert nichts, außer das ich während der eigentlichen Berechnung Eingaben machen kann. Dennoch bricht er aber die Procedure nach einer gewissen Zeit, bzw erst nach mehreren Durchläufen (je nach Fischzahl) ab und ich bekomme einen StackOverflow.

Nur was löst diesen aus?

Die Procedure in einen Thread auszulagern war schon geplant, aber das wollte ich erst machen, wenn sie auch geht.
Johannes M.
  Mit Zitat antworten Zitat
Hawkeye219

Registriert seit: 18. Feb 2006
Ort: Stolberg
2.227 Beiträge
 
Delphi 2010 Professional
 
#4

Re: Wator - Problem mit Arrayberechnung

  Alt 5. Mär 2006, 13:16
Hi monta,

wenn ich das richtig sehe, überprüfst Du an keiner Stelle die als Index benutzten Variablen x2 und y2, wodurch in der Repeat-Schleife der zulässige Bereich (bei Dir 0..124) verlassen werden kann. Beim Schreibzugriff auf das Feld tempWator[] dürft dann der Fehler auftreten. Um meine Theorie zu überprüfen, kannst Du ja mal in den Compileroptionen die Bereichsüberprüfung einschalten. Wenn Du dann das Programm in der IDE laufen läßt, sollte Dir die fehlerhafte Zeile angezeigt werden.

Noch was: Du greifst nach den beiden For-Schleifen auf die Schleifenvariablen x und y zu. Laut Delphi-Hilfe ist der Inhalt einer Schleifenvariable außerhalb der Schleife undefiniert.
  Mit Zitat antworten Zitat
monta

Registriert seit: 18. Okt 2004
Ort: Dresden
141 Beiträge
 
#5

Re: Wator - Problem mit Arrayberechnung

  Alt 5. Mär 2006, 13:30
Da die for-schleife von 1 bis 123 geht und ich die Variblen maximal um eins verringere bzw erhöhe, dürfte der Bereich doch nicht überschritten werden
Die Bereichsprüfung war auch beim testen die ganze Zeit aktiviert und hat nkeinerlei Fehler gemeldet.

Zitat:
Noch was: Du greifst nach den beiden For-Schleifen auf die Schleifenvariablen x und y zu. Laut Delphi-Hilfe ist der Inhalt einer Schleifenvariable außerhalb der Schleife undefiniert.
Stimmt, wa aber nur ein Fehler bei der Eingabe hier, da ich davor zuerst noch eine for-Schleife stehen hatte. Die richtige Zuweisung heißt natürlich Wator := tempWator; hab ich oben schon geändert
Johannes M.
  Mit Zitat antworten Zitat
Hawkeye219

Registriert seit: 18. Feb 2006
Ort: Stolberg
2.227 Beiträge
 
Delphi 2010 Professional
 
#6

Re: Wator - Problem mit Arrayberechnung

  Alt 5. Mär 2006, 14:34
Stimmt, ich hatte übersehen, daß Du in der Repeat-Schleife die Variablen x2 und y2 initialisierst.

Aber einen kleinen Fehler gibt es: Random(4) liefert nur Werte im Bereich 0..3!
  Mit Zitat antworten Zitat
Benutzerbild von Airblader
Airblader

Registriert seit: 29. Okt 2004
Ort: Geislingen an der Steige
742 Beiträge
 
#7

Re: Wator - Problem mit Arrayberechnung

  Alt 5. Mär 2006, 22:21
Kann es sein, dass es sich bei der Abbruchbedingung der repeat-Schleife verheddert, weil es sein kann, dass ein Hai eben keinen Fisch in seiner Umgebung hat und die Schleife sich dadurch aufhängt?
Denn bei dir muss - soweit ich das sehe - ein Hai einen Fisch finden. Findet er keinen, so soll er ja weiterschwimmen. Bei dir hängt sich das ganze allerdings auf, glaube ich

MfG, air
Ingo Bürk
Es nimmt der Augenblick, was Jahre geben.

Johann Wolfgang von Goethe
  Mit Zitat antworten Zitat
monta

Registriert seit: 18. Okt 2004
Ort: Dresden
141 Beiträge
 
#8

Re: Wator - Problem mit Arrayberechnung

  Alt 11. Mär 2006, 12:51
Danke für eure Hilfe, ich hab meinen Fehler gefunden...er hat wirklich nicht aus der Schleife gefunden.
Johannes M.
  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 00:07 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