-
Data: 2012-11-03 14:07:57
Temat: Re: Błędny epsilon - this is not a bug, this is ?
Od: Tomasz Sowa <t...@N...ttmath.org> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 2012.11.03 12:54, slawek wrote:
>> Na wikipedii jest 2.220446e-16 (zjedź na dół do przykładu)
>
> A ty przeczytaj tabelę u góry (na tej samej stronie Wikipedii). Jak
> na to nie patrzeć - trzeba poprawić - albo u góry, albo u dołu, albo
> w obu miejscach.
Poprawione, ktoś sobie założył że ma 53 bity precyzji a tak naprawdę
jest 52 plus jeden domniemany z przodu ale on 'nie działa w tym
przypadku'. Wrzuciłem także do części talk dowód tego i przykłady
w c++: http://en.wikipedia.org/wiki/Talk:Machine_epsilon
Na razie poprawione dla binary32 i binary64 jak znajdę jutro czas to
przyjrzę się pozostałym.
>> A po co taki naiwny algorytm? definicja maszynowego epsilon chyba
>> jest jasna?
>
> A po co lepszy? Skoro i tak liczy się w mniej niż sekundę? (Czyli o
> parę rzędów wielkości krócej, niż trwało np. napisanie przez ciebie
> tekstu?)
Bo popełniasz błąd który się propaguje w każdej iteracji algorytmu.
>> I jest to prawidłowa wartość.
>
> Możliwe. Pod warunkiem, że przyjmiemy inną definicję niż podana w
> samym pliku float.h.
>
> Wniosek - albo definicja w pliku float.h (z pakietu MSVS) jest
> błędna, albo wartość w pliku float.h (ibidem) jest błędna, albo obie
> są błędne. I to właśnie (podobnie jak hasło w Wikipedii) wymagałoby
> wyprostowania.
>
>> Pokaż ten program.
>
> Nie będę ciebie obrażał podejrzeniem, że nie potrafisz. Do
> sprawdzenia, że 1.0+1.5E-16 > 1.0 to wystarczy ci jedna linijka
> zaczynająca się od cout.
Właśnie mówie pokaż program, bo pewnie przykład robisz obliczając na 80
bitach ;)
>> Nie wiem co tu jest do dzielenia, aby obliczyć maszynowe epsilon
>> nic nie trzeba dzielić, przykład:
>
> Owszem, ale ty nie obliczasz epsilona jako inf { x in R : op(1,x) >
> 1 }, czyli jako najmniejszej liczby, która w wyniku "operacji
> dodawania maszynowego" do liczby 1 daje wynik większy niż 1. Zajrzyj
> sobie do Teukolsky'ego - oczywiście masz prawo twierdzić, że są tam
> bzdury. Ale w takim razie warto napisać do Teukolsky'ego - i pouczyć
> go jak ma zmienić fragment rozdziału.
Definicja z dodawaniem nie jest dobra, trzeba uwzględnić zaokrąglanie.
Możesz dodawać do jedynki 'bardzo malutką wartość' a zaokrąglanie masz
ustawione w górę i wartość ci wyjdzie różna od jeden. Ale to co dodałeś
nie będzie prawidłowym maszynowym epsilonem.
Lepsza jest definicja że maszynowy epsilon dla danego typu to po prostu
różnica
pomiędzy następną *reprezentowalną* liczbą w tym typie za jedynką a samą
jedynką.
> Prawdą jest (w opisanych warunkach), że (double)1.0 +
> (double)2.22E-16 > (double)1.0 , ale prawdą jest też, że np.
> (double)1.0 + (double)1.5E-16 > (double)1.0E-16.
W procesorze masz 80 bitów a nie 64.
--
Tomek
http://www.ttmath.org
Następne wpisy z tego wątku
- 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
- 05.11.12 16:17 AK
- 05.11.12 16:33 Marek Borowski
Najnowsze wątki z tej grupy
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
Najnowsze wątki
- 2025-05-25 Będzie Android z obsługą monitorów. Ciekawe bo to już było i się nazywało MHL
- 2025-05-25 Trump jak stereotypowy "twój stary". Obsługa iPhone'a go przerasta
- 2025-05-25 M$ kroczy tradycyjną ścieżką amerykańskich korpo wytyczoną przez IBM i Dehomag w latach 30. XXw. w III Rzeszy
- 2025-05-25 M$ kroczy tradycyjną ścieżką amerykańskich korpo wytyczoną przez IBM i Dehomag w latach 30. XXw. w III Rzeszy
- 2025-05-25 We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- 2025-05-25 We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- 2025-05-25 We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- 2025-05-25 Ponad 300 pracowników Aquinos Bedding Poland w Łodzi nie otrzymało dotychczas pensji za kwiecień
- 2025-05-25 Trzy największe polskie centrale związkowe domagają się znacznych podwyżek w budżetówce i wzrostu płacy minimalnej.
- 2025-05-25 Ponad 300 pracowników Aquinos Bedding Poland w Łodzi nie otrzymało dotychczas pensji za kwiecień
- 2025-05-25 Ponad 300 pracowników Aquinos Bedding Poland w Łodzi nie otrzymało dotychczas pensji za kwiecień
- 2025-05-25 Lasy Państwowe znów weryfikują piłami starolasy
- 2025-05-24 Apteczka wg DIN 13164
- 2025-05-24 Ada-Europe - AEiC 2025 early registration deadline imminent
- 2025-05-24 Miliony tanich, opuszczonych domów w Japonii