Aussenlienine einer Gitterform finden



  • SOrry das erwähnst du ja schon, habs ubersehen, sry, danke vielmals


  • Mod

    Quowe schrieb:

    Normale der Line herausfinden
    Prüfen ob auf beiden seiten punkte sind

    Nein, viel zu kompliziert. Und scheitert wahrscheinlich an verrückten Formen. Bei einem Dreiecksgitter würde ich dies benutzen: Eine Linie ist die direkte Verbindung zwischen zwei Punkten. Bei einer Außenlinie gibt es nur höchstens eine andere Verbindung zwischen den Punkten mit nur einer Zwischenstation. Bei einer Innenlinie gibt es hingegen immer zwei. Also:
    -Punkt A nehmen
    -Einen der Nachbarpunkte, B, wählen
    -Alle anderen Nachbarpunkte von A durchgucken, ob sie auch Nachbarn von B sind
    -Findet man man 1 oder weniger, so ist AB eine Außenlinie



  • OK, macht sinn, danke nochmals, ich probiers mal aus



  • In deinem Beispiel gilt:

    x ist Randpunkt => x hat weniger als 6 Nachbarn. Also erstmal alle Punkte mit 6 Nacbarn raushauen. Alternativ auch: die Winkelsumme zwischen den Verbindungen zu allen nachbarn hin ist < 360°. Dann bleiben nur die Randpunkte über.



  • Meine erste Frage wäre: was hast du genau gegeben? Das netz als graph? Dann kannst du einfach den Rand der Facette ablaufen zum beispiel imgegen-uhrzeigersinn: laufen, nächste kante im gegen-uzs nehmen usw. Damit alle facetten ablaufen, und die äußere wählen.

    @SeppJ: dein kriterium für ne Randkante ist falsch, es kann beliebig viele solcher verbindungen geben.



  • otze schrieb:

    In deinem Beispiel gilt:

    x ist Randpunkt => x hat weniger als 6 Nachbarn.

    Nein. Zum Beispiel der Punkt direkt links unterhalb des Eckpunkts ganz rechts in der Mitte: Der hat nur 5 Nachbarn und ist kein Randpunkt.

    Ich weiß nicht, ob folgende Idee schon genannt wurde:

    Alle Dreiecke auflisten. Die Kanten, die nur zu einem Dreieck beitragen, sind Randkanten.


  • Mod

    Jester schrieb:

    @SeppJ: dein kriterium für ne Randkante ist falsch, es kann beliebig viele solcher verbindungen geben.

    Wir reden schon von 2D-Dreiecksgittern, oder?



  • Ja klar. Man kann ja auch 5 oder 17 solcher verbindungen haben. 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.


  • Mod

    Ach das meinst du. Ich bin von Gittern ohne Schnittpunkten ausgegangen, wie im Beispiel des TE.



  • Ja, der graph ist planar. Jetzt tellst du dich aber grad ein bissel an, oder?


  • Mod

    edit:



  • Klar geworden oder soll ich ein Bild malen?



  • 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.

    Angenommen es handelt sich um eine Delaunay-Triangulierung, dann haben Randpunkte eine Voronio-Zelle (Dual zu Delaunay), die sich ins unendliche erstreckt. ... Nee, falsch, mist.


  • Mod

    Jester schrieb:

    Klar geworden oder soll ich ein Bild malen?

    Ja. Peinlich, da dran nicht gedacht zu haben.



  • Gregor schrieb:

    otze schrieb:

    In deinem Beispiel gilt:

    x ist Randpunkt => x hat weniger als 6 Nachbarn.

    Nein. Zum Beispiel der Punkt direkt links unterhalb des Eckpunkts ganz rechts in der Mitte: Der hat nur 5 Nachbarn und ist kein Randpunkt.

    Deswegen steht dort => und nicht <=>.



  • otze schrieb:

    Gregor schrieb:

    otze schrieb:

    In deinem Beispiel gilt:

    x ist Randpunkt => x hat weniger als 6 Nachbarn.

    Nein. Zum Beispiel der Punkt direkt links unterhalb des Eckpunkts ganz rechts in der Mitte: Der hat nur 5 Nachbarn und ist kein Randpunkt.

    Deswegen steht dort => und nicht <=>.

    Oh, sorry, habe da die falsche Message reininterpretiert. Zumindest kannst Du über die Anzahl der Nachbarn die Randpunkte nicht direkt von den anderen Punkten trennen.



  • Wahrscheinlich ist es am einfachsten einen modifizierten Flood-Fill-Algorithmus zu verwenden.



  • 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.


Anmelden zum Antworten