Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-07-2008, 13:00   #1
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6669
[C] Cast double float

Salve,
ho un dubbio su questo tipo di cast. Siccome ho un programma che scrive i risultati in un file binario, ma tali risultati prima li casta da double a float, siamo sicuri che ogni volta che tronca in double dia esattamente lo stesso risultato ? Inoltre prima tali valori li mette in una funzione sin(atan(x))

Perché il binario mi viene differente ogni volta
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2008, 13:33   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Non ho ben capito il cast che fai, se fai un cast da float a double non ci sono perdite di dati, se fai il contrario invece possono esserci
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2008, 13:44   #3
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6669
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Non ho ben capito il cast che fai, se fai un cast da float a double non ci sono perdite di dati, se fai il contrario invece possono esserci
Da double a float. So che possono esserci perdite di dati, ma quello che mi chiedevo è se tali perdite sono sempre le stesse o possono variare.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2008, 15:17   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Se il numero è sempre lo stesso la perdita deve essere sempre uguale, se i numeri sono diversi le perdite saranno differenti, potrebbero anche non esserci per alcuni numeri
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2008, 20:48   #5
!k-0t1c!
Member
 
Iscritto dal: Jul 2008
Messaggi: 237
Dato lo stesso input e lo stesso codice eseguibile anche le perdite saranno costanti pur ripetendo una data operazione N volte. Dunque se salvando un double x si ottiene un float che ad esempio vale x - FLT_EPSILON, ciò non vuol dire che salvando un double y il valore salvato varrà y - FLT_EPSILON, ma salvando 10 volte un double x castato a float (effettuando il casting ad ogni salvataggio) si salverà 10 volte lo stesso float. Bisogna comunque considerare che lo stesso sorgente C(++) può essere compilato in diversi modi, e la modifica di un'impostazione di ottimizzaizione può cambiare la precisione delle operazioni in virgola mobile se applicata al codice che li usa. In sostanza è da considerarsi *VIETATO* salvare dati in maniera approssimata rispetto all'uso che se ne fa all'interno del programma (se hai un double salvarlo come float etc).
!k-0t1c! è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2008, 01:06   #6
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da !k-0t1c! Guarda i messaggi
Dato lo stesso input e lo stesso codice eseguibile anche le perdite saranno costanti pur ripetendo una data operazione N volte. Dunque se salvando un double x si ottiene un float che ad esempio vale x - FLT_EPSILON, ciò non vuol dire che salvando un double y il valore salvato varrà y - FLT_EPSILON, ma salvando 10 volte un double x castato a float (effettuando il casting ad ogni salvataggio) si salverà 10 volte lo stesso float. Bisogna comunque considerare che lo stesso sorgente C(++) può essere compilato in diversi modi, e la modifica di un'impostazione di ottimizzaizione può cambiare la precisione delle operazioni in virgola mobile se applicata al codice che li usa. In sostanza è da considerarsi *VIETATO* salvare dati in maniera approssimata rispetto all'uso che se ne fa all'interno del programma (se hai un double salvarlo come float etc).
Analisi interessante, ma... non bastava un "sì"?
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Google Pixel 10a disponibile al prezzo m...
Microsoft Copilot nei guai: email riserv...
AOC a 399€ su Amazon: QD-OLED 240 Hz e 0...
La Cina ha recuperato dal mare il primo ...
Boeing CST-100 Starliner: la NASA rende ...
hiop e TaDa uniscono le forze per trasfo...
Thermal Grizzly mostra il Ryzen 7 9850X3...
AMD Ryzen 'Olympic Ridge' Zen 6 per desk...
Donald Trump renderà pubbliche in...
Prezzo mai visto da mesi: ECOVACS DEEBOT...
Non solo S26, Samsung sta per lanciare a...
Windows 11 avrà a breve uno Speed...
Ask Intel: l'assistente IA che ti aiuta ...
Nasce Freedom.gov: il portale USA per ag...
Bose QuietComfort SC a 179,95€: ANC legg...
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: 18:18.


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