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!newsfeed2.atman.pl!newsfeed.
    atman.pl!newsfeed.neostrada.pl!unt-exc-02.news.neostrada.pl!unt-spo-a-01.news.n
    eostrada.pl!news.neostrada.pl.POSTED!not-for-mail
    From: "slawek" <h...@s...pl>
    Newsgroups: pl.comp.programming
    References: <50924bb1$0$1308$65785112@news.neostrada.pl>
    <a...@g...com>
    <50926d86$0$1216$65785112@news.neostrada.pl>
    <k6tusp$elk$1@node1.news.atman.pl>
    In-Reply-To: <k6tusp$elk$1@node1.news.atman.pl>
    Subject: Re: Błędny epsilon - this is not a bug, this is ?
    Date: Thu, 1 Nov 2012 16:39:09 +0100
    MIME-Version: 1.0
    Content-Type: text/plain; format=flowed; charset="UTF-8"; reply-type=response
    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: 42
    Message-ID: <5092979f$0$1208$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 62.69.202.124
    X-Trace: 1351784351 unt-rea-b-01.news.neostrada.pl 1208 62.69.202.124:59411
    X-Complaints-To: a...@n...neostrada.pl
    Xref: news-archive.icm.edu.pl pl.comp.programming:200453
    [ ukryj nagłówki ]

    Użytkownik "bartekltg" napisał w wiadomości grup
    dyskusyjnych:k6tusp$elk$...@n...news.atman.pl...

    >we float.h dali ciała z definicją/warunkami zaokrąglania.

    Bartuś, gratuluję ci pewności siebie. Przyda ci się ona przy wyjaśnianiu
    dlaczego twórcy procesorów dodają liczby z większą "rozdziałką" niż one są
    zapisywane.

    Owszem, opis we float.h jest niezbyt udany (m.i. dlatego, że w określeniu
    "najmniejszą liczbą x która 1 + x != 1" zapomniano o liczbach ujemnych).

    Nadal jednak masz problem - twierdzisz coś zupełnie innego niż Wikipedia -
    więc może sprostujesz wpis ibidem? Przy okazji doprowadzając hasło do
    porządku: ta sama Wikipedia podaje jako wartość epsilon - w tym samym
    tekście - raz jako 1.1E-16 a raz jako 2.2E-16. Jako w miarę inteligentny
    człowiek rozumiesz, że niezależnie od tego ile naprawdę wynosi epsilon
    (nawet jeżeli jest to okrągłe 42) - to przynajmniej jedną z tych wartości
    należy wykluczyć. (Nie, nie twierdzę że Wikipedia jest nieomylna - ale że
    skoro potrafisz, to powinieneś sprostować błędy w Wikipiedii, nie będę
    zabraniał.)

    Co do Matlaba - jeżeli jest inna definicja - to eps z Matlaba jest ok - w
    sensie zgodności z definicją. Niemniej jednak błędem jest w takim razie
    odrzucanie liczb mniejszych niż eps (tj. niż wartość jaką zwraca funkcja eps
    z Matlaba), bo te liczby jednak zmieniają (i powinny zmieniać) wynik. Taki
    przykładzik, w którym f jest taka że dla każdego n funkcja f(n+1) < f(n)
    oraz f(n) > 0 :

    m = 1; while( f(m) >= eps ) m++; /* m = 10*m + 100; */ s = 0.; for (k =
    m; k > 0; k--) s += f(m);

    Jeżeli użyjesz definicji i wartości eps z Matlab, to możesz - przez
    przypadek - otrzymać inny wynik, niż kiedy usuniesz komentarz. Jeżeli
    użyjesz definicji MS (i oczywiście o połowę mniejszego eps) - to niezależnie
    od tego, czy usuniesz komentarz, czy go zostawisz - będziesz miał ten sam
    wynik.

    Wniosek jest oczywisty - podana przez ciebie definicja może w określonych
    sytuacjach prowadzić do błędnych wyników. Definicja MS jest bardziej
    bezpieczna.

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: