AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Delphi 32bit FixedPoint Math und multiplikation mit Kehrwert
Thema durchsuchen
Ansicht
Themen-Optionen

32bit FixedPoint Math und multiplikation mit Kehrwert

Ein Thema von Memnarch · begonnen am 24. Mai 2012 · letzter Beitrag vom 24. Mai 2012
Antwort Antwort
Benutzerbild von Memnarch
Memnarch

Registriert seit: 24. Sep 2010
737 Beiträge
 
#1

AW: 32bit FixedPoint Math und multiplikation mit Kehrwert

  Alt 24. Mai 2012, 11:18
@jfheins: ja für multiplikationen > 0.

aber mach mal

FixedPointU = (1 shl 16) div FixpointU

FixedPointA * FixedPointU

das wird nicht funktionieren. Die zahl wird größer, nie kleiner.

@shmia wie? einfach die mittigen 32bit rausschnibbeln und als ergebnis nutzen?
Da man Trunc nicht auf einen Integer anwenden kann, muss dieser zuerst in eine Float kopiert werden
  Mit Zitat antworten Zitat
gammatester

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

AW: 32bit FixedPoint Math und multiplikation mit Kehrwert

  Alt 24. Mai 2012, 11:29
Für 32-Bit-Arithmetik mit Maximalwerten <= 30000 wird x div u wird ersetzt durch x * invu shr 16 mit invu := $10000 div u .
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#3

AW: 32bit FixedPoint Math und multiplikation mit Kehrwert

  Alt 24. Mai 2012, 11:41
@jfheins: ja für multiplikationen > 0.
das wird nicht funktionieren. Die zahl wird größer, nie kleiner.
Ach so, ja wenn beide Operanden Fixkommazahlen sind klappt das natürlich nicht so einfach... mein Fehler

In dem Fall brauchst du ein 64bit Zwischenergebnis, aber dann klappt das auch ohne Probleme.
  Mit Zitat antworten Zitat
Benutzerbild von Memnarch
Memnarch

Registriert seit: 24. Sep 2010
737 Beiträge
 
#4

AW: 32bit FixedPoint Math und multiplikation mit Kehrwert

  Alt 24. Mai 2012, 12:58
@gammatester: ah danke, klappt
Da man Trunc nicht auf einen Integer anwenden kann, muss dieser zuerst in eine Float kopiert werden
  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 12:41 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