Winged Edge

Winged Edge

Zur Speicherung von Polygonen und polygonalen Netzen, wie sie in der 3D-Computergrafik verwendet werden, gibt es eine Reihe bekannter Datenstrukturen. Die bekanntesten Strukturen sind die Knotenliste, Kantenliste, Winged Edge und die doppelt verkettete Kantenliste (doubly connected halfedge list).

Unterschiedliche Drahtgittermodelle, die einfachste Möglichkeit, ein Polygonnetz darzustellen.

Inhaltsverzeichnis

Einfache Datenstrukturen

Knotenliste

Bei der Knotenliste werden die Punkte in einer separaten Punktliste abgelegt. Eine Fläche wird dann als eine Liste von Zeigern auf die Punkte in dieser Liste definiert. Dadurch wird eine Trennung zwischen der Geometrie (den Koordinaten der Knoten) und der Topologie (welche Knoten verbinden welche Kanten, welche Kanten begrenzen welche Flächen) realisiert.

Kantenliste

Die Nachteile der Knotenliste werden bei der Kantenliste dadurch umgangen, dass alle Kanten in einer separaten Liste gespeichert werden. Facetten werden hier als Zeiger auf die Kantenliste definiert. Neben dem Anfangs- und Endpunkt werden auch die maximal zwei zugehörigen Facetten für jede Kante abgelegt. Die Reihenfolge der Angabe der Eckpunkte für Kanten legt eine Orientierung fest und bestimmt bei Facetten, wo Innen und wo Außen ist.

Vor-/Nachteile

Datenstruktur Vorteile Nachteile
Knotenliste
  • Trennung von Geometrie und Topologie
  • minimale Redundanzen (Punkte werden nur 1x abgelegt)
  • Kanten werden mehrmals durchlaufen und ausgegeben
  • Suche nach zu Kanten gehörenden Facetten nicht effizient möglich (nur mit erschöpfender Suche möglich) Für alle Kanten in F1 (jedes Knotenpaar) suchen wir in allen weiteren Facetten, ob sie enthalten ist, wenn Nein dann Randkante)
  • Suchen nach Facetten welche eine Kante / Ecke enthalten ist ineffizient
Kantenliste
  • Trennung von Geometrie und Topologie
  • Schnelle Bestimmung von Randkanten (Kanten mit nur einem Verweis auf Facette)
  • Suchen nach Facetten welche eine Kante / Ecke enthalten ist ineffizient

Generell gilt für Knoten- und Kantenlisten dass die Suche ausgehend von einer Facette nach untergeordneten Objekten wie Kanten und Knoten sehr effizient durchführbar ist. In umgekehrter Richtung verhält es sich jedoch gegenteilig. So ist z.B. die Suche nach allen Facetten welche eine bestimmte Ecke enthalten immer noch nur durch eine erschöpfende Suche möglich.

Komplexere Datenstrukturen

Winged Edge nach Baumgart

Eine Datenstruktur, mit deren Hilfe sehr viele Abfragen effizient bearbeitet werden können ist die Winged-Edge-Darstellung nach Baumgart. Zusätzlich zu den Informationen der Kantenliste werden hier noch Zeiger auf die Kanten abgelegt, die von Anfangs- und Endpunkt der aktuellen Kante abgehen. Aufgrund der Orientierung wird jede Kante einmal positiv (im Uhrzeigersinn) und einmal negativ (gegen den Uhrzeigersinn) durchlaufen.

Es gibt insgesamt neun Nachbarschaftsbeziehungen, die für polygonale Netze abgefragt werden können. Welche Facette, Kante oder Ecke gehört zu jeder Facette, zu jeder Kante oder zu jeder Ecke? Mit der Winged-Edge-Datenstruktur ist es möglich, in konstanter Zeit abzufragen, welche Knoten oder Facetten zu einer gegebenen Kante gehören. Hat eine Facette k Kanten, können in linearer Zeit diese Kanten nacheinander abgesucht werden (nur bei polygonalen Netzen ohne Änderung der Durchlaufrichtung eines Polygons). Andere Anfragen, insbesondere solche ausgehend von einer Ecke, die nach den Kanten oder Facetten, in denen diese Ecke enthalten ist, suchen, sind deutlich langsamer.

Doppelt verkettete Kantenliste (Half Edge)

Die Half-Edge-Datenstruktur ist ein wenig ausgereifter als die Winged-Edge-Liste. Sie erlaubt, die meisten in der folgenden Tabelle aufgeführten Operationen in konstanter Zeit auszuführen, d.h. konstanter Zeit pro gesammelte Information. Wenn man z.B. alle zu einem Eckpunkt benachbarten Kanten herausfinden will, ist die Operation linear bezüglich der Anzahl der benachbarten Kanten aber konstant in der Zeit pro Kante. Half Edge funktioniert nur mit Mannigfaltigkeiten, d.h. jede Kante ist von genau zwei Facetten (zu jeder Halbkante gibt es eine entgegen gesetzte Halbkante) umgeben, d.h. T-Verbindungen, innere Polygone und Brüche sind nicht erlaubt.

