IMA4 2018/2019 P35 : Différence entre versions
(→Semaine 6-7) |
(→Semaine 6-7) |
||
Ligne 233 : | Ligne 233 : | ||
==Semaine 6-7== | ==Semaine 6-7== | ||
Nous avons commencé la semaine avec un rendez-vous avec notre tuteur afin de faire un compte rendu du simulateur de robotino. On lancer logiciel Rviz et utilise la mannette pour piloter notre robot.La vitesse et la vitesse angulaire à cet instant sont enregistrées automatiquementtoutes toutes les 0,01 secondes. Chaque fois on pilote le robot jusqu'à la destination, la prochaine destination apparaîtra au hasard sur la carte et ensuit on ferme l'acquisition, et toutes les données sur cet itinéraire seront automatiquement enregistrées sous forme de texte, Il faut faire attention que les données de la prochaine destination seront enregistrées aussi à ce moment-là, n'oubliez pas de supprimer. Parce que nous utilisons la mannette pour collecter manuellement des données, nous ne pouvons que contrôler le robot suive l'itinéraire optimal approximatif. Si parfois l'itinéraire que nous empruntons et que les meilleurs itinéraires sont éloignés, nous devons supprimer cette itinéraire inutiles. | Nous avons commencé la semaine avec un rendez-vous avec notre tuteur afin de faire un compte rendu du simulateur de robotino. On lancer logiciel Rviz et utilise la mannette pour piloter notre robot.La vitesse et la vitesse angulaire à cet instant sont enregistrées automatiquementtoutes toutes les 0,01 secondes. Chaque fois on pilote le robot jusqu'à la destination, la prochaine destination apparaîtra au hasard sur la carte et ensuit on ferme l'acquisition, et toutes les données sur cet itinéraire seront automatiquement enregistrées sous forme de texte, Il faut faire attention que les données de la prochaine destination seront enregistrées aussi à ce moment-là, n'oubliez pas de supprimer. Parce que nous utilisons la mannette pour collecter manuellement des données, nous ne pouvons que contrôler le robot suive l'itinéraire optimal approximatif. Si parfois l'itinéraire que nous empruntons et que les meilleurs itinéraires sont éloignés, nous devons supprimer cette itinéraire inutiles. | ||
+ | |||
+ | |||
[[Fichier:6terminaux.jpg]] | [[Fichier:6terminaux.jpg]] | ||
+ | |||
+ | Pour réaliser toutes les fonctions, il faut lancer 6 terminaux (droite à gauche). | ||
+ | *Le premier et le deuxième terminal sont d'ouvrir refbox. Les commandes suivantes: | ||
+ | dans le 1er terminal: | ||
+ | cd refbox/rcll-refbox/ | ||
+ | bin/llsf-refbox | ||
+ | dans le 2ème terminal: | ||
+ | cd refbox/rcll-refbox/ | ||
+ | bin/llsf-refbox | ||
+ | |||
+ | *Le troisième terminal est d'ouvrir l'environnement de simulateur et lancer le fichier de simulateur. Le | ||
=Documents Rendus= | =Documents Rendus= |
Version du 7 mars 2019 à 11:38
Sommaire
Présentation générale
Nom du projet : Machine Learning pour navigation autonome de robots mobiles
Résumé : Le but du projet est d'améliorer l'algorithme pour réaliser un robot mobile autonome
Etudiants : Wenjing CHEN et Puyuan LIN
Description
Cette année, nous avons choisi le sujet, Machine Learning pour navigation autonome de robots mobiles pour notre projet de filière IMA (Informatique Microélectronique et Automatique) de l'école Polytech Lille. Ce projet s'inspire du concours Robo Cup qu'il faudra mettre en place un système autonome de production à l'aide de Robotinos (robots mobiles de Festo ayant un système d'exploitation Linux). Robotino est basé sur un ensemble d'entraînement omnidirectionnel, qui permet au système de se déplacer librement. Le robot est contrôlé par un système PC standard, suffisamment modéré pour permettre de planifier des itinéraires pour une conduite totalement autonome. Via un lien WLAN, Robotino peut envoyer toutes les lectures du capteur sur un PC externe dans l’autre sens, les commandes de contrôle peuvent être émises par le PC externe, ce qui permet aux programmes de contrôle de s’exécuter directement sur le PC externe ou directement sur Robotino. Un mode mixte ou un contrôle partagé sont également possibles. Robotino peut être facilement programmé dans son environnement de programmation «RobotinoView 2» . Les programmeurs plus expérimentés trouveront peut-être utile que le robot puisse également être programmé en C, C ++, Java, .NET, Matlab, Simulink. , Labview et Microsoft Robotics Developer Studio.
L'apprentissage automatique (en anglais machine learning ) est un champ d'étude de l'intelligence artificielle qui se fonde sur des approches statistiques pour donner aux ordinateurs la capacité d' « apprendre » à partir de données, c'est-à-dire d'améliorer leurs performances à résoudre des tâches sans être explicitement programmés pour chacune. Plus largement, cela concerne la conception, l'analyse, le développement et l'implémentation de telles méthodes. Dans notre projet, machine learning est appliqué au robot prenant les données du capteur comme les entrées et donnant les comportements d'action du robot dans la situation correspondante comme les sorties. Nous fournissons au robot un ensemble de données d'entrée / sortie des . Le robot apprend l'ensemble d'entrée/sortie pour obtenir un modèle du calcul lui-même. Donc le robot peut utiliser ce modèle pour permettre la navigation autonome.
Nous traiterons dans ce projet de l'aspect navigation autonome de robot, notre tâche principale est de proposer un algorithme de machine learning pour réaliser le fonctionnement de robotino, ce qui signifie que le robot peut trouver l'itinéraire optimale, suivre cette itinéraire et détecter des obstacles lui-même.
Objectifs
Dans le but de réaliser notre projet nous devrons remplir les objectifs suivants:
- Nous devons apprendre et utiliser python pour améliorer l'algorithme d'origine afin de réaliser la fonction de machine learning, afin que le robot puisse trouver le meilleur itinéraire et avancer par lui-même.
- Nous devons apprendre et utiliser TensorFlow pour apprendre le machine learning.
- Nous devons apprendre et utiliser Intel Neural Compute Stick pour calculer nos base de donnée.
Analyse du projet
Positionnement par rapport à l'existant
Il existe actuellement une grande tendance de robots mobiles de navigation autonome, dont certaines utilisent la carte intégrée pour atteindre la destination, tandis que d’autres obtiennent le chemin en avant via le code à barres attaché au sol. Mais pour éviter les obstacles, il s’agit essentiellement de capteurs pour surveiller les obstacles environnants.
Analyse du premier concurrent
Aethon Inc,un fournisseur mondial de robots de transport mobiles autonomes, a été fondé en 2001.Sa technologie principale comprend les robots mobiles automatiques(TUG). Le TUG est un robot mobile autonome et intelligent doté de devenir une phénomène normale dans les hôpitaux car il délivre matériaux et fournitures. TUG livre efficacement des chariots de fournitures là où ils sont nécessaires, y compris les repas, linge de maison, ainsi que l'enlèvement des ordures.Contrairement aux autres robots de navigation autonomes, il utilise des cartes intégrées et une gamme de capteurs embarqués pour la navigation. Les développeurs utilisent des cartes de haute précision des installations hospitalières, puis programment leur agencement, y compris l’utilisation des ascenseurs, l’ouverture automatique des portes, les points de livraison et les stations de recharge. La carte programmée est chargée dans la mémoire du TUG. TUG utilise des cartes embarquées à des fins de guidage et calcule sa position en temps réel à l'aide de l'algorithme d'odométrie breveté d'Aethon. Il utilise des capteurs embarqués pour ajuster les corridors dynamiques et changeants en temps réel, naviguant en toute sécurité autour des personnes et des obstacles, tout en utilisant toujours sa carte intégrée pour le suivi.
Analyse du second concurrent
Amazon Robotics, anciennement Kiva Systems, est une entreprise du Massachusetts qui fabrique des systèmes d'exécution robotiques mobiles. Traditionnellement, les marchandises sont déplacées autour d’un centre de distribution à l’aide d’un système de convoyage ou de machines actionnées par l’homme (comme des chariots élévateurs). Dans l’approche de Kiva, les articles sont stockés sur des unités de stockage portables. Lorsqu'une commande est validée dans le système de base de données Kiva, le logiciel localise le robot mobile le plus proche de l'article et lui ordonne de le récupérer. Les robots mobiles naviguent dans l’entrepôt en suivant une série d’autocollants de codes à barres informatisés posés au sol. Chaque unité d’entraînement est équipée d’un capteur qui l’empêche de se heurter aux autres. Lorsque l'unité d’entraînement arrive à l'endroit objectif, elle glisse sous la nacelle et la soulève du sol grâce à un tire-bouchon. Le robot transporte ensuite la nacelle vers l'opérateur pour prendre les articles.Kiva a deux modèles de robots. Le plus petit modèle mesure environ 2 pieds sur 2,5 pieds et un pied de haut et peut soulever 1 000 livres. Le plus grand modèle peut transporter des palettes et des charges pesant jusqu'à 3 000 livres. La vitesse maximale d'un robot est de 1,3 mètre par seconde. Les robots mobiles sont alimentés par batterie et doivent être rechargés toutes les heures pendant cinq minutes.
https://www.amazonrobotics.com/
Scénario d'usage du produit ou du concept envisagé
- Nos produits sont adaptés à les entreprise logistiques ou les entreprises de commerce électronique. Le robot peut traiter lui-même la commande afin de terminer la livraison des marchandises, en réduisant les coûts de main-d'œuvre et en améliorant l'efficacité.
- Nos produits conviennent également à la gestion des entrepôts de l'entreprise.
- La perspective de cette voiture intelligente peut également être utilisée dans les futures voitures intelligentes. Nous pouvons planifier le point de départ et la destination de la voiture, puis la voiture fonctionne de manière autonome pour éviter les obstacles et atteindre la fin.
Réponse à la question difficile
Est-ce qu'on commence à zéro ou utilise des bibliothèque?
Nous n'avons pas besoin d'écrire le programme entier à partir de zéro. Parce que ce sujet est assez grand, il peut se diviser en plusieurs parties, par exemple la partie de création de la carte d'endroit, la partie de connaissance des obstacles statiques, la partie de détections des gens et des robots, la partie de navigation, etc. C'est difficile pour nous de réaliser tous pour le temps limité. Tout ce que nous devons faire est de réaliser un algorithme de machine learning pour réaliser un seul but, la navigation autonome. Pour les restes, nous pouvons utiliser les code précédent pour apporter des améliorations en fonction de cela.
Est-ce que la mémoire de robot est assez suiffissant pour stocker le base de donnée de machine learning?
La taille de la mémoire de robot n'arrive pas à réaliser nombreux de calcul, nous devons utiliser intel neural compute stick pour calculer et stocker des données.
Préparation du projet
Cahier des charges
Le robot mobile autonome devra réaliser:
- Générer une trajectoire automatiquement selon le point de départ et la destination par lui-même.
Phase d'apprentissage
- Prise de connaissance de machine learning et familiarisation avec l'environnement Tensorflow.
- Prise de connaissance de langage de programmation (Python).
- Prise de connaissance de Intel Neural Compute Stick.
- Prise de connaissance du principe d'algorithme dans le domaine de machine learning.
Techniques Logicielles
- Utilisation de Tensorflow.
- Utilisation de Python.
- Utilisation de Intel Neural Compute Stick.
Liste des tâches à effectuer
- Conception du schéma global des différentes parties :
- Apprentissage des logicielles (programmable, robotique)
- Génération de trajectoires avec un algorithme
- Exécution de trajectoire
- Validation du modèle
Calendrier prévisionnel
Réalisation du Projet
Feuille d'heures
Tâche | Prélude | Heures S1 | Heures S2 | Heures S3 | Heures S4 | Heures S5 + vacance | Heures S6 | Heures S7 | Heures S8 | Heures S9 | Heures S10 | Total |
---|---|---|---|---|---|---|---|---|---|---|---|---|
Analyse du projet | 4 | 4 | 2 | 2 | 1 | 0 | ||||||
Analyse de la structure de donnée d'entrée et sortie | 0 | 0 | 3 | 2 | 1 | 1 | ||||||
Installation du Tensorflow et Python | 0 | 0 | 0 | 0 | 3 | 0 | ||||||
Analyse de la modèle du reseau de neurone | 0 | 0 | 0 | 5 | 0 | 5 | ||||||
Programmation de Tensorflow | 0 | 0 | 0 | 0 | 0 | 4.5 | ||||||
Rédaction du wiki | 3 | 1 | 0.5 | 0.5 | 0.5 | 1 | ||||||
Total de la semaine (heure) | 8 | 5 | 5.5 | 9.5 | 5.5 | 11.5 |
Prologue
Semaine 1
Cette semaine nous avons commencé nos recherches sur machine learning et avons essayé de comprendre le principe de la palteforme «Tensorflow». Nous avons determiné nos prochaines étapes:
- 1.Exploration de données: Connaître la format des données d'entrées et sorties.
- 2.Préparation de données: Transformer des données en format standard(Tous les tableaux entiers sont en même taille.)
- 3.Construire une modèle.
- 4.Former la modèle: Utiliser des échantillons pour la formation.
- 5.Evaluer la modèle: Calculer taux de précision en utilisant l'ensemble du test
Semaine 2
Avec l'aide de Monsieur Vincent Coelen, nous avons déterminé comment collecter des données pour entraîner la modèles de machine learning. On veut utiliser la simulation qu'il fournit la carte virtuelle dont nous avons besoin et le robotino peut s'y déplacer pour simuler l'itinéraire de navigation. Nous utilisons la manette externe pour contrôler le mouvement du robotino. On utilise cette méthode pour collecter des données. Après avoir les données, il faut utiliser l'autre logicielle pour les stocker.
Semaine 3
Cette semaine, nous avons analysé de la structure de la donnée qu'on nous devons collecte. Nous avons décidé de collecter la vitesse de l'abscisse, la vitesse de l'ordonnée et la vitesse angulaire de chaque point sur une trajectoire, afin de pouvoir relier tous les points en une trajectoire entier. En même temps, il faut noter les coordonnées du point de départ et la destination.
Semaine 4
- Initiation au Deep learning. Suivre le lien [1] pour avoir accès à des cours et des travaux pratiques centrés sur l'apprentissage approfondi.
- Pour installer Anaconda : [2]
- Pour installer PyTorch : [3]
- Pour installer Tensorflow : [4]
Semaine 5
Nous avons décidé notre méthode pour construire notre modèle de machine learning avec l'aide de Monsieur Vincent Coelen.
- Nous utilison le simulateur et la manntte pour collecter toutes les données dont nous avons besion. Ils se composent des points de départ, des points de destination et de tous les points de vitesse chaque 0,1 seconde (la frèquence du simulateur = 10Hz). Parce qu'on pilote le robot jusqu'à la destination munuellement, nous devons donc le contrôler artificiellement pour choisir la trajectoire optimale et supprimer les chemins qui sont loin du meilleur.
- Après dans la phase d'entraînement, nous donnons toutes de trajectoires qu'on a collecté au reseau de neurones. Grâce à ce processus d'entraînement, le robot peut mémoriser la carte et l'emplacement des obstacles. Si plus de données sont formées, plus la carte en mémoire est précise, nous avons décidé de collecter au moins 100 jeux de données.Ensuite, après la modèle est finie, il faut évaluer la fidélité de la modèle. On a décidé d'utiliser l'algorithme du gradient pour augmenter la fidélité petit-à-petit.
- Enfin, dans la phase d'utilisation, on fournit le point de départ et la destination comme les entrées, et par ailleurs, on aussi donne les premiers 10 points de vitesse pour arriver à la destination comme les entrées. Donc le réseau peut utiliser ces conditions et calculer pour continuer à deplacer pas-à-pas (1 point) jusqu'à la destination. Bien sûr, si nous plus de points comme l'entrée, la précision sera meilleure. Nous avons temporairement fixer à 10 points. Le robot va sûrement s'arrêter pour calculer le point suivant. Mais le temps est très court. Donc on pense qu'on peut le négliger.
Semaine 6-7
Nous avons commencé la semaine avec un rendez-vous avec notre tuteur afin de faire un compte rendu du simulateur de robotino. On lancer logiciel Rviz et utilise la mannette pour piloter notre robot.La vitesse et la vitesse angulaire à cet instant sont enregistrées automatiquementtoutes toutes les 0,01 secondes. Chaque fois on pilote le robot jusqu'à la destination, la prochaine destination apparaîtra au hasard sur la carte et ensuit on ferme l'acquisition, et toutes les données sur cet itinéraire seront automatiquement enregistrées sous forme de texte, Il faut faire attention que les données de la prochaine destination seront enregistrées aussi à ce moment-là, n'oubliez pas de supprimer. Parce que nous utilisons la mannette pour collecter manuellement des données, nous ne pouvons que contrôler le robot suive l'itinéraire optimal approximatif. Si parfois l'itinéraire que nous empruntons et que les meilleurs itinéraires sont éloignés, nous devons supprimer cette itinéraire inutiles.
Pour réaliser toutes les fonctions, il faut lancer 6 terminaux (droite à gauche).
- Le premier et le deuxième terminal sont d'ouvrir refbox. Les commandes suivantes:
dans le 1er terminal: cd refbox/rcll-refbox/ bin/llsf-refbox dans le 2ème terminal: cd refbox/rcll-refbox/ bin/llsf-refbox
- Le troisième terminal est d'ouvrir l'environnement de simulateur et lancer le fichier de simulateur. Le