abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 11:22 | Bezpečnostní upozornění

    Úřad pro ochranu osobních údajů řeší desítky stížností na jednotné měsíční hlášení zaměstnavatele, které stát spustil počátkem dubna. Systém, jenž má firmám odlehčit od desítek formulářů, nejenže výrazně zatížil jejich účetní oddělení, ale docházelo v něm i k únikům osobních dat zaměstnanců k firmám, kde nepracovali. Podle ministerstva práce a sociálních věcí stála za problémem technická chyba. „Incident se týkal několika stovek

    … více »
    Ladislav Hagara | Komentářů: 3
    dnes 10:46 | Nová verze

    Byla vydána (𝕏, Bluesky) nová verze 22.0.0 open source webového aplikačního frameworku Angular (Wikipedie). Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Nová verze

    Vim Classic byl vydán ve verzi 8.3. Drew DeVault oznámil tento fork editoru Vim (verze 8.2.0148, tj. těsně před zavedením Vim9 skriptování) v březnu letošního roku. Důvodem forku bylo, že vývojáři editorů Vim a Neovim začali při vývoji využívat LLM.

    Ladislav Hagara | Komentářů: 5
    dnes 03:44 | Komunita

    Open source konference DevConf.CZ 2026 proběhne 18. a 19. června v Brně na FIT VUT. Publikován byl program a spuštěna byla registrace.

    Ladislav Hagara | Komentářů: 0
    včera 19:44 | Nová verze

    Společnost JetBrains uvolnila verzi 2 svého open-source velkého jazykového modelu (LLM) pro vývojáře Mellum.

    Ladislav Hagara | Komentářů: 0
    včera 14:44 | IT novinky

    Probíhá konference Microsoft Build 2026. Microsoft představuje své novinky: kvantový čip Majorana 2, Surface Laptop Ultra a Surface RTX Spark Dev Box s NVIDIA RTX Spark, Intelligent Terminal, Coreutils for Windows (fork Rust Coreutils), AI modely MAI, AI agenta Scout, platformu pro agent-first zařízení Project Solara, …

    Ladislav Hagara | Komentářů: 0
    včera 12:44 | Nová verze

    Google Chrome 149 byl prohlášen za stabilní. Nejnovější stabilní verze 149.0.7827.53 přináší řadu novinek. Podrobný přehled v poznámkách k vydání. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    včera 10:55 | Nová verze

    Pluto.jl, reaktivní notebook pro programovací jazyk Julia, dospěl do verze 1.0.

    Ladislav Hagara | Komentářů: 4
    2.6. 13:44 | Nová verze

    Byla vydána nová verze 12.0.0 vizuálního programovacího jazyka Snap! (Wikipedie) inspirovaného jazykem Scratch (Wikipedie). Přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 0
    2.6. 11:44 | IT novinky

    Počítačovou hru Gravity Circuit (ProtonDB) lze do 14. června do 19:00 získat na Steamu zdarma. Napořád.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (15%)
     (31%)
     (4%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1816 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: Porovnanie desatinnych cisel

    25.5.2006 14:54 robob | skóre: 12 | blog: robob
    Porovnanie desatinnych cisel
    Přečteno: 204×
    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: 63 | 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.