Ich fand einen sehr interessanten Artikel, der sich mit der effizienten Auslastung aller Kerne eines Prozessors bei der Abarbeitung voneinander abhängiger Tasks beschäftigt. Daraus wuchs der Wunsch, dies Idee zu implementieren und dann damit zu experimentieren.
Der Artikel beschreibt zunächst das Problem: Zahlreiche Tasks müssen abgearbeitet werden. Allerdings sind diese nicht völlg unabhängig voneinander, sondern es existieren solche, die erst nach der Abarbeitung bestimmter anderer gestartet werden dürfen.
Dazu wird ein Algorithmus vorgestellt - eben die namensgebende topologische Sortierung - und erläutert, wie man diese effizient auf das Beispielprojekt anwenden kann.
Meine Experimente erzeugten die unten angehängten Datenstrukturen und Klassen. Zusammengenommen stellen sie Werkzeuge zur Modellierung eines gerichteten Graphen dar. In der vorliegenden Version ist es möglich, den Graphen im dot-Format zu serialisieren, so dass man sich die Beziehungen der Knoten untereinander zum Beispiel hier visualisieren kann.
Beispiel für die Visualisierung des Datenmodells mittels dot bzw. GraphViz
Ein weiteres Beispiel ist hier im dot-Format zu sehen
digraph {
rankdir=LR;
label="ModuleWorkspace";
"3";
"1";
"7" -> { "3", "1", "0"};
"6" -> { "3"};
"5" -> { "2"};
"8";
"10" -> { "7", "4"};
"4" -> { "3"};
"2";
"0";
}
Die Datenstruktur lässt sich natürlich auch mittels der zentralen Komponente der sQLshell und in dWb+ visualisieren, wie die beiden angehängten SVG-Graphiken zeigen sollen.
06.07.2019
Ich habe mein System zur Erzeugung der Webseite um die Erstellung einer Sitemap als Graph erweitert
08.07.2017
Einige neue Generatoren wurden für das Framework zur Erzeugung von Testdaten geschaffen.
InfluxDB Appender für Log4J 1.x
17.03.2018
Nachdem ich vor einiger Zeit zwei Appender für Log4J 1.x vorgestellt habe, habe ich - motiviert durch meine Experimente mit Raspi und ADS-B - einen weiteren verfasst - diesmal zum Schreiben der Daten in eine Zeitreihendatenbank.
Weiterlesen...Android Basteln C und C++ Chaos Datenbanken Docker dWb+ ESP Wifi Garten Geo Git(lab|hub) Go GUI Gui Hardware Java Jupyter Komponenten Links Linux Markdown Markup Music Numerik PKI-X.509-CA Python QBrowser Rants Raspi Revisited Security Software-Test sQLshell TeleGrafana Verschiedenes Video Virtualisierung Windows Upcoming...
Ich habe mich ein wenig mit Attribut-Zertifikaten beschäftigt - Resultat sind einige Klassen zum leichteren Zugriff auf die enthaltenen Attribute...
Weiterlesen...Ich wollte eine Methode schaffen, neue Graphik-Primitiven, die zumindest in java.awt.Graphics2D - in Java noch fehlen, zu ergänzen.
Weiterlesen...Ich wollte eine Methode schaffen, unterschiedlichste Schraffuren in beliebigen Shapes zu erzeugen. diese Möglichkeit fehlt - zumindest in java.awt.Graphics2D - in Java noch.
Weiterlesen...Manche nennen es Blog, manche Web-Seite - ich schreibe hier hin und wieder über meine Erlebnisse, Rückschläge und Erleuchtungen bei meinen Hobbies.
Wer daran teilhaben und eventuell sogar davon profitieren möchte, muß damit leben, daß ich hin und wieder kleine Ausflüge in Bereiche mache, die nichts mit IT, Administration oder Softwareentwicklung zu tun haben.
Ich wünsche allen Lesern viel Spaß und hin und wieder einen kleinen AHA!-Effekt...
PS: Meine öffentlichen GitHub-Repositories findet man hier - meine öffentlichen GitLab-Repositories finden sich dagegen hier.