abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 10:22 | Komunita

    Celkový počet stažení aplikací z Flathubu překročil 2 miliardy. Aktuální Statistiky Flathubu: Celkový počet stažení 2 002 793 783. Celkem desktopových aplikací 2 636.

    Ladislav Hagara | Komentářů: 0
    21.6. 23:33 | Nová verze

    Byla vydána nová verze 4.8.0 programu na úpravu digitálních fotografií darktable (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    21.6. 23:11 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 142 (pdf) a HackSpace 79 (pdf).

    Ladislav Hagara | Komentářů: 0
    21.6. 18:22 | Nová verze

    Qtractor (Wikipedie) dospěl do verze 1.0.0. Jedná se o Audio/MIDI vícestopý sekvencer.

    Ladislav Hagara | Komentářů: 0
    21.6. 14:33 | Nová verze

    Byl vydán svobodný kancelářský balík OnlyOffice Docs 8.1. Vedle četných oprav přináší několik funkcí včetně podpory editace textu v PDF a vytváření formulářů v PDF.

    Fluttershy, yay! | Komentářů: 36
    21.6. 12:33 | Zajímavý článek

    Daniel Stenberg, autor nástroje curl, z databáze SteamDB zjistil, že aktuálně 22 734 her na Steamu používá curl.

    Ladislav Hagara | Komentářů: 4
    20.6. 19:55 | IT novinky

    Společnost Anthropic vydala Claude 3.5 Sonnet, tj. novou verzi své umělé inteligence Claude (Wikipedie). Videoukázky na YouTube. S Claude 3, stejně jak s GPT-3.5, Llama 3 a Mixtral, si lze pokecat bez přihlašování na DuckDuckGo AI Chat.

    Ladislav Hagara | Komentářů: 0
    20.6. 16:55 | Nová verze

    Byla vydána nová stabilní verze 6.8 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 126. Přehled novinek i s náhledy v příspěvku na blogu a na YouTube. Vypíchnuta jsou vylepšení v integrovaném poštovním klientu.

    Ladislav Hagara | Komentářů: 0
    20.6. 12:11 | Zajímavý článek

    Příspěvek Aukce domén – měsíc po spuštění na blogu CZ.NIC shrnuje první měsíc provozu Aukce domén .CZ. Aukcemi prošlo celkem 18 174 domén, z toho na 742 z nich byl učiněn alespoň 1 příhoz. Nejdražší aukcí byla na doménu virtualnisidlo.cz s cenou 95 001 Kč, která však nebyla včas uhrazena. Nejdražší aukcí, která byla vydražena i zaplacena je praguecityline.cz s cenovkou 55 600 Kč.

    Ladislav Hagara | Komentářů: 15
    20.6. 11:11 | IT novinky

    Před 40 lety, 19. června 1984, Bob Scheifler představil první verzi okenního systému X (X Window System). Vycházela z okenního systému W (W Window System).

    Ladislav Hagara | Komentářů: 67
    Rozcestník

    Dotaz: Porovnanie desatinnych cisel

    25.5.2006 14:54 robob | skóre: 12 | blog: robob
    Porovnanie desatinnych cisel
    Přečteno: 155×
    Zdravim. Potreboval by som numericky korektne porovnanie desatinnych cisel v programe. Desatinne cisla sa do binarnej formy prevedu s urcitou chybou. To je znamy fakt. Ako teda porovnat ci sa dve cisla "zhruba" rovnaju?

    Uvediem priklad a moje riesenie, kde mam porovnat if (t == det):
    #define EPS 1e-08
    double dxa, dya, dxb, dyb, dx1, dy1, det, t, det_eps, t_eps;
    
    det = dxa * dyb - dya * dxb;
    det_eps = EPS * (abs(dxa) + abs(dyb) + abs(dya) + abs(dxb));
    
    t = dx1 * dyb - dy1 * dxb;
    t_eps = EPS * (abs(dx1) + abs(dyb) + abs(dy1) + abs(dxb));
    
    if (abs(t-det) < abs(t_eps) + abs(det_eps))
    
    Matematicke oddovodnenie tu radsej neuvadzam.

    Budem vdacny za kazdy odkaz na nejaku literaturu na webe, rsp. za Vase riesenie.

    Odpovědi

    25.5.2006 15:10 rastos | skóre: 62 | blog: rastos
    Rozbalit Rozbalit vše Re: Porovnanie desatinnych cisel
    Nechápem prečo tam čaruješ. Akú má chybu toto?
    #define EPS 1e-8
    #define FLOAT_EQUAL(x,y) (abs((x)-(y))<EPS)
    
    if (FLOAT_EQUAL(t,det)) ...
    25.5.2006 15:24 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Porovnanie desatinnych cisel
    miesto EPS treba pouzivat "strojove epsilon"
    v gcc je to tusim float.h, konstanty FLT_EPSILON, DBL_EPSILON, LDBL_EPSILON
    25.5.2006 15:30 robob | skóre: 12 | blog: robob
    Rozbalit Rozbalit vše Re: Porovnanie desatinnych cisel
    Takze konkretny priklad:

    x = 1000000000.1 a y = 4.5

    det = x * y

    Tu zrejme asi nebude korektne eps = 1e-8 pre det, ci ano ? Chyba pri cisle y sa totiz zmnohonasobi a uz to nebude stare dobre cislo 1e-8.
    vdusek avatar 25.5.2006 15:21 vdusek | skóre: 27
    Rozbalit Rozbalit vše Re: Porovnanie desatinnych cisel
    Pokud to je reálné (vzhledem k počtu desetinných míst a délce čísla) tak bych desetinná čísla převedl na vynásobením na integer a pak porovnával. Záleží, jaké je původní zadání, resp. jak ta desetinná čísla vznikají. Třeba by bylo zajímavé počítat od začátku v integer s tím, že výsledek na konci podělím....
    25.5.2006 15:36 robob | skóre: 12 | blog: robob
    Rozbalit Rozbalit vše Re: Porovnanie desatinnych cisel
    V skutocnosti to naozaj mozem obist a robit v celych cislach (prenasobenim). Chcel som poznat nazor niekoho, kto trochu numericky premysla.
    25.5.2006 15:39 robob | skóre: 12 | blog: robob
    Rozbalit Rozbalit vše Re: Porovnanie desatinnych cisel
    Ak by niekoho zaujimalo, tak som nasiel na webe toto: Why doesn't my floating-point comparison work?
    25.5.2006 16:03 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Porovnanie desatinnych cisel
    Ty zdrojáky jsou do soutěže o co nejméně efektivní porovnání dvou floatů? :-D

    Jinak doporučuji k pozornosti nový seriál Pavla Tišnovského Fixed point arithmetic.
    When your hammer is C++, everything begins to look like a thumb.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.