Algorithmus zum Finden der Lösung eines Verschieberätsels


  • Mod

    In einem anderen, von den meisten wohl unbeachteten, Thread ist ein interessantes Problem aufgekommen:
    https://www.c-plusplus.net/forum/331062

    Es geht darum, ein quadratisches Rastermuster in ein anderes zu überführen, wobei man jeweils eine Zeile um eine Position nach links oder rechts, beziehungsweise eine Spalte um eine Position nach oben oder unten verschieben kann (wobei etwas, was an einem Rand raus geht, an der anderen Seite wieder rein kommt. Beispiel:

    -----
    |   |
    |  X|
    |  X|
    -----
    

    Zieht man die zweite Zeile um eins nach links, erhält man:

    -----
    |   |
    | X |
    |  X|
    -----
    

    noch eins weiter:

    -----
    |   |
    |X  |
    |  X|
    -----
    

    und noch eins weiter erhält man wieder das Original:

    -----
    |   |
    |  X|
    |  X|
    -----
    

    Die Gitterpunkte können dabei nur zwei Zustände annehmen (in obigem Beispiel Leerzeichen und 'X'). Ziel ist es, aus einer gegebenen Ausgangskonfiguration in möglichst wenigen Zügen eine vorgegebene andere Konfiguration zu erzeugen. Es reicht vermutlich eine gute Zugfolge, es braucht wohl nicht die perfekt kürzeste Folge zu sein.

    Im Originalproblem ist das Spielfeld 9x9, eine Brute-Force Lösung kommt daher wohl kaum in Frage. Verstand ist gefragt. Dummerweise fällt mir so spontan aber erst einmal nichts ein, von dem ich begeistert bin. Habe aber auch erst ein paar Minuten über das Problem nachgedacht.
    Bisherige Überlegungen:
    Mein erster Gedanke (nach Brute Force) war, dass man da etwas mit einer Gütefunktion machen kann und dann den Zugraum nach immer besseren Stellungen durchsuchen kann. Aber ich sehe da zwei große Probleme: Zum einen kann ich mir vorstellen, dass man dabei sehr, sehr tiefe lokale Minima antrifft. Man will ja exakt die Endstellung erreichen, eine Stellung die bis auf wenige Pixel dem gewünschten Ergebnis gleicht ist letztlich wertlos. Es könnten, wenn man Pech hat, sehr, sehr viel Züge nötig sein, um von einer Stellung in eine ähnlich aussehende, andere Stellung zu transformieren. Das könnte die Suche schwierig machen. Zum anderen hat man bei diesem Ansatz nichts, was einem als Ergebnis eine möglichst kurze Zugfolge ergibt.

    Das war erst einmal mein Senf, ich bin mal eine Weile vom Rechner weg und bin gespannt, was andere dazu denken.



  • Sofern das noch hilft man hat halt nur eine begrenzte anzahl an züge, wenn man das "level" neu startet kann sich diese anzahl an zügen auch verändern (um 1 bis 3 züge jeweils)

    die frage von mir als unwissende. wieso ist eine beinahe annäherung an das ergebnis nicht praktisch wenn ich noch angenommen 20 züge übrig hätte und das muster so gut wie gelöst ist, kann ja der menschliche verstand den rest machen.

    man wüsste halt sehen wie sehr die annäherung an das ergebnis ist.

    nochmals vielen dank seppj für deine unterstützung.


  • Mod

    iwona schrieb:

    Sofern das noch hilft man hat halt nur eine begrenzte anzahl an züge, wenn man das "level" neu startet kann sich diese anzahl an zügen auch verändern (um 1 bis 3 züge jeweils)

    Moment! Das klingt hoch relevant! Bitte mehr erzählen!



  • Das Level es sind 10 Stück (also 10 Muster) können immer wieder neu gestartet werden, dann wird das Feld neu durchgewürfelt so wie man beim Cube auf "Shuffle" drückt, es wird einach Bunt gemixt.

    Nehmen wir das Pastebin bsp. Zug: 27 wenn ich das Level neustarte könnt eich auch 29 Züge bekommen aber mit einem anderen Startfeld.



  • Hier zum besseren verständnis.

    Das ist die Zielmatrix
    ----------------------------------------------------------------
    |       A   B   C   D   E   F   G   H   I                      |
    |     -------------------------------------      Zug:       0  |
    |   9 | O | O |   |   | O | O |   |   | O | J                  |
    |     -------------------------------------      Score:     0  |
    |   8 |   |   | O | O |   |   | O | O |   | K                  |
    |     -------------------------------------      Level:    10  |
    |   7 | O | O |   |   | O | O |   |   | O | L                  |
    |     -------------------------------------      ZielMatrix:   |
    |   6 |   |   | O | O |   |   | O | O |   | M                  |
    |     -------------------------------------        OO  OO  O   |
    |   5 | O | O |   |   | O | O |   |   | O | N        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   4 |   |   | O | O |   |   | O | O |   | O        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   3 | O | O |   |   | O | O |   |   | O | P        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   2 |   |   | O | O |   |   | O | O |   | Q        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   1 | O | O |   |   | O | O |   |   | O | R                  |
    |     -------------------------------------                    |
    |       0   Z   Y   X   W   V   U   T   S                      |
    ----------------------------------------------------------------
    
    So fängt das Level an:
    ----------------------------------------------------------------
    |       A   B   C   D   E   F   G   H   I                      |
    |     -------------------------------------      Zug:      43  |
    |   9 | O |   |   |   | O | O |   | O |   | J                  |
    |     -------------------------------------      Score:     0  |
    |   8 | O | O | O | O | O |   | O | O |   | K                  |
    |     -------------------------------------      Level:    10  |
    |   7 |   |   |   |   |   |   |   |   | O | L                  |
    |     -------------------------------------      ZielMatrix:   |
    |   6 | O | O | O | O | O | O | O | O |   | M                  |
    |     -------------------------------------        OO  OO  O   |
    |   5 | O |   |   |   | O |   |   |   |   | N        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   4 | O |   | O | O | O | O |   |   | O | O        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   3 |   |   |   |   |   | O |   |   | O | P        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   2 |   | O | O | O | O | O |   | O | O | Q        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   1 | O |   | O |   |   | O |   | O |   | R                  |
    |     -------------------------------------                    |
    |       0   Z   Y   X   W   V   U   T   S                      |
    ----------------------------------------------------------------
    
    Es kann aber auch so ausehen beim Start des Level:
    ----------------------------------------------------------------
    |       A   B   C   D   E   F   G   H   I                      |
    |     -------------------------------------      Zug:      43  |
    |   9 | O | O |   |   |   | O |   | O |   | J                  |
    |     -------------------------------------      Score:     0  |
    |   8 |   | O | O |   |   |   | O |   |   | K                  |
    |     -------------------------------------      Level:    10  |
    |   7 |   |   |   | O |   |   | O | O | O | L                  |
    |     -------------------------------------      ZielMatrix:   |
    |   6 |   |   | O |   | O |   | O |   | O | M                  |
    |     -------------------------------------        OO  OO  O   |
    |   5 |   | O | O |   | O | O | O |   | O | N        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   4 | O |   | O |   |   |   |   | O | O | O        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   3 | O | O | O | O |   |   |   | O |   | P        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   2 | O | O |   |   |   | O | O | O |   | Q        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   1 |   | O | O | O |   | O | O |   | O | R                  |
    |     -------------------------------------                    |
    |       0   Z   Y   X   W   V   U   T   S                      |
    ----------------------------------------------------------------
    
    Oder so (hier habe ich 2 Züge mehr)
    ----------------------------------------------------------------
    |       A   B   C   D   E   F   G   H   I                      |
    |     -------------------------------------      Zug:      45  |
    |   9 |   | O |   |   |   | O | O |   | O | J                  |
    |     -------------------------------------      Score:     0  |
    |   8 | O | O |   |   | O | O | O |   |   | K                  |
    |     -------------------------------------      Level:    10  |
    |   7 |   | O | O |   |   | O | O | O | O | L                  |
    |     -------------------------------------      ZielMatrix:   |
    |   6 |   | O | O |   |   | O | O |   | O | M                  |
    |     -------------------------------------        OO  OO  O   |
    |   5 |   |   |   | O |   |   |   |   | O | N        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   4 | O | O |   | O | O |   |   | O |   | O        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   3 |   | O |   |   | O | O | O | O |   | P        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   2 |   | O |   |   |   | O |   |   |   | Q        OO  OO    |
    |     -------------------------------------        OO  OO  O   |
    |   1 |   | O | O | O | O | O |   | O | O | R                  |
    |     -------------------------------------                    |
    |       0   Z   Y   X   W   V   U   T   S                      |
    ----------------------------------------------------------------
    

    Das ist halt immer Random (so scheint es)



  • Das Problem erinnert mich irgendwie an den Rubik's Cube und ich glaube, wenn man das algorithmisch/mathematisch angehen will, dann wird das wohl irgendwo in die Gruppentheorie gehen. Ist jedenfalls auf gar keinen Fall trivial.

    Edit: @ SeppJ: Na, immernoch für 40€ dabei? 👍



  • Ein Paper habe ich dazu gefunden: How to Solve the Torus Puzzle



  • Ich wäre auch bereit das Geld einer Orga seiner wahl zu spenden, wenn das jemanden glücklich macht, ich bin da nicht so. Er würde es ja sogar freiwillig machen, daher mein vorschlag mit der spende. Mir gehts nur darum so nen solver zu bekommen.

    Versteht mich nicht falsch ich weiss nicht wieviel aufwand es ist, deswegen bin ich ja hier. Wenn es wirklich so schwer ist wie gedacht *achselzuck* muss ja net morgen fertig sein das teil.



  • Das war keine Kritik meinerseits, sondern vielmehr ein ironischer Kommentar á la "scheinbar einfache Probleme sind viel komplizierter, als man denkt", und das nicht nur für Leute, die sich mit der Materie nicht so auskennen.
    Ich denke, das Problem wird nur jemand in seiner Freizeit für lau (=40€) angehen, der ansonsten extrem unterfordert ist (was leider sehr selten vorkommt).



  • Och ich habs nicht so böse aufgenommen, im grunde genommen fühle ich mich wie penny bei the big bang theorie ^^



  • Furble Wurble schrieb:

    Ein Paper habe ich dazu gefunden: How to Solve the Torus Puzzle

    Na das ist ja schon mal ein vielversprechender Ansatz. Man könnte jetzt eine Nummerierung der Felder raten und den Algorithmus als Black Box draufwerfen. Das wiederholt man so lange, bis der Algorithmus eine hinreichend kurze Sequenz auswirft. Wenn man sich beim Raten der Nummerierung geschickt anstellt, kann ich mir gut vorstellen, dass das praktikabel ist.



  • Hier ist noch ein Paper, das Heuristiken behandelt: http://dl.acm.org/citation.cfm?id=2184526



  • Furble Wurble schrieb:

    Ein Paper habe ich dazu gefunden: How to Solve the Torus Puzzle

    Das ist nicht dasselbe. Dort sind keine identitätslosen Murmeln vorgegeben, sondern Zahlen. Man weiß also genau welches Feld wo landen muss und kann damit eine bessere Abschätzung vornehmen. Das hilft sicher.

    @Topic: Ich würde folgendes vorschlagen. Eine Lösung muss jedes Feld der Eingabe auf ein Feld der Ausgabe verschieben. Die Anzahl der Schritte um ein Feld zu einem Zielfeld zu verschieben ist die Summe aus horizontalem und vertikalem Abstand (Torusstruktur beachten!). Wir suchen nun eine Zuordnung von Quellfeldern zu Zielfeldern, die die Summe all dieser Abstände minimiert, nennen wir diese Summe der Abstände X. In jedem Zug kommen bis zu 9 Felder ihrem eigentlichen Zielort um 1 näher. Eine untere Schranke für die Anzahl der nötigen Schritte ist also X/9. Das benutzt man nun für einen bidirektionalen A*-Algorithmus vom Start vorwärts und vom Ziel rückwärts.


  • Mod

    Jodocus schrieb:

    Edit: @ SeppJ: Na, immernoch für 40€ dabei? 👍

    Nach wie vor ist das Problem interessant genug, dass ich es eigentlich fast freiwillig machen würde. Wobei es immer mehr danach aussieht, dass ich vermutlich einfach nicht genug Freizeit hätte, um das in vernünftiger Zeit umzusetzen. Das Rätsel ist schwer.

    iwona schrieb:

    die frage von mir als unwissende. wieso ist eine beinahe annäherung an das ergebnis nicht praktisch wenn ich noch angenommen 20 züge übrig hätte und das muster so gut wie gelöst ist, kann ja der menschliche verstand den rest machen.

    Eine aus den folgenden Gründen offensichtlich nicht gut taugliche, aber naheliegende, Heuristik wäre ja, dass man die Güte einer Stellung anhand der Anzahl übereinstimmender (oder nahezu* übereinstimmender) Pixel bestimmt.
    Angenommen die Zielmatrix:

    ###   ###
    #########
    ###   ###
     #     # 
     #     #
     #     #
    ###   ###
    #########
    ###  ####
    

    und zwischendurch schafft man es irgendwie, folgende Stellung zu erzeugen:

    ###   ###
    #########
    ####  ###
     #     # 
     #     #
     #     #
    ###   ###
    #########
    ###   ###
    

    Übereinstimmung fast überall. Die Heuristik wäre begeistert. Aber um von der einen Stellung zur anderen zu kommen ist nicht einfach. Ein Algorithmus, der in der (zugtechnischen) Nähe einer guten Stellung nach Verbesserungen sucht, würde wohl niemals von der einen Stellung zur anderen kommen, weil die Zwischenstellungen allesamt sehr viel schlechter bewertet würden als die fast perfekte Ausgangsstellung. (Ich habe nicht geprüft, ob diese Stellungen überhaupt ineinander überführbar wären. Dies ist nur ein Beispiel für zwei ähnliche Stellungen, die offensichtlich sehr schwer ineinander zu überführen wären)

    *: Es gilt natürlich den Begriff "nahezu" in diesem Zusammenhang zu klären. Auch wenn ich durchaus Vorstellungen dazu hätte, will ich nicht weiter darauf eingehen, weil dieser Beitrag ja ohnehin ein Beispiel bringt, wieso die Technik an sich keine gute Idee sein könnte.



  • Nicht dass ich irgend eine Idee hätte, aber eine Frage dafür: ist die optimale Lösung gesucht, oder nur irgendeine Lösung, oder irgendeine Lösung mit <= N Zügen die aber nicht optimal sein muss?


  • Mod

    hustbaer schrieb:

    Nicht dass ich irgend eine Idee hätte, aber eine Frage dafür: ist die optimale Lösung gesucht, oder nur irgendeine Lösung, oder irgendeine Lösung mit <= N Zügen die aber nicht optimal sein muss?

    Soweit ich das verstanden habe, eine Lösung mit <= N Zügen.

    Wobei N anscheinend im zweistelligen Bereich ist, die Anzahl möglicher Kombinationen ist daher gigantisch.



  • Jester schrieb:

    Furble Wurble schrieb:

    Ein Paper habe ich dazu gefunden: How to Solve the Torus Puzzle

    Das ist nicht dasselbe. Dort sind keine identitätslosen Murmeln vorgegeben, sondern Zahlen. Man weiß also genau welches Feld wo landen muss und kann damit eine bessere Abschätzung vornehmen.

    Du hast recht. Allerdings behandeln die Autoren das Problem als Black-White Variante in Teil 4 der Abhandlung.

    Darüberhinaus erleichtern ein paar Stichworte die Suche nach Arbeiten in die richtige Richtung.
    Torus/Donut/toroid [sliding] puzzle oder ähnlich.



  • das ist korrekt. du hast nur eine begrenzte anzahl an zügen pro muster diese können aber im wert sich zwischen 1 und 3 zügen jeweils verändern.

    also anstatt 45 züge habe ich dann 42 züge aber auch ein anderes geshuffelte feld.



  • ach jetzt war nicht eingeloggt, na gut steht ja oben was ich meinte. doch um das hier nochmal aufzugreifen

    Eine aus den folgenden Gründen offensichtlich nicht gut taugliche, aber naheliegende, Heuristik wäre ja, dass man die Güte einer Stellung anhand der Anzahl übereinstimmender (oder nahezu* übereinstimmender) Pixel bestimmt.
    Angenommen die Zielmatrix:

    ABCDEFGHI
    
    ###   ###
    #########
    ###   ###
     #     #
     #     #
     #     #
    ###   ###
    #########
    ###  ####
    

    und zwischendurch schafft man es irgendwie, folgende Stellung zu erzeugen:

    ABCDEFGHI
    
    ###   ### Y
    ######### X
    ####  ### V
     #     #  N
     #     #  M
     #     #  S
    ###   ### J
    ######### K
    ###   ### L
    
    !"§$%&/()
    

    Übereinstimmung fast überall. Die Heuristik wäre begeistert. Aber um von der einen Stellung zur anderen zu kommen ist nicht einfach. Ein Algorithmus, der in der (zugtechnischen) Nähe einer guten Stellung nach Verbesserungen sucht, würde wohl niemals von der einen Stellung zur anderen kommen, weil die Zwischenstellungen allesamt sehr viel schlechter bewertet würden als die fast perfekte Ausgangsstellung. (Ich habe nicht geprüft, ob diese Stellungen überhaupt ineinander überführbar wären. Dies ist nur ein Beispiel für zwei ähnliche Stellungen, die offensichtlich sehr schwer ineinander zu überführen wären)

    Es ist aber recht einfach gelöst.

    d, d, &, Y, Y, Y, $, F

    *nochmal drüber schau* ... so sollte es richtig sein.

    Na gut wir verdoppeln das Anfangsgebot. Ich biete nun 80 Euro.



  • iwona schrieb:

    Es ist aber recht einfach gelöst.

    d, d, &, Y, Y, Y, $, F

    *nochmal drüber schau* ... so sollte es richtig sein.

    Kann ich nicht nachvollziehen.
    Schreib das bitte mal schrittweise auf, mit Zwischenstellungen und so.


Anmelden zum Antworten