Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-04-2007, 21:41   #1
k_mishima
Member
 
Iscritto dal: Jan 2007
Messaggi: 173
[C] Rappresentazione di un float

Ciao, devo fare questo esercizio sempre sulle rappresentazioni di numeri

Non riesco a far visualizzare correttamente la mantissa, e non capisco dove ho sbagliato

La traccia dell'esercizio sta a inizio codice

Codice:
/* Scrivere una function per la rappresentazione di un numero float (s,e,m) */

#include <stdio.h>
void FLOAT (float x, short *segno, short *esponente, int mantissa[23]);
void dec2bin(unsigned int inp, char binstr[8]);
main()
{    

      short segno,esponente,i;
      int mantissa[23];
      char esponente_b[8];
      float x;
      puts("Un float e' rappresentato da 32 bit cosi' divisi secondo lo standard IEEE 754");
      puts("1 bit per il segno");
      puts("8 bit per l'esponente");
      puts("23 bit per la mantissa\n");
      
      puts("Il bit segno e' 0 se il numero e' positivo, 1 se e' negativo");
      puts("L'esponente si rappresenta come un BIASED quindi vale da 0 a 255\n");
      puts("Ricordarsi che un bit della mantissa e' implicito e che qui i\nnumeri sono normalizzati");
      puts("Digita il numero da rappresentare: ");
      scanf("%f",&x);
      FLOAT(x,&segno,&esponente,mantissa);
      
      dec2bin(esponente,esponente_b);
      
      printf("\nSEGNO: %hd\n",segno);
      printf("ESPONENTE: ");
      for (i=0;i<8;i++)
      printf("%c",esponente_b[i]);
      printf("\nMANTISSA: ");
      for (i=22;i>=0;i++)
      printf("%d",mantissa[i]);
      printf("\n");
      system("pause");

      
}

void FLOAT (float x, short *segno, short *esponente, int mantissa[23])
{
            short i,BIAS=127;
            *esponente=0;
                      
            if (x>=0)
            *segno=0;
            else
            *segno=1;
            
            while (((int)x>1))
            {
            mantissa[22-*esponente]=(int)x%2;      
            x/=2;
            *esponente+=1; 
            }

            for (i=22-(*esponente);i>=0;i--)
            mantissa[i]=0;
            *esponente+=BIAS;
}
                       
void dec2bin(unsigned int inp, char binstr[8])
{
    int i;
    for (i = 0; i < 8; i++, inp >>= 1)
        binstr[7-i] = (inp & 1) + '0';
}
Qualcuno sa' dove ho sbagliato? Tnx
k_mishima è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2007, 22:11   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da k_mishima Guarda i messaggi
Ciao, devo fare questo esercizio sempre sulle rappresentazioni di numeri

Non riesco a far visualizzare correttamente la mantissa, e non capisco dove ho sbagliato
Seguendo le specifiche IEEE 754, per estrarre le tre parti si potrebbe fare una cosa del genere (non testato!):
Codice:
float val = 1.234f;

int fbits, segno, esponente, mantissa;

fbits = *((int*) &val);

segno = (fbits >> 31) & 1;
esponente = (fbits >> 23) & 0xFF;
mantissa = fbits & 0x7FFFFF;
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2007, 15:54   #3
k_mishima
Member
 
Iscritto dal: Jan 2007
Messaggi: 173
Appena testato, funziona perfettamente grazie (sul mio poi mi sono accorto che avevo sbagliato un i++ nella stampa, ma cmq funzionava solo con i numeri positivi e interi)


Mi spiegheresti questa riga?
Codice:
fbits = *((int*) &val);
poi 0xFF è 8 '1', 0x7FFFFF è 23 '1' consecutivi vero?

Ogni F sono 4 bit '1' perchè vale 16, mentre il 7 sono 3 bit '1'.

Non sono pratico della notazione esadecimale, perchè si scrive 0x(valori) ?

Cmq effettivamente è molto comoda questa notazione, altrimenti in decimale avresti dovuto mettere 2^23 che non è un numero piccolo.

