![]() |
AW: Schnelle Alternativen für Multiplikation mit 2
Und wenn man schon optimiert, dann muss man das auch an den richtigen Stellen tun. Was nützt es mir, wenn mein Programm bei einer einfachen Rechenoperation 2 Taktzyklen einspart, dann aber 2 Millionen Datensätze sequentiell durchsucht?
|
AW: Schnelle Alternativen für Multiplikation mit 2
Zitat:
Ich hatte noch "das Glück der frühen Geburt", Wordperfect 5, Turbo-Pascal 6.0 (und vorherige Versionen) und Geoworks Ensemble (Versionsnummer nicht mehr geläufig) kennenzulernen. Alle drei waren n.m.W. in Assembler bzw. Maschinencode geschrieben und hinsichtlich Geschwindigkeit und Stabilität einfach exzellent. Bei Geoworks Ensemble hatte man durchaus das Gefühl, vor einem Computer jenseits der PC-Architektur zu sitzen. Auch der Starwriter war sehr schnell und stabil, überlebte und mündete letzlich in das Open Office. Allerdings gab es damals noch kein präemtives Multitasking, das muß man dem heutigen Windows zugutehalten. Zitat:
|
AW: Schnelle Alternativen für Multiplikation mit 2
Zitat:
Problematisch ist shr, da hier offensichtlich auch bei signed Typen der Assemblerbefehl SHR und nicht SAR benutzt wird:
Delphi-Quellcode:
Die Ergebnisse sind 2147483643 und -5. Aber selbst SAR ist noch nicht äquivalent zu div, da zwar -10 SAR 1 = -5 ist aber -1 SAR 1 = -1 und -1 div 2 = 0.
var
x,y: longint; begin x := -10; y := x shr 1; writeln(y); y := x div 2; writeln(y); end. |
AW: Schnelle Alternativen für Multiplikation mit 2
Zitat:
Zitat:
Und wie schon gesagt wurde der Flaschenhals ist selten eine nicht optimierte Rechneoperation, sondern meist der Datentransfer über die Hardware oder schlechte Speicherveraltung. |
AW: Schnelle Alternativen für Multiplikation mit 2
Zitat:
|
AW: Schnelle Alternativen für Multiplikation mit 2
Zitat:
Delphi-Quellcode:
Mavarik
Aus: A := A * 8; wird
Add ebx,ebx Add ebx,ebx Add ebx,ebx Aus: A := A div 2; wird mov ecx,2 mov eax,ebx cdq idev ecx mov ebx,eax |
AW: Schnelle Alternativen für Multiplikation mit 2
Wieso macht der Compiler das? Alignment? Ich hab’s mal getestet, und es ist (auf meinem Core 2) sowohl langsamer als die echte Multiplikation als auch das Shifting:
Code:
(das ganze sind Millisekunden für jeweils 1 000 000 000 Durchläufe)
Add, Add, Add: 1435
Shl: 421 IMul: 1264 |
AW: Schnelle Alternativen für Multiplikation mit 2
Zitat:
Mavarik |
AW: Schnelle Alternativen für Multiplikation mit 2
Ich erlaube mir, dieses leicht angetagte Thema noch einmal aufzuwärmen.
Der (bzw. die) Delphicompiler optmiert (optimieren) also in mehrerlei Hinsicht. Da dieses Forum auch ein Lazarusforum ist: Vermutlich stecken im Freepascalcompiler bzw. in Lazarus noch mehr Optmierungspotential. Doch Vorsicht bei den Eliminationen mit vermeintlich oder tatsächlich schnelleren Alternativen: Die Ergebnisse sind nicht immer denen in/mit Delphi gleich und können auch inkonsistent sein, siehe ![]() |
AW: Schnelle Alternativen für Multiplikation mit 2
Wenn überhaupt ist der sog. "Freepascal-Bug" ein Delphi-Bug: pred und succ sollten den gleichen Ergebnistyp haben wie das Argument. FreePascal, BorlandPascal und VirtualPascal machen das auch, nur Delphi in seiner unendlichen Weisheit definiert
Delphi-Quellcode:
und behauptet dann noch frech:
function Pred(X: Ordinal): Integer;
Zitat:
![]()
Delphi-Quellcode:
liefern FPC, BP7 und VP2.1 jeweils 255 255, die Delphi-Versionen D2 .. D12 allerdings 255 -1
{$Q-,R-}
var b,c: byte; begin b := 0; c := pred(b); writeln(c:6, pred(b):6); end. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:46 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