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 00:44 | Humor

    Nové verze webových prohlížečů Chrome a Firefox jsou vydávány každé 4 týdny. Aktuální verze Chrome je 145. Aktuální verze Firefoxu je 148. Od září přejde Chrome na dvoutýdenní cyklus vydávání. V kterém týdnu bude mít Chrome větší číslo verze než Firefox? 😀

    Ladislav Hagara | Komentářů: 0
    včera 21:55 | IT novinky Ladislav Hagara | Komentářů: 0
    včera 13:44 | Komunita

    Bylo spuštěno hlasování o přednáškách a workshopech pro letošní Installfest, jenž proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13.

    Ladislav Hagara | Komentářů: 1
    včera 04:33 | Nová verze

    Byla vydána (Mastodon, 𝕏) třetí RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 0
    2.3. 21:44 | IT novinky

    Apple představil iPhone 17e a iPad Air s čipem M4.

    Ladislav Hagara | Komentářů: 13
    2.3. 21:11 | Zajímavý software

    Byla vydána verze 1.0 editoru kódů Gram. Jedná se o fork editoru Zed bez telemetrie a umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    2.3. 20:33 | IT novinky

    Byla oznámena spolupráce GrapheneOS s Motorolou. Podrobnosti v tiskové zprávě. GrapheneOS (Wikpedie) je varianta Androidu zaměřující se na bezpečnost a soukromí.

    Ladislav Hagara | Komentářů: 0
    2.3. 02:22 | Nová verze

    Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu optimalizovaná pro jednodeskové počítače na platformě ARM a RISC-V, ke stažení ale také pro Intel a AMD, byl vydán ve verzi 26.2.1. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 0
    2.3. 02:11 | Komunita

    Volí se dvě místa v Radě openSUSE. Seznamte se se čtyřmi kandidáty. Členové projektu openSUSE mohou hlasovat od 1. do 8. března. Výsledky budou oznámeny 9. března.

    lkocman | Komentářů: 3
    1.3. 19:22 | IT novinky

    Společnost OpenAI uzavřela dohodu s americkým ministerstvem obrany o poskytování technologií umělé inteligence (AI) pro utajované sítě americké armády. Firma to oznámila několik hodin poté, co prezident Donald Trump nařídil vládě, aby přestala využívat služby společnosti Anthropic.

    Ladislav Hagara | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (6%)
     (0%)
     (11%)
     (27%)
     (2%)
     (5%)
     (1%)
     (13%)
     (25%)
    Celkem 1002 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: půlhodinové průměry

    12.7.2010 13:03 jura
    půlhodinové průměry
    Přečteno: 389×
    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.