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

    VASA-1, výzkumný projekt Microsoftu. Na vstupu stačí jediná fotka a zvukový záznam. Na výstupu je dokonalá mluvící nebo zpívající hlava. Prý si technologii nechá jenom pro sebe. Žádné demo, API nebo placená služba. Zatím.

    Ladislav Hagara | Komentářů: 0
    dnes 04:44 | Nová verze

    Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 140 (pdf) a HackSpace 77 (pdf).

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

    ESPHome, tj. open source systém umožňující nastavovat zařízení s čipy ESP (i dalšími) pomocí konfiguračních souborů a připojit je do domácí automatizace, například do Home Assistantu, byl vydán ve verzi 2024.4.0.

    Ladislav Hagara | Komentářů: 0
    včera 22:11 | IT novinky Ladislav Hagara | Komentářů: 0
    včera 20:55 | Nová verze

    Neziskové průmyslové konsorcium Khronos Group vydalo verzi 1.1 specifikace OpenXR (Wikipedie), tj. standardu specifikujícího přístup k platformám a zařízením pro XR, tj. platformám a zařízením pro AR (rozšířenou realitu) a VR (virtuální realitu). Do základu se z rozšíření dostalo XR_EXT_local_floor. Společnost Collabora implementuje novou verzi specifikace do platformy Monado, tj. open source implementace OpenXR.

    Ladislav Hagara | Komentářů: 2
    včera 17:22 | Nová verze

    Byla vydána nová verze 0.38.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 4.4 nebo novější a také libplacebo 6.338.2 nebo novější.

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

    ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzích 1.3.1, 1.2.3 a 1.0.6. Ve verzi 1.3.1 je mimo jiné řešena bezpečnostní chyba CVE-2024-20380.

    Ladislav Hagara | Komentářů: 2
    včera 12:11 | IT novinky

    Digitální a informační agentura (DIA) oznámila (PDF, X a Facebook), že mobilní aplikace Portál občana je ode dneška oficiálně venku.

    Ladislav Hagara | Komentářů: 10
    včera 05:11 | Komunita

    #HACKUJBRNO 2024, byly zveřejněny výsledky a výstupy hackathonu města Brna nad otevřenými městskými daty, který se konal 13. a 14. dubna 2024.

    Ladislav Hagara | Komentářů: 2
    17.4. 17:55 | IT novinky

    Společnost Volla Systeme stojící za telefony Volla spustila na Kickstarteru kampaň na podporu tabletu Volla Tablet s Volla OS nebo Ubuntu Touch.

    Ladislav Hagara | Komentářů: 3
    KDE Plasma 6
     (68%)
     (10%)
     (2%)
     (20%)
    Celkem 562 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    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: 683×

    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.