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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
včera 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 0
včera 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
2.12. 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 16
2.12. 15:30 | Zajímavý projekt

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 8
2.12. 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 2
2.12. 12:55 | Nová verze

Google Chrome 55 byl prohlášen za stabilní. Nejnovější stabilní verze 55.0.2883.75 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo také 36 bezpečnostních chyb. Mariusz Mlynski si například vydělal 22 500 dolarů za 3 nahlášené chyby (Universal XSS in Blink).

Ladislav Hagara | Komentářů: 4
2.12. 11:55 | Pozvánky

Máte rádi svobodný software a hardware nebo se o nich chcete něco dozvědět? Přijďte na 135. sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.

xkucf03 | Komentářů: 0
2.12. 00:10 | Nová verze

Byla vydána verze 3.2 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata. Z novinek lze zmínit například podporu protokolů DNP3 a CIP/ENIP, vylepšenou podporu TLS a samozřejmě také aktualizovanou dokumentaci.

Ladislav Hagara | Komentářů: 0
1.12. 21:00 | Nová verze

Byla vydána beta verze Linux Mintu 18.1 s kódovým jménem Serena. Na blogu Linux Mintu jsou hned dvě oznámení. První o vydání Linux Mintu s prostředím MATE a druhé o vydání Linux Mintu s prostředím Cinnamon. Stejným způsobem jsou rozděleny také poznámky k vydání (MATE, Cinnamon) a přehled novinek s náhledy (MATE, Cinnamon). Linux Mint 18.1 bude podporován až do roku 2021.

Ladislav Hagara | Komentářů: 0
1.12. 16:42 | Nová verze

Byl vydán Devuan Jessie 1.0 Beta 2. Jedná se o druhou beta verzi forku Debianu bez systemd představeného v listopadu 2014 (zprávička). První beta verze byla vydána v dubnu letošního roku (zprávička). Jedna z posledních přednášek věnovaných Devuanu proběhla v listopadu na konferenci FSCONS 2016 (YouTube, pdf).

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 767 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: [c] generování náhodných desetinných čísel

14.10.2012 19:30 Medved
[c] generování náhodných desetinných čísel
Přečteno: 924×
Dobrý den, Potřeboval bych radu ohledně vygenerování náhodných desetinných čísel v c. Můj požadavek je generovat čísla datovýho typu třebas float z intervalu (horní mez, dolní mez). Vím o funkcích rand() srand(), ale ty mi generují jen int. Já bych potřeboval generovat desetinná alespoň na počet míst co má float...existuje na to prosím nějaká funce? Děkuji

Řešení dotazu:


Odpovědi

14.10.2012 21:34 sss
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Mela by k tomu stacit jednoducha linearni funkce.
Josef Kufner avatar 14.10.2012 21:36 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
rand() / (double) RAND_MAX
Hello world ! Segmentation fault (core dumped)
14.10.2012 21:56 l4m4
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Ve standardní knihovně ne. Pokud ti stačí 23 bitů floatu, tak to asi moc velké nároky na generátor nemáš, a stačí vydělit integer získaný rand(), jak píše Josef Kufner.

Jinak zkus použít gsl_rng_uniform() z knihovny GSL s generátorem taus2, gfsr4 nebo mt13397.
14.10.2012 22:10 Jose
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Na některých platformách je RAND_MAX rovno jen 32767.
14.10.2012 23:43 l4m4
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Jistě, na některých platformách je int jen 16bitový, takže by se do něj ani větší číslo nevešlo.
15.10.2012 08:19 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Na některých platformách je int 32bitový a RAND_MAX rovno jen 32767.
Aby to bylo kompletní :-)
To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
Josef Kufner avatar 15.10.2012 09:53 Josef Kufner | skóre: 66
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Ano, závisí to na implementaci generátoru. Tak jako tak, dělení čímkoliv jiným než RAND_MAX ovlivní rovnoměrnost rozložení generovaných čísel (tedy nemusí, pokud víš jak, ale šance to zvorat je dost vysoká).

