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:48 | Nová verze

Po půl roce od vydání verze 9.0 (zprávička) byla vydána verze 10.0 zvukového serveru PulseAudio. Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
dnes 00:33 | Komunita Ladislav Hagara | Komentářů: 0
včera 17:30 | Zajímavý článek

Mozilla.cz informuje, že webový prohlížeč Firefox bude od verze 53 obsahovat integrovaný prohlížeč dat ve formátu JSON. Firefox kromě strukturovaného prohlížení nabídne také možnost filtrace a uložení na disk. Dle plánu by měl Firefox 53 vyjít 18. 4. 2017.

Ladislav Hagara | Komentářů: 1
včera 11:00 | Komunita

Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už zítra 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.

xkucf03 | Komentářů: 0
17.1. 21:55 | Komunita

Nadace pro svobodný software (FSF) oznámila aktualizaci seznamu prioritních oblastí (changelog), na které by se měli vývojáři a příznivci svobodného softwaru zaměřit. Jsou to například svobodný operační systém pro chytré telefony, hlasová a video komunikace nebo softwarový inteligentní osobní asistent.

Ladislav Hagara | Komentářů: 15
17.1. 16:44 | Nová verze

Byla vydána verze 2.0.0 knihovny pro vykreslování grafů v programovacím jazyce Python Matplotlib (Wikipedie, GitHub). Přehled novinek a galerie grafů na stránkách projektu.

Ladislav Hagara | Komentářů: 0
17.1. 15:33 | Komunita

V australském Hobartu probíhá tento týden konference linux.conf.au 2017. Na programu je celá řada zajímavých přednášek. Sledovat je lze online.

Ladislav Hagara | Komentářů: 0
17.1. 10:20 | Zajímavý článek

Pavel Tišnovský se v dvoudílném článku na MojeFedora.cz věnuje bitmapovým (rastrovým) grafickým editorům ve Fedoře. V prvním dílu se věnuje editorům MyPaint, MtPaint, Pinta, XPaint, Krita a GIMP. V pokračování pak editorům GNU Paint (gpaint), GrafX2, KolourPaint, KIconEdit a Tux Paint.

Ladislav Hagara | Komentářů: 1
16.1. 17:11 | Komunita

Byl proveden bezpečnostní audit svobodného IMAP a POP3 serveru Dovecot (Wikipedie). Audit byl zaplacen z programu Mozilla Secure Open Source a provedla jej společnost Cure53. Společnost Cure53 byla velice spokojena s kvalitou zdrojových kódu. V závěrečné zprávě (pdf) jsou zmíněny pouze 3 drobné a v upstreamu již opravené bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
16.1. 15:30 | IT novinky

Nadace Raspberry Pi představila na svém blogu Raspberry Pi Compute Module 3 (CM3 a CM3L), tj. zmenšené Raspberry Pi vhodné nejenom pro průmyslové využití. Jedná se o nástupce Raspberry Pi Compute Module (CM1) představeného v dubnu 2014. Nový CM3 vychází z Raspberry Pi 3 a má tedy dvakrát více paměti a desetkrát větší výkon než CM1. Verze CM3L (Lite) je dodávána bez 4 GB eMMC flash paměti. Uživatel si může připojit svou vlastní. Představena byla

… více »
Ladislav Hagara | Komentářů: 2
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (3%)
 (74%)
 (3%)
 (10%)
Celkem 317 hlasů
 Komentářů: 24, poslední 17.1. 10:14
    Rozcestník
    Reklama

    Dotaz: C - float do pole uint 16b

    Beda0 avatar 31.5.2009 16:28 Beda0 | skóre: 28
    C - float do pole uint 16b
    Přečteno: 419×
    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: 28
    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.