eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingBłędny epsilon - this is not a bug, this is ?Re: Błędny epsilon - this is not a bug, this is ?
  • Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!news.cyf-kr.edu.pl!news.nask
    .pl!news.nask.org.pl!news.internetia.pl!newsfeed.neostrada.pl!unt-exc-02.news.n
    eostrada.pl!unt-spo-b-01.news.neostrada.pl!news.neostrada.pl.POSTED!not-for-mai
    l
    From: "slawek" <h...@s...pl>
    Newsgroups: pl.comp.programming
    References: <50924bb1$0$1308$65785112@news.neostrada.pl>
    <k72sqt$gq$1@news.dialog.net.pl>
    <509505f2$0$1317$65785112@news.neostrada.pl>
    <k734vm$43g$1@news.dialog.net.pl>
    In-Reply-To: <k734vm$43g$1@news.dialog.net.pl>
    Subject: Re: Błędny epsilon - this is not a bug, this is ?
    Date: Sat, 3 Nov 2012 16:10:07 +0100
    MIME-Version: 1.0
    Content-Type: text/plain; format=flowed; charset="iso-8859-2"; reply-type=original
    Content-Transfer-Encoding: 8bit
    X-Priority: 3
    X-MSMail-Priority: Normal
    Importance: Normal
    X-Newsreader: Microsoft Windows Live Mail 15.4.3555.308
    X-MimeOLE: Produced By Microsoft MimeOLE V15.4.3555.308
    Lines: 52
    Message-ID: <509533d1$0$26687$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 62.69.202.124
    X-Trace: 1351955410 unt-rea-a-01.news.neostrada.pl 26687 62.69.202.124:62237
    X-Complaints-To: a...@n...neostrada.pl
    Xref: news-archive.icm.edu.pl pl.comp.programming:200481
    [ ukryj 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.

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: