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 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 11
    dnes 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

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

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    včera 13:55 | Nová verze

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

    Ladislav Hagara | Komentářů: 0
    včera 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    22.12. 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 14
    19.12. 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 1
    Kdo vám letos nadělí dárek?
     (30%)
     (3%)
     (11%)
     (3%)
     (1%)
     (3%)
     (14%)
     (21%)
     (14%)
    Celkem 76 hlasů
     Komentářů: 18, poslední dnes 15:30
    Rozcestník

    Dotaz: C - float do pole uint 16b

    Beda0 avatar 31.5.2009 16:28 Beda0 | skóre: 29
    C - float do pole uint 16b
    Přečteno: 513×
    Zdravím, v C mam proměnnou typu float (32b) a pole typu unsigned short int (16b) potřebuju tu proměnnou dostat do dvou prvků toho pole a pak z těch dvou prvků pole zase zpátky do float, jak se to dělá? Radši napíšu nějakej pseudokód:
    float x;
    unsigned short int y[10];
    y[5]=//první půlka x;
    y[6]=//druhá půlka x;
    
    a pak zase spojit y[5] a y[6] do x.

    Odpovědi

    oroborus avatar 31.5.2009 16:58 oroborus | skóre: 20 | blog: Bulanci
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b

    #include <stdio.h>
    #include <math.h>
    #include <string.h>

    int main()
    {
        float x;
        unsigned short int y[10];
        int i;

        memset(y, 0, sizeof(unsigned short int)*10);

        x = M_PI;

        printf("pred x = %f\n", x);

        memcpy(y+5, &x, sizeof(x));
        //y[5]=//první půlka x;
        //y[6]=//druhá půlka x;

        x = 0.0;

        memcpy(&x, y+5, sizeof(x));
        //y[5]=//první půlka x;
        //y[6]=//druhá půlka x;

        printf("po x = %f\n", x);

        return 0;
    }

    Beda0 avatar 31.5.2009 17:01 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    Dík moc....
    31.5.2009 17:03 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    Zkuste použít union - viz příklad.
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    31.5.2009 20:28 deadmail
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
     y[5] = x & 0xffff;
     y[6] = x >> 16;
     x = (y[6] << 16) | y[5];
    
    1.6.2009 15:28 nikis
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b

    Elegance C-ka :)

    herne the hunter avatar 1.6.2009 17:25 herne the hunter | skóre: 10 | tor lara
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    pěkný, až na to, že to nepůjde. operandy bitových operátorů by měly být afaik celočíselný typy. nebo se pletu?
    i am herne the hunter and you are a leaf driven by the wind.
    1.6.2009 17:51 #Tom | skóre: 32 | blog: Inspirace, aneb co jsem kde vyhrabal
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    Po obměnění to fungovat bude:
    y[5] = * (unsigned short int *) &x;
    y[6] = * ((unsigned short int *) &x + 1);
    ...
    * (unsigned short int *) &x = y[5];
    * ((unsigned short int *) &x + 1) = y[6];
    
    Nebo tak:
    * (float *) &y[5] = x;
    ...
    x = * (float *) &y[5];
    
    1.6.2009 18:24 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    Fuj.
    1.6.2009 20:40 darkanry
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b

    v c je taky dostupna union. Takze:

    typedef union {

      float fCislo;

      uint16 au16Cisla[2];

    } CisloVLoterii;

    ...

    CisloVLoterii *pCislo;

    ...

    pCislo = (CisloVLoterii *)&y[5];

    pCislo->fCislo = x;

    printf('%d %d\n', pCislo->au16Cisla[0], pCislo->au16Cisla[1]);

    ...

     

    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.