AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

System.Math.InRange(..) mit Epsilon?

Ein Thema von Der schöne Günther · begonnen am 16. Dez 2016 · letzter Beitrag vom 16. Dez 2016
Antwort Antwort
Der schöne Günther

Registriert seit: 6. Mär 2013
6.181 Beiträge
 
Delphi 10 Seattle Enterprise
 
#1

System.Math.InRange(..) mit Epsilon?

  Alt 16. Dez 2016, 20:03
Delphi-Version: 5
Wenn man Fließkommazahlen mit einer bestimmten Genauigkeit vergleichen will macht man das z.B. so:
Delphi-Quellcode:
uses System.Math;

const
   epsilon = 1E-2;
begin
   if SameValue(a, b, epsilon) then [...]
end;
Wenn ich schauen will ob Zahl c zwischen a und b liegt kenne ich InRange:
Delphi-Quellcode:
uses System.Math;

begin
   if InRange(meineZahl, 10.5, 75.6) then [...]
end;
Ich kann aber nirgendwo ein Epsilon angeben. Wenn meineZahl nun 10.499999999999 ist, schlägt die Überprüfung fehl. Mir als Mensch ist es allerdings genau genug

Meine Frage: Gibt es da nichts fertiges in der Standard-Bibliothek?

Unter Vergleichsroutinen habe ich sonst nichts gefunden...
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: System.Math.InRange(..) mit Epsilon?

  Alt 16. Dez 2016, 21:20
Man war einfach der Meinung, dass niemand sowas braucht.

Delphi-Quellcode:
if InRange(meineZahl, 10.5-, 75.6+DoubleResolution) then

// oder

function InRange(const AValue, AMin, AMax: Double): Boolean;
begin
  Result := (AValue+DoubleResolution >= AMin) and (AValue-DoubleResolution <= AMax);
end;

// oder

function InRange(const AValue, AMin, AMax: Double): Boolean;
begin
  Result := InRange(AValue, AMin-DoubleResolution, AMax+DoubleResolution);
end;
Gut, das "Epsilon" hab ich hier bissl "minimiert" ... man darf es gern für AMin und AMax jeweils entsprechend den Berechnungen in SameValue berechnen, bzw.
Delphi-Quellcode:
function InRange(const AValue, AMin, AMax: Double): Boolean;
begin
  Result := System.Math.InRange(AValue, AMin, AMax) or SameValue(AValue, AMin) or SameValue(AValue, AMax);
end;
InRange bekommt alle Parameter in Registern, die theoretisch auch in der Funktion nicht auf den Stack wandern müssten, falls der Compiler "schlau" genug ist.
Mit einem 4. Parameter für Epsilon und vorallem auch den internen Berechnungen, für ein fehlendes Epsilon, ist das definitiv nicht mehr möglich.
$2B or not $2B

Geändert von himitsu (16. Dez 2016 um 22:21 Uhr)
  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 20:45 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 by Thomas Breitkreuz