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 12:00 | Zajímavý článek

    Správcovský tým repozitáře F-Droid pro Android sdílí doporučení, jak řešit žádosti o odstranění nelegálního obsahu. Základem je mít nastavené formální procesy, vyhrazenou e-mailovou adresu a být transparentní. Zdůrazňují také důležitost volby jurisdikce (F-Droid je v Nizozemsku).

    🇵🇸 | Komentářů: 0
    dnes 05:33 | Bezpečnostní upozornění

    Byly publikovány informace o další zranitelnosti v procesorech. Nejnovější zranitelnost byla pojmenována VMScape (CVE-2025-40300, GitHub) a v upstream Linuxech je již opravena. Jedná se o variantu Spectre. KVM host může číst data z uživatelského prostoru hypervizoru, např. QEMU.

    Ladislav Hagara | Komentářů: 0
    včera 22:00 | Komunita

    V červenci loňského roku organizace Apache Software Foundation (ASF) oznámila, že se částečně přestane dopouštět kulturní apropriace a změní své logo. Dnes bylo nové logo představeno. "Indiánské pírko" bylo nahrazeno dubovým listem a text Apache Software Foundation zkratkou ASF. Slovo Apache se bude "zatím" dál používat. Oficiální název organizace zůstává Apache Software Foundation, stejně jako názvy projektů, například Apache HTTP Server.

    Ladislav Hagara | Komentářů: 11
    včera 17:33 | Nová verze

    Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.104 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.104 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    včera 15:33 | IT novinky

    Spotify spustilo přehrávání v bezztrátové kvalitě. V předplatném Spotify Premium.

    Ladislav Hagara | Komentářů: 0
    včera 15:00 | IT novinky

    Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.

    Ladislav Hagara | Komentářů: 3
    10.9. 21:22 | Nová verze

    Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 0
    10.9. 18:22 | IT novinky

    T-Mobile od 15. září zpřístupňuje RCS (Rich Communication Services) zprávy i pro iPhone.

    Ladislav Hagara | Komentářů: 3
    10.9. 13:22 | IT novinky

    Společnost ARM představila platformu Arm Lumex s Arm C1 CPU Cluster a Arm Mali G1-Ultra GPU pro vlajkové chytré telefony a počítače nové generace.

    Ladislav Hagara | Komentářů: 0
    10.9. 05:44 | Nová verze

    Unicode Consortium, nezisková organizace koordinující rozvoj standardu Unicode, oznámila vydání Unicode 17.0. Přidáno bylo 4 803 nových znaků. Celkově jich je 159 801. Přibylo 7 nových Emoji.

    Ladislav Hagara | Komentářů: 0
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (83%)
     (7%)
     (2%)
     (2%)
     (4%)
     (2%)
    Celkem 166 hlasů
     Komentářů: 12, poslední 10.9. 13:00
    Rozcestník

    Dotaz: Pascal - bitove operace : ma to cenu?

    24.7.2013 16:52 plexiskex
    Pascal - bitove operace : ma to cenu?
    Přečteno: 660×
    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.