-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
atman.pl!news.task.gda.pl!news.dialog.net.pl!not-for-mail
From: Tomasz Sowa <t...@N...ttmath.org>
Newsgroups: pl.comp.programming
Subject: Re: Błędny epsilon - this is not a bug, this is ?
Date: Sat, 03 Nov 2012 11:48:52 +0100
Organization: Dialog Net
Lines: 89
Message-ID: <k72sqt$gq$1@news.dialog.net.pl>
References: <50924bb1$0$1308$65785112@news.neostrada.pl>
NNTP-Posting-Host: dynamic-78-8-96-237.ssp.dialog.net.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2
Content-Transfer-Encoding: 8bit
X-Trace: news.dialog.net.pl 1351939741 538 78.8.96.237 (3 Nov 2012 10:49:01 GMT)
X-Complaints-To: a...@d...net.pl
NNTP-Posting-Date: Sat, 3 Nov 2012 10:49:01 +0000 (UTC)
User-Agent: Mozilla/5.0 (X11; FreeBSD amd64; rv:16.0) Gecko/20121101
Thunderbird/16.0.2
In-Reply-To: <50924bb1$0$1308$65785112@news.neostrada.pl>
Xref: news-archive.icm.edu.pl pl.comp.programming:200478
[ ukryj nagłówki ]On 2012.11.01 11:15, slawek wrote:
> Tzw. maszynowy epsilon (see Wikipedia) wynosi nie więcej niż 1.111E-016 dla
> liczb 64-bitowych.
Na wikipedii jest 2.220446e-16 (zjedź na dół do przykładu)
> Taki wynik łatwo otrzymać nawet naiwnym algorytmem, w
> którym po kolei sprawdzane są w pętli kolejne wartości epsilon - każda
> kolejna nieco (o ułamek procenta) mniejsza od poprzedniej.
A po co taki naiwny algorytm? definicja maszynowego epsilon chyba jest
jasna?
> Algorytm "fast"
O(1) patrz poniżej
> adaptacyjnie zmienia krok itd. - nie ma to znacznego wypływu na wynik, ale
> liczba kroków jest znacznie mniejsza.
>
> Jednak zaglądając do float.h w MS VS C++ można znaleźć definicję
> DBL_EPSILON, wraz ze stosownym komentarzem, 2.22044604925031310000E-016.
I jest to prawidłowa wartość.
> Jest to niemal 2 razy więcej, niż naprawdę wynosi epsilon (obliczony właśnie
> programem skompilowanym w MSVS C++). "This is not a bug, this is
> inaccuracy" - chciałoby się powiedzieć.
Pokaż ten program.
> Zaglądamy dalej - Matlab - tak ostatnio chwalony - ma wbudowaną funkcję
> eps - zgadnijcie co zwraca eps jako wynik liczbowy? Tak, też się zdziwiłem -
> przecież Matlab to Matlab.
>
> Jeszcze raz rzut oka do Wikipedii - jest sobie wyraźnie dobra wartość
> epsilona dla double w tabelce - ale już np. program w Phytonie i wyniki z
> niego - znowu błędne 2.22E-16 . I nie jest to "wina Phytona" - ale po prostu
> błąd w programie.
>
> "Phytonowcy", staff MS i ludzie z MathWorks popełnili jeden i ten sam błąd -
> dzielili przez dwa. Ciąg wartości x[n], jakie otrzymywali, dla dostatecznie
> dużego n nie spełniał nierówności 1.0+x[n] > 1.0.
Nie wiem co tu jest do dzielenia, aby obliczyć maszynowe epsilon nic nie
trzeba dzielić, przykład:
#include <iostream>
#include <stdint.h>
#include <iomanip>
int main()
{
union
{
double f;
uint64_t i;
} u1, u2, u3;
u1.i = 0x3ff0000000000000ul;
// jeden (exponent na 1023 mantysa na zero -- jeden bit z przodu
// mantysy jest domniemany)
u2.i = 0x3ff0000000000001ul;
// jeden i ciupka (ostatni bit mantysy na jeden i jeden bit z przodu
// domniemany)
u3.f = u2.f - u1.f;
std::cout << "Maszynowe epsilon: " << std::setprecision(18) <<
u3.f << std::endl;
}
/home/tomek/roboczy/test$ g++ -O2 -o test test.cpp && ./test
Maszynowe epsilon: 2.22044604925031308e-16
Oczywiście nie widzę sensu wypisywania tej wartości jako decimal (to
tylko przybliżenie).
W C++ jako stałą możesz mieć w ten sposób:
std::cout << std::numeric_limits<double>::epsilon() << std::endl;
--
Tomek
http://www.ttmath.org
Następne wpisy z tego wątku
- 03.11.12 12:54 slawek
- 03.11.12 14:07 Tomasz Sowa
- 03.11.12 16:10 slawek
- 03.11.12 17:59 Michoo
- 03.11.12 22:22 slawek
- 04.11.12 15:42 kenobi
- 04.11.12 22:50 AK
- 04.11.12 23:00 AK
- 05.11.12 08:26 Adam Wysocki
- 05.11.12 11:07 Michoo
- 05.11.12 11:52 slawek
- 05.11.12 12:14 slawek
- 05.11.12 12:48 slawek
- 05.11.12 13:04 slawek
- 05.11.12 13:10 Michoo
Najnowsze wątki z tej grupy
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
Najnowsze wątki
- 2025-02-06 PROGRAM DOPŁAT DO AUT ELEKTRYCZNYCH TO ABSURD. ZA ŚRODKI Z KPO KUPIMY NIEMIECKIE I CHIŃSKIE AUTA
- 2025-02-05 ceny OC
- 2025-02-05 Re: ceny OC
- 2025-02-05 Re: ceny OC
- 2025-02-07 Smar do video
- 2025-02-06 Litowe baterie AA Li/FeS2 a alkaliczne
- 2025-02-07 Gliwice => Business Development Manager - Network and Network Security
- 2025-02-07 Warszawa => System Architect (Java background) <=
- 2025-02-07 Warszawa => System Architect (background deweloperski w Java) <=
- 2025-02-07 Warszawa => Solution Architect (Java background) <=
- 2025-02-07 Gliwice => Ekspert IT (obszar systemów sieciowych) <=
- 2025-02-07 Lublin => Programista Delphi <=
- 2025-02-07 Warszawa => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2025-02-07 Dęblin => Node.js / Fullstack Developer <=
- 2025-02-07 Bieruń => Spedytor Międzynarodowy (handel ładunkami/prowadzenie flo