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 21:33 | Bezpečnostní upozornění

    Ve FreeBSD byla nalezena a opravena zranitelnost FatGid aneb CVE-2026-45250. Jedná se o lokální eskalaci práv. Neprivilegovaný uživatel se může stát rootem.

    Ladislav Hagara | Komentářů: 0
    včera 14:33 | IT novinky

    Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).

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

    Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.

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

    Společnost Red Hat oznámila vydání Red Hat Enterprise Linuxu (RHEL) 10.2 a 9.8. Vedle nových vlastností a oprav chyb přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Vypíchnout lze CLI AI asistenta goose. Podrobnosti v poznámkách k vydání (10.2 a 9.8).

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

    Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

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

    Byla vydána nová verze 7.0 svobodného open source redakčního systému WordPress. Kódové jméno Armstrong bylo vybráno na počest amerického jazzového trumpetisty a zpěváka Louise Armstronga (What A Wonderful World).

    Ladislav Hagara | Komentářů: 0
    včera 04:55 | Bezpečnostní upozornění

    V Drupalu byla nalezena a opravena kritická zranitelnost SA-CORE-2026-004 (CVE-2026-9082). Útočník může provádět libovolné SQL dotazy na webech používajících databázi PostgreSQL.

    Ladislav Hagara | Komentářů: 0
    20.5. 14:11 | Komunita

    Richard Hughes oznámil, že službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzoruje také společnost HP.

    Ladislav Hagara | Komentářů: 3
    20.5. 13:33 | IT novinky

    O víkendu proběhla demopárty Outline 2026. Publikována byla prezentovaná dema. Upozornit lze na 16 bajtové, opravdu šestnáct bajtové, zvukově obrazové demo Wake Up! 16b (YouTube).

    Ladislav Hagara | Komentářů: 2
    20.5. 04:22 | Nová verze

    Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1678 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: půlhodinové průměry

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