Le mappeur de chemin : 6 étapes
Le mappeur de chemin : 6 étapes
Anonim
Le mappeur de chemin
Le mappeur de chemin
Le mappeur de chemin
Le mappeur de chemin
Le mappeur de chemin
Le mappeur de chemin

Dans ce projet IoT, nous connectons un NEO-6M (module GPS) pour fournir des données de localisation via l'Arduino à une feuille Excel qui sera enregistrée sur l'ordinateur. Ensuite, avec Tableau Public, nous créons une visualisation des données de ces données pour tracer le chemin que nous avons emprunté. Bien qu'il s'agisse d'une façon de collecter et de présenter des données en temps réel dans une visualisation de données hautement corrélée, ce processus peut également être appliqué à d'autres projets axés sur les données.

Étape 1: Acquisition de matériaux

Acquisition de matériaux
Acquisition de matériaux

Pour ce projet, vous aurez besoin des éléments suivants:

  • Module GPS NEO-6M
  • Arduino Uno
  • Fils de liaison mâle/mâle (vous aurez besoin de 4 fils)
  • Câble USB 2.0 de type A vers B
  • Ordinateur avec ces programmes: Tableau Public, Arduino IDE (avec TinyGPS++) et Processing

Étape 2: Configuration des appareils

Configuration des appareils
Configuration des appareils
Configuration des appareils
Configuration des appareils

Nous devons d'abord configurer le module GPS avec l'Arduino UNO pour que l'Arduino nous donne une interface pour afficher les données. Chacun des quatre fils connectés au NEO-6M correspond à des ports spécifiques. Si votre NEO-6M n'est pas livré avec les fils, vous devrez le câbler directement avec des fils de liaison. Dans le diagramme ci-dessus, le rouge correspond à l'alimentation (VCC), le noir à la terre (GND), le jaune à la transmission des données (TxD) et le blanc à la réception des données (RxD). Nous connectons ces fils à des cavaliers mâles/mâles afin de pouvoir les connecter à l'Arduino. En suivant le schéma ci-dessus, nous connectons le fil de terre à la broche numérique GND sur l'Arduino, le fil TxD à 4, le fil RxD à ~ 3 et le fil VCC à 5V pour la tension. Dans une prochaine étape, nous devrons définir TxD et RxD avec les bons numéros dans le SoftwareSerial.

Une fois que les deux appareils sont câblés l'un à l'autre, nous devons fournir une source d'alimentation. Connectez le câble USB 2.0 à votre ordinateur portable et le voyant du NEO-6M devrait s'allumer.

Étape 3: Codage de l'Arduino pour extraire les données

Codage de l'Arduino pour extraire des données
Codage de l'Arduino pour extraire des données

Maintenant que nous avons configuré les appareils pour collecter les données GPS des satellites, nous allons écrire du code pour analyser les données GPS que nous voulons. En supposant que vous ayez capté un signal (mon module GPS clignoterait en bleu), le NEO-6M imprime par défaut des données brutes sur le moniteur série sous la forme de messages NMEA, qui ressemblent à $GP suivis de plus de lettres et d'une série de nombres. L'image ci-dessus donne une idée générale de ce qui doit être affiché sur votre moniteur série une fois le code Arduino de base inséré.

Pour expliquer le code que j'ai joint (ou si vous souhaitez essayer de le coder vous-même), vous devez d'abord inclure les bibliothèques SoftwareSerial et TinyGPS++ (pour cette dernière, Sketch > Inclure > Ajouter une bibliothèque. ZIP). SoftwareSerial nous permet d'avoir une connexion série; TinyGPS++ nous donne un outil simple pour imprimer les informations ciblées sous une forme lisible. Assurez-vous d'initialiser l'objet SoftwareSerial sur les broches correspondantes de l'Arduino. Dans la fonction de configuration, nous utilisons 9600 comme débit en bauds.

Aux fins de cette instructable, nous n'imprimerons que sept types de données dans la fonction de boucle: latitude (degrés), longitude (degrés), vitesse (km), cap (degrés), altitude (km), nombre de satellites dans utiliser, et hdop. Vous pouvez rechercher la syntaxe pour imprimer ces informations dans la bibliothèque Arduiniana. La forme générale est Serial.print(). Par exemple, pour imprimer la longitude, nous taperions Serial.print(gps.location.lng(), 6). Le 6 représente le nombre de chiffres que nous voulons à droite de la virgule décimale.

Mon code a des caractères supplémentaires imprimés pour une expression régulière facilement formatée à l'étape suivante. Si vous souhaitez vous arrêter à cette étape, n'hésitez pas à formater les données différemment pour faciliter la visualisation sur le moniteur série.

Étape 4: Utiliser le traitement pour écouter

Utiliser le traitement pour écouter
Utiliser le traitement pour écouter

