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 14:22 | Komunita

    Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.

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

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

    Ladislav Hagara | Komentářů: 0
    dnes 12:44 | Nová verze

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

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

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

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

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

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

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

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

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

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

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

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

    Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.

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

    Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (72%)
     (9%)
     (2%)
     (17%)
    Celkem 748 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: Pascal - bitove operace : ma to cenu?

    24.7.2013 16:52 plexiskex
    Pascal - bitove operace : ma to cenu?
    Přečteno: 622×
    Dobry den, snazim se nalezt nejakou uspokojivou odpoved na nasledujici otazku: Kolikrat je rychlejsi scitani (resp. nasobeni,deleni, porovnavani,...) dvou integeru implementovane pomoci bitovych operaci nez obycejne plus (ve Free Pascalu)?

    Respektive jsem se nekde docetl, ze "bitove operace jsou velmi rychle", ale nevim, co vlastne zpomaluje normalni plus? Dival jsem se do dokumentace fpc, ale ten kod moc nechapu.

    Nevim totiz, jestli ma cenu si nadefinovat nove operatory (+,-,*,/) pomoci bitovych operaci, a v podobnem duchu dopsat cely program. Pro predstavu, pisu program, ktery ma faktorizovat velka cisla (odhaduju to na nekolik milionu nasobeni).

    dekuju za Vase odpovedi.

    Řešení dotazu:


    Odpovědi

    24.7.2013 17:20 Michy
    Rozbalit Rozbalit vše Re: Pascal - bitove operace : ma to cenu?
    Předesílám, že nejsem úplně odborník na Pascal, ale předpokládám, že "obyčejné" plus s "obyčejnými" celočíselnými typy kompilátor přeloží na nejefektivnější instrukci/e procesoru. Pokud chceš ale pracovat s "neobyčejnými"/velkými celočíselnými typy, potom si budeš muset dané operace implementovat sám. Tvoje dilema s bitovými/"nebitovými" operacemi chápu spíš jako dilema, zda zvolit pro reprezentaci velkých celých čísel binární (dvojkovou) nebo dekadickou (desítkovou) soustavu. Z hlediska rychlosti operací a paměťové náročnosti je zcela jistě efektivnější binární reprezentace. Dekadická soustava má výhodu snad jen ve snadnější transformaci na lidsky čitelnou podobu.
    Beda0 avatar 24.7.2013 17:35 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: Pascal - bitove operace : ma to cenu?

    Asi bude nejjednoudšší si to sám změřit.

    Dřív než řešit rychlost násobení je nutné zvolit vhodný algoritmus, kteřý třeba rychost násobení ani tolik neovlivní. Počítat faktoriál rekurzivním násobením jinde než v ukázkových příkladech není dobrý nápad - je to hrozně neefektivní, existuje spousta daleko lepších algoritmů, případně pro velká čísla často postačí aproximace, která je ještě rychlejší.

    24.7.2013 18:00 Michy
    Rozbalit Rozbalit vše Re: Pascal - bitove operace : ma to cenu?
    Faktorizace je rozklad na prvočísla, s faktoriálem to asi moc nesouvisí. A zrovna u faktorizace nepředpokládám, že by aproximace vedla k cíli. :-)
    Beda0 avatar 24.7.2013 18:33 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: Pascal - bitove operace : ma to cenu?

    Ááá, fakt je dneska hrozný vedro, omlouvám se.

    Řešení 1× (plexiskex (tazatel))
    24.7.2013 18:39 R
    Rozbalit Rozbalit vše Re: Pascal - bitove operace : ma to cenu?
    Zalezi od kompilatora. Ak je kompilator dobry, tak taketo veci nemusis riesit, urobi to sam.

    Najlepsie to bude otestovat. Daj si to do cyklu milionkrat a porovnaj casy.
    Řešení 2× (plexiskex (tazatel), rADOn)
    24.7.2013 22:17 potato
    Rozbalit Rozbalit vše Re: Pascal - bitove operace : ma to cenu?
    Nevím, jak velká jsou ta velká čísla, ale předpokládám taková, která se nevejdou do 64bitového intu, dokonce ani do ničeho jako __int128 (má fpc vůbec 128bitová čísla?), a potřebují aritmetiku s neomezenými čísly (GMP, ...). Ani v takovém případě, pokud nejsou čísla hodně velká, milion násobení pořád nic moc není.

    Každopádně když potřebuji aritmetiku s neomezenými čísly, řešení je použít knihovnu pro práci s neomezenými čísly (GMP, ...). Když potřebuji faktorizovat velká čísla, použiji efektivní faktorizační metodu, kterou naprogramovali lidi, kteří tomu rozumějí líp než já, třeba gmp-ecm.

    Jinak k otázce bitových operací, inteligentní kompilátor automaticky optimalizuje jednoduché případy typu násobení mocninou dvou na bitové operace -- těžko říci, zda to dělá fpc, v Pascalu jsem tak patnáct let nic nepsal. Na ostatních se oproti instrukci násobení na současných procesorech těžko něco ušetří, spíš naopak, když se začne kód komplikovat.

    Kompilace pro konkrétní procesor, na kterém to poběží, u některých operací umožňuje inteligentímu kompilátoru použít efektivnější instrukce (rozdíl může být i řádový), opět nevím, zda se to týká i fpc.
    24.7.2013 23:14 plexiskex
    Rozbalit Rozbalit vše Re: Pascal - bitove operace : ma to cenu?
    Jo, Velkymi Cisly myslim pole Wordu, pocita to v 2^16-kove soustave, nasobenim myslim nasobeni techto Velkych Cisel (zatim skolsky alg., pozdeji mozna Karatsuba). Ale nasobeni a scitani Wordu tvori nasobeni Velkeho Cisla, proto dotaz na nasobeni integeru.

    Nejdriv jsem se pokousel stahnout knihovnu gmp, ale protoze moc neovladam "IT hantyrku", nebyl jsem se schopen prokousat navodama na kompilaci. Navic ten program je semestralka do skoly, takze pouzit neco, co naprogramoval nekdo jiny neni uplne OK :-D (i kdyz aritmetiku mam povolenou) Zkusil jsem si teda naprogramovat "gmp" sam, mam uz zakladni operace hotove, ale trochu me desi, ze umocnit deset-milionkrat na druhou cislo 12345 (19 desitkovych cifer) trva zhruba pul minuty.. Zkusim teda napsat neco s bitovymi operacemi a otestovat.

    Jeste jednou dik za odpovedi...
    28.7.2013 21:13 potato
    Rozbalit Rozbalit vše Re: Pascal - bitove operace : ma to cenu?
    GMP jsem sice asi párkrát kompiloval, ale je ve všech běžných distribucích, tudíž knihovnu samu není zapotřebí kompilovat a podle návodu

    http://wiki.freepascal.org/gmp

    by měla ve fpc fungovat, stačí ji mít nainstalovánu včetně -dev(el) balíčku.

    U toho testu rychlosti úplně nerozumím, co znamená umocnit ‚deset-milionkrat na druhou cislo 12345 (19 desitkovych cifer)‘, protože 12345 jich má pět, jeho druhá mocnina devět, a když ho umocníš postupně desetimilionkrát na druhou, tak má výsledek něco jako 10300000 cifer, což je fakt hodně. Nic tam tedy nemá 19 cifer.

    Každopádně i s GMP lze čekat pro rozumně malá velká čísla zpomalení tak o jeden řád oproti normálním 64bitovým číslům. U jednoduše napsaných vlastních funkcí to bude podstatně horší. Tři mikrosekundy na jedno násobení je ale hodně. Potíž bude těžko v instrukci násobení, která trvá nějaké nanosekundy, takže bys jich za tři mikrosekundy pořád zvládl tisícovku. Bitovými operacemi to nevyřešíš. Potíž je v tom, že ti jedno násobení trvá jako tisíc instrukcí násobení, takže máš někde brutální overhead. Těžko říci kde.

    Obecně končí použitelnost učebnicové faktorizační metody právě okolo 264[*]. Celá ta věc je tedy spíš nepraktické cvičení, protože pro čísla, pro kterou ji můžeš použít, stačí běžné integery. Pak je otázka, jak velký je problém, že to poběží hodinu, co přesně musíš dodržet a co si můžeš udělat, jak chceš, a pod.

    [*]Tedy pro efektivní, leš stále de facto učebnicovou implementaci trvá řádově 1 s.

    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.