Surveillance routière : 15 étapes
Surveillance routière : 15 étapes
Anonim
Surveillance des routes
Surveillance des routes

Aujourd'hui, nous allons vous montrer comment nous avons mis en place un système de surveillance des anomalies routières basé sur des accéléromètres, LoRaWAN, Amazon Web Services et Google Cloud API.

Étape 1: Exigences

  • Carte DISCO-L072CZ-LRWAN1
  • Module d'extension X-NUCLEO-IKS01A2 (pour l'accéléromètre)
  • X-NUCLEO-GNSS1A1 (pour la localisation)
  • Un compte AWS
  • Un compte Google Cloud Platform

Étape 2: Création et flashage du micrologiciel du capteur

Connectez l'IKS01A2 et le GNSS1A1 sur le dessus de la carte via les broches GPIO. Téléchargez le code du firmware depuis GitHub. Créez (si vous n'en avez pas déjà un) un compte sur ARM Mbed et importez le code dans le repo sur le compilateur en ligne. Définissez la plate-forme cible sur DISCO-L072CZ-LRWAN1 et enregistrez le projet. Rendez-vous maintenant sur The Things Network et créez un compte si vous ne l'avez pas déjà. Créez une application, créez un nouvel appareil dans l'application et définissez le mode de connexion sur OTAA. Saisissez les paramètres appropriés pour remplir les champs suivants dans le fichier mbed_app.json: "lora.appskey", "lora.nwkskey", "lora.device-address".

Le capteur enregistrera périodiquement les données de l'accéléromètre et du GNSS et les enverra via la connexion LoRa à la passerelle la plus proche, qui les transmettra à notre application sur The Things Network. L'étape suivante consiste à configurer un serveur cloud et une intégration HTTP sur TTN.

Étape 3: configuration du cloud

Configuration du cloud
Configuration du cloud

Nous sommes maintenant prêts à mettre en place l'infrastructure cloud qui collectera et agrégera les données de toutes les cartes déployées. Cette infrastructure est illustrée dans la figure ci-dessous et elle est composée de:

  • Kinesis, pour gérer le flux de données entrant;
  • Lambda, pour filtrer et prétraiter les données avant de les stocker;
  • S3, pour stocker toutes les données;
  • EC2, pour analyser les données et héberger notre front-end.

Étape 4: configurer AWS Lambda

Configurer AWS Lambda
Configurer AWS Lambda

Nous allons illustrer les étapes nécessaires à la mise en place de cette infrastructure, en commençant par Lambda.

  1. Connectez-vous avec votre compte AWS et depuis la page principale de la console et accédez à Lambda
  2. Cliquez sur Créer une fonction
  3. Dans la partie supérieure de la page, il doit être sélectionné Author from Scratch. Remplissez ensuite les autres champs comme sur l'image puis cliquez sur Créer une fonction
  4. Maintenant que vous avez créé une fonction AWS Lambda, accédez à https://github.com/roadteam/data-server et copiez le contenu du fichier aws_lambda.py dans l'éditeur que vous trouverez dans la seconde moitié de la page. Votre fonction Lambda est maintenant prête:)

Étape 5: configuration du flux de données AWS Kinesis Firehose

Configurer le flux de données AWS Kinesis Firehose
Configurer le flux de données AWS Kinesis Firehose
  1. Revenez maintenant à la page principale de la console AWS et dans Services, accédez à Kinesis
  2. Vous êtes maintenant dans la page principale de Kinesis. À droite de la page, sous « Flux de diffusion Kinesis Firehose », sélectionnez « Créer un nouveau flux de diffusion »
  3. Dans « Nom du flux de livraison », écrivez « road-monitoring-stream ». Laissez les autres champs par défaut et cliquez sur suivant
  4. Maintenant, sous « Transformer les enregistrements source avec AWS Lambda », sélectionnez Activé et, en tant que fonction Lambda, cliquez sur le nouveau « road-monitoring-lambda ». Ne vous inquiétez pas si un avertissement concernant le délai d'expiration de la fonction apparaît, car l'opération que nous effectuons n'est pas coûteuse en calcul. Laissez les autres champs par défaut et cliquez sur suivant
  5. En tant que destination, sélectionnez Amazon S3, et en tant que destination S3, sélectionnez Créer un nouveau. En tant que nom de compartiment, saisissez « road-monitoring-bucket », puis allez-y. Laissez maintenant les autres champs par défaut et cliquez sur Suivant
  6. Vous pouvez définir la taille du tampon sur 1 Mo et l'intervalle du tampon sur 60 secondes. Le tampon sera vidé vers S3 chaque fois que l'une des deux conditions est satisfaite. Ne quittez pas la page, voir étape suivante

Étape 6: Configurer le rôle IAM pour Kinesis