Grazie
k_mishima è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2007, 19:29   #4
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da k_mishima Guarda i messaggi
Mi spiegheresti questa riga?
Codice:
fbits = *((int*) &val);
È il "fulcro" di tutta la estrazione ....

Sui tipi di dati floating-point (float o double che sia) non si possono eseguire operazioni con gli operatori bitwise (AND, OR, ecc....) e nemmeno usare gli operatori di shift.
E per esaminare i singoli bit non ha nemmeno senso fare un cast a int, ad esempio. Perché così faresti solamente una mera conversione a valore intero, che tronca i decimali e che quindi causa una perdita di precisione/magnitudo del valore originale.

Quindi supponendo che un float abbia la stessa dimensione di un int (cioè 32 bit) si può fare in modo da avere nel valore int gli stessi bit che compongono il float.

&val ..... denota l'indirizzo di val, come tipo è un float*
(int*) &val ..... fa un cast da float* a int*
*((int*) &val) ..... il puntatore a int viene dereferenziato, i 4 byte che compongono il float vengono "visti" come componenti di un int, quindi appunto prelevati e messi in fbits.

Quote:
Originariamente inviato da k_mishima Guarda i messaggi
poi 0xFF è 8 '1', 0x7FFFFF è 23 '1' consecutivi vero?


Quote:
Originariamente inviato da k_mishima Guarda i messaggi
Ogni F sono 4 bit '1' perchè vale 16, mentre il 7 sono 3 bit '1'.
0xF vale 15

Quote:
Originariamente inviato da k_mishima Guarda i messaggi
Non sono pratico della notazione esadecimale, perchè si scrive 0x(valori) ?
Perché questa è la sintassi richiesta dal "C" come anche da molti altri linguaggi (Java, C#, PHP ecc...).

Quote:
Originariamente inviato da k_mishima Guarda i messaggi
Cmq effettivamente è molto comoda questa notazione, altrimenti in decimale avresti dovuto mettere 2^23 che non è un numero piccolo.
2^23 in hex è 0x800000, non vedo cosa centra con i valori menzionati sopra.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 03-05-2007, 16:11   #5
k_mishima
Member
 
Iscritto dal: Jan 2007
Messaggi: 173
Quote:
Originariamente inviato da andbin Guarda i messaggi
È il "fulcro" di tutta la estrazione ....

Sui tipi di dati floating-point (float o double che sia) non si possono eseguire operazioni con gli operatori bitwise (AND, OR, ecc....) e nemmeno usare gli operatori di shift.
E per esaminare i singoli bit non ha nemmeno senso fare un cast a int, ad esempio. Perché così faresti solamente una mera conversione a valore intero, che tronca i decimali e che quindi causa una perdita di precisione/magnitudo del valore originale.

Quindi supponendo che un float abbia la stessa dimensione di un int (cioè 32 bit) si può fare in modo da avere nel valore int gli stessi bit che compongono il float.

&val ..... denota l'indirizzo di val, come tipo è un float*
(int*) &val ..... fa un cast da float* a int*
*((int*) &val) ..... il puntatore a int viene dereferenziato, i 4 byte che compongono il float vengono "visti" come componenti di un int, quindi appunto prelevati e messi in fbits.
Ah ok, ora mi è chiaro.

Quote:
Originariamente inviato da andbin Guarda i messaggi
2^23 in hex è 0x800000, non vedo cosa centra con i valori menzionati sopra.
intendevo 2^23 meno 1, mi sono dimenticato il meno 1

Cmq grazie mille, i tuoi consigli sono preziosi
k_mishima è offline   Rispondi citando il messaggio o parte di esso
Old 03-05-2007, 16:23   #6
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da k_mishima Guarda i messaggi
ntendevo 2^23 meno 1, mi sono dimenticato il meno 1
Ah, ok. In C si può scrivere: (1<<23)-1
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
I coupon nascosti di Amazon si rinnovano...
Disponibili i video e le immagini in alt...
La NASA ha rilasciato le prime fotografi...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 12:50.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v