|
dummy2k |

Forum-Anfänger
|
 |
Beiträge: 26
|
 |
|
 |
Anmeldedatum: 05.09.12
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 30.11.2012, 16:24
Titel: bitshift != x*2^n ?
|
 |
Hallo,
mir ist aufgefallen, dass ab einer gewissen Zahlengröße die Werte von Bitshift(x,y) nicht mehr mit x*2^y übereinstimmen. Kann es vielleicht sein, dass ab Bitmax, die überlaufenden Bitstellen einfach weggelassen werden und somit eine ganz andere Zahl erscheint, als wenn ich es rechnerisch x*2^y berechne?
Gibs eigentlich eine Möglichkeit mit wenig aufwand rechnerisch auf das gleiche Ergebnis zu kommen wie mit Bitshift?
Wieder vielen Dank im Voraus!
|
|
|
|
|
Jan S |

Moderator
|
 |
Beiträge: 11.057
|
 |
|
 |
Anmeldedatum: 08.07.10
|
 |
|
 |
Wohnort: Heidelberg
|
 |
|
 |
Version: 2009a, 2016b
|
 |
|
|
 |
|
Verfasst am: 30.11.2012, 23:52
Titel: Re: bitshift != x*2^n ?
|
 |
Hallo dummy2k,
Bitte erkläre doch mal genauer, was Dir aufgefallen ist. Ab welcher Zahlengröße? Welchen Typ habe x und y, doubles, int64, etc?
Einerseits hat BITSHIFT einen Überlauf. Andererseits gilt das natürlich auch für x*2^y. Bei DOUBLEs werden nur Zahlen bis 2^53 akkurat gespeichert, darüber hinaus jedoch nicht, da ja nur etwa 16 signifikante Stellen zur Verfügung stehen.
Ich würde keine Zeit investieren um arithmetische Operationen zur perfekten Emulation eines BITSHIFT zu implementieren. BITSHIFT arbeitet zuverlässig und mit Integer-Typen auch effizient genug. Das in Matlab das BITSHIFTing auch für DOUBLEs definiert ist, halte ich für eine schräge Eigenart, die damit zusammenhängt, das Matlab zunächst Integertypen nicht unterstützt hat.
Gruß, Jan
|
|
|
|
|
Einstellungen und Berechtigungen
|
|
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
|
|
Impressum
| Nutzungsbedingungen
| Datenschutz
| FAQ
| RSS
Hosted by:
Copyright © 2007 - 2025
goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.
|
|