Pokud je RAND_MAX rovno 2n - 1, tak můžeš vygenerovat více čísel, slepit je pomocí bitového psunu a vydělit odpovídajícím novým 2N - 1. To by mělo zachovat vlstnosti generátoru a zvýšit přesnost generovaných čísel.
Hello world ! Segmentation fault (core dumped)
15.10.2012 10:42 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Jen jsem doplnil, že RAND_MAX není přímo odvislý od velikosti int…
Jinak i tady se to trochu diskutovalo…
To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
15.10.2012 09:36 kuka
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Predevsim si ujasni, zda chces desetinna cisla nebo cisla v pohyblive carce (float). Pokud destinna, tak trivialni pozorovani je, ze se jedna o cela cisla, do kterych se pouze "umisti" desetinna carka. Tzn. napr. pokud chces desetinne cislo mensi nez 1 s presnosti na x mist, vygeneruj si odpovidajici integer a pak si ho vydel 10^x.
15.10.2012 19:08 l4m4
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Mi přijde dost zvláštní označit toto jako řešení. Jednak se tedy neřeší, jak budu s těmi integery representujícími desetinná čísla pak cokoli dělat (použiji GMP?). A nebudou-li se čísla coby integery representovat pořád, tj. vzápětí se naivně vydělí tím 10x, tak je v tu chvíli po desetinné representaci, protože float desetinná čísla nerepresentuje přesně. Ale především ‚vygeneruj si odpovídající integer‘ je rada naprosto naprd, protože člověk, který se na takovou věc musí ptát, ho zaručeně bude generovat s biasem. Takže takhle ne.
15.10.2012 23:02 kuka
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Po pravde nevim, jestli je to reseni. Tazatel si stezoval, ze chce desetinna cisla, ale zna jen funkce pro nahodna cisla typu integer. Nerekl, co bude s temi cisly delat, a proto to neresim, co bych na tom jako mel resit? Moje rada smeruje k tomu, ze pokud umi integer, umi rovnou i desetinna cisla (coz vubec neznamena typu float - zda si je rozdilu vedom nevim). Vydeleni znamena prevod na desetinne cislo a pouze tazatel muze vedet, proc ho vlastne chce delat - pokud chce cislo treba jen vypsat, tak ho asi samotneho napadne, ze nic delit nema.
15.10.2012 14:24 tom
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
drand48() odkazuje se na to primo manualova stranka rand() pripadne se to da najit primocare pres apropos
$ apropos 'random number'
drand48 (3)          - generate uniformly distributed pseudo-random numbers
 ...
Naucte se pouzivat dokumentaci ;)
15.10.2012 14:37 l4m4
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
*rand48() používá klasickou lineární kongruenci, tudíž má sice více bitů, ale jinak je to pořád generátor naprd. Jak jsem psal, jsou-li na ten generátor vůbec nějaké požadavky, tak od těch v libc ruce pryč. Nejsou-li, tak je to jedno...
15.10.2012 14:45 tom
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Je-li ten pozadavek rychlost, tak libc na tom neni tak spatne. Treba v raytraceru je ta horsi kvalita trochu videt, ale pokud tim budete ridit prisery ve hrach, tak asi tezko nekdo neco pozna
15.10.2012 14:53 l4m4
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
OK, řízení příšer ve hrách není moje doména... Zato v Monte Carlo simulacích mohou i drobné problémy generování vést k nejrůznějším systematickým odchylkám, takže moje požadavky na ,skutečný` generátor asi začínají někde trochu jinde.
15.10.2012 16:21 Nikola Pajkovský | skóre: 16
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
/dev/random?
Save the whales. Feed the hungry. Free the mallocs
15.10.2012 18:58 l4m4
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
To je zase příšerně pomalé; /dev/random je fajn, když potřebuješ pár tisíc bitů na šifrovací klíč. Ne když jich potřebuješ pár bilionů na simulaci...
Goheeca avatar 15.10.2012 19:29 Goheeca | skóre: 7
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Trochu zlepšit se to dá pomocí audio-entropyd a generátorem bílého šumu.
15.10.2012 20:58 tom
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
To je pomale, na simulace je asi nejsnazsi pouzivat jako zdroj nahody soubor vygenerovanej nejakym lepsim generatorem.
15.10.2012 21:42 l4m4
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Což jsou (pro dobrý poměr náhodnost/CPU-náročnost) např. ty tři z GSL, které jsem vyjmenoval výše. Případně MWC generátory nebo ISAAC. Dneska se ještě lidi dost matlají s 32bitovými slovy, ale jelikož např. 64bitová instrukce násobení udělá čtyřikrát tolik práce co 32bitová (nikoli dvakrát), dají se z hlediska poměru náhodnost/CPU-náročnost ještě čekat slušné pokroky.

Otázka vždy je, zda a jak může člověk použít externí knihovnu, zda těch čísel potřebuje fakt obří množství (což preferuje inlinovatelný kód), jak používá vlákna, ... Bez znalosti detailů těžko říci, v takovém případě prostě radím GSL.
15.10.2012 17:12 nyan
Rozbalit Rozbalit vše Re: [c] generování náhodných desetinných čísel
Zajima vas spis rychlost generatoru, nebo spis pohodlnost (tj hledate existujici knihovnu ?)

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.