Bei der Half-Edge-Struktur werden nicht Kanten, sondern Halbkanten abgelegt. Halbkanten sind gerichtet und zwei zusammengehörende Halbkanten (Paar) bilden eine Kante und zeigen in die entgegengesetzte Richtung.

Laufzeitvergleich

Folgende Tabelle zeigt einen Vergleich der asymptotischen Laufzeit in Abhängigkeit von den vorhandenen Elementen Knoten , Kanten und Flächen. Es gibt neun mögliche Abfragen auf die Struktur, nämlich "welche Ecke, Kante oder Fläche gehört zu welcher Ecke Kante oder Fläche". Der Vergleich zeigt, wie unterschiedlich gut die Datenstrukturen die Anfrageklassen bearbeiten.

Suchanfrage (gegeben → gesucht) Knotenliste Kantenliste Winged Edge Half Edge
Kante → Eckpunkte N/A \mathcal{O}(1) \mathcal{O}(1) \mathcal{O}(1)
Kante → Facetten N/A \mathcal{O}(1) \mathcal{O}(1) \mathcal{O}(1)
Kante → angrenzende Kanten N/A \mathcal{O}(k) \mathcal{O}(k) \mathcal{O}(k_v)
Eckpunkt → Kanten \mathcal{O}(f*k_f) \mathcal{O}(k) \mathcal{O}(k) \mathcal{O}(k_v)
Eckpunkt → Facetten \mathcal{O}(f*k_f) \mathcal{O}(k) \mathcal{O}(k) \mathcal{O}(k_v)
Facette → Kanten \mathcal{O}(k_f) \mathcal{O}(k_f) \mathcal{O}(k_f) \mathcal{O}(k_f)
Facette → Eckpunkte \mathcal{O}(k_f) \mathcal{O}(k_f) \mathcal{O}(k_f) \mathcal{O}(k_f)
Facette → benachbarte Facette \mathcal{O}(f * k_{f}^{2}) \mathcal{O}(k_f) \mathcal{O}(k_f) \mathcal{O}(k_f)

Hierbei bezeichnet:

  • k: Anzahl aller Kanten
  • kf: Anzahl der Kanten einer Facette
  • kv: Anzahl der Kanten, welche zu einem Punkt gehören
  • f: Anzahl aller Facetten

Erläuterung der Anfrageklassen

Anfrage Knotenliste Kantenliste Winged Edge Half Edge
Kante → Eckpunkte Nicht möglich (es gibt keine Kanten) direkt über Kanten ablesbar direkt über Eintrag für Kante abzulesen über Halbkante→vert und pair→vert.
Kante → Facetten Nicht möglich (es gibt keine Kanten) direkt aus Kanten ablesbar direkt aus Kante ersichtlich die angrenzenden Flächen über edge→face und edge→pair→face bestimmen.
Kante → angrenzende Kanten Nicht möglich (es gibt keine Kanten) für beide Eckpunkte: „Eckpunkt → Kante“ durchführen siehe Kantenliste siehe Kantenliste
Eckpunkt → Kanten Da es sich um geschlossene Polygone handelt, hat jede Facette (genauso viele Kanten wie Punkte) Kanten, diese müssen zu jeder Fläche bestimmt werden und nachgeschaut werden, ob die gegebene Ecke darin enthalten ist einfach alle Kanten durchlaufen Startkante zum Punkt ermitteln, dann über „Vorgänger rechts“ suchen solange bis keine Kante mehr da ist, dann wieder bei Startkante beginnen und in andere Richtung laufen. über vert→edge erste Kante holen, danach entgegen gesetzte Kante holen und links weiterlaufen. Dies so lange machen, bis links keine Nachfolgerkante da ist, dann wieder mit vert→edge anfangen und diesmal so lange nach rechts laufen, bis keine Nachbarkante mehr vorhanden ist.
Eckpunkt → Facetten Einfach für alle Facetten die Kanten durchgehen, und schauen, ob der gesuchte Eckpunkt enthalten ist. „Eckpunkt → Kante“ ausführen und aus diesen Kanten dann direkt die zugehörige Facette lesen. einfach nur die Kanten zum Punkt ermitteln und in konstanter Zeit die dazugehörigen Flächen ermitteln siehe Kantenliste
Facette → Kanten Alle Kanten einer Facette jeweils paarweise bilden direkt aus Facetten ablesbar siehe Half Edge Bei Startkante der Facette beginnen und nach links laufen. Gehört die nachfolgende Kante zur gleichen Facette dann in gleicher Laufrichtung weitermachen. Wird das erst mal kein Nachfolger gefunden kehrt man die Laufrichtung um. Gehört der Nachfolger zur gleichen Facette, dann in dieser Laufrichtung weitermachen, an-sonsten abbrechen. Die Laufrichtung kann sich mehrmals ändern. Irgendwann wird man bei der Startkante angekommen sein. Dann kann man aufhören.
Facette → Eckpunkte Einfach direkt aus Facetten auslesen „Facette → Kanten“ ausführen und in konstanter Zeit die zugehörigen Eckpunkte auslesen siehe Half Edge “Facette → Kanten” ausführen und aus den Kanten die Punkte herauslesen, doppelte Punkte rausschmeißen.
Facette → benachbarte Facette Alle Kanten der zu überprüfenden Facette ermitteln und für jede Kante schauen, ob die anderen Facetten diese Kante auch enthalten. „Facette → Kanten“ ausführen und dann direkt aus den Kanten die zugehörigen Facetten ablesen „Facette → Kanten“ ausführen und zu jeder Kante die angrenzende Fläche auslesen siehe Winged Edge

