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 04:44 | Nová verze

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    dnes 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 0
    dnes 01:55 | Humor

    Microsoft zveřejnil zdrojový kód XAML Studia a uvolnil ho pod MIT licencí. XAML Studio je nástroj ze světa Windows, určený pro tvorbu uživatelského rozhraní aplikací pomocí XAML (Extensible Application Markup Language). Stalo se tak zhruba po osmi letech od prvního prohlášení Microsoftu, že se tento kód chystá zveřejnit.

    NUKE GAZA! 🎆 | Komentářů: 0
    dnes 01:44 | Zajímavý projekt

    TimeCapsule, 'časová kapsle', je jazykový model trénovaný výhradně na datech z určitých míst a časových období, aby se tak napodobila autentická slovní zásoba, způsob vyjadřování a názory dané doby. Na Hugging face jsou k dispozici modely natrénované na historických textech dostupných v oblasti Londýna mezi lety 1800 až 1875.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 17:55 | Nová verze

    Radicle byl vydán ve verzi 1.6.0 s kódovým jménem Amaryllis. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Upozornění

    Zemřel Scott Adams, tvůrce komiksových stripů Dilbert parodujících pracovní prostředí velké firmy.

    Ladislav Hagara | Komentářů: 3
    včera 13:00 | Nová verze

    Sdružení CZ.NIC vydalo novou verzi Knot Resolveru (6.1.0). Jedná se o první vydanou stabilní verzi 6, která je nyní oficiálně preferovanou a doporučovanou verzí, namísto předešlé verze 5. Více o Knot Resolveru 6 je možné se dočíst přímo v dokumentaci.

    VSladek | Komentářů: 1
    včera 01:22 | Nová verze

    Byl vydán Linux Mint 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 1
    13.1. 21:33 | Nová verze

    Wine bylo po roce vývoje od vydání verze 10.0 vydáno v nové stabilní verzi 11.0. Přehled novinek na GitLabu. Vypíchnuta je podpora NTSYNC a dokončení architektury WoW64.

    Ladislav Hagara | Komentářů: 5
    13.1. 16:11 | Nová verze

    Byl vydán Mozilla Firefox 147.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Firefox nově podporuje Freedesktop.org XDG Base Directory Specification. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 147 bude brzy k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (5%)
     (0%)
     (8%)
     (19%)
     (3%)
     (6%)
     (3%)
     (11%)
     (45%)
    Celkem 434 hlasů
     Komentářů: 12, poslední včera 21:12
    Rozcestník

    Dotaz: Jak si overit, jestli vysledne cislo neni -nan || nan

    Bundas avatar 15.7.2014 23:31 Bundas | skóre: 14 | Pardubice
    Jak si overit, jestli vysledne cislo neni -nan || nan
    Přečteno: 353×

    U teto matematicke operace stranaB = sqrt(pow(stranaC,2) - pow(stranaA,2)); obcas vyjde, ze vysledek je -nan nebo nan. To znamena, ze je to matematicky nemozny, nebo tk neco. :-D

    Nevite, jak si overit, jestli vysledek je nebo neni -nan || nan? Nejak takhle?

    if((stranaB = sqrt(pow(stranaC,2) - pow(stranaA,2)) == -nan || (stranaB = sqrt(pow(stranaC,2) - pow(stranaA,2)) == nan){}

     

    nebo jak?

     

    predem diky za pomoc

    Abe the Messiah has come.

    Odpovědi

    vdusek avatar 15.7.2014 23:43 vdusek | skóre: 27
    Rozbalit Rozbalit vše Re: Jak si overit, jestli vysledne cislo neni -nan || nan

    Začal bych zde http://www.mathworks.com/help/matlab/ref/nan.html a ošetřil proěnné podle tyu operace.

     

    Např. kontroloval zda nedělím nulou, nedělám odmocninu ze záporného čísla apod. Poté výsledek +-NaN nemohu získat

    16.7.2014 00:12 chrono
    Rozbalit Rozbalit vše Re: Jak si overit, jestli vysledne cislo neni -nan || nan
    Ak nevadí, že sa použije C99, tak sa dá použiť funkcia isnan.
    16.7.2014 02:25 Sněhulák
    Rozbalit Rozbalit vše Re: Jak si overit, jestli vysledne cislo neni -nan || nan
    Spíš si zařiď, abys nedělal odmocninu ze záporné ho čísla, pak ti nebude vycházet NaN. Stačí neodečítat od menšího čísla větší a žádné ověřování na NaN nebude potřeba. Taky bys to mohl trochu upravit, aby se to všechno nepočítalo zbytečně dvakrát...
    16.7.2014 12:19 potato
    Rozbalit Rozbalit vše Re: Jak si overit, jestli vysledne cislo neni -nan || nan
    Pokud to záporné čislo vzniká kvůli konečné přesnosti, je to obecně problém, pokud nechceš striktní IEEE sémantiku (tedy pomalou matematiku): splnění nějaké podmínky dvěma floating point čísly nezaručuje splnění téže podmínky v budoucnu, když se třeba mezitím přesnesou z registrů do paměti a zpět...

    Vím-li, že se potýkám jen s konečnou přesností, tak normálně stačí
    sqrt(fmax(stranaC*stranaC - stranaA*stranaA, 0.0))
    (superpomalou funkci pow() na vynásobení dvou čísel používá jen prase).
    16.7.2014 12:15 lertimir | skóre: 64 | blog: Par_slov
    Rozbalit Rozbalit vše Re: Jak si overit, jestli vysledne cislo neni -nan || nan
    Předpokádám, že jsou to zase ty trojúhelníky a to, co počítáš je Pythagorova věta. NaN ti vyjde, když sqrt má záporný argument, což je když A>C. A to je správně i z pohledu trojúhelníků, protože pravoúhlý trojúhelník neuděláš, když jedna odvěsna bude delší než přepona. Takže posoudit ifem na C>A a jen v tom případě vzorec počítat.
    8.8.2014 15:33 mluno
    Rozbalit Rozbalit vše Re: Jak si overit, jestli vysledne cislo neni -nan || nan
    Ještě pitomnější je, když se NaN zacyklí. Mějjme třeba algoritmus filtru prvního řádu y_nové = k1*x + k2*y_předchozí je jasné, že pokud se tam jednou jedinkrát dostane NaN tak už nikdy nic jiného nedostanete (NaN + cokoliv je zase NaN). A to samý platí pro inf, které se při dělení nulou obdrží (a to spíš měl být náš případ, ale mám pocit, že to bylo NaN). To se mi to dobře mluví, ale dva dny jsme pitvali program a už jsme chtěli do mathworksu volat o pomoc a chtít vrátit peníze a já nevim co, než jsme toto objevili. V našem případě to vznikalo dělením nulou, tak jsme zajistili, že pokud je číslo menší než něco, nahradí se tím něco a problém zmizel (vzniklo sice veliké číslo, ale to se potom o kus dál násobí tim malym a výsledkem je skoro nula). Jinak samozřejmně jsou tu funkce isnan, isfinite, isfloat a další, kterými by se to také vyřešilo, pro náš případ bylo výhodnější eliminovat to dělení nulou tak, jak jsem psal. Ve vašem případě by se dalo přidat pod to odmocnítko abs() což by sice nezpůsobilo NaN ale dávalo by to chybné výsledky v případě chybného zadání. Takže spíš to zachitit před tím odmocněním např. xxx = pow(stranaC,2) - pow(stranaA,2);
    if xxx>0
    ...stranaB = sqrt(xxx);
    else
    ...///něco je špatně, když vychází pod odmocnítkem záporné
    číslo
    ...// případně stranaB = j*sqrt(-xxx) pokud to má smysl - u délek stran asi - imaginární délka neexistuje
    end

    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.