![]() |
AW: Dictionary statt binärer Suche?
Leider kann ich mit meinem Delphi 2009 auf dem Beispiel von Sir Rufo nicht aufsetzen, da gibt es anscheinend einiges noch nicht, was in dem Code verwendet wird.
Natürlich ist ein guter Algorithmus zum möglichst kollisionsfreien Berechnen der Hashcodes wichtig. Allerdings würde eine bessere Implementierung des Dictionary bei weitem nicht so empfindlich reagieren wie diese, wenn Kollisionen etwas häufiger vorkommen. |
AW: Dictionary statt binärer Suche?
Zitat:
ELF z.B. ist in UNIX sehr weit verbreitet, PJW wird im Compilerbau häufig verwendet, MD5 und SHA256 sind anerkannt.. |
AW: Dictionary statt binärer Suche?
Zitat:
Zum Vergleich mit 50.000 Einträgen
Mit MAENNER_HASH von 50.000->420.000 rechnerisch hätten 95.76 rauskommen "sollen" Ohne MAENNER_HASH von 50.000->420.000 rechnerisch hätten nur 27625,08 rauskommen "sollen", ist aber faktor 12,4 langsammer... Mavarik :stupid: |
AW: Dictionary statt binärer Suche?
Das Ergebnis war genau so zu erwarten, weil der Algorithmus, mit dem Kollisionen durch diese Implementierung von TDirectory behandelt werden, zu immer grösseren "Klumpen" von Kollisionen führt, die die Performance komplett abstürzen lassen. Sobald sich einmal so ein Klumpen, aus welchem Grund immer, gebildet hat, hilft der beste Algorithmus zur gleichmässigen Verteilung der Hashkeys nicht mehr weiter, weil nicht zu vermeiden ist, dass immer wieder Hashkeys irgendwo in diesen Klumpen hineinfallen und ihn weiter vergrössern.
Und das ganze ist eine Teufelsspirale, weil je grösser ein Klumpen wird, umso grösser wird die Wahrscheinlichkeit, dass irgend ein zufälliger Hashkey gerade in diesen Klumpen hineinfällt. |
AW: Dictionary statt binärer Suche?
Also halten wir mal fest:
Das von Emba implementierte
Delphi-Quellcode:
ist sehr performant, wenn man einen vernünftigen Hash-Algorithmus anbietet.
TDictionary
Hat man einen Grütze-Hash-Algorithmus, dann geht die Performance in den Keller. Es gibt irgendwo auf dieser grossen weiten Welt jemand ganz kluges, der eine wesentlich bessere Implementierung von
Delphi-Quellcode:
bauen kann, der dann auch mit einem Grütze-Hash-Algorithmus besser klar kommt.
TDictionary
Die maximale Performance erhält man aber auch hier nur mit einem vernünftigen Hash-Algorithmus. Mein Fazit:
|
AW: Dictionary statt binärer Suche?
Hallo,
@Sir Rufo: Du hast mich überzeugt das wir in diesem Fall beide Recht haben. Zitat:
Zitat:
Denn den Hash-Algorithmus bei der Emba-Implementierung kannst du ja nicht im ganzen austauschen, da ein Teil fest in TDictionary eingebaut ist. Auch wird kein Programmierer von sich aus auf die Idee kommen für bis 32bit-Werte den Hash mittels einer Formel zu ermitteln. Da wird jeder einen Cast benutzen. Und dann schlägt der Feste Teil richtig böse zu. einbeliebigername. |
AW: Dictionary statt binärer Suche?
Das sehe ich auch so.
Es wäre halt einfacher, wenn man nur eine einfache "Id" als Integer übergeben müsste, die dann von der Komponente in einen passenden Hashwert umgerechnet wird. Es würde Fehlermöglichkeiten halt auf einfache Weise reduzieren. |
AW: Dictionary statt binärer Suche?
Um ehrlich zu sein komme ich zu 99% nicht über Punkt 1 hinaus.
Zu Punkt 3 komme ich eher nur in 0,01% aller Fälle. Ob die
Delphi-Quellcode:
-Implementierung gut oder schlecht ist, ist mir so lange egal, wie die Performance ausreichend ist und das Dingen tut was es soll.
TDictionary
Ich bin aber offen für Alternativen ... dann pusten wir die gleichen Daten da mal rein und messen die Zeiten. @stahli Du kannst doch einfach eine Integer-ID zurückgeben (wenn diese ID die Entität eindeutig identifiziert). Du musst doch nur einen Hash zusammenrechnen, wenn du einen zusammengesetzte ID hast. Und es gibt auch schon eine eingebaute Hash-Funktion
Delphi-Quellcode:
, der man einfach einen Pointer und Size auf die Daten gibt und der bastelt sich dann den Hashwert.
BonJenkinsHash
Ich sehe hier einfach keine Schwierigkeit beim Erstellen des Hash-Werts. Man kann auch mal nach ![]() |
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:26 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz