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

Julia Evans pomocí svých kreslených obrázků proniká do Linuxu a informačních technologií. Vedle ucelených zinů publikuje také jednotlivé kreslené obrázky (RSS).

Ladislav Hagara | Komentářů: 1
včera 13:22 | Zajímavý software

Jordi Sanfeliu vydal verzi 1.0.0 svého unixového jádra Fiwix (Wikipedie) určeného také pro výuku operačních systémů. Dle článku na OSNews na něm začal pracovat již před více než dvaceti lety. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT. Stáhnout a vyzkoušet lze živou disketu nebo CD s GNU/Fiwixem.

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

Byla vydána nová verze 10.7 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab (Wikipedie). Představení nových vlastností v příspěvku na blogu. Vývojáři GitLabu zdůrazňují Web IDE (YouTube) a SAST (Static Application Security Testing) pro Go a C/C++.

Ladislav Hagara | Komentářů: 0
22.4. 14:00 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, zveřejnil na svém blogu recenzi notebooku Librem 13 od společnosti Purism. Používá jej již sedm měsíců a s ním i jako umělec spokojen. Potřebu francouzské AZERTY klávesnice vyřešil přelepkami. Na displej se podíval kalibrační sondou, barvy vyladil pomocí open source softwaru DisplayCAL, v aplikaci Inkscape nastavil zvětšování na 170 % aby 1 cm v Inkscapu byl 1 cm v reálu. Webovou kameru, mikrofon, Wi-Fi a Bluetooth lze na Librem 13 hardwarově vypnout.

Ladislav Hagara | Komentářů: 7
21.4. 23:44 | Komunita

Několik posledních verzí GNOME Shellu obsahuje chybu způsobující memory leak (únik paměti). Viz například videozáznamy verzí 3.26 nebo 3.28. Nalezení chyby #64 a její opravě se věnuje Georges Basile Stavracas Neto v příspěvku na svém blogu [reddit].

Ladislav Hagara | Komentářů: 1
21.4. 10:33 | Komunita

V pondělí měl na YouTube online premiéru otevřený krátký 2D film Hero vytvořený v 3D softwaru Blender. Cílem stejnojmenného projektu Hero je vylepšit nástroj Grease Pencil (tužka) v Blenderu 2.8.

Ladislav Hagara | Komentářů: 4
20.4. 23:22 | Nová verze

Byla vydána verze 4.0 kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Přehled novinek v Changelogu (GitHub).

Ladislav Hagara | Komentářů: 0
20.4. 17:22 | Komunita

Včera vydanou hru Rise of the Tomb Raider pro Linux lze do pondělí 23. dubna koupit na Steamu s 67% slevou. Místo 49,99 € za 16,49 €.

Ladislav Hagara | Komentářů: 0
20.4. 16:11 | Komunita

Na Humble Bundle lze získat počítačovou hru Satellite Reign (Wikipedie, YouTube) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 5
20.4. 15:44 | Zajímavý software

Společnost Apple koupila před třemi lety společnost FoundationDB vyvíjející stejnojmenný NoSQL databázový systém FoundationDB (Wikipedie). Včera byl tento systém uvolněn jako open source pod licencí Apache 2.0. Zdrojové kódy jsou k dispozici na GitHubu.

Ladislav Hagara | Komentářů: 0
Používáte na serverech port knocking?
 (2%)
 (7%)
 (46%)
 (27%)
 (17%)
Celkem 362 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    Rozcestník

    Dotaz: Pascal - bitove operace : ma to cenu?

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