AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Projekte Generische Graphen-Klasse
Thema durchsuchen
Ansicht
Themen-Optionen

Generische Graphen-Klasse

Ein Thema von Codewalker · begonnen am 23. Aug 2011
Antwort Antwort
Benutzerbild von Codewalker
Codewalker
Registriert seit: 18. Nov 2005
Hallo liebe DP-ler.

Nachdem ich sie jetzt etwas aufpoliert habe, möchte ich meine generische Graphenklasse vorstellen. Wer nicht weiß, was Graphen sind: http://de.wikipedia.org/wiki/Graphentheorie.

Die gesamte Klasse ist mit Generics gebaut und man dadurch neben dem Graphen beliebige Daten an jeden Knoten und an jede Kante hängen. Man kann derzeit nur gerichtete Graphen verwenden. Aktuell ist auch nur ein sinnvoller Graphenalgorithmus enthalten, nämlich die Erkennung, ob der Graph kreisfrei ist. Mehr Algorithmen sollen folgen, wer etwas interessantes dafür entwickelt hat, darf sich gerne bei mir melden. Ich würde mich freuen, wenn irgendwann eine ausgereifte große Graphenklasse draus wird.

Wegen der Generics läuft das ganze erst ab Delphi 2009. Wer es in älteren Versionen einsetzen möchte, muss halt die generischen Typen durch eine konkrete Variante ersetzen (so wie das halt früher mit TList etc. auch war).

Besonders angenehm ist die Anbindung an GraphViz. Mit dieser netten Software kann man recht komfortabel z.B. PNG-Bilder von Graphen erstellen. Dazu ist aber der Download und die Installation der kostenlosen Software GraphViz auf dem Rechner nötig (http://www.graphviz.org/Download..php).

Das ganze Projekt ist OpenSource, gehostet bei Sourceforge (https://sourceforge.net/p/gengraph/home/Home/) und steht derzeit unter der GPL. Der Quellcode ist einigermaßen gut dokumentiert, eine ausführliche Dokumentation fehlt noch. Für den schnellen Einstieg sind aber zwei Demos mit im Paket.

TO DO:
  • Irgendwo ist noch ein Memory-Leak im SimpleDemo.
  • Einfacheren Zugriff auf die Elemente (z.B. namensbasiert)
  • Graphen mit Objektverwaltung bauen, ähnlich wie TList und TObjectList
  • Mehr Graphenalgorithmen einbauen
  • Vollständigere Unterstützung von GraphViz

Downloadlink: http://sourceforge.net/projects/geng...1.zip/download

Ich bin gespannt auf Euer Feedback

Grüße
Thomas
Miniaturansicht angehängter Grafiken
demo2.png  
 
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 09:47 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