Portál AbcLinuxu, 13. července 2025 19:32


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: 475×
Odpovědět | Admin
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.
Nástroje: Začni sledovat (1) ?Zašle upozornění na váš email při vložení nového komentáře.

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
Odpovědět | | Sbalit | Link | Blokovat | Admin

#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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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
Odpovědět | | Sbalit | Link | Blokovat | Admin
 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
Odpovědět | | Sbalit | Link | Blokovat | Admin

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, (c) 1999-2007 Stickfish s.r.o.