IMA5 2018/2019 P30 : Différence entre versions
(→Semaine 6 du 11/02) |
|||
Ligne 275 : | Ligne 275 : | ||
Faire l'échange entre serveur et Arduino, possiblement en passant par un programme en C, ou en établissant une communication directe entre le port série et le Js du serveur. Après réflexion et tests, nous avons décidé d'établir une liaison directe entre le serveur et l'Arduino, sans passer par un langage intermédiaire. En effet, passer par un programme C ralenti le processus en ajoutant un intermédiaire inutile, et malgré des tests concluants de communications entre le programme en C et l'Arduino, faire un programme en Js n'a pas été difficile, et simplifie considérablement nos échanges. | Faire l'échange entre serveur et Arduino, possiblement en passant par un programme en C, ou en établissant une communication directe entre le port série et le Js du serveur. Après réflexion et tests, nous avons décidé d'établir une liaison directe entre le serveur et l'Arduino, sans passer par un langage intermédiaire. En effet, passer par un programme C ralenti le processus en ajoutant un intermédiaire inutile, et malgré des tests concluants de communications entre le programme en C et l'Arduino, faire un programme en Js n'a pas été difficile, et simplifie considérablement nos échanges. | ||
− | Au niveau du site web, nous avons modifié les fichiers du Joystick pour qu'il envoie les | + | Au niveau du site web, nous avons modifié les fichiers du Joystick pour qu'il envoie des valeurs comprises entre -500 et 500, valeurs ensuite envoyées au serveur en communication http par le client. Puis nous récupérons ces données et nous les envoyons en série à l'Arduino en respectant le format de la trame demandée à savoir : 'X' suivi de '+' ou '-' puis la valeur de x sur 3 chiffres (ex: 000 ou 089) puis 'Y' suivi de '+' ou '-' et sa valeur sur trois chiffres également. Un exemple de message correct serait 'X+450Y+000'. |
− | En fin de semaine, nous avons enfin obtenu le résultat désiré, en utilisant le joystick du site web, hébergé par un ordinateur connecté à l'Arduino, pour contrôler les roues du robot. Tout le process est donc techniquement fonctionnel | + | En fin de semaine, nous avons enfin obtenu le résultat désiré, en utilisant le joystick du site web, hébergé par un ordinateur connecté à l'Arduino, pour contrôler les roues du robot. Tout le process de communication est donc techniquement fonctionnel. Pour ce test, le robot était contrôlé par un autre ordinateur, connecté sur le même wifi que l'ordinateur du robot. Il reste cependant à corriger des défauts dans le joystick, qui n'envoie pas toujours les valeurs correspondant à celles voulues (il glitch et se déplace très rapidement vers le centre quand on approche des bords du Joystick). |
+ | |||
+ | '''*** ViDEO ***''' | ||
La Kinect, l'ordinateur et l'écran seront alimentés grâce au 12V sortant du convertisseur 24/12V. Les capteurs seront alimentés et commandés par l'Arduino. Il s'avère que le convertisseur 24->12V ne sort pas du 12 mais du 13.6V. C'est correct pour alimenter l'écran, mais pas la kinect ou l'ordinateur. Un pont diviseur consommerais trop de courant et on n'aurait plus assez de puissance pour alimenter les appareils. Un autre convertisseur à été trouvé, cette fois-ci allant bien de 24 vers 12V, et qui peut sortir au maximum 360W. C'est plus que suffisant pour notre application, qui nécessite seulement 90W pour l'ordinateur, 13W pour la Kinect, et 42W pour l'écran, pour un total de 145Watts demandés. Cependant, ce convertisseur présente un autre défaut majeur, il aurait tendance à chauffer jusqu'aux 150 degrés, ce qui est inacceptable pour notre robot. Un autre convertisseur à été commandé, et sera testé après la semaine d'interruption pédagogique. Avant de se rendre compte que le précédent convertisseur ne donnait pas les 12V demandés, le test a fait chauffer l'alimentation de la Kinect. Il faudra donc déterminer grâce à la nouvelle alimentation si celle de la Kinect à grillé ou non. | La Kinect, l'ordinateur et l'écran seront alimentés grâce au 12V sortant du convertisseur 24/12V. Les capteurs seront alimentés et commandés par l'Arduino. Il s'avère que le convertisseur 24->12V ne sort pas du 12 mais du 13.6V. C'est correct pour alimenter l'écran, mais pas la kinect ou l'ordinateur. Un pont diviseur consommerais trop de courant et on n'aurait plus assez de puissance pour alimenter les appareils. Un autre convertisseur à été trouvé, cette fois-ci allant bien de 24 vers 12V, et qui peut sortir au maximum 360W. C'est plus que suffisant pour notre application, qui nécessite seulement 90W pour l'ordinateur, 13W pour la Kinect, et 42W pour l'écran, pour un total de 145Watts demandés. Cependant, ce convertisseur présente un autre défaut majeur, il aurait tendance à chauffer jusqu'aux 150 degrés, ce qui est inacceptable pour notre robot. Un autre convertisseur à été commandé, et sera testé après la semaine d'interruption pédagogique. Avant de se rendre compte que le précédent convertisseur ne donnait pas les 12V demandés, le test a fait chauffer l'alimentation de la Kinect. Il faudra donc déterminer grâce à la nouvelle alimentation si celle de la Kinect à grillé ou non. | ||
− | + | Au cours de la semaine, nous avons également préparé une clé bootable avec la distribution Debian Stretch de Linux dessus pour l'installer sur l'ordinateur intégré au robot. Nous l'avons donc branché à l'ordinateur et nous avons constaté que linux était déjà installé dessus et qu'un utilisateur centaure existait déjà. | |
− | |||
− | |||
− | |||
− | |||
− | linux | ||
==Fin (interruption pédagogique)== | ==Fin (interruption pédagogique)== |
Version du 25 février 2019 à 10:51
Sommaire
Présentation générale
Description
Encadrants : Xavier Redon / Alexandre Boé / Thomas Vantroys
Objectif : Contrôler un robot de grande taille à partir d'une tablette.
Description : Un robot de grande taille a été réalisé à partir de moteurs de fauteuil roulant.
Le système de contrôle électrique a été détruit lors d'un précédent projet, il est à reprendre totalement.
Le système de commande à base d'Arduino commandant des contrôleurs de moteurs de puissance doit être revu lui aussi.
Il faut ensuite s'assurer d'un dispositif d'arrêt d'urgence en cas d'obstacle proche. Pour la détection d'obstacles vous pouvez vous appuyer sur des détecteurs infrarouges et sur une Kinect.
Enfin le PC embarqué doit être configuré pour se connecter sur les points d'accès WiFi de l'école et comporter un site Web permettant ainsi de le contrôler à distance avec les images des Webcam comme retour.
Pour un déplacement dans tous les bâtiments de l'école, prévoir un dispositif pour appuyer sur les boutons des ascenseurs.
Objectifs
- Faire à nouveau rouler le robot, rendre son câblage compréhensible et clair.
- Connecter le robot en wifi grâce à l'ordinateur qui y sera intégré, et réaliser un site web permettant d'accéder au robot.
- Vérifier les capteurs et s'en servir pour contrôler le robot à distance, le faire se déplacer dans Polytech, et le faire prendre les ascenseurs.
Préparation du projet
Cahier des charges
Choix techniques : matériel et logiciel
Nous utilisons un robot pré existant, et en grande partie du matériel pré existant. Pour la fixation des cartes dans le robot, nous allons acheter nous mêmes la visserie spécifique dont nous avons besoin si elle n'est pas à notre disposition. L'ordinateur a intégrer au robot, la webcam, l'écran, les régulateurs de moteur, l’Arduino méga, et les batteries sont déjà fournis.
Liste des tâches à effectuer
- Faire rouler à nouveau le robot
- Faire du ménage dans les câblages et tout faire tenir à l'intérieur pour que le robot soit mobile (joystick)
- Installer l'ordinateur et connecter le robot au wifi
- Réaliser un site web permettant de contrôler le robot
- Lire le retour de la webcam et des infrarouges pour le contrôle à distance
- Faire rouler le robot en utilisant le site web et le wifi
- Prendre les ascenseurs?
Calendrier prévisionnel
Contacter Nicolas Havard (Semaine 1)
Lire la documentation pertinente (Semaine 1)
Refaire les câblages, faire du rangement dans le robot (Semaine 1)
Comprendre le fonctionnement des régulateurs de vitesse et du robot (Semaine 1)
Etape 1: Contrôler le robot à l’aide de la manette (Semaine 1)
Y intégrer un ordinateur pour contrôler le robot de cette façon (via le port série) (Semaine 2)
Faire le site internet de contrôle du robot (Semaine 3/4)
Connecter le robot en wifi (Semaine 3/4)
Etape 2: Contrôler le robot à l’aide du site en wifi (Semaine 3/4)
Gérer la webcam (Semaine 5)
Tester les capteurs (Semaine 5)
Etape 3: Contrôler le robot à l’aide du wifi et des capteurs à distance (Semaine 5)
Wiki (Toutes les semaines) (Semaines 1-8)
Si on en a le temps: utilisation des ascenseurs.
Réalisation du Projet
Semaine 1 du 07/01
Nos objectifs pour la semaine sont de démonter, nettoyer, et remonter correctement le robot, afin que le câblage soit lisible et que tout puisse y rentrer. Nous allons également le tester afin de s'assurer qu'il roule sans soucis et que le contrôle au joystick soit fonctionnel. Si possible, nous désirons également corriger le système d'arrêt d'urgence et de démarrage pour qu'ils soient accessibles à la fois de façon logicielles et physiques, en parallèle. De cette façon, lorsque l'on passera à l'étape du wifi, nous pourrons contrôler le robot entièrement à distance. Il est très important que tout fonctionne sans soucis, nous comptons ensuite nous baser sur le contrôle au joystick pour créer le contrôle via l'ordinateur. Si l'on réussi à disposer d'un robot fonctionnel, et de bons plans pour y intégrer l'ordinateur et la wifi rapidement à la semaine 2, ce sera un bon début de projet.
Jour 1: Prendre connaissance de l'état du robot, et des choses à faire avant de pouvoir réellement commencer le projet. Création du wiki. Lecture de la documentation pré existante. Création d'un plan du robot et mesure de toutes ses dimensions importantes.
Jour 2: Réaliser un schéma des branchements actuels puis tout débrancher pour réorganiser le robot. Retirer les plaques de soutien actuelles, réduire la taille des borniers, trouver un moyen élégant et efficace de soutenir les différents éléments composant le robot. Comprendre le PCB présentement réalisé pour pouvoir le reproduire de façon potentiellement plus efficace, peut être avec un shield supplémentaire sur l'Arduino Méga.
Jour 3-5: Réaliser le PCB et le système de compartimentation du robot afin d'essayer de la refaire fonctionner pour la fin de la semaine 1 ou le début de la semaine 2, et pouvoir ensuite s'attaquer au projet en lui-même.
Schéma du PCB actuel
Le PCB actuel rempli un objectif principal, qui est de diminuer le nombre de câbles présents à l'intérieur du robot, et rendre le tout plus lisible et agréable à regarder. Pour cela, il fait le lien entre les régulateurs de vitesse, le joystick, les relais, l'Arduino Mega et les batteries.
En un premier temps, le joystick doit pouvoir transmettre des informations à l'Arduino pour la commande en vitesse. Un câble 'ethernet' RJ12, et le port associé, permettent de connecter l'Arduino au PCB, et 6 pins relient le PCB à l'Arduino pour cette fonction.
L'Arduino, en suivant ces informations, va commander les relais, qui influent sur les entrées des régulateurs. Le PCB présente donc des pins pour l'Arduino, pour y connecter les relais, et ensuite des pins pour les relais, pour y connecter les régulateurs.
L'intérêt de chaque pin a été intégré au PCb sur le silkscreen, afin de pouvoir s'en servir facilement et sans devoir toujours en réfèrer à la documentation.
Deux versions ont été réalisées, l'une un PCB standard, et l'autre un PCB destiné à être un shield qu'on puisse fixer sur le sensor shield déjà présent, pour encore réduire le câblage, et simplifier le tout.
On pourra conserver ce PCB à l'avenir car l'objectif est ensuite de simplement remplacer le joystick pour l'ordinateur, qui viendra se brancher sur la même prise RJ11 et enverra les mêmes informations que le joystick. Nous créons donc un système utilisable avec n'importe quel port RJ11 envoyant des informations correctes.
Plans pour le maintien des composants au sein du robot
Avant de pouvoir faire rouler le robot et le tester dans Polytech, nous devons fixer tous les composants présents dans le corps du robot. Pour ce faire, nous devons dessiner :
- 1 étage en bas pour maintenir les batteries
- 2 piliers pour fixer le bornier présent en bas et le relais
- 1 étage en haut qui va supporter toute la partie électronique (et ses pieds pour le maintenir élevé)
- 2 supports pour fixer les régulateurs de vitesse
- 1 tour qui contiendra PCB, Arduino Méga, Relais et l'ordinateur
Nous avons pris les mesures du robot comme faire se pouvait et avons dessiné un premier jet que voici :
Après l'avoir installé dans le robot, nous avons remarqué quelques modifications à faire :
- Les pieds de l'étage supérieur sont inutiles puisqu'il est déjà soutenu par les piliers fixant le bornier et le relais, nous pouvons donc les enlever
- Les trous faits pour laisser les bouchons des batteries passer sont eux aussi inutiles puisque nous avons acheter des colliers plats pour remplacer les bouchons et gagner de la place
- Nous enlevons également la barre entre les deux batteries sinon nous ne pouvons pas mettre les batteries
- Enfin nous ajustons la taille des étages et de la hauteur des piliers pour qu'ils soient adaptés au robot
Ce qui nous amène donc au deuxième jet :
Pour celui-ci, nous avons aussi voulu essayer de mettre l'emplacement de la future boîte qui contiendra le PC et l'arduino à droite afin de voir quel endroit lui convient le mieux.
Cette fois-ci, les étages sont légèrement trop long, donc en nous basant sur les deux essais précédents, nous allons pouvoir trouver une juste valeur pour la version finale. Il en va de même pour la longueur des encoches que nous avions agrandit.
Grâce aux deux versions précédentes, nous avons pu dessiner une troisième version qui sera aussi la version finale découpée en Plexi.
Celle-ci sera terminée et découpée la semaine prochaine.
Semaine 2 du 14/01
Nouveau PCB
Changement de design du PCB, on passe d'un shield a mettre sur le shield actuel, à un shield qui remplacerais le shield actuel et remplirais donc toutes les fonctionnalités demandées d'un coup. Ce shield sera posé directement sur l'Arduino Mega, nous allons utiliser directement les pins dont nous avons besoin et les autres seront toujours accessibles, grâce à des connecteurs femelle similaires à ceux présents sur l'Arduino Mega de base. De par sa fonction, ce shield doit être très bien documenté afin qu'il soit facilement compréhensible et utilisable.
Ce shield disposera d'une led pour le debug, de pins pour les deux régulateurs, les relais, ainsi que les DAC. Une prise RJ11 sera présente pour le joystick tant qu'on en aura besoin. Nous allons également inclure 18 pins à 5V et 18 pins au Gnd sur le PCB afin de pouvoir utiliser autant de capteurs que l'on désire. Les quelques résistances nécesaires aux branchements sont également inclues sur ce montage.
Jusq'aù mardi de la deuxième semaine, le deuxième PCB est en cours de design. Il est ensuite envoyé à Monsieur Boé pour approbation. Une fois que ces premières étapes de PCB et rangement dans le robot sont terminées, un plan est réalisé pour les semaines restantes, afin de savoir quoi faire de jour en jour.
Cependant, les PCB réalisés à Polytech ne peuvent pas être vraiment fait en double couche, du fait de l'impossibilité de réaliser des vias métalliques. De plus, les câbles étaient initialement trop fins. Il a donc fallut réaliser un nouveau routage du PCB en simple couche. J'ai néamoins pu optimiser le routage, ce qui fait que l'on n'aura besoin que de deux jumpers pour finaliser le routage. Les gravures ont également été diminuées afin de simplifier le travail à la découpe.
Design des pièces de maintien
Cette semaine, nous avons terminé le design des étages du haut et du bas qui serviront à créer des compartiments au sein du robot.
Grâce aux deux versions tests dessinées et découpées la semaine dernière, nous avons pu élaborer une troisième et dernière version. Pour celle-ci, nous avons ajuster la longueur des étages, nous avons ajouté des encoches pour les derniers éléments qui n'avaient pas encore de place attitrée. De plus, nous avons ajouté les trous de vis dans les piliers pour aider à fixer les éléments.
Nous avons pris le soin de faire les découpes et de tester le résultat au fur et à mesure pour éviter tout problème et gâchis de matériau. Nous avons donc découpé les deux étages. Malheureusement, la découpeuse est devenue HS alors que nous devions découper les piliers ce qui retardera le processus. En attendant, nous allons réaliser le premier jet de design de notre site internet pour la commande à distance du robot.
Après seulement deux jours, la découpeuse était à nouveau opérationnelle, nous avons donc repris le cours normal de notre projet. Nous avons donc découpé les piliers qui vont servir à maintenir l'étage du haut à une certaine hauteur de l'étage du bas et sur lesquels seront vissés certaines pièces du robot.
Une fois ces pièces prêtes, nous avons entamé de remonter le robot. Cette partie a pris plus de temps que prévu puisque les câbles sont assez rigides et il est compliqué de leur donner la forme que l'on souhaite. De plus, comme nous avons changer la place des différents éléments du robot, la longueur des câbles n'est plus forcément adapté et nous avons du les ajuster ce qui s'est révélé assez long.
Entre temps, nous avons commencé le design des boîtes qui serviront à garder en place l'électronique de l'étage supérieur et nous les testerons la semaine prochaine. Nous finirons également de monter le robot la semaine prochaine.
Test des capteurs
Les valeurs renvoyées par les capteurs ne correspondent pas vraiment aux valeurs indiquées sur la datasheet. Cependant, il semblerait qu'il puisse détecter des objets plus proches et moins loin que prévus, ce qui correspond mieux à nos besoins.
Insérer graphique, tableau, référence
Semaine 3 du 21/01
Convertisseur
La première chose à faire à été de faire sertir les câbles qui seraient utilisés pour le convertisseur 24->12V. Ces câbles devaient être présents pour la finition de l'étage du bas du robot. Il n'est possible de sertir que des câbles souples, il n'a donc pas été possible d'utiliser des câbles rigides utilisés dans le reste du robot.
Programmation
Ensuite un premier test de la Kinect a été réalisé, afin de vérifier la simplicité d'utilisation de celle-ci. Pour notre application actuelle, à savoir simplement afficher le retour vidéo sur un écran, il est très simple d'installer les bibliothèques requises sont linux et d'afficher la vidéo sur notre écran. Il sera ensuite simplement question d'ouvrir ce flux vidéo en le redirigeant vers le serveur plutôt que vers un écran directement.
Le programme Arduino sera d'abord repris du projet de Nicolas Havard, de l'année précédente. Le contrôle des moteurs par l'Arduino sera un peu amélioré afin que la transition de marche avant à marche arrière se face sans problèmes. En effet, jusque là lors d'un passage de marche avant à marche arrière, le robot ne passait pas forcément par l'état arrêt, et cet état est nécessaire pour empêcher les régulateurs de se bloquer. Ça à donc été ajouté au programme. Il a ensuite fallut ajouter la lecture des senseurs du robot et envoyer le résultat de cette lecture sur le port série.
Ensuite, la dernière partie du programme concernant l'Arduino consiste à envoyer des informations sur le port série, puis à lire la réponse de l'ordinateur, qui à terme va remplacer le joystick pour la transmission d'ordres au robot. Il s'agit donc d'écrire un programme en C qui puisse utiliser le port série en lecture/écriture. Ceci est fait sans trop de problèmes, on a maintenant un programme Arduino capable de transmettre l'état des capteurs à l'ordinateur et de lire l'état du joystick virtuel donné par l'ordinateur, afin de réaliser le mouvement demandé.
De plus, on fait en sorte que le programme en C se lance dès l'allumage de l'ordinateur, et qu'il tourne en boucle afin d'être actif en permanence dès l'allumage du robot.
Maintien
Une fois les pièces rassemblées, nous avons pu commencer le montage du robot. Nous avons commencé par assembler les câbles de petits diamètre car ils étaient plus nombreux et que pour fixer les câbles des batteries, nous aurions dû tout visser à l'intérieur du robot alors qu'il est plus facile de visser à l'extérieur un maximum.
En commençant à mettre les câbles en place, nous avons pensé d'avantage au branchement, et nous avons réalisé que quelques ajustements sur les étages seraient judicieux, nous avons donc entrepris de dessiner et nous avons redécoupé sur les étage déjà existant de nouveaux trous pour les passages des câbles.
Tout d'abord, nous avons remarqué que les parties déjà dénudées des câbles étaient abîmées à cause de leurs précédentes multiples utilisations. Nous avons donc décidé de couper les parties abîmées et de les dénuder à nouveau, comme ces câbles sont plus longs que nécessaire, en couper une partie ne posait pas problème. Vu le diamètre des câbles, nous avons eu besoin de matériel spécial emprunté à M. Flamand. Cependant, malgré les outils prêtés, la tâche ne s'est pas avérée aisée et a pris plus de temps que prévu.
Ensuite, nous avons entrepris de placer les câbles précédemment coupés de façon à ce qu'il atteignent leur bornier tout en ne gênant pas le reste du câblage. Pour cette étape, comme les câbles étaient trop longs et qu'il est certes facile de raccourcir un câble mais pas de le rallonger, nous avons décidé de les plier. Par contre, ce sont des câbles plutôt rigides et ils ne prennent pas facilement la forme que l'on souhaite leur donner. Après de multiple essais pour les plier à la main ou à l'aide d'une pince, nous avons testé une autre méthode. En effet, en fin de semaine, nous avons eu l'idée de scotcher les câbles en place en leur donnant la forme que l'on souhaitait et de les laisser ainsi une nuit pour voir s'ils avaient gardé cette forme. Bonne surprise, le lendemain matin car cette méthode avait fonctionné.
En fin de semaine, nous avons donc pu procéder à la finalisation de l'assemblage de l'étage du bas.
Au cours de la semaine, nous avons également pris le temps de dessiner une boîte qui maintiendrait en place le convertisseur et nous l'avons découpée dans des chutes de plexi. De légers ajustement seront à faire sur cette boîte pour la version définitive.
La semaine prochaine, en plus de monter l'étage du haut, nous allons devoir régler un dernier détail sur l'étage du bas. En effet, en déposant la plaque de plexi de l'étage du haut, nous nous sommes rendu compte qu'il était bancal. Nous avions oublié que certaines cosses des batteries ne pouvaient être enfoncées correctement et provoquait ce décalage de hauteur. Nous devrons donc trouver une solution pour les enfoncer correctement la prochaine fois.
De plus, alors que nous avons essayé d'enlever l'étage du haut du robot, une fissure s'est créée. Nous allons donc essayer de la réparer avant qu'elle ne s'aggrave et qu'une partie de la plaque ne casse.
Site
A partir du design du site précédemment réalisé, nous avons choisi un bootstrap qui va nous permettre de réaliser un site esthétiquement agréable tout en gagnant du temps. Nous avons ensuite adapté le bootstrap à nos besoins pour avoir la structure de base HTML de notre choix. Grâce à ces modifications, nous avons maintenant notre base à laquelle nous allons pouvoir ajouter notre autres éléments tel le joystick; la webcam, les capteurs, etc...
En parallèle, nous avons entamé les recherches sur le joystick virtuel. En effet, des librairies avec des Joystick existent déjà et nous regardons les différentes possibilités pour savoir lesquelles implanter.
Semaine 4 du 28/01
PCB
Faire découper la deuxième version du PCB, la souder et la tester, en récupèrant des composants sur le PCB de l'année précédente. Des petits problèmes de contacts sont réglés par des soudures, notamment au niveau de la prise RJ11. Le PCB n'est pas tout à fait à la bonne taille, mais fonctionne toujours bien comme Shield. Il y a également, lors du premier test, deux problèmes : le premier hardware, deuxs fils avaient été branchés à l'envers au niveau des relais, ce qui fait que le robot ne pouvait aller qu'en marche avant. Cependant, ça n'a pas causé de problèmes à long terme. Le second, en software, était issu de l'inversion de deux pins en hardware qui n'avait pas été répercutée en software. Problème qui a été réglé facilement une fois qu'il a été trouvé.
Arduino
Le programme Arduino a été amélioré avec plusieurs fonctionnalités. Tout d'abord, lorsqu'une commande en vitesse impliquant une tension inférieure à 70mV est envoyée, cela entraîne la coupure des régulateurs, et il faut alors redémarrer tout le robot. On ignore ici cette commande et on éteint directement le moteur à la place. Ensuite, quand on met le joystick de façon a avoir un y nul, et une valeur en x, le robot effectue maintenant une manœuvre avec les deux roues tournant dans des sens opposés, ce qui n'était pas pris en compte auparavant. La mobilité et le contrôle que l'on a sur le robot sont donc grandement améliorés.
Le programme Arduino a ensuite été adapté afin de pouvoir prendre en compte la lecture des capteurs. En effet, si les capteurs sont branchés, il suffit du mettre une variable globale à 1 pour prendre en compte ceux-ci et arrêter le robot si un objet est trop proche de celui-ci.
Enfin, le programme Arduino peut maintenant lire le port série pour recevoir des commandes au lieu de lire la prise RJ11. Cette dernière fonctionnalité n'est pas encore au point, on analyse bien les messages reçus, mais il y a des problèmes de réception des messages sur le port série depuis un code en C qui se contente d'émettre en boucle un message.
Programme en C et script linux
Le programme en C actuel a été réalisé sans trop de problèmes et permet d'ouvrir le port USB sur lequel l'Arduino est branché, pour ensuite y envoyer des données. On va ensuite essayer de lire une donnée, qui sera la réponse de l'Arduino et devra être envoyée vers le serveur par la suite, même si celui-ci n'est pas encore tout à fait opérationnel.
Le script C permet simplement de lancer le programme. Il était prévu d'également modifier les droits de l'utilisateur dans le script, pour lui permettre d'accèder au port série, mais il apparait qu'il est en fait plus simple d'ajouter l'utilisateur au groupe dialout, groupe autorisé à utiliser les ports série.
Branchements & Fixations
En début de semaine, nous avons enfoncé les collier des batteries pour qu'ils soient tous au même niveau. Pour ce faire, nous avons emprunté une pince et un tournevis de force à M. Flamand qui nous ont permis d'écarté les colliers le temps de les mettre en place.
Nous avons ensuite pu re-finaliser les branchements de l'étage du bas, puis nous avons assemblé les piliers avec l'étage du haut et procédé au branchement de l'étage du haut.
Après tout ceci, nous avons fait le premier test pour faire rouler le robot en filaire à l'aide du Joystick réalisé par Nicolas Havard lors du semestre précédent. Comme le premier test n'a pas fonctionné, nous avons entamé la phase de "debbugage" où nous cherchions la cause du soucis, réglions le problème, testions à nouveau et ainsi de suite jusqu'à fonctionnement. Après moult essais et problèmes rencontrés, nous avons réussi à faire tourner le robot en fonction du joystick. Voici une courte démonstration :
*****Demo*****
De plus, nous avons profité d'un peu de temps dans la semaine pour "réparer" notre fissure dans la plaque du haut. Nous avons essayé deux méthodes différentes, pour l'une d'elle nous avons mis de l'acétone sur la fissure puis de la superglue par mesure de précaution. Puis pour l'autre, nous avons tenté de faire fondre le plexi avec un fer à souder, comme cela a créé une légère crevasse, nous l'avons remplie avec de la superglue également. Nous allons être plus prudent dorénavant et nous allons espérer que cela tienne en place.
Site web
En parallèle des branchements, nous avons continué à réaliser le site web. Nous avons ajouté un joystick dont les valeurs varient entre -1 et 1 pour x et y, et celles-ci s'affichent en dessous du joystick pour des besoins de debuggage.
De plus, nous avons fait des recherches sur le serveur et particulièrement l'envoi continu de données pour envoyer la position de notre joystick virtuel à notre serveur. Suite à ces recherches, nous sommes arrivés à une démonstration de communication serveur-client (http) et pour les besoins de celle-ci, nous avons du mettre à jour notre version de Linux ubuntu et nos paquets nodejs et npm.
Nous avons maintenant deux fichiers qui permettent la communication client-serveur et l'envoi de message simples, des chaînes de caractères. Et d'autres fichiers qui gèrent le joystick, ses valeurs x et y. Nous allons donc devoir comprendre ces différents fichiers pour savoir comment récupérer nos valeurs en x et en y et les envoyer au serveur.
Semaine 5 du 04/02
Simon
Correction du programme arduino, notamment d'un problème lors de l'émission réception en série des données. Le délai minimum obtenu pour l'instant est d'une seconde, ce qui pourrait s’avérer insuffisant. Le message a été réduit au minimum, il faut déterminer quelle action prend beaucoup de temps, et si ce temps est compressible. La communication série entre l'Arduino et l'ordinateur se fait en 115200B, ce qui devrait être plus que suffisant pour envoyer un message de 10 octets en quelques millièmes de secondes, mais ce n'est apparemment pas le cas. Pour envoyer un message de 10 octets à 115200B, il faudrait en principe 7 micro-secondes. On remarque également des erreurs lors de la transmission série, ce qui entraine la nécessité de transmettre plusieurs fois un message avant qu'il ne soit bien reçu. Même en prenant en compte les erreurs de transmission, et la nécessité de devoir attendre une réponse sur 24 octets, ça ne justifie pas un délai de presque une seconde entre chaque message.
Problèmes sur le dual boot de travail, une machine virtuelle à suroccupé l'espace, puis sa désinstallation à entrainé des problèmes sur Linux.
Ajout de la lecture/écriture de fichiers sur le programme en C, ainsi que la gestion des interruptions. Il reste à déterminer si les verrous posés lors de l'utilisation des fichiers vont fonctionner pour éviter de lire pendant une écriture. Le protocole d'échanges des données par fichiers, doit encore être implémenté côté serveur, et nous pourrons ensuite tester le bon fonctionnement de l'ensemble.
Le problème principal est que le serveur peut transmettre des instructions vers le robot bien plus vite que celui-ci ne peut les recevoir, et l'idée principale qui a été retenue est d'écrire les informations dans un fichier, sans conserver les informations précédentes. De cette façon, on n'a pas de fichier de stockage prenant des trop grandes dimensions, et on est sûr de toujours lire les informations les plus récentes.
Maeva
Pour compléter le rangement des éléments à l'intérieur du robot, nous avons dessiné les supports destinés aux variateurs. Pour cela nous avons pris exemple sur les supports déjà existants, nous les avons redessinés puis ajustés pour qu'ils entrent dans les fentes prévues à cet effet sur la plaque de l'étage du haut.
Nous avons ensuite fait un test de découpe pour ces supports ainsi que pour le convertisseur 24V-12V dont les plans avaient été dessinés précédemment. Après ce test, sont venues les étapes de rectifications pour que les composants s'emboîtent correctement sur leur support, et de redécoupe. Nous avons donc maintenant des supports!
Malheureusement, au cours de la semaine, mon ordinateur a cessé de fonctionner et nous avons donc perdu un peu de temps pour en recommander un, et faire les installations nécessaires dessus. Une fois le nouvel ordinateur prêt, nous avons récupéré notre projet sur git. Heureusement notre avancement était archivé sur un git, ainsi seulement les parties de tests ont été perdues.
Semaine 6 du 11/02
Finir les branchements du robot. Il est nécessaire de terminer l'intérieur du robot avant la fin du projet. En effet, il est tout a fait possible d'obtenir un robot fonctionnel sans cela, mais l'aspect esthétique ne doit pas être négligé. Nous avons passé beaucoup de temps, au cours de ces semaines, à modifier l'intérieur et à découper du plexiglas afin que tous les câblages ne soient pas trop présents. Ce robot devra être présentable, quelle que soit son utilisation future. Il ne nous reste qu'a terminer les branchements de la partie supérieure, et à découper une boite qui pourra maintenir l'Arduino, les relais, et l'ordinateur. Un problème que nous avions rencontré auparavant, était également la non-fiabilité des borniers utilisés pour les contacts. Au cours de cette semaine, nous avons essayé de tout resserrer afin que ce genre de problème ne se reproduise plus. De multiples tests ont également été effectués afin de s'assurer qu'on puisse démarrer le robot de façon fiable sans devoir l'ouvrir. Le bouton d'arrêt d'urgence à également enfin été mis en place de façon définitive. Un faux contact au niveau du PCB a également été résolu.
Faire l'échange entre serveur et Arduino, possiblement en passant par un programme en C, ou en établissant une communication directe entre le port série et le Js du serveur. Après réflexion et tests, nous avons décidé d'établir une liaison directe entre le serveur et l'Arduino, sans passer par un langage intermédiaire. En effet, passer par un programme C ralenti le processus en ajoutant un intermédiaire inutile, et malgré des tests concluants de communications entre le programme en C et l'Arduino, faire un programme en Js n'a pas été difficile, et simplifie considérablement nos échanges.
Au niveau du site web, nous avons modifié les fichiers du Joystick pour qu'il envoie des valeurs comprises entre -500 et 500, valeurs ensuite envoyées au serveur en communication http par le client. Puis nous récupérons ces données et nous les envoyons en série à l'Arduino en respectant le format de la trame demandée à savoir : 'X' suivi de '+' ou '-' puis la valeur de x sur 3 chiffres (ex: 000 ou 089) puis 'Y' suivi de '+' ou '-' et sa valeur sur trois chiffres également. Un exemple de message correct serait 'X+450Y+000'. En fin de semaine, nous avons enfin obtenu le résultat désiré, en utilisant le joystick du site web, hébergé par un ordinateur connecté à l'Arduino, pour contrôler les roues du robot. Tout le process de communication est donc techniquement fonctionnel. Pour ce test, le robot était contrôlé par un autre ordinateur, connecté sur le même wifi que l'ordinateur du robot. Il reste cependant à corriger des défauts dans le joystick, qui n'envoie pas toujours les valeurs correspondant à celles voulues (il glitch et se déplace très rapidement vers le centre quand on approche des bords du Joystick).
*** ViDEO ***
La Kinect, l'ordinateur et l'écran seront alimentés grâce au 12V sortant du convertisseur 24/12V. Les capteurs seront alimentés et commandés par l'Arduino. Il s'avère que le convertisseur 24->12V ne sort pas du 12 mais du 13.6V. C'est correct pour alimenter l'écran, mais pas la kinect ou l'ordinateur. Un pont diviseur consommerais trop de courant et on n'aurait plus assez de puissance pour alimenter les appareils. Un autre convertisseur à été trouvé, cette fois-ci allant bien de 24 vers 12V, et qui peut sortir au maximum 360W. C'est plus que suffisant pour notre application, qui nécessite seulement 90W pour l'ordinateur, 13W pour la Kinect, et 42W pour l'écran, pour un total de 145Watts demandés. Cependant, ce convertisseur présente un autre défaut majeur, il aurait tendance à chauffer jusqu'aux 150 degrés, ce qui est inacceptable pour notre robot. Un autre convertisseur à été commandé, et sera testé après la semaine d'interruption pédagogique. Avant de se rendre compte que le précédent convertisseur ne donnait pas les 12V demandés, le test a fait chauffer l'alimentation de la Kinect. Il faudra donc déterminer grâce à la nouvelle alimentation si celle de la Kinect à grillé ou non.
Au cours de la semaine, nous avons également préparé une clé bootable avec la distribution Debian Stretch de Linux dessus pour l'installer sur l'ordinateur intégré au robot. Nous l'avons donc branché à l'ordinateur et nous avons constaté que linux était déjà installé dessus et qu'un utilisateur centaure existait déjà.
Fin (interruption pédagogique)
aka rapport + wiki