WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

bitshift != x*2^n ?

 

dummy2k
Forum-Anfänger

Forum-Anfänger


Beiträge: 26
Anmeldedatum: 05.09.12
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 30.11.2012, 16:24     Titel: bitshift != x*2^n ?
  Antworten mit Zitat      
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!
Private Nachricht senden Benutzer-Profile anzeigen


Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 30.11.2012, 23:52     Titel: Re: bitshift != x*2^n ?
  Antworten mit Zitat      
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
Private Nachricht senden Benutzer-Profile anzeigen
 
Neues Thema eröffnen Neue Antwort erstellen



Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

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 | goMatlab RSS Button 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.