Configurer le rôle IAM pour Kinesis
Configurer le rôle IAM pour Kinesis

Nous configurons maintenant les autorisations de sécurité pour Kinesis, car il doit appeler la fonction Lambda pour le prétraitement, puis il écrira sur S3

  1. Au bas de la page où vous vous trouvez dans le « Rôle IAM », sélectionnez « Créer un nouveau ou choisissez », créez un nouveau rôle IAM comme sur l'image et cliquez sur Autoriser
  2. Vous êtes maintenant revenu à la page précédente, cliquez sur suivant. Maintenant, vous voudrez peut-être revérifier tous les paramètres. Lorsque vous avez terminé, cliquez sur « Créer un flux de diffusion »

Le pipeline Kinesis-Lambda-S3 est opérationnel !

Étape 7: configurer AWS EC2

Configurer AWS EC2
Configurer AWS EC2

Nous allons maintenant configurer une instance EC2 avec des API qui nous permettront de pousser et d'extraire des données du cloud AWS ainsi que du serveur sur lequel héberger notre interface d'application. Dans un environnement de production, vous souhaiterez peut-être publier l'API à l'aide de la passerelle d'API AWS plus évolutive.

  1. Depuis la page principale de la console AWS, accédez au service EC2
  2. Cliquez sur Lancer l'instance
  3. Dans la barre de recherche supérieure collez ce code: ‘ami-08935252a36e25f85’, c’est le code identifiant de la machine virtuelle préconfigurée à utiliser. Cliquez sur Sélectionner à droite
  4. Sélectionnez t2.micro dans la colonne « Type » et cliquez sur « Examiner et lancer ». Ne lancez pas encore l'instance, passez à l'étape suivante

Étape 8: Configurer le rôle de sécurité IAM pour EC2

Configurer le rôle de sécurité IAM pour EC2
Configurer le rôle de sécurité IAM pour EC2
  1. Avant de lancer nous voulons modifier le groupe de sécurité de notre instance. Pour ce faire, à l'extrême droite de la section « Groupes de sécurité », cliquez sur « Modifier les groupes de sécurité » Configurez un nouveau groupe de sécurité comme suit. Cela configure essentiellement le pare-feu de votre instance exposant le port 22 pour la connexion SSH et le port 80 pour les services
  2. Cliquez à nouveau sur « Examiner et lancer ». Vérifiez maintenant que tous les paramètres sont définis. Lorsque vous avez terminé, cliquez sur Lancer
  3. En cliquant, une nouvelle fenêtre apparaîtra pour configurer une paire de clés pour la connexion ssh à l'instance. Sélectionnez « Créer une nouvelle paire de clés » et comme nom, entrez « ec2-road-monitoring ». Cliquez sur Télécharger la paire de clés. Il est extrêmement important que ce fichier se perde ou (pire) soit stocké de manière non sécurisée: vous ne pourrez plus télécharger la clé. Une fois la clé.pem téléchargée, l'instance est prête à être lancée

Étape 9: accédez à votre instance EC2

Accédez à votre instance EC2
Accédez à votre instance EC2

Votre nouvelle instance EC2 est dans le cloud AWS. Vous pouvez vous y connecter avec le fichier de clé téléchargé précédemment (pour ce tutoriel, nous supposons que vous connaissez les bases de ssh). Vous pouvez récupérer l'IP de l'instance en la sélectionnant dans le tableau de bord dans la section "Description" comme suit: Vous pouvez utiliser à la fois votre IP publique ou votre DNS public c'est la même chose. Avec un client ssh, entrez maintenant la commande:

ssh -i ec2-road-monitoring.pem ec2-user@YOUR-IP-ADDR-OR-DNS

où ec2-road-monitoring.pem est votre clé générée auparavant.

Maintenant, passez à travers le code côté serveur

git clone --recursive

Étape 10: récupérer l'API Google Maps

Récupérer l'API Google Maps
Récupérer l'API Google Maps

Nous avons presque terminé. Nous devons maintenant configurer l'API google maps dans notre page html afin d'afficher la carte avec les waypoints à l'utilisateur:

  1. Connectez-vous à votre compte Google et accédez à
  2. Cliquez sur « Commencer » sur la gauche de la page
  3. Sélectionnez « Cartes » dans le menu, puis cliquez sur Continuer
  4. En tant que nom du projet, entrez « road-monitoring » et cliquez sur Suivant
  5. Saisissez vos informations de facturation et cliquez sur Continuer
  6. Maintenant, votre projet est prêt et nous allons obtenir la clé API en cliquant sur API & Services -> Credentials

Étape 11: Lancer le serveur

Serveur de lancement
Serveur de lancement

Et voilà votre clé API. La dernière chose que vous avez à faire est d'aller dans data_visualization/anomalies_map.html et de copier votre clé à la fin du fichier comme ceci, en remplaçant "VOTRE-CLE-ICI"