Zusammenfassung

Wie man sieht, sind die Winged-Edge- und die Half-Edge-Struktur von den enthaltenen Informationen nahezu identisch. Sie weisen deshalb auch fast die gleichen Laufzeiten für das Suchen auf. Half Edge ist in den komplexeren Anfragen etwas besser. Hier müssen aufgrund des Zeigers eines Punktes auf eine zugehörige Startkante beim Suchen aller Kanten eines Punktes auch nur diese angefasst werden. Die Knotenliste scheidet von vornherein aus und die Kantenliste ist vom Suchen her genauso gut wie die Winged-Edge-Liste, benötigt jedoch etwas mehr Speicherplatz, da bei Winged Edge zu einer Facette nur eine Startkante abgelegt werden muss.

Siehe auch


Wikimedia Foundation.

Игры ⚽ Поможем написать курсовую

Schlagen Sie auch in anderen Wörterbüchern nach:

  • Winged edge — The winged edge data structure is a commonly used data representation used to describe polygon models in computer graphics. It explicitly describes the geometry and topology of faces, edges, and vertices when three or more surfaces come together… …   Wikipedia

  • Edge of Seventeen — «Edge of Seventeen» Сингл …   Википедия

  • Edge of Seventeen (chanson) — Edge of Seventeen Single par Stevie Nicks extrait de l’album Bella Donna Face B Outside the Rain[1] Sortie 15 février 1982 …   Wikipédia en Français

  • Edge of Seventeen (song) — Infobox Single Name = Edge of Seventeen Artist = Stevie Nicks from Album = Bella Donna B side = Edge of Seventeen (live) Released = February 20, 1982 Format = Vinyl record 7 Recorded = 1981 Genre = Rock, hard rock Length = 5:28 Label = Modern… …   Wikipedia

  • winged incisor — a rotation deformity of a maxillary incisor tooth in which the distal edge of the tooth protrudes labially …   Medical dictionary

  • Quad-edge — A quad edge data structure is a computer representation of the topology of a two dimensional or three dimensional map, that is, a graph drawn on a (closed) surface.OverviewThe quad edge data structure: * represents simultaneously both the map,… …   Wikipedia

  • Doubly connected edge list — The doubly connected edge list (DCEL) is a data structure to represent an embedding of a planar graph in the plane and polytopes in 3D. This data structure provides efficient manipulation of the topological information associated with the objects …   Wikipedia

  • Doubly-connected edge list — Die Doubly connected edge list (DCEL, doppelt verkettete Kantenliste) ist eine Datenstruktur, die einen zusammenhängenden planaren Graphen repräsentiert, der in die Ebene eingebettet ist. Die Datenstruktur wird in der algorithmischen Geometrie… …   Deutsch Wikipedia

  • One-Winged Angel — Musique de Final Fantasy VII Musique de la série Final Fantasy Final Fantasy IV Final Fantasy V Final Fantasy VI licence Final Fantasy VII Final Fantasy VIII Final Fantasy IX Final Fantasy X et X 2 Final Fantasy Tactics …   Wikipédia en Français

  • One Winged Angel — Musique de Final Fantasy VII Musique de la série Final Fantasy Final Fantasy IV Final Fantasy V Final Fantasy VI licence Final Fantasy VII Final Fantasy VIII Final Fantasy IX Final Fantasy X et X 2 Final Fantasy Tactics …   Wikipédia en Français

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”