Aussenlienine einer Gitterform finden



  • knivil schrieb:

    Als kleines beispiel betrachte den vollständigen graphen mit vier knoten und bau noch was dazu, sodass nur noch eine seiner kanten außen liegt ... Klar geworden oder soll ich ein Bild malen?

    Das Bild suggeriert eine Triangulierung, wobei Kanten gerade Strecken sind. Male mir doch mal das Bild mit einer einzigen Aussenkante. Alle Knoten sollten erreichbar sein.

    So langsam mache ich mir Sorgen. Ich schrieb, dass er Sachen dazubauen soll, sodass nur noch eine *seiner* Kanten (also eine der Kanten des vollständigen Graphen mit vier Knoten) außen liegt. Dadurch entstehen natürlich andere, neue Randkanten. Die sind aber nicht weiter von Belang.

    Mal Hand aufs Herz: wenn Du jetzt einfach mal davon ausgegangen wärest, dass an meinem Einwand was dran ist, dann hättest Du das aus obigem Text schon rauslesen können, oder?



  • Ich glaube die zentrale Frage bleibt: Was ist die Eingabe?

    Ein Bild oder ein Graph mit gegebenem Layout?



  • So langsam mache ich mir Sorgen.

    Das mit dem dazubauen habe ich verstanden, wie ihm das helfen soll noch nicht. Klar meinn Defizit, aber ich habe so eine Ahnung ...

    Also hier nach nochmaligem Nachdenken mein Vorschlag, der wahrscheinlich schon mal genannt wurde:

    gegeben:
    - Graph G als Menge von Knoten und Kanten
    - G ist planar und "zusammenhaengend" (zwei zusammenhaengende Teilgraphen besitzen mind. eine gemeinsame Kante)
    - Kanten entsprechen Strecken im 2D
    gesucht: Pfad entlang der ausseren Begrenzung

    Nehme eine Kante, die garantiert aussen liegt (leicht). Waehle Start- und Endpunkt (S,E) so, dass aussen links von (S,E) liegt. Suche aus den Kanten ausgehend von E jene Kante (E, P), bei der der Winkel zw. ES und EP maximal ist (0..360 Grad). Jener Punkt P bzw. Kante (E,P) ist wieder Aussenkante. Wiederhole bis S wieder erreicht wurde.

    Sollte es sich beim Gegebenen doch um ein Bild handeln, der Algorithmus nicht. Funktioniert fuer Pixel aber aehnlich.



  • das sollte auch nicht helfen sondern stellte die Beschreibung eines Gegenbeispiels für das von SeppJ vorgeschlagene Kriterium dar, nicht mehr und nicht weniger.

    Wenn man wirklich den Graphen hat, dann betrachtet man die kombinatorische Einbettung (zyklische Ordnung der Kanten um die Knoten) -> google-Stichwort! Nun kann man ganz einfach Facetten ablaufen, indem man immer eine Kante entlangläuft und die nächste ausgehende (im Gegenuhrzeigersinn) entlangläuft. Wenn man wieder bei der Startkante ankommt ist man eine Facette abgelaufen. Im vorliegenden Fall ist wahrscheinlich die größte Facette ein guter Kandidat für die äußere.

    Oder eben wie Du vorschlägst irgendwoher eine äußere Kante finden und dann mit dem beschriebenen Vorgehen die Facette ablaufen.



  • knivil schrieb:

    gegeben:
    - Graph G als Menge von Knoten und Kanten
    - G ist planar und "zusammenhaengend" (zwei zusammenhaengende Teilgraphen besitzen mind. eine gemeinsame Kante)
    - Kanten entsprechen Strecken im 2D
    gesucht: Pfad entlang der ausseren Begrenzung

    Das reicht nicht.

    knivil schrieb:

    Nehme eine Kante, die garantiert aussen liegt (leicht).

    Unmöglich.

    knivil schrieb:

    Suche aus den Kanten ausgehend von E jene Kante (E, P), bei der der Winkel zw. ES und EP maximal ist (0..360 Grad).

    Winkel? Aha, Du hast also die Koordinaten der Punkte alle. Ja, dann gehts einfach.


Anmelden zum Antworten