Both sides previous revision Previous revision Next revision | Previous revision |
products:kronos:rtkronos:rtkronos_communication_protocol [2021/04/03 17:11] – [Table] manu | products:kronos:rtkronos:rtkronos_communication_protocol [2022/05/02 14:04] (current) – manu |
---|
tags: RTK, Kronos, RTKronos, communication | tags: RTK, Kronos, RTKronos, communication |
| |
===== - Utilisation ===== | ===== - Utilisation port série et port SPI module XLBee 2 ===== |
| |
La carte renvoie toutes les secondes la position et l'orientation de déplacement données par le GPS. | La carte renvoie toutes les secondes la position et l'orientation de déplacement données par le GPS. |
Ces informations sont disponibles sur le port série et le port SPI du module XLBee 2 (SOCKET 2 sur la carte). | Ces informations sont disponibles sur le port série et le port SPI du module XLBee 2 (SOCKET 2 sur la carte). |
| |
===== - Protocole ===== | |
| ==== - Protocole ==== |
| |
* **[0:1]** : //(uint16)// packet_id | * **[0:1]** : //(uint16)// packet_id |
* **[4:packet_length]** : payload | * **[4:packet_length]** : payload |
| |
==== - Payload format for every packet ID/type ==== | === - Payload format for every packet ID/type === |
| |
| == - Id 0x0001: Complete position information == |
| {| class="contenttable sortable" style="width: 864px;text-align:center;" border="1" |
| |- style="background-color: lightgrey; height: 22px;" |
| ! style="text-align:center; width: 132px; height: 22px;"|Field |
| ! style="text-align:center; width: 743px; height: 22px;"|Format |
| ! style="text-align:center; width: 508px; height: 22px;"|Description |
| ! style="text-align:center; width: 85px; height: 22px;"|Offset |
| |
| |- style="height: 177.047px;" |
| | style="width: 132px; height: 177.047px;"|sol status |
| | style="width: 743px; height: 177.047px;"|Enum (4 octets) |
| | style="width: 508px; height: 177.047px;"| |
| |
| {| class="contenttable sortable" style="width: 518px;" border="1" |
| |- style="background-color: lightgrey; height: 22px;" |
| ! style="background-color: lightgrey;text-align:center; width: 64px; height: 22px;"|Value |
| ! style="background-color: lightgrey;text-align:center; width: 133px; height: 22px;"|Status |
| ! style="background-color: lightgrey;text-align:center; width: 298px; height: 22px;"|Description |
| |- style="height: 30px;" |
| | style="width: 64px; height: 30px;"| 0 |
| | style="width: 133px; height: 30px;"|SOL_COMPUTED |
| | style="width: 298px; height: 30px;"|Solution computed |
| |- style="height: 22px;" |
| | style="width: 64px; height: 22px;"|1 |
| | style="width: 133px; height: 22px;"|INSUFFICIENT_OBS |
| | style="width: 298px; height: 22px;"|Insufficient observation |
| |- style="height: 22px;" |
| | style="width: 64px; height: 22px;"|2 |
| | style="width: 133px; height: 22px;"|NO_CONVERGENCE |
| | style="width: 298px; height: 22px;"|No convergence |
| |- style="height: 22px;" |
| | style="width: 64px; height: 22px;"|4 |
| | style="width: 133px; height: 22px;"|COV_TRACE |
| | style="width: 298px; height: 22px;"|Trace of covariance matrix exceeds maximum (trace>1000m) |
| |} |
| |
| | style="width: 85px; height: 177.047px;"|0 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|pos type |
| | style="width: 743px; height: 22px;"|Enum (4 octets) |
| | style="width: 508px; height: 300px"| |
| |
| {| class="contenttable sortable" style="width: 515px;" border="1" |
| |- style="background-color: lightgrey;" |
| ! style="width: 62px;"|Value |
| ! style="width: 147px;"|Type |
| ! style="width: 282px;"|Description |
| |- |
| | style="width: 62px;"|0 |
| | style="width: 147px;"|NONE |
| | style="width: 282px;"|No solution |
| |- |
| | style="width: 62px;"|1 |
| | style="width: 147px;"|FIXEDPOS |
| | style="width: 282px;"|Position has been fixed manually |
| |- |
| | style="width: 62px;"|8 |
| | style="width: 147px;"|DOPPLER_VELOCITY |
| | style="width: 282px;"|Velocity is derived from real-time Doppler message |
| |- |
| | style="width: 62px;"|16 |
| | style="width: 147px;"|SINGLE |
| | style="width: 282px;"|Single point position |
| |- |
| | style="width: 62px;"|17 |
| | style="width: 147px;"|PSRDIFF |
| | style="width: 282px;"|Pseudo-range difference decomposing |
| |- |
| | style="width: 62px;"|32 |
| | style="width: 147px;"|L1_FLOAT |
| | style="width: 282px;"|L1 floating solution |
| |- |
| | style="width: 62px;"|33 |
| | style="width: 147px;"|IONOFREE_FLOAT |
| | style="width: 282px;"|Ionospheric-free floating solution |
| |- |
| | style="width: 62px;"|34 |
| | style="width: 147px;"|NARROW_FLOAT |
| | style="width: 282px;"|Narrow-lane floating solution |
| |- |
| | style="width: 62px;"|48 |
| | style="width: 147px;"|L1_INT |
| | style="width: 282px;"|L1 integer solution |
| |- |
| | style="width: 62px;"|49 |
| | style="width: 147px;"|WIDE_INT |
| | style="width: 282px;"|Wide-lane integer solution |
| |- |
| | style="width: 62px;"|50 |
| | style="width: 147px;"|NARROW_INT |
| | style="width: 282px;"|Narrow-lane integer solution |
| |} |
| |
| | style="width: 85px; height: 22px;"|4 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|lat |
| | style="width: 743px; height: 22px;"|Double (8 octets) |
| | style="width: 508px; height: 22px;"|Latitude |
| | style="width: 85px; height: 22px;"|8 |
| |- style="height: 34px;" |
| | style="width: 132px; height: 34px;"|lon |
| | style="width: 743px; height: 34px;"|Double (8 octets) |
| | style="width: 508px; height: 34px;"| |
| Longitude |
| |
| | style="width: 85px; height: 34px;"| |
| 16 |
| |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|hgt |
| | style="width: 743px; height: 22px;"|Double (8 octets) |
| | style="width: 508px; height: 22px;"|Height (altitude) |
| | style="width: 85px; height: 22px;"|24 |
| |- style="height: 44px;" |
| | style="width: 132px; height: 44px;"|undulation |
| | style="width: 743px; height: 44px;"|Float (4 octets) |
| | style="width: 508px; height: 44px;"|Geoid undulation (distance between the geoid and the WGS84 ellipsoid in meter) |
| | style="width: 85px; height: 44px;"|32 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|datum id# |
| | style="width: 743px; height: 22px;"|Enum |
| | style="width: 508px; height: 22px;"|ID code of coordinate system, onlysupporting WGS84 at present, ID: WE |
| | style="width: 85px; height: 22px;"|36 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|lat σ |
| | style="width: 743px; height: 22px;"|Float (4 octets) |
| | style="width: 508px; height: 22px;"|Latitude standard deviation |
| | style="width: 85px; height: 22px;"|40 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|lon σ |
| | style="width: 743px; height: 22px;"|Float (4 octets) |
| | style="width: 508px; height: 22px;"|Longitude standard deviation |
| | style="width: 85px; height: 22px;"|44 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|hgt σ |
| | style="width: 743px; height: 22px;"|Float (4 octets) |
| | style="width: 508px; height: 22px;"|Height standard deviation |
| | style="width: 85px; height: 22px;"|48 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|stn id |
| | style="width: 743px; height: 22px;"|Char[4] |
| | style="width: 508px; height: 22px;"|Base station ID |
| | style="width: 85px; height: 22px;"|52 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|diff_age |
| | style="width: 743px; height: 22px;"|Float (4 octets) |
| | style="width: 508px; height: 22px;"|Differential age in seconds |
| | style="width: 85px; height: 22px;"|56 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|sol_age |
| | style="width: 743px; height: 22px;"|Float (4 octets) |
| | style="width: 508px; height: 22px;"|Solution age in seconds |
| | style="width: 85px; height: 22px;"|60 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|#SVs |
| | style="width: 743px; height: 22px;"|uint8 |
| | style="width: 508px; height: 22px;"|Number of satellite tracked |
| | style="width: 85px; height: 22px;"|64 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|#solnSVs |
| | style="width: 743px; height: 22px;"|uint8 |
| | style="width: 508px; height: 22px;"|Number of satellite used in solution |
| | style="width: 85px; height: 22px;"|65 |
| |- style="height: 22px;" |
| | style="width: 132px; height: 22px;"|sig mask |
| | style="width: 743px; height: 22px;"|Enum (1 octet) |
| | style="width: 508px; height: 200px;"| |
| |
| {| class="contenttable sortable" style="width: 515px;" border="1" |
| |- style="background-color: lightgrey;" |
| ! style="background-color: lightgrey;text-align:center; width: 64px; height: 22px;" | Bit |
| ! style="background-color: lightgrey;text-align:center; width: 64px; height: 22px;" | Mask |
| ! style="background-color: lightgrey;text-align:center; width: 64px; height: 22px;" | Description |
| |- |
| |0 |
| |0x01 |
| |GPS L1 used in calculation |
| |- |
| |1 |
| |0x02 |
| |GPS L2 used in calculation |
| |-style="background-color: lightgrey;text-align:center; width: 64px; height: 22px;" |
| |2 |
| |0x04 |
| |GPS L5 used in calculation |
| |- |
| |3 |
| |0x08 |
| |BDS B3 used in calculation |
| |- |
| |4 |
| |0x10 |
| |GLONASS L1 used in calculation |
| |- |
| |5 |
| |0x20 |
| |GLONASS L2 used in calculation |
| |- |
| |6 |
| |0x40 |
| |BD2 B1 used in calculation |
| |- |
| |7 |
| |0x80 |
| |BD2 B2 used in calculation |
| |} |
| | style="width: 85px; height: 22px;"|66 |
| |} |
| |
| |
| |
| |
| |
| |
| == - Id 0x0002: Heading data == |
| |
| |
| {| class="contenttable sortable" style="width: 886px;text-align:center;" border="1" |
| |- style="background-color: lightgrey;" |
| ! style="text-align:center; width: 99px;"|Field |
| ! style="text-align:center; width: 112px;"|Format |
| ! style="text-align:center; width: 476px;"|Description |
| ! style="text-align:center; width: 166px;"|Offset |
| |- |
| | style="width: 99px;"|heading |
| | style="width: 112px;"|Float (4 octets) |
| | style="width: 476px;"|Heading angle in degrees from True North |
| | style="width: 166px;"|0 |
| |} |
| |
| == - Id 0x0003: Satellite count == |
| |
| |
| {| class="contenttable sortable" style="width: 886px;text-align:center;" border="1" |
| |- style="background-color: lightgrey;" |
| ! style="text-align:center; width: 99px;"|Field |
| ! style="text-align:center; width: 112px;"|Format |
| ! style="text-align:center; width: 476px;"|Description |
| ! style="text-align:center; width: 166px;"|Offset |
| |- |
| | style="width: 99px;"|GPS L1 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on GPS L1 band |
| | style="width: 166px;"|0 |
| |- |
| | style="width: 99px;"|GPS L2 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on GPS L2 band |
| | style="width: 166px;"|1 |
| |- |
| | style="width: 99px;"|GPS L5 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on GPS L5 band |
| | style="width: 166px;"|2 |
| |- |
| | style="width: 99px;"|GLONASS L1 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on GLONASS L1 band |
| | style="width: 166px;"|3 |
| |- |
| | style="width: 99px;"|GLONASS L2 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on GLONASS L2 band |
| | style="width: 166px;"|4 |
| |- |
| | style="width: 99px;"|BD2 B1 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on BD2 B1 band |
| | style="width: 166px;"|5 |
| |- |
| | style="width: 99px;"|BD2 B2 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on BD2 B2 band |
| | style="width: 166px;"|6 |
| |- |
| | style="width: 99px;"|BD2 B3 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on BD2 B3 band |
| | style="width: 166px;"|7 |
| |- |
| | style="width: 99px;"|Galileo E1 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on Galileo E1 band |
| | style="width: 166px;"|8 |
| |- |
| | style="width: 99px;"|Galileo E5 |
| | style="width: 112px;"|uint8 |
| | style="width: 476px;"|Number of active satellites on Galileo E5 band |
| | style="width: 166px;"|9 |
| |} |
| |
| ===== - Utilisation sortie directe GPS RTK ===== |
| En Mars 2022, nous avons ajouté la sortie en direct sur le port dédié du GPS (port COM3 de l'UB4B0).\\ |
| Cela permet d'avoir une fréquence des messages garantie par le module GPS RTK (sans délai de traitement).\\ |
| Pour le moment seuls les messages de type GNGGA sont disponibles sous format ASCII. |
| |
| |
| {{:products:kronos:rtkronos:rtkronos_com3_for_direct_rtk_positioning_data.png?500|}} |
| ==== - Description du format GNGGA ==== |
| |
| ^ ID ^ Champs ^ Description ^ Nombre et type des symboles ^ Example ^ |
| | 1 | <WRAP> %%$GNGGA%% </WRAP> | Préambule permettant d'identifiant le type du message | 6 caractères fixes | <WRAP> %%$GNGGA%% </WRAP> | |
| | 2 | utc | Temps UTC de la position calculée \\ (heures/minutes/secondes/dixièmes de\\ secondes). \\ Précision 10ms | hhmmss.ss (8 digits et un point de virgule) | 132530.60 | |
| | 3 | lat | Latitude(DDmm.mmmmmmmm) \\ en degrés, minutes et décimales de minutes | LLLL.LL | 4834.65851118 | |
| | 4 | lat dir | Latitude direction(N = North, S = South) | a | N | |
| | 5 | lon | Longitude(DDDmm.mmmmmmmm) \\ en degrés, minutes et décimales de minutes | LLLLL.LL | 00744.99485270 | |
| | 6 | lon dir | Longitude direction(E = East, W = West) | a | E | |
| | 7 | Qualité de la solution | <WRAP> Position Solution Quality indicator\\ 0 = fix not available or invalid\\ 1 = point fix\\ 2 = pseudo-range difference\\ 4 = RTK fixed solution\\ 5 = RTK floating solution\\ 7 = Position set by user(Fixed Position)\\ </WRAP> | x | 1 | |
| | 8 | Nombre de satellites utilisés pour calculer la solution | Nombre de satellites utilisés, \\ pas équivalent au nombre de satellites vus. | xx | 11 | |
| | 9 | hdop | Horizontal dilution of precision | x.x | 1.5 | |
| | 10 | alt | Altitude par rapport au niveau de la mer\\ peut être négatif. | x.xxxx | 151.4783 | |
| | 11 | Unité pour l'altitude | M=mètres | M | M | |
| | 12 | ondulation | Ondulation du géoïde: la distance entre le géoïde \\ et le modèle terrestre éllipsoïde WGS84\\ peut être négatif | x.xxxx | 48.4225 | |
| | 13 | Unité pour l'ondulation | M=mètres | M | M | |
| | 14 | Âge des données différentielles | Âge des données de correction différentielles en secondes (<99s) \\ utilisées pour corriger la solution et provenant d'une base RTK.\\ Vide lorsqu'aucune correction différentielle de moins de 99 secondes \\ n'est disponible. | xx | 13 | |
| | 15 | ID de la base RTK de correction | Id de la station de base d'où proviennent les corrections \\ différentielles utilisées.\\ Vide lorsqu'aucune correction différentielle de moins de 99 secondes \\ n'est disponible. | xxxx-xxxx | 0000-0002 | |
| | 16 | *CS | Checksum | *hh | *71 | |
| | 17 | [CR][LF] | Sentence terminator (carriage return, new line) | \r\n | \r\n | |
| |
| === - Passage de degrés, minutes, décimales de minutes à degrés décimaux === |
| - séparer les degrés des minutes (minutes décimales) vous avez donc: |
| - un entier pour les degrés |
| - un flottant pour les minutes |
| - diviser les minutes décimales par 60 (mm.mmmmmmmmm / 60) |
| - ajouter le résultat aux degrés précédent |
| - Pour la latitude, si la lettre est S, multiplier par -1. |
| - Pour la longitude, si la lettre est W, multiplier par -1. |
| |
| === - Example de trame complète === |
| |
| <code> |
| $GNGGA,132530.60,4834.65851118,N,00744.99485270,E,1,11,1.5,151.4783,M,48.4225,M,,*71 |
| </code> |
| |
| Cela correspond en degrés décimaux à : |
| * latitude: (48+34.65851118/60) soit: 48.577641853 degrés |
| * longitude: (007+44.99485270/60) soit 7.749914211666667 degrés |
| |
| À chaque fois, on est du côté positif, si on était en latitude S, ou en longitude W, il faudrait multiplier le résultat par -1. |
| |
| === - Comparaison avec les trames sur XLBEE2 === |
| Notez bien que les valeurs données pour la précision de la solution sont très différentes entre les 2 types de trames.\\ |
| On peut néanmoins faire une équivalence: |
| ^ Trame XLBEE2 ^ Trame COM3 ^ |
| | 0: pas de solution | 0: pas de solution | |
| | 16: Single point position | 1: point fix | |
| | 17: Pseudo-range difference decomposing | 2: pseudo-range difference | |
| | 48 ou 49 ou 50: XXXX_INT | 4: RTK fixed solution | |
| | 32 ou 33 ou 34: XXXX_FLOAT | 5: RTK floating solution | |
| | 1: Position has been fixed manually | 7: Position set by user(Fixed Position) | |
| |
=== - Id **0x0001**: Complete position information === | Donc la meilleure solution a pour valeur 4 dans la trame GNGGA et pour valeur 50 dans la trame sur le XLBEE.\\ |
^ Field ^ Format ^ Description ^ Offset ^ | Elles ne sont pas exactement équivalentes car on ne sait pas s'il s'agit de la valeur 48, 49 ou 50 sachant qu'en terme de précision: |
| sol status | Enum (4 octets) | | 0 | | 50 > 49 > 48. |
| pos type | Enum (4 octets) | | 4 | | |
| lat | Double (8 octets) | Latitude | 8 | | |
| lon | Double (8 octets) | Longitude | 16 | | |
| hgt | Double (8 octets) | Height (altitude) | 24 | | |
| undulation | Float (4 octets) | Geoid undulation (distance between the geoid and the WGS84 ellipsoid in meter) | 32 | | |
| datum id# | Enum | ID code of coordinate system, onlysupporting WGS84 at present, ID: WE | 36 | | |
| lat σ | Float (4 octets) | Latitude standard deviation | 40 | | |
| lon σ | Float (4 octets) | Longitude standard deviation | 44 | | |
| hgt σ | Float (4 octets) | Height standard deviation | 48 | | |
| stn id | Char[4] | Base station ID | 52 | | |
| diff_age | Float (4 octets) | Differential age in seconds | 56 | | |
| sol_age | Float (4 octets) | Solution age in seconds | 60 | | |
| #SVs | uint8 | Number of satellite tracked | 64 | | |
| #solnSVs | uint8 | Number of satellite used in solution | 65 | | |
| sig mask | Enum (1 octet) | | 66 | | |
| |
| ==== - Librairie arduino recommandée pour parser les messages GNGGA ==== |
| MicroNMEA de Steve MARPLE: |
| * https://www.arduino.cc/reference/en/libraries/micronmea/ |
| * https://github.com/stevemarple/MicroNMEA |