Capteur de CO2 SCD30 : Notation "Big-Endian"
Résolu
A voir également:
- Ne pas couvrir la zone de l'écouteur et du capteur de proximité
- Alternative zone telechargement - Accueil - Outils
- La zone de données passée à un appel système est insuffisante - Windows 11
- Partage de proximité - Guide
- Boîtier ecouteur jbl perdu ✓ - Forum Casque et écouteurs
- Son dans un seul écouteur avec fil ✓ - Forum Audio
3 réponses
Bonjour,
Pour faire une conversion little endian - big endian, il faut réordonner les octets (bytes) comme expliqué dans cet article. En python, cela peut se faire à l'aide d'un
Cependant il y a un autre piège, et c'est sans doute ce qui t'empêche de comprendre l'exemple. Les 4 octets, une fois réordonnés, servent à encoder un
Méthode 1 : en passant par un
(Note que dans cette implémentation, je dois convertir
Résultat :
Méthode 2 : en passant par
Face à l'inélégance du constructeur de
Bonne chance
Pour faire une conversion little endian - big endian, il faut réordonner les octets (bytes) comme expliqué dans cet article. En python, cela peut se faire à l'aide d'un
bytearraycomme expliqué dans cette discussion.
Cependant il y a un autre piège, et c'est sans doute ce qui t'empêche de comprendre l'exemple. Les 4 octets, une fois réordonnés, servent à encoder un
floatet non un
int(il m'a moi même fallu un peu de temps pour comprendre, car l'exemple est mal choisi et omet la partie décimale). J'ai pu recoller les bouts grâce à la documentation complète (p19) qui donne un exemple en C, donc il m'a suffit de traduire cela en python en m'inspirant de cette discussion.
Méthode 1 : en passant par un
bytearray
import struct def le_hex_to_co2_ppm(le_hex): ba = bytearray.fromhex("%x" % le_hex) # Conversion string -> bytearray ba.reverse() # Conversion big endian -> little endian tup = struct.unpack("f", ba) # Conversion 4 octets -> float return tup[0] print(le_hex_to_co2_ppm(0x43c80000)) # Exemple que tu as cité print(le_hex_to_co2_ppm(0x43DB8C2E)) # Exemple p19
(Note que dans cette implémentation, je dois convertir
le_hexsous forme de chaîne de caractère pour initialiser
ba, c'est assez inélégant mais je n'ai pas trouvé mieux.
Résultat :
400.0
439.09515380859375
Méthode 2 : en passant par
to_bytes
Face à l'inélégance du constructeur de
bytearray, j'ai creusé et j'ai trouvé la méthode
to_bytesqui permet de faire la même chose de manière bien plus directe :
def le_hex_to_co2_ppm(le_hex): tup = struct.unpack("f", le_hex.to_bytes(4, byteorder="little")) return tup[0]
Bonne chance
Bonjour,
Le code ne peut pas être lu si tu n'utilises pas la balise [ <> ] pour le poster.
Néanmoins on peut y lire:
Le code ne peut pas être lu si tu n'utilises pas la balise [ <> ] pour le poster.
Néanmoins on peut y lire:
strucco2 = var[0]<<24 | var[1]<<16 | var[3]<<8 | var[4]Qui correspond à lire les 4 octets pour en faire un nombre issu de données Big-endian. Il te faut modifier cette ligne pour qu'elle devienne : lire les 4 octets pour en faire un nombre issu de données Little-endian.