AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Schnelle Alternativen für Multiplikation mit 2
Thema durchsuchen
Ansicht
Themen-Optionen

Schnelle Alternativen für Multiplikation mit 2

Ein Thema von Delphi-Laie · begonnen am 16. Jan 2012 · letzter Beitrag vom 23. Jan 2012
Antwort Antwort
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.659 Beiträge
 
Delphi 12 Athens
 
#1

AW: Schnelle Alternativen für Multiplikation mit 2

  Alt 16. Jan 2012, 14:29
Wobei so ein Test aber auch nur dann aussagefähig ist, solange unter exakt gleichen Bedingungen verglichen wird.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.154 Beiträge
 
Delphi 10.3 Rio
 
#2

AW: Schnelle Alternativen für Multiplikation mit 2

  Alt 17. Jan 2012, 09:55
Warum ist alles langsammer als früher obwohl die Rechner 100x schneller geworden sind?

Weil keiner mehr optimiert...

Früher hab ich mit der Z80 Bibel von Rodnay Zaks für jede - wichtige - Routine die Taktzüglen zusammen addiert um zu schauen, ob ich nicht mit anderen Befehlen 2 oder 3 sparen kann.

Also warum nicht shl verwenden... Dann bist Du Dir sicher das es aus so benutzt wird... Falls der Compiler es anders sieht!

Mavarik
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.373 Beiträge
 
Delphi 12 Athens
 
#3

AW: Schnelle Alternativen für Multiplikation mit 2

  Alt 17. Jan 2012, 10:12
Im Prinzip hat es DeddyH schon gesagt:
Möglichts "einfachen" Code schreiben, denn der ist besser wartbar
und das ist oftmals eigentlich wichtiger, als eine Nanosekunde weniger zu benötigen.

Der Compiler optimiert dann so Einiges und wenn dann immernoch ein paar Takte zuviel sind, welche unbedingt weg müssen, dann kann man immernoch optimieren.

Wie gesagt, mit SHL muß man aufpassen, da es keinen Pascal-Befehl für ein "signed shift" gibt. (k.A. warum)

PS: Ich hab auch schonmal 'ne ganze Weile dran gesessen und mit Assembler rumoptimiert, mit dem Ergebnis, daß die Codeoptimierung etwa genauso gut war und somit sinnlos Zeit verschwendet wurde, welche wo anderes nötiger gewesen wäre.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.659 Beiträge
 
Delphi 12 Athens
 
#4

AW: Schnelle Alternativen für Multiplikation mit 2

  Alt 17. Jan 2012, 10:21
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?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
gammatester

Registriert seit: 6. Dez 2005
999 Beiträge
 
#5

AW: Schnelle Alternativen für Multiplikation mit 2

  Alt 17. Jan 2012, 12:18
Wie gesagt, mit SHL muß man aufpassen, da es keinen Pascal-Befehl für ein "signed shift" gibt. (k.A. warum)
Nein, shl ist unproblematisch, da sowohl bei shiften als auch bei der Multiplakation die hochsten Bits im Nirvana landen und die Ergebnisse gleich sind (wenn die Checks ausgeschaltet sind).

Problematisch ist shr, da hier offensichtlich auch bei signed Typen der Assemblerbefehl SHR und nicht SAR benutzt wird:
Delphi-Quellcode:
var
  x,y: longint;
begin
  x := -10;
  y := x shr 1;
  writeln(y);
  y := x div 2;
  writeln(y);
end.
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.
  Mit Zitat antworten Zitat
Delphi-Laie

Registriert seit: 25. Nov 2005
1.474 Beiträge
 
Delphi 10.1 Berlin Starter
 
#6

AW: Schnelle Alternativen für Multiplikation mit 2

  Alt 17. Jan 2012, 12:13
Warum ist alles langsammer als früher obwohl die Rechner 100x schneller geworden sind?

Weil keiner mehr optimiert...
Richtig, Windows ist das beste Beispiel.

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.

und das ist oftmals eigentlich wichtiger, als eine Nanosekunde weniger zu benötigen.
Wie hier schon erwähnt, die Menge/Masse macht es. Und Windows macht nahezu jeden PC zur Schnecke, wenn es denn will. Lediglich bei den heutigen Mehrkernprozessoren im x-Gigahertz-Bereich habe ich den Eindruck, daß Billys Mannen bei deren Rechengeschwindigkeit mit dem Programmieren ihrer Schnecken- und Zeitlupenroutinen auch nicht mehr hinterherkommen.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#7

AW: Schnelle Alternativen für Multiplikation mit 2

  Alt 17. Jan 2012, 13:36
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.
Dann vergleich aber mal die Funktionalität uns Usabillity. Da liegen Welten zwischen damals und heute.

Zitat:
Wie hier schon erwähnt, die Menge/Masse macht es. Und Windows macht nahezu jeden PC zur Schnecke, wenn es denn will. Lediglich bei den heutigen Mehrkernprozessoren im x-Gigahertz-Bereich habe ich den Eindruck, daß Billys Mannen bei deren Rechengeschwindigkeit mit dem Programmieren ihrer Schnecken- und Zeitlupenroutinen auch nicht mehr hinterherkommen.
Das ist Unsinn. Ich habe hier XP mit einem etwas älteren Prozessor und ich kann nicht über ein langsames Windows klagen.

Und wie schon gesagt wurde der Flaschenhals ist selten eine nicht optimierte Rechneoperation, sondern meist der Datentransfer über die Hardware oder schlechte Speicherveraltung.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.960 Beiträge
 
Delphi 12 Athens
 
#8

AW: Schnelle Alternativen für Multiplikation mit 2

  Alt 17. Jan 2012, 14:07
Zitat:
Wie hier schon erwähnt, die Menge/Masse macht es. Und Windows macht nahezu jeden PC zur Schnecke, wenn es denn will. Lediglich bei den heutigen Mehrkernprozessoren im x-Gigahertz-Bereich habe ich den Eindruck, daß Billys Mannen bei deren Rechengeschwindigkeit mit dem Programmieren ihrer Schnecken- und Zeitlupenroutinen auch nicht mehr hinterherkommen.
Das ist Unsinn. Ich habe hier XP mit einem etwas älteren Prozessor und ich kann nicht über ein langsames Windows klagen.
Ich habe selbst mit Windows 7 auf einem ca. 10 Jahre alten Medion Laptop keine Geschwindigkeitsprobleme (der RAM ist auf 1,5 GiB aufgerüstet, sonst alles unverändert). Das startet ähnlich schnell wie XP.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
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 05:07 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