-
Data: 2012-11-03 16:10:07
Temat: Re: Błędny epsilon - this is not a bug, this is ?
Od: "slawek" <h...@s...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Użytkownik "Tomasz Sowa" napisał w wiadomości grup
dyskusyjnych:k734vm$43g$...@n...dialog.net.pl...
>Poprawione, ktoś sobie założył że ma 53 bity precyzji a tak naprawdę
I dobrze. Przynajmniej jest jakaś spójność. Zajrzałeś wcześniej do standardu
IEEE-754 ? Referencje do źródeł?
>Bo popełniasz błąd który się propaguje w każdej iteracji algorytmu.
Nie ma błędu. Za każdym razem jest na nowo sprawdzanie 1.0+eps > 1.0, tj.
pętla while(1.0 + eps > 1.0) {...}
Nawet jeżeli były jakieś zaokrąglenia wcześniej itd. ("propagował się") - to
spełnienie/niespełnienie warunku zależy wyłącznie od aktualnej wartości
("nie widzi historii").
>Właśnie mówie pokaż program, bo pewnie przykład robisz obliczając na 80
>bitach ;)
Robię obliczenia na przeciętnych PC przy domyślnych ustawieniach
kompilatora - z którym to dostarczany jest plik float.h z DBL_EPSILON takim
jaki tam jest.
To chyba nie moją rolą jest obudować ten DBL_EPSILON jakimiś ifdef-ami, albo
przynajmniej dać komentarz, kiedy jego wartość jest sensowna? ;)
>Definicja z dodawaniem nie jest dobra, trzeba uwzględnić zaokrąglanie.
Definicja z dodawaniem JEST DOBRA - właśnie dlatego, że UWZGLĘDNIA
DODAWANIE. Jako end-usera nie obchodzi mnie, ile i jakich bitów jest gdzie -
mogą być nawet analogowe napięcia w miliwoltach, mogą być natężenia
przepływu syropu, mogą być jakieś q-bity czy p-bity. Obchodzi mnie tylko,
kiedy 1+x policzone na danej maszynce da w okienku wyników 1, choć x nie
było zerem.
>ustawione w górę i wartość ci wyjdzie różna od jeden. Ale to co dodałeś
>nie będzie prawidłowym maszynowym epsilonem.
To co ty nazywasz "maszynowym epsilonem" nie jest "maszynowe" - ale
zwyczajnie "pamięciowe". Jest wielkością charakterystyczną dla /sposóbu/
zapisu liczb w pamięci (tj. w RAM, w rejestrach FPU itd.)
>Lepsza jest definicja że maszynowy epsilon dla danego typu to po prostu
To nie jest lepsza definicja - choć i nie gorsza. To po prostu inna
definicja.
>W procesorze masz 80 bitów a nie 64.
Niekoniecznie. Są różne procesory i różne tryby ich pracy.
Następne wpisy z tego wątku
- 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
- 05.11.12 19:38 slawek
Najnowsze wątki z tej grupy
- 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
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
Najnowsze wątki
- 2024-11-04 GNSS Motorola G85 vs Redmi Note 9 pro
- 2024-11-04 Katowice => SAP BTP Consultant (mid/senior) <=
- 2024-11-04 Katowice => Spedytor międzynarodowy <=
- 2024-11-04 Warszawa => Specjalista/tka ds. Zamówień publicznych <=
- 2024-11-04 Poznań => QA Engineer <=
- 2024-11-04 Poznań => QA Inżynier <=
- 2024-11-04 Polskie sądy są bardzo wyrozumiałe...
- 2024-11-04 Wrocław => SAP Project System/EPPM Consultant <=
- 2024-11-04 Gliwice => Team Lead / Tribe Lead FrontEnd <=
- 2024-11-04 Kraków => Programista Full Stack (.Net Core) <=
- 2024-11-04 Kraków => Software .Net Developer <=
- 2024-11-04 Kraków => Programista Full Stack .Net <=
- 2024-11-04 Warszawa => Key Account Manager <=
- 2024-11-04 Warszawa => Spedytor Międzynarodowy <=
- 2024-11-04 Warszawa => E-COMMERCE specialist <=