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:33 | IT novinky

    Po vlastních microSD kartách nabízí nově Raspberry Pi také vlastní NVMe SSD disky. Samostatně i v sadách s M.2 HAT+.

    Ladislav Hagara | Komentářů: 0
    dnes 06:11 | Zajímavý článek

    Byla zveřejněna (𝕏) Zpráva o činnosti Digitální a informační agentury (DIA) za rok 2023 (pdf). Začíná slovy ředitele: "Vznik Digitální a informační agentury (DIA) je v posledních letech možná jedním z nejvýznamnějších kroků, který dodá potřebný impuls digitalizaci státní správy."

    Ladislav Hagara | Komentářů: 6
    dnes 05:11 | Nová verze

    Vývojáři AlmaLinuxu představili AlmaLinux OS Kitten 10, tj. vývojovou verzi AlmaLinux OS 10 vycházejícího z CentOS Stream 10. Přehled novinek v poznámkách k vydání. Proč Kitten? Verze AlmaLinux OS jsou pojmenované podle kočkovitých šelem. Z kotěte vyroste další kočka.

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

    Kryptografická knihovna OpenSSL byla vydána v nové verzi 3.4. Přehled změn na GitHubu.

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

    Bylo objeveno nové největší prvočíslo. Jedná se o Mersennovo prvočíslo známé též jako M136279841. To znamená, že v binární formě je prvočíslo tvořeno 136 279 841 jedničkami. Objeveno bylo v rámci distribuovaného výpočetních projektu GIMPS (Great Internet Mersenne Prime Search). Zajímavostí je, že na rozdíl od předchozích takto objevených prvočísel nebylo objeveno pomocí CPU, ale na grafické kartě NVIDIA A100 s pomocí programu Gpuowl.

    DaBler | Komentářů: 3
    včera 16:44 | IT novinky

    Protokol MQTT (Wikipedie) dnes slaví 25 let (Mastodon, 𝕏). První publikovaná specifikace je z 22. října 1999.

    Ladislav Hagara | Komentářů: 0
    včera 15:00 | Nová verze

    Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.4. Přehled novinek na GitLabu. Z novinek lze zmínit podporu telefonu Google Pixel 7. Na stránkách Murena lze koupit Murena Pixel 7.

    Ladislav Hagara | Komentářů: 0
    včera 02:11 | Pozvánky

    Připojte se ve středu 30. 10. 2024 od 10:00 do 12:00 na náš webinář "Řízení přístupu do PostgreSQL prostřednictvím externího autentizačního providera" (registrace zdarma) a naučte se, jak nastavit ověřování pomocí GSSAPI pro bezpečný přístup k databázím (Microsoft Active Directory nebo FreeIPA). Záznam předchozího webináře "Co je nového v PostgreSQL 17" můžete zhlédnout zde.

    … více »
    Heřmi | Komentářů: 0
    21.10. 21:33 | Nová verze

    Byla vydána nová verze 0.55 open source počítačové hry Unvanquished (Wikipedie), forku počítačové hry Tremulous. Instalovat ji lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    21.10. 14:22 | IT novinky

    Dle plánu bylo dnes vydáno Factorio 2.0 a Factorio: Space Age, tj. aktualizace 2.0 počítačové hry Factorio (Wikipedie) oficiálně běžící také na Linuxu a velké vesmírní rozšíření Factorio: Space Age.

    Ladislav Hagara | Komentářů: 0
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: Existuje nejake presnejsie casovanie v C?

    1.2.2009 15:56 xsustek | skóre: 6
    Existuje nejake presnejsie casovanie v C?
    Přečteno: 685×

    Potreboval by som nejaku kniznicu, kde si mozem zistovat cas. Nieco podobne ako time.h ale aby to bolo presnejsie. Je nieco tak v C-ecku?

    Odpovědi

    1.2.2009 19:07 Michal
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Jaké konkrétní akce potřebujete s časem provádět? Pokud vám jde jen o zjištění času v milisekundách (a ne v sekundách, jak je tomu u time()), nestačila by fce ftime() ze sys/timeb.h?
    1.2.2009 19:12 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Potrebujem len zitovat aktualny cas , tak aby som ho mohol odcitac a dostat nejaky casovu hodnotu mezdi dvoma akciami. A este potom uspat program na nejaky cas.

    1.2.2009 19:31 Michal
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Špatně jsem se vyjádřil. Jde spíš o to, v jakých jednotkách ten čas potřebujete.

    Pokud v sekundách, stačí vám funkce time() z time.h na zjištění aktuálního času od 1.1.1970 a funkce sleep() z unistd.h, která uspí proces na určitý počet sekund.

    Pokud v milisekundách, budete potřebovat funkci ftime() ze sys/timeb.h, která vám umožní zjistit počet milisekund od 1.1.1970 a funkci usleep z unistd.h, která uspí proces na určitý počet mikrosekund (pozor mikrosekund a ne milisekund)...použijte "man usleep" a "man ftime".
    1.2.2009 19:36 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Presnost staci na milisekundy. Takze skusim ftime a usleep. A este sa chcem opytat, ci je tu nejaka odcitavacia funkcia, ktora vrati rozdiel dvoch casov. Nieco ako difftime. Alebo si to musim rucne odpocitat?

    4.2.2009 15:18 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Nevyhovuje klasicke odcitanie?
    1.2.2009 19:46 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Este jeden problem, ze funkcia usleep. Uspava program max na 1 s. Ja by som potreboval funkciu, ktora uspi progmram na dlhsie, ale ma presnost aspon na milisekundy. Videl by som to na

    struct timeval

    gettimeofday

    ale opat tu asi nieje nejaka odcitacia funkcia, co by nebol az taky problem. Ale uspavacia funkcia, ktora by vyhovovala poziadavkam je nanosleep. Ibaze ta pouziva sturkturu timespec. Chcel by som sa vyhnut zakazdim preratavat z mikrosekund na nanasekundy.

    1.2.2009 20:29 Michal
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    no vygooglil jsem, že v time.h je fce clock_gettime(). Ta pracuje se struct timespec. Pak můžes použít nanosleep() - zkoušel jsem, jde to. Tady dávám odkaz na článek, který jsem vygooglil, je tam i sepsaná fce na rozdíl dvou timespeců. Jinak nezapomeň přidat -lrt až budeš kompilovat, ta fce clock_gettime() potřebuje librt. Mimochodem na uspání je taky funkce clock_nanosleep(), ale tu jsem nezkoušel.
    1.2.2009 20:47 xsustek | skóre: 6
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Hej, toto vyzera rozumne. Diky

    4.2.2009 18:56 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Ješte jde spát pomocí selectu. Záleží jak moc to chcete přenositelné. Pod windows gettimeofday není, je potřeba použít něco jiného. Některé knihovny (např. MPI) to umí zaobalit.
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.2.2009 08:55 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Uspava program max na 1 s. Ja by som potreboval funkciu, ktora uspi progmram na dlhsie, ale ma presnost aspon na milisekundy.
    1) Můžeš zavolat sleep na sekundy a následně usleep na milisekundy.

    2) Přesnost uspání na milisekundy je hezká věc, ale nic ti nezaručuje, že ti jádro ten proces probudí opravdu za daný čas a ne třeba o chvíli později.
    Quando omni flunkus moritati
    4.2.2009 18:57 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Ad 2 je to tak, ale pokud chci spát např. 100 ms +- autobus, tak se to použít dá.
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.2.2009 21:21 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Jenže 100ms +/- autobus není přesnost na milisekundy - #5
    Quando omni flunkus moritati
    5.2.2009 06:45 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    No, to je taky pravda.
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.2.2009 15:27 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    Uspavanie s presnostou na milisekundy resp. nanosekundy je teoria. Pozri napr. Tabulku 1 v clanku na IBM Developer works:
    Note that while the unit of time of the return value is a millisecond, the granularity of the value depends on the underlying operating system and may be larger. For example, many operating systems measure time in units of tens of milliseconds.
    Inak povedane, to, ze nejaka metoda wait/sleep akceptuje casovy udaj s vysokou granularitou este neznamena ze bude s takouto granularitou aj cakat/spat. Tu na abicku sme to uz riesili.

    4.2.2009 18:58 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    Doba spánku zaručena není. Ale je celkem zajímavé vyzkoušet, jak se to chová ve většině případů. Tak třeba tenhle prográmek

    #!/usr/bin/python
    import time
    
    def spi(delay):
        start = time.time()
        time.sleep(delay)
        stop = time.time()
        print delay, stop - start - delay
    
    for i in range(-10, 0):
        delay = 2**i
        spi(delay)
    

    usíná na různě dlouhé intervaly a pak zjišťuje, jak dlouho doopravdy spal. Jsem docela překvapený, jak často se daří zvládnout přesnost lepší než milisekundu.

    4.2.2009 21:22 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    ZKoušel jsi to i na vytíženém systému? (Tj. všechna jádra mají nějakou další práci)
    Quando omni flunkus moritati
    4.2.2009 22:05 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?

    No, nechci udávat nějaká univerzální čísla, raději ať si to každý vyzkouší v konkrétní situaci. Ale program jsem pozměnil na

    #!/usr/bin/python
    import time, random
    
    def spi(delay):
        start = time.time()
        time.sleep(delay)
        stop = time.time()
        diff = stop - start - delay
        if diff > 0.001: print delay, diff
    
    while True:
        delay = random.random()
        spi(delay)
    

    takže vypíše jen zpoždění delší než milisekundu. Pak podtaktoval procesor na 1GHz. Pak pustil současně mplayer, audacious, find /, gtkperf (dvakrát), jakousi nekonečnou smyčku a bláznivě přeblikával mezi plochama.

    Nejdelší zpoždění bylo 7 milisekund. S prioritama jsem si nehrál.

    4.2.2009 23:53 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    To docela jde...
    Quando omni flunkus moritati
    5.2.2009 06:46 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Existuje nejake presnejsie casovanie v C?
    A teď to zkuste s clocksource=jiffies :)
    In Ada the typical infinite loop would normally be terminated by detonation.

    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.