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 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

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

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 22
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

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

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    22.12. 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 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ářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (34%)
     (2%)
     (11%)
     (2%)
     (1%)
     (2%)
     (16%)
     (18%)
     (13%)
    Celkem 93 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    Rozcestník

    Dotaz: Pascal - bitove operace : ma to cenu?

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