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 17:44 | IT novinky

    Byl aktualizován seznam 500 nejvýkonnějších superpočítačů na světě TOP500. Nejvýkonnějším superpočítačem zůstává El Capitan od HPE (Cray) s výkonem 1,809 exaFLOPS. Druhý Frontier má výkon 1,353 exaFLOPS. Třetí Aurora má výkon 1,012 exaFLOPS. Nejvýkonnější superpočítač v Evropě JUPITER Booster s výkonem 1,000 exaFLOPS je na čtvrtém místě. Nejvýkonnější český superpočítač C24 klesl na 192. místo. Karolina, GPU partition klesla na 224. místo a Karolina, CPU partition na 450. místo. Další přehledy a statistiky na stránkách projektu.

    Ladislav Hagara | Komentářů: 0
    dnes 17:22 | IT novinky

    Microsoft představil Azure Cobalt 200, tj. svůj vlastní SoC (System-on-Chip) postavený na ARM a optimalizovaný pro cloud.

    Ladislav Hagara | Komentářů: 0
    dnes 12:00 | IT novinky

    Co způsobilo včerejší nejhorší výpadek Cloudflare od roku 2019? Nebyl to kybernetický útok. Vše začalo změnou oprávnění v jednom z databázových systémů a pokračovalo vygenerováním problém způsobujícího konfiguračního souboru a jeho distribucí na všechny počítače Cloudflare. Podrobně v příspěvku na blogu Cloudflare.

    Ladislav Hagara | Komentářů: 5
    včera 23:44 | Nová verze

    Byla vydána (Mastodon, 𝕏) první RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 1
    včera 23:22 | Komunita

    Eugen Rochko, zakladatel Mastodonu, tj. sociální sítě, která není na prodej, oznámil, že po téměř 10 letech odstupuje z pozice CEO a převádí vlastnictví ochranné známky a dalších aktiv na neziskovou organizaci Mastodon.

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

    Byla vydána nová major verze 5.0 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v obsáhlých poznámkách k vydání. Videopředstavení na YouTube.

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

    Cloudflare, tj. společnost poskytující "cloudové služby, které zajišťují bezpečnost, výkon a spolehlivost internetových aplikací", má výpadek.

    Ladislav Hagara | Komentářů: 10
    včera 04:22 | Pozvánky

    Letos se uskuteční již 11. ročník soutěže v programování Kasiopea. Tato soutěž, (primárně) pro středoškoláky, nabízí skvělou příležitost procvičit logické myšlení a dozvědět se něco nového ze světa algoritmů – a to nejen pro zkušené programátory, ale i pro úplné začátečníky. Domácí kolo proběhne online od 22. 11. do 7. 12. 2025 a skládá se z 9 zajímavých úloh různé obtížnosti. Na výběru programovacího jazyka přitom nezáleží – úlohy jsou

    … více »
    SoutezKasiopea | Komentářů: 1
    včera 04:11 | Nová verze

    Byla vydána nová verze 2.52.0 distribuovaného systému správy verzí Git. Přispělo 94 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    17.11. 18:00 | Nová verze

    VKD3D-Proton byl vydán ve verzi 3.0. Jedná se fork knihovny vkd3d z projektu Wine pro Proton. Knihovna slouží pro překlad volání Direct3D 12 na Vulkan. V přehledu novinek je vypíchnuta podpora AMD FSR 4 (AMD FidelityFX Super Resolution 4).

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (19%)
     (18%)
     (23%)
     (15%)
     (23%)
     (15%)
     (17%)
    Celkem 369 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    Rozcestník

    Dotaz: Numerické řešení rovnic

    stativ avatar 31.12.2009 09:52 stativ | skóre: 54 | blog: SlaNé roury
    Numerické řešení rovnic
    Přečteno: 982×
    Na rovinu přiznám, že je to zadání semestrálky, které jsem si vybral jen proto, že o tématu nevím vůbec nic. V zásadě jde o to vytvořit program ,co vypočítá všechny kořeny rovnice jedné proměnné v oboru reálných čísel. Našel jsem si k tomu spoustu materiálů (krásný je třeba úvod do numerických metod).

    Už jsem si některé z těch metod zkoušel a fungují docela pěkně (i když se mi stalo, že jednou jsem se s Newtonem jsem zasekl, nejspíš v nějakém lokálním minimu).

    Co mi ale není jasné je, jak řešit větší množství kořenů:
    1. tj. jak určím prvotní odhady kořenů pro Newtonovu metodu tak, abych se dostal ke všem kořenům a ne jenom jednomu?
    2. tj. jak určím, kde je funkce kladná a záporná bez „brute force“ pro jiné metody? Tady mě nejdřív napadlo nejdřív vyřešit, kdy je derivace nula, ale to je zase ten samý problém.
    PS.: Co myslí za triky v
    Není-li rozsah uveden (protože se jedná o nepovinný parametr), rozumí se definičním oborem celý obor reálných čísel. Protože však zobrazení reálných čísel v počítači je omezené, jak rozsahem, tak přesností, je třeba v takovém případě aplikovat triky z oblasti numerických metod.
    Asi nejelegantnější způsob jak se tomu vyhnout by bylo použít GMP, ale je otázka,jestli by to prošlo. Navíc problém je rychlost a paměťová náročnost.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk

    Řešení dotazu:


    Odpovědi

    stativ avatar 31.12.2009 09:55 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Numerické řešení rovnic
    K tomu PSku: asi to není kritické, protože dále je možno se dočíst:
    pokud nedojde k ukončení již dříve z důvodů omezení zobrazení reálných čísel v počítači
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    31.12.2009 12:03 l4m4
    Rozbalit Rozbalit vše Re: Numerické řešení rovnic
    Taková velkolepá zadání miluju. Program, který skutečně nalezene všechny kořeny f(x) = 0 v celém reálném oboru, prokazatelně nikdy neskončí ani při dost silných podmínkách na funkci (kvůli nemožnosti zjistit, že už nalezl všechny), takže program while(1){} postačí úplně stejně...

    Nebudu řešit evidentní sin(x)=0, stačí rovnice h(x) = 0 kde
             1 - exp(8/ε²) exp(-1/(x-c-ε)²) exp(-1/(x-c+ε)²),  pro c-ε/2 < x < c+ε/2
    h(x) = {
             1,                                                jinak
    
    která má pouze jediný kořen c, byť dvojitý (to se dá vylepšit). Funkce h je C∞ v celém reálném oboru, a řešení nelze nalézt jinak než prohledáním všech intervalů délky ε, kterých je samozřejmě nekonečně mnoho.

    Potom je samozřejmě možnost projít všech cca 2⁶⁴ representovatelných reálných čísel, to skončí v konečném čase.

    ------------

    Teď něco trochu praktického: kořene a se po nalezení lze zbavit řešením f(x)/(x - a) = 0 namísto f(x) = 0, ovšem numericky se to samozřejmě rozesere v okolí bodu a (hrubou silou to lze spravit zvýšením přesnosti až na dvojnásobek) a přímo v něm (lze ošetřit).

    Co je ale skutečně zásadní problém, je že při sudém počtu kořenů v [pod]intervalu neexistuje 100% fungující algoritmus pro bracketing (viz příklad s h(x) výše), takže můžeš dělat různé věci, ale vždycky se najde protipříklad, kdy to vůbec nezjistí, že funkce nějaké kořeny má.
    stativ avatar 31.12.2009 14:31 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Numerické řešení rovnic
    Taková velkolepá zadání miluju. Program, který skutečně nalezene všechny kořeny f(x) = 0 v celém reálném oboru, prokazatelně nikdy neskončí ani při dost silných podmínkách na funkci (kvůli nemožnosti zjistit, že už nalezl všechny), takže program while(1){} postačí úplně stejně...
    Tak epické to zas není, po nalezení 100 kořenů to má přestat hledat.

    Teď něco trochu praktického: kořene a se po nalezení lze zbavit řešením f(x)/(x - a) = 0 namísto f(x) = 0, ovšem numericky se to samozřejmě rozesere v okolí bodu a (hrubou silou to lze spravit zvýšením přesnosti až na dvojnásobek) a přímo v něm (lze ošetřit).
    Díky, to se určitě hodí.
    Co je ale skutečně zásadní problém, je že při sudém počtu kořenů v [pod]intervalu neexistuje 100% fungující algoritmus pro bracketing (viz příklad s h(x) výše), takže můžeš dělat různé věci, ale vždycky se najde protipříklad, kdy to vůbec nezjistí, že funkce nějaké kořeny má.
    Leda tak to řešit symbolicky ;-) A díky za navedení na bracketing, snad mi to pomůže při dalším hledání.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    31.12.2009 12:56 peter
    Rozbalit Rozbalit vše Re: Numerické řešení rovnic
    1, ten prvotny odhad by sa mohol dat spravit pomocou bisekce (alebo teda aspon urcit ci koren je medzi x1, x2)
    stativ avatar 31.12.2009 14:33 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Numerické řešení rovnic
    Ale jestli jsem to pochopil správně, tak na bisekci musím znát x_1, x_2 taková, že mají opačná znaménka. Což je problém č. 2.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    1.1.2010 12:04 tomas
    Rozbalit Rozbalit vše Re: Numerické řešení rovnic
    To se da resit stochasticky tj. pomoci nahodneho dosazovani. Generuj nahodna cisla z intervalu <-c,c>, kde c se se po kazdem pokusu zvetsi napr. jako c = c * (1 + epsilon). Jakmile najdes dve x s ruznym znamenkem f(x), lze pouzit puleni intervalu. Pak bych si zvolil nejaky epsilon, ktery mi rekne, jak daleko od sebe musi byt dva koreny. Pokud pri puleni intervalu skonverguju do nejakeho takoveho epsilon okoli jiz nalezeneho bodu, vypocet zrusim a zkousim hledat dal. Tahle uloha se neda vyresit nijak elegatne, aniz bys o zadane funkci resp. o rozdeleni korenu neco vedel.
    stativ avatar 1.1.2010 12:44 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Numerické řešení rovnic
    Jo, něco takového jsem našel (pozor, obsahuje to hnusné DRM) v knize Numerical Recipes. Díky všem za rady.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk

    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.