Maintenant, tout est prêt et prêt à partir ! Pour le faire démarrer s'exécuter dans l'instance EC2: 'cd data-server' 'python flask_app.py'

Entrez dans votre navigateur l'adresse ip ou DNS de votre instance EC2, vous devriez voir la carte des anomalies avec des données factices

Étape 12: Effectuez l'intégration HTTP sur le réseau des objets

Effectuer l'intégration HTTP sur le réseau des objets
Effectuer l'intégration HTTP sur le réseau des objets

Maintenant que toute l'infrastructure backend est opérationnelle, nous pouvons procéder à l'intégration

  1. Créez une nouvelle application et enregistrez votre appareil. Nous supposons une connaissance de base de TTN, sinon reportez-vous au guide de démarrage rapide
  2. Dans le menu de votre application, sélectionnez « Intégrations » puis « Ajouter une intégration »
  3. Sélectionnez l'intégration
  4. Renseignez les champs suivant l'image et remplacez par votre ip EC2 ou DNS public

Étape 13: Traitement des données

Pour chaque tuple de données T collecté à partir du capteur, vous devez effectuer les étapes suivantes:

  1. Obtenez l'ensemble de tuples dont les coordonnées GPS tombent dans la zone locale de T. La zone locale correspond à tous les tuples situés à 100 mètres autour de T.
  2. Pour chaque tuple N le plus proche, calculez la moyenne carrée de l'axe Z de l'accéléromètre en N. En pseudocode: moyenne = somme ([x. Z_accel ** 2 for x in near]) / near.size
  3. Calculer l'écart type au carré. En pseudocode: std = sum ([(x. Z_accel ** 2 - Mean) ** 2 pour x in near])
  4. Sortie dans ce format: lat, long, Z_accel **2, Mean, std

Pour calculer la zone locale, utilisez la distance GPS en mètres. En C++:

#définir D2R (M_PI / 180.0)

#define EARTH_RAY 6371 double distance(double lat1, double long1, double lat2, double long2) { double dlong = (long2 - long1) * D2R; double dlat = (lat2 - lat1) * D2R; double a = pow(sin(dlat/2.0), 2) + cos(lat1*D2R) * cos(lat2*D2R) * pow(sin(dlong/2.0), 2); double c = 2 * atan2(sqrt(a), sqrt(1-a));

Maintenant, en utilisant les données intermédiaires générées à l'étape précédente, détectez les anomalies et faites une classification naïve à l'aide de ce sniped appliqué à chaque ligne:

line = map(float, line.split(", "))

v = ligne[2] moyenne = ligne[3] std = ligne[4] if v (moyenne + std*3): if v (moyenne + std*2): si v (moyenne + std): o.append([1, ligne[0], ligne[1]) else: o.append([2, ligne[0], ligne[1]) else: o.append([3, ligne[0], ligne[1])

Les anomalies sont classées selon la règle 68-95-99.7

Vous avez maintenant une collection avec ce format [type, lat, long].

La signification du type est la suivante:

  1. Légère anomalie, probablement sans importance
  2. Anomalie moyenne
  3. Anomalie critique

Étape 14: Visualisation

Visualisation
Visualisation

Pour comprendre et peut-être changer la partie visualisation, nous devons apprendre à utiliser des marqueurs personnalisés, une fonctionnalité de l'API Google Maps

Tout d'abord, la carte doit être initialisée dans un callback:

function initMap() {

données = requêteDonnées(); map = new google.maps. Map(document.getElementById('map'), { zoom: 15, center: {lat: data[0][1], lng: data[0][2]} }); remarque(); }

Précisez le nom de ce callback dans l'url (nous avons inséré ici avant notre clé API) dans une balise HTML:

Un marqueur peut être inséré dans la carte lors de la création de l'objet:

nouveau google.maps. Marker({ position: {lat: LATITUDE, lng: LONGITUDE}, carte: carte, icône: "/chemin/vers/icon.png" })

Vous pouvez voir dans le code que pour chaque donnée du jeu de données des anomalies un marqueur est inséré (voir la fonction remark()) et l'icône est basée sur la classe de l'anomalie. Lors de l'exécution dans le navigateur, nous pouvons explorer une carte dans laquelle les anomalies peuvent être filtrées à l'aide de cases à cocher, comme le montre l'image.

Étape 15: Crédits et liens externes

Ce projet a été réalisé par Giovanni De Luca, Andrea Fioraldi et Pietro Spadaccino, étudiants en première année de MSc in Engineering in Computer Science à l'Université Sapienza de Rome.

  • Diapositives utilisées par les auteurs pour présenter cette preuve de concept:

    www.slideshare.net/PietroSpadaccino/road-m…

  • Repos GitHub avec tout le code:

    github.com/roadteam