Bien que nous ayons du code pour la configuration de l'IDE Arduino, nous avons un problème pour enregistrer ces données. Pour le moment, nous ne pouvons afficher que les données sur le moniteur série au fur et à mesure que nous les collectons. Il existe de nombreuses façons d'enregistrer ces données, mais j'ai choisi Processing principalement parce que son interface imite l'IDE Arduino et qu'il utilise Java, un langage que je connais bien (notez que vous pouvez également contrôler la carte Arduino avec Processing si vous téléchargez Firmata). Le traitement écoute sur le port connecté à l'Arduino et a la capacité de manipuler les données qui sont lues sur le moniteur série. Pour trouver le nom de ce port, reportez-vous à votre fichier IDE Arduino et vérifiez dans Outils > Port.

J'ai fourni le code de traitement, mais voici un aperçu rapide du fonctionnement du code.

Avant la fonction de configuration, assurez-vous d'avoir des variables pour le port, la table résultante, la ligne avec laquelle nous allons travailler et le nom du fichier. Ensuite, dans la fonction de configuration, il existe des paramètres pour définir la taille de votre fenêtre d'exécution, mais ces nombres n'affectent pas notre fonctionnalité (par exemple, définissez-les sur (500, 500)). Lorsque vous initialisez le port, utilisez le nom du port sous forme de chaîne et un débit en bauds de 9600. Enfin, créez les neuf colonnes (pour les sept catégories GPS, l'heure et la date) pour initialiser la table.

Dans la fonction de dessin, nous utilisons les fonctions de date et d'heure intégrées pour garder une trace du moment où chaque ensemble de données GPS est extrait. Maintenant, pour lire le flux de données de l'Arduino et le placer sous les en-têtes appropriés avec l'heure et la date correctes, nous utilisons des expressions régulières.

J'utilise regex pour analyser les données exactes avec la fonction matchAll qui recherche toute expression entre le signe égal et le point-virgule (les délimiteurs que j'ai mis dans mon code Arduino). Cela place ensuite toutes les balises correspondantes, les données numériques, dans un tableau à deux dimensions. On peut alors faire appel à ces indices de tableau pour les mettre sous les en-têtes de la feuille Excel.

Pour enregistrer le nouveau fichier.csv, nous utilisons une touche pour fermer la fenêtre Exécuter. Plus vous attendez pour appuyer sur une touche, plus vous collecterez de données. À la manière d'un autre guide, j'ai également décidé d'enregistrer le fichier dans le dossier de données avec la date et l'heure comme nom de fichier.

Étape 5: Affichage des données sur Tableau Public

Afficher des données sur Tableau Public
Afficher des données sur Tableau Public
Afficher des données sur Tableau Public
Afficher des données sur Tableau Public
Afficher des données sur Tableau Public
Afficher des données sur Tableau Public

La dernière étape implique une certaine visualisation des données. Il existe de nombreux programmes pour créer et afficher des visualisations de données, c'est-à-dire Plotly, mais pour ce projet, nous utiliserons Tableau. Ouvrez Tableau Public et ouvrez le fichier Excel enregistré en tant que fichier texte. Pour créer une feuille de calcul, cliquez sur Feuille 1 en bas à gauche.

Puisque nous travaillons avec des données GPS, nous utiliserons une carte pour représenter nos informations. Dans la colonne de gauche où il est indiqué Mesures, nous allons faire glisser la longitude dans les colonnes et la latitude dans les lignes en haut. Tableau définit par défaut les deux mesures sur AVG, alors cliquez sur le menu déroulant à côté des termes et changez les deux en Dimension. Maintenant, la carte devrait avoir un chemin affiché en utilisant les valeurs de latitude et de longitude collectées.

Pour nettoyer vos données en cas d'erreur (ce qui peut également être fait avant d'ouvrir Tableau), vous pouvez choisir d'exclure certains cercles de localisation en cliquant dessus et en sélectionnant l'option. Mon module GPS n'est pas précis à 100%, car certaines parties de mon chemin n'ont pas été localisées, mais le chemin général a été enregistré.

Étape 6: Affiner la visualisation

Affiner la visualisation
Affiner la visualisation

La dernière partie est de rendre ces données plus lisibles. Si vous voulez un contexte de rue, vous pouvez aller dans Carte > Couche de carte > Rues et autoroutes. N'hésitez pas à expérimenter avec d'autres marques. J'ai fait glisser Vitesse sur Couleur pour montrer comment l'intensité de la couleur augmente lorsque la vitesse augmente. J'ai également utilisé Detail au lieu de Label for Course car Label afficherait les numéros sur la carte alors que je voulais que les informations apparaissent uniquement lorsque vous survolez les points de localisation.

Maintenant que vous avez expérimenté tout le processus de collecte de données et d'affichage de ce que vous avez sur une visualisation de données, vous pouvez l'appliquer à d'autres projets !

par Pingdi Huang, été 2018

Conseillé: