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í
×
    včera 23:00 | IT novinky

    Společnost Pebble představila (YouTube) chytré hodinky Pebble Round 2. S kulatým e-paper displejem, s open source PebbleOS a vydrží baterie přibližně dva týdny. Předobjednat je lze za 199 dolarů s plánovaným dodáním v květnu.

    Ladislav Hagara | Komentářů: 0
    včera 14:22 | Humor

    Na novoroční inauguraci starosty New Yorku Zohrana Mamdaniho bylo zakázáno si s sebou přinést Raspberry Pi anebo Flipper Zero. Raspberry Pi i Flipper Zero jsou explicitně uvedeny v seznamu zakázaných věcí jak na na veřejné pozvánce, tak i na oficiálních stránkách města.

    NUKE GAZA! 🎆 | Komentářů: 18
    včera 11:33 | Nová verze

    OpenTTD (Wikipedie), tj. open source klon počítačové hry Transport Tycoon Deluxe, byl vydán v nové stabilní verzi 15.0. Přehled novinek v seznamu změn a také na YouTube. OpenTTD lze instalovat také ze Steamu.

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

    Správce oken IceWM byl vydán ve verzi 4.0.0, která např. vylepšuje navigaci v přepínání velkého množství otevřených oken.

    |🇵🇸 | Komentářů: 4
    včera 01:33 | Zajímavý projekt

    Od 1. ledna 2026 jsou všechny publikace ACM (Association for Computing Machinery) a související materiály přístupné v její digitální knihovně. V rámci této změny je nyní digitální knihovna ACM nabízena ve dvou verzích: v základní verzi zdarma, která poskytuje otevřený přístup ke všem publikovaným výzkumům ACM, a v prémiové zpoplatněné verzi, která nabízí další služby a nástroje 'určené pro hlubší analýzu, objevování a organizační využití'.

    NUKE GAZA! 🎆 | Komentářů: 5
    1.1. 16:44 | IT novinky

    S koncem roku 2025 skončila standardní podpora operačního systému HP-UX (Hewlett Packard Unix).

    Ladislav Hagara | Komentářů: 10
    1.1. 14:33 | Nová verze

    K 1. lednu 2026 končí 70leté omezení majetkových autorských práv děl autorů zesnulých v roce 1955, viz 2026 in public domain. V americkém prostředí vstupují do public domain díla z roku 1930, viz Public Domain Day.

    |🇵🇸 | Komentářů: 3
    31.12. 15:00 | Nová verze

    Všem vše nejlepší do nového roku 2026.

    Ladislav Hagara | Komentářů: 12
    31.12. 13:33 | Zajímavý software

    Crown je multiplatformní open source herní engine. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT a GPLv3+. Byla vydána nová verze 0.60. Vyzkoušet lze online demo.

    Ladislav Hagara | Komentářů: 0
    31.12. 12:11 | Zajímavý článek

    Daniel Stenberg na svém blogu informuje, že po strncpy() byla ze zdrojových kódů curlu odstraněna také všechna volání funkce strcpy(). Funkci strcpy() nahradili vlastní funkcí curlx_strcopy().

    Ladislav Hagara | Komentářů: 6
    Které desktopové prostředí na Linuxu používáte?
     (0%)
     (5%)
     (0%)
     (17%)
     (32%)
     (12%)
     (5%)
     (5%)
     (12%)
     (34%)
    Celkem 65 hlasů
     Komentářů: 1, poslední včera 06:15
    Rozcestník

    Dotaz: půlhodinové průměry

    12.7.2010 13:03 jura
    půlhodinové průměry
    Přečteno: 387×
    Obracím se s prosbou o pomoc, jak vypočítat půhodinové pruměry.

    příklad dat
    2010-06-01 00:00:26 1.9138
    2010-06-01 00:02:07 1.9145
    2010-06-01 00:03:49 1.9150
    2010-06-01 00:05:30 1.9141
    2010-06-01 00:07:12 1.9123
    2010-06-01 00:08:53 1.9154
    2010-06-01 00:10:34 1.9132
    2010-06-01 01:12:16 1.9118
    2010-06-01 01:13:57 1.9119
    2010-06-01 01:15:38 1.9123

    Nemohu přijít na to jak šikovně grupovat data podle datumu a času.

    Děkuji za pomoc

    Jura

    Řešení dotazu:


    Odpovědi

    12.7.2010 14:08 Ivan
    Rozbalit Rozbalit vše Re: půlhodinové průměry
    ema exponential moving average. Vice viz treba zdrojaky net-snmp.
    rADOn avatar 12.7.2010 16:51 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: půlhodinové průměry
    zgrupis podle pulhodin, nejak takhle:

    select avg( hodnota ) from sometable group by floor(unix_timestamp( datum ) / 1800)

    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    13.7.2010 10:26 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: půlhodinové průměry
    Měl jsem to napsané ale neodeslané a je mi to líto smazat, toš:

    Jednoduše to lze například na MySQL takto (je to zbytečně rozepsané):

    SELECT FLOOR(UNIX_TIMESTAMP(datum)/(60*30)) AS cas,
           FROM_UNIXTIME(FLOOR(UNIX_TIMESTAMP(datum)/(60*30))*(60*30)) AS cas_date,
           AVG(cislo) AS avg_cislo
             FROM test1 GROUP BY cas;
    
    nad tabulkou:
    CREATE TABLE `test1`(
     `datum` datetime NOT NULL , 
     `cislo` double,
      PRIMARY KEY  (`datum`)
    );
    
    s daty:
    INSERT INTO test1 (datum, cislo) VALUES 
    ('2010-06-01 00:00:26', 1.9138),
    ('2010-06-01 00:02:07', 1.9145),
    ('2010-06-01 00:03:49', 1.9150),
    ('2010-06-01 00:05:30', 1.9141),
    ('2010-06-01 00:07:12', 1.9123),
    ('2010-06-01 00:08:53', 1.9154),
    ('2010-06-01 00:10:34', 1.9132),
    ('2010-06-01 01:12:16', 1.9118),
    ('2010-06-01 01:13:57', 1.9119),
    ('2010-06-01 01:15:38', 1.9123);
    je výsledek:
    +--------+---------------------+-----------------+
    | cas    | cas_date            | avg_cislo       |
    +--------+---------------------+-----------------+
    | 708524 | 2010-06-01 00:00:00 | 1.9140428571429 |
    | 708526 | 2010-06-01 01:00:00 |           1.912 |
    +--------+---------------------+-----------------+
    
    Ale pokud bych to chtěl tak nějak čistější:
    SELECT DATE(datum) AS jen_datum, TIME(datum) AS jen_cas,
           FLOOR(TIME_TO_SEC(TIME(datum)) / (60*30)) AS filtr,
           AVG(cislo) AS avg_cislo
             FROM test1 GROUP BY jen_datum, filtr;
    
    A tady je to pro hezký výpis:
    SELECT jen_datum, CONCAT_WS('-',TIME_FORMAT(SEC_TO_TIME(filtr*(60*30)),'%H:%i'),TIME_FORMAT(SEC_TO_TIME((filtr+1)*(60*30)),'%H:%i')) AS usek, ROUND(avg_cislo,4) AS rndavg_cislo
     FROM (SELECT DATE(datum) AS jen_datum, TIME(datum) AS jen_cas,
             FLOOR(TIME_TO_SEC(TIME(datum)) / (60*30)) AS filtr,
             AVG(cislo) AS avg_cislo
               FROM test1 GROUP BY jen_datum, filtr) AS t1;
    
    z výsledkem:
    +------------+-------------+--------------+
    | jen_datum  | usek        | rndavg_cislo |
    +------------+-------------+--------------+
    | 2010-06-01 | 00:00-00:30 |       1.9140 |
    | 2010-06-01 | 01:00-01:30 |       1.9120 |
    +------------+-------------+--------------+
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†

    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.