BIOLOID commandé par Arduino : Différence entre versions

De Wiki d'activités IMA
(Matériel nécessaire)
 
(162 révisions intermédiaires par 2 utilisateurs non affichées)
Ligne 1 : Ligne 1 :
 +
<include nopre noesc src="/home/pedago/pimasc/include/video-BIOLOIDControleArduino-iframe.html" />
 +
__TOC__
 +
<br style="clear: both;"/>
 
= Cahier des charges =
 
= Cahier des charges =
 +
=== Encadrant ===
 +
Blaise Conrard <br/>
 +
Pour le projet, nous avons directement pris rendez-vous avec Blaise Conrard afin de discuter de nos idées.
  
=== Encadrant ===
+
=== Présentation du projet ===
Blaise Conrard
+
 
 +
Les kits Bioloid sont des kits robotiques programmables qui se basent sur les servomoteurs intelligents Dynamixel. Ces servomoteurs Dynamixel sont reconnus comme les servomoteurs les plus performants pour la robotique personnelle et éducative. Nous avons eu l'opportunité en IMA3 de développer des programmes sur ces robots via le logiciel RoboPlus et son interface type grafcet. Pour ce projet nous avons l'opportunité d'aller plus loin en programmant directement avec une carte Arduino.
 +
<br/>
 +
 
 +
=== Objectif ===
  
Pour le projet, nous avons directement pris rendez-vous avec Blaise Conrard afin de discuter de nos idées.
+
Le but de notre projet, est de de développer une application permettant à notre robot Bioloid, commandé par Arduino, d'écrire l'heure sur une ardoise magnétique.
 +
<br>
  
=== Cahier des charges ===
+
=== Description du projet ===
  
Les kits Bioloid sont des kits robotiques programmables qui se basent sur les servomoteurs intelligents Dynamixel. Ces servomoteurs Dynamixel sont reconnus comme les servomoteurs les plus performants pour la robotique personnelle et éducative. Nous avons eu l'opportunité en IMA3 de développer des programmes sur ces robots via le logiciel RoboPlus et son interface type grafcet.
+
Notre robot pourra être utiliser par toutes personnes souhaitant connaître l'heure. Il indiquera l'heure d'une façon originale, puisqu'il l'écrira, chaque minute, sur une ardoise magnétique. L'horloge robotique, rendra donc un service de type informatif. Par soucis de lisibilité et d'esthétique, le robot ainsi que l'ardoise seront fixés sur une surface plane (verticale ou horizontale). De plus, le robot sera positionné à moins de 10 cm en dessous de l'ardoise. Etant donné que la carte arduino devra être alimenté de 12 Volts, il est nécessaire de disposer d'une prise secteur et d'un transfo à proximité du robot.<br><br>
 +
Pour mener à bien ce projet, nous avons établi plusieurs contraintes, à savoir :<br/><br/>
 +
- L'heure est écrite de la même façon que les afficheurs 7 segments<br/>
 +
- Le robot possède deux bras, l'un pour écrire et l'autre pour effacer<br/>
 +
- Le stylo aimanté est fixé à un bras, tout comme le levier d'effacement<br/><br/>
 +
Afin de se faire une image plus représentative du projet, voici un croquis du robot :
  
Pour ce projet nous avons l'opportunité d'aller plus loin en programmant directement avec une carte Arduino.  
+
[[Fichier:logo_jo.png|300px]]
Nous avons décidé de développer une application qui permettrait à notre robot de dessiner l'heure sur une ardoise magnétique puis de l'effacer toutes les 60 seconde. Ainsi, l'heure sera toujours écrite en temps réel.
+
<br>
 +
Nous avons pu également fixer des limites de temps : <br/><br/>
 +
- Toutes les 60 secondes l'ardoise magnétique s'efface<br/>
 +
- Le temps pour nettoyer la surface doit être relativement court, de l'ordre de 2 secondes<br/>
 +
- Le robot doit écrire l'heure en moins de 50 secondes<br/><br/>
  
Pour cela, nous avons eu comme idée de construire deux bras robotiques afin d'écrire et d'effacer l'heure.
+
Contraintes électroniques :<br/><br/>
Ces bras seront dirigés par les servos-moteurs AX12 directement programmés par l'Arduino.  
+
- Alimenter la carte entre 9-12V<br/>
Afin d'une plus grande fluidité, l'heure sera manuscrite en caractère types 7-segments.
+
- Utiliser un buffer 3 états afin que la liaison TX/RX ne circule que sur un bus de données vers le servo.<br/><br/>
 +
Notre Bioloid, sera donc composés de deux bras commandés par les servos-moteurs AX12, directement programmés par l'Arduino. Dans un premier temps, nous réaliserons des fonctions élémentaires afin de bien comprendre l’interaction entre l'Arduino et les servos, puis nous passerons à la réalisation de l'application.<br/>
 +
Nous avons choisi de programmer à l'aide de l'IDE Arduino en C++ afin d'utiliser les éléments de la programmation objet, ceci dans le but d'utiliser les notions étendues du langage au sujet des instances, classes et fonctions.
  
 
=== Matériel nécessaire ===
 
=== Matériel nécessaire ===
Ligne 25 : Ligne 47 :
 
  | 0
 
  | 0
 
  |  
 
  |  
 +
|-
 +
| Servos-moteurs AX12
 +
| 0
 +
|
 
  |-
 
  |-
 
  | Non inverting buffer 74HC126
 
  | Non inverting buffer 74HC126
 
  | 2
 
  | 2
  |
+
  | Fournisseur : [http://www.mouser.fr/ProductDetail/NXP-Semiconductors/74HC126D653/?qs=sGAEpiMZZMuiiWkaIwCK2RTxPVPWGz6WVfjhJh2Mav0%3d]
 
  |-
 
  |-
 
  | Résistance 50 Ohms
 
  | Résistance 50 Ohms
 
  | 0
 
  | 0
 
  |
 
  |
  | -
+
  |-
 
  | Résistance 10kOhms
 
  | Résistance 10kOhms
 
  | 0
 
  | 0
 
  |
 
  |
  | -
+
  |-
 
  | Ardoise magnétique
 
  | Ardoise magnétique
 
  | 1
 
  | 1
 
  | Ardoise nécessaire pour l'application finale
 
  | Ardoise nécessaire pour l'application finale
  | -
+
  |-
 
  | Transfo 220V / 9V
 
  | Transfo 220V / 9V
  | 1
+
  | 0
 
  | Alim Arduino
 
  | Alim Arduino
}
+
|-
 +
|}
 +
 
 +
= Avancement du projet =
 +
 
 +
=== Définition du sujet ===
 +
 
 +
Pour répondre à la problématique énoncé dans le cahier des charges, nous devrons définir une méthode de programmation intuitive pour commander les servos-moteurs en temps réel. Pour cela, nous programmerons directement l'arduino qui contrôlera les servos-moteurs.
 +
 
 +
[[Fichier:arduino_uno_ax12.jpg‎|200px|center]]
 +
 
 +
Les différentes étapes du projet seront : <br/>
 +
 
 +
1) Adapter électriquement l'arduino aux servos-moteurs (alimentation,commande...) <br/>
 +
2) Créer des fonctions pour commander les moteurs <br/>
 +
3) Incorporer une gestion du temps <br/>
 +
4) Réfléchir à l'application finale (fonctions, contraintes ...) <br/>
 +
5) Réaliser cette application <br/>
 +
 
 +
=== Partie électronique ===
 +
 
 +
Pour ce projet, nous devons remplacer le CM5 par une carte arduino, ceci afin d'avoir des possibilités de programmation étendue.
 +
Avant toute chose , étudions les caractéristiques électroniques du CM5.
 +
 
 +
 
 +
[[Fichier:datasheet_buffer.png‎|350px|center|alt=Texte alternatif|Datasheet du CM5]]
 +
 
 +
 
 +
Après avoir étudié ces caractéristiques, nous avons remarqué que l'on pourrait directement passer par les ports RX et TX de l'arduino pour le contrôle des servos-moteurs, il suffirait juste d'ajouter un composant 74HC126D pour les contrôles alternatifs de TX et RX. En effet ce buffer trois états permettrait de faire passer alternativement Rx ou Tx en état d'haute impédance, ceci dans le but de n'avoir qu'une unique information sur le bus data vers le servo.
 +
 
 +
{| class="wikitable centre" caption ="table de vérité d'une porte 3 états"
 +
! colspan=2 | Entrées || Sortie
 +
|-
 +
! A || B || C
 +
|-
 +
| 0 || rowspan=2 | 0 || rowspan=2 | Z
 +
|-
 +
| 1
 +
|-
 +
| 0 || 1 || 0
 +
|-
 +
| 1 || 1 || 1
 +
|}
 +
 
 +
 
 +
Enfin, pour ce qui concerne l'alimentation, nous avons remarqué en lisant les caractéristiques de l'AX12 qu'il était nécessaire d'avoir environ 9V pour une alimentation correcte. Nous avons donc conclu qu'il serait nécessaire d'utiliser un transformateur 9V pour alimenter l'arduino, celui-ci pourra ainsi délivrer 9V par l'intermédiaire du pin VIN.
 +
 
 +
Après étude des caractéristiques du buffer 74HC126, et par soucis de matériel, nous avons choisi de remplacer ce composant par un buffer non inverseur SN74LS241N. Nous avons réalisé les branchements entre l'arduino et les servos via ce composant en nous aidant de la datasheet du CM5. De cette façon, il sera possible de se substituer du CM5 et de commander directement les servos via l'arduino.
 +
 
 +
Nous avons effectué quelques tests en connectant les ports TX et RX de l'arduino sur les différentes entrées du buffer 3 états. Nous avons finalement choisi de brancher TX sur la partie non inverseuse et RX sur la partie inverseuse du composant.
 +
 
 +
[[Fichier:buffer_txrx.jpg‎|350px|center|alt=Texte alternatif|Branchement du buffer]]
 +
 
 +
Ce qui donne pour notre circuit, la figure ci-dessous :<br/><br/>
 +
 
 +
[[Fichier:circuit_fin_ax12.jpg‎|350px|center|alt=Texte alternatif|Circuit]]
 +
 
 +
<br/>
 +
 
 +
=== Premières fonctions de commande ===
 +
 
 +
Une fois la communication entre l'arduino et les servos rendu possible, nous allons désormais chercher à créer des fonctions dans le but de commander les servos moteurs en position et en vitesse. La première étape consiste à créer un fichier header dans lequel nous définirons les adresses des servos-moteurs.<br/>
 +
Nous créerons également une classe Dynamixel dans laquelle nous spécifierons les différentes variables et méthodes nécessaires au contrôle des servos.
 +
 
 +
[[Fichier:apercu_c++.jpg‎|200px|alt=Texte alternatif|Code]]
 +
<br/><br/>
 +
 
 +
Une fois les prototypes et classes déclarés, nous pouvons désormais passer à la programmation des fonctions de commande. Pour cela nous nous sommes d'abord renseignés sur la manière de commander le servo-moteur via notre code (sans passer par le logiciel Bioloid). Nous avons trouvé des informations très intéressantes sur un site dédié à l'[https://github.com/7Robot/Eurobot-2012/tree/master/Arduino Eurocop 2012]  où quelques exemples d'utilisation des moteurs sont présentés. On y trouve notamment des informations sur la gestion du pin de contrôle de buffer en fonction des actions désirées et des fonctions utilisées.<br/>
 +
Nous avons donc appliqués ces méthodes pour coder nos fonctions, celles-ci nous permettront de contrôler directement les servos en position et en vitesse.
 +
 
 +
<br />
 +
[[Fichier:moveSpeed.jpg‎|500px|alt=Texte alternatif|Code]]
 +
<br />
 +
 
 +
De cette façon nous avons pu effectuer notre premier test. Nous avons choisi d'effectuer une rotation de 90 degres en aller/retour.
 +
Pour cela, étant donné que le moteur reçoit des consignes entre 0~1023 correspondant à 0~90°, on étalonne d'abord nos instructions via la fonction map.
 +
On choisit ensuite des délais d'attente de 3 secondes pour bien voir les rotations. Le test s'est avéré opérationnel, nous pouvons désormais réfléchir à la conception de l'horloge robotique.
 +
<br/>
 +
 
 +
[[Fichier:test_dyna.jpg‎|300px|alt=Texte alternatif|Code]]
 +
<br/><br>
 +
 
 +
=== Gestion du temps ===
 +
 
 +
L'un des points essentiels à la réalisation de notre projet, est la gestion du temps. Vous avez pu constater dans nos codes précédents, que nous utilisions la fonction ''delay()'' pour contrôler le temps. Or, cette approche n'est pas concevable pour notre horloge robotique, car la fonction suspend tout le programme pendant une durée définie, ce qui risquerait de décaler l'heure.
 +
 
 +
Pour pallier ce problème, nous avons 3 solutions:<br/>
 +
- Le module RTC (Real Time Clock)  <br/>
 +
- Les interruptions<br/>
 +
- La fonction ''millis()''  <br/>
 +
 
 +
Tout d'abord, l'une des solutions évidentes, est la mise en place d'un module RTC. Ce circuit intégré, qui se branche directement sur l'arduino, permet de connaître l'heure et la date à chaque instant. Cependant, ce matériel n'était pas disponible à Polytech Lille et relevait d'un prix assez élevé. C'est donc dans un soucis de rentabilité et d'économie, que nous avons décidé d'explorer d'autres méthodes. <br/>
 +
 
 +
Etant donné que nous souhaitions envoyer des tâches périodiques, l'utilisation des interruptions s'est proposée naturellement. Toutefois, pour le côté pratique, nous avons préféré écarter cette solution. <br/>
 +
 
 +
Il nous restait donc la fonction ''millis()''. Cette fonction permet de connaître le nombre de millisecondes depuis que la carte à exécuter son programme. En jouant sur les sommes et les soustractions, nous avons réussi à compter chaque seconde. Cependant, au bout d'un certain temps, la fonction ''millis()'' ne s'incrémente plus. En effet, elle supporte une durée de 50 jours. Pour pallier ce problème, nous avons décidé d’implémenter une interruption qui permet, tous les 40 jours, de réinitialiser le programme via un reset logiciel.<br/><br/>
 +
 
 +
=== Construction du robot ===
 +
 
 +
Les parties électroniques et informatiques étant opérationnelles, il nous faut désormais passer à la construction du robot. Pour cela, nous avons d'abord réfléchi à l'assemblage des servos et du matériel bioloid afin d'avoir un robot ayant une liberté de mouvement la plus complète. Après divers essais, nous avons finalement réussi à construire le bras en nous équipant de quatre servos_moteurs : un servo de base qui permettra de gérer horizontalement le bras et trois servos permettant une synchronisation horizontale. Enfin nous avons fixé le stylo au dernier servo pour pouvoir écrire sur l'ardoise.
 +
 
 +
De plus, nous avons trouvé une solution pour l'effacement des informations inscrites sur l'ardoise. Pour cela, nous nous sommes servis de deux servos moteurs situés de part et d'autre de l'ardoise. A l'aide d'une ficelle, nous avons fixés le levier d'effacement sur les servos qui par, des mouvements circulaires, seront capables d'effacer correctement l'heure toutes les 60 secondes. <br/>
 +
 
 +
Enfin nous nous sommes rendu compte que notre bras n'était pas stable lors de mouvements complexes, nous avons résolu le problème en modélisant une planche aux  dimensions de notre robot à l'aide de la découpeuse laser au FabLab. Cette planche servira de support au bras et à l'ardoise.
 +
 
 +
Un aperçu de notre bras robotique une fois construit : <br/>
 +
 
 +
[[Fichier:projet_bras.jpg‎|200px|center]]
 +
<br/>
 +
 
 +
=== Application : horloge robotique ===
 +
 
 +
Et maintenant il est temps de passer à l'application finale, nous allons pour cela créer des fonctions de contrôle de servos permettant d'écrire sur l'ardoise. Ces fonctions seront gérés en temps réel via la gestion du temps conçu précédemment. Il suffira ensuite de gérer l'effacement toutes les minutes.
 +
 
 +
La première étape fût de choisir une position initiale,neutre au robot afin que celui-ci puisse ensuite se déplacer correctement. Nous avons ainsi fait en sorte qu'il soit placé au milieu juste au-dessus de l'ardoise.
 +
 
 +
Une fois cette position réalisée, nous avons, à partir des fonctions créés précédemment, créer quatre mouvement à partir du servo-moteurs de base, soit quatre différentes rotations. Ces rotations permettront au robot de pouvoir écrire sur les quatres différents quadrants de l'horloge à chaque nouvelle minute.
 +
 
 +
Ensuite, il a fallu développer une solution afin d'écrire toutes les heures possibles. Nous avons dû permettre au robot d'écrire les chiffres de 1 à 9 (leurs positions étant contrôlés par la fonction précédente).
 +
 
 +
Pour cela, nous avons créer des fonctions permettant de définir l'ensemble des mouvements possibles sur un 7-seg à partir d'une position fixe que nous avons choisi de placer en bas à gauche. De par ces différentes fonctions, il nous a été possible de créer les chiffres très simplement.
 +
Par exemple pour écrire 0, on utilise l'association d'un tiret_droite, de deux tirets vers le haut, d'un tiret à gauche et de deux traits descendants. Ce qui donne au niveau du robot : un placement en bas à droite puis une écriture sur les bons digits de notre 7-seg ainsi créé.
 +
 
 +
Par la suite, nous avons créer une fonction permettant d'écrire les deux points en synchronisant correctement les servos en position.
 +
 
 +
On obtient le rendu suivant après trois minutes écoulées :
 +
<br/>
 +
[[Fichier:heure.jpg‎|200px|center]]
 +
<br/>
 +
Puis nous avons placé les deux servos dédiés à l'effacement de part et d'autre de l'ardoise en les fixant sur la planche en bois.
 +
<br/>
 +
[[Fichier:maniv.jpg‎|200px|center]]
 +
<br/>
 +
 
 +
Enfin nous avons dû géré la fin de l'effacement des deux moteurs correspondants. Nous avions initialement eu comme idée de placer deux fins de courses de part et d'autre de l'ardoise afin qu'il détecte la fin de l'effacement. Malheureusement, ces composants étant indisponibles, nous avons placé deux boutons poussoirs. Ces boutons envoient une information à l'arduino dès que l'effacement est terminé, celui-ci peut ainsi stopper le mouvement des servos correspondants.
 +
 
 +
=Fin du projet=
 +
 
 +
==Rapport==
 +
 
 +
Le rapport est disponible ici : [[Fichier:Rapport_P27.pdf]]
 +
 
 +
Le code-source est disponible ici : [[Fichier: projet_fonctions.zip]]
 +
 
 +
==Conclusion==
 +
Bien que notre application ne soit pas parfaitement optimale, nous sommes tout de même satisfait de notre travail.<br/> Nous avons parfaitement répondu au cahier des charges en adaptant une méthode de programmation par Arduino sur les servos-moteur bioloid.<br/> Enfin, notre application fonctionne très bien malgré quelques petits défauts : absence de RTC, pas de fin de courses. Nous avons commis quelques erreurs sur la gestion du matériel de notre projet, ce qui n'est qu'expérience pour la suite.<br/>
 +
Du point de vue pédagogique, ce projet nous a permis de mettre en pratique les connaissances que nous avions en électronique/informatique (gestion de micro-contrôleur, circuits électroniques) mais également de découvrir de nouvelles choses (C++,comportement de l'arduino).

Version actuelle datée du 14 juin 2016 à 08:46


Vidéo HD


Cahier des charges

Encadrant

Blaise Conrard
Pour le projet, nous avons directement pris rendez-vous avec Blaise Conrard afin de discuter de nos idées.

Présentation du projet

Les kits Bioloid sont des kits robotiques programmables qui se basent sur les servomoteurs intelligents Dynamixel. Ces servomoteurs Dynamixel sont reconnus comme les servomoteurs les plus performants pour la robotique personnelle et éducative. Nous avons eu l'opportunité en IMA3 de développer des programmes sur ces robots via le logiciel RoboPlus et son interface type grafcet. Pour ce projet nous avons l'opportunité d'aller plus loin en programmant directement avec une carte Arduino.

Objectif

Le but de notre projet, est de de développer une application permettant à notre robot Bioloid, commandé par Arduino, d'écrire l'heure sur une ardoise magnétique.

Description du projet

Notre robot pourra être utiliser par toutes personnes souhaitant connaître l'heure. Il indiquera l'heure d'une façon originale, puisqu'il l'écrira, chaque minute, sur une ardoise magnétique. L'horloge robotique, rendra donc un service de type informatif. Par soucis de lisibilité et d'esthétique, le robot ainsi que l'ardoise seront fixés sur une surface plane (verticale ou horizontale). De plus, le robot sera positionné à moins de 10 cm en dessous de l'ardoise. Etant donné que la carte arduino devra être alimenté de 12 Volts, il est nécessaire de disposer d'une prise secteur et d'un transfo à proximité du robot.

Pour mener à bien ce projet, nous avons établi plusieurs contraintes, à savoir :

- L'heure est écrite de la même façon que les afficheurs 7 segments
- Le robot possède deux bras, l'un pour écrire et l'autre pour effacer
- Le stylo aimanté est fixé à un bras, tout comme le levier d'effacement

Afin de se faire une image plus représentative du projet, voici un croquis du robot :

Logo jo.png
Nous avons pu également fixer des limites de temps :

- Toutes les 60 secondes l'ardoise magnétique s'efface
- Le temps pour nettoyer la surface doit être relativement court, de l'ordre de 2 secondes
- Le robot doit écrire l'heure en moins de 50 secondes

Contraintes électroniques :

- Alimenter la carte entre 9-12V
- Utiliser un buffer 3 états afin que la liaison TX/RX ne circule que sur un bus de données vers le servo.

Notre Bioloid, sera donc composés de deux bras commandés par les servos-moteurs AX12, directement programmés par l'Arduino. Dans un premier temps, nous réaliserons des fonctions élémentaires afin de bien comprendre l’interaction entre l'Arduino et les servos, puis nous passerons à la réalisation de l'application.
Nous avons choisi de programmer à l'aide de l'IDE Arduino en C++ afin d'utiliser les éléments de la programmation objet, ceci dans le but d'utiliser les notions étendues du langage au sujet des instances, classes et fonctions.

Matériel nécessaire

Matériel A commander Commentaires
Carte Arduino 0
Servos-moteurs AX12 0
Non inverting buffer 74HC126 2 Fournisseur : [1]
Résistance 50 Ohms 0
Résistance 10kOhms 0
Ardoise magnétique 1 Ardoise nécessaire pour l'application finale
Transfo 220V / 9V 0 Alim Arduino

Avancement du projet

Définition du sujet

Pour répondre à la problématique énoncé dans le cahier des charges, nous devrons définir une méthode de programmation intuitive pour commander les servos-moteurs en temps réel. Pour cela, nous programmerons directement l'arduino qui contrôlera les servos-moteurs.

Arduino uno ax12.jpg

Les différentes étapes du projet seront :

1) Adapter électriquement l'arduino aux servos-moteurs (alimentation,commande...)
2) Créer des fonctions pour commander les moteurs
3) Incorporer une gestion du temps
4) Réfléchir à l'application finale (fonctions, contraintes ...)
5) Réaliser cette application

Partie électronique

Pour ce projet, nous devons remplacer le CM5 par une carte arduino, ceci afin d'avoir des possibilités de programmation étendue. Avant toute chose , étudions les caractéristiques électroniques du CM5.


Texte alternatif


Après avoir étudié ces caractéristiques, nous avons remarqué que l'on pourrait directement passer par les ports RX et TX de l'arduino pour le contrôle des servos-moteurs, il suffirait juste d'ajouter un composant 74HC126D pour les contrôles alternatifs de TX et RX. En effet ce buffer trois états permettrait de faire passer alternativement Rx ou Tx en état d'haute impédance, ceci dans le but de n'avoir qu'une unique information sur le bus data vers le servo.

Entrées Sortie
A B C
0 0 Z
1
0 1 0
1 1 1


Enfin, pour ce qui concerne l'alimentation, nous avons remarqué en lisant les caractéristiques de l'AX12 qu'il était nécessaire d'avoir environ 9V pour une alimentation correcte. Nous avons donc conclu qu'il serait nécessaire d'utiliser un transformateur 9V pour alimenter l'arduino, celui-ci pourra ainsi délivrer 9V par l'intermédiaire du pin VIN.

Après étude des caractéristiques du buffer 74HC126, et par soucis de matériel, nous avons choisi de remplacer ce composant par un buffer non inverseur SN74LS241N. Nous avons réalisé les branchements entre l'arduino et les servos via ce composant en nous aidant de la datasheet du CM5. De cette façon, il sera possible de se substituer du CM5 et de commander directement les servos via l'arduino.

Nous avons effectué quelques tests en connectant les ports TX et RX de l'arduino sur les différentes entrées du buffer 3 états. Nous avons finalement choisi de brancher TX sur la partie non inverseuse et RX sur la partie inverseuse du composant.

Texte alternatif

Ce qui donne pour notre circuit, la figure ci-dessous :

Texte alternatif


Premières fonctions de commande

Une fois la communication entre l'arduino et les servos rendu possible, nous allons désormais chercher à créer des fonctions dans le but de commander les servos moteurs en position et en vitesse. La première étape consiste à créer un fichier header dans lequel nous définirons les adresses des servos-moteurs.
Nous créerons également une classe Dynamixel dans laquelle nous spécifierons les différentes variables et méthodes nécessaires au contrôle des servos.

Texte alternatif

Une fois les prototypes et classes déclarés, nous pouvons désormais passer à la programmation des fonctions de commande. Pour cela nous nous sommes d'abord renseignés sur la manière de commander le servo-moteur via notre code (sans passer par le logiciel Bioloid). Nous avons trouvé des informations très intéressantes sur un site dédié à l'Eurocop 2012 où quelques exemples d'utilisation des moteurs sont présentés. On y trouve notamment des informations sur la gestion du pin de contrôle de buffer en fonction des actions désirées et des fonctions utilisées.
Nous avons donc appliqués ces méthodes pour coder nos fonctions, celles-ci nous permettront de contrôler directement les servos en position et en vitesse.


Texte alternatif

De cette façon nous avons pu effectuer notre premier test. Nous avons choisi d'effectuer une rotation de 90 degres en aller/retour. Pour cela, étant donné que le moteur reçoit des consignes entre 0~1023 correspondant à 0~90°, on étalonne d'abord nos instructions via la fonction map. On choisit ensuite des délais d'attente de 3 secondes pour bien voir les rotations. Le test s'est avéré opérationnel, nous pouvons désormais réfléchir à la conception de l'horloge robotique.

Texte alternatif

Gestion du temps

L'un des points essentiels à la réalisation de notre projet, est la gestion du temps. Vous avez pu constater dans nos codes précédents, que nous utilisions la fonction delay() pour contrôler le temps. Or, cette approche n'est pas concevable pour notre horloge robotique, car la fonction suspend tout le programme pendant une durée définie, ce qui risquerait de décaler l'heure.

Pour pallier ce problème, nous avons 3 solutions:
- Le module RTC (Real Time Clock)
- Les interruptions
- La fonction millis()

Tout d'abord, l'une des solutions évidentes, est la mise en place d'un module RTC. Ce circuit intégré, qui se branche directement sur l'arduino, permet de connaître l'heure et la date à chaque instant. Cependant, ce matériel n'était pas disponible à Polytech Lille et relevait d'un prix assez élevé. C'est donc dans un soucis de rentabilité et d'économie, que nous avons décidé d'explorer d'autres méthodes.

Etant donné que nous souhaitions envoyer des tâches périodiques, l'utilisation des interruptions s'est proposée naturellement. Toutefois, pour le côté pratique, nous avons préféré écarter cette solution.

Il nous restait donc la fonction millis(). Cette fonction permet de connaître le nombre de millisecondes depuis que la carte à exécuter son programme. En jouant sur les sommes et les soustractions, nous avons réussi à compter chaque seconde. Cependant, au bout d'un certain temps, la fonction millis() ne s'incrémente plus. En effet, elle supporte une durée de 50 jours. Pour pallier ce problème, nous avons décidé d’implémenter une interruption qui permet, tous les 40 jours, de réinitialiser le programme via un reset logiciel.

Construction du robot

Les parties électroniques et informatiques étant opérationnelles, il nous faut désormais passer à la construction du robot. Pour cela, nous avons d'abord réfléchi à l'assemblage des servos et du matériel bioloid afin d'avoir un robot ayant une liberté de mouvement la plus complète. Après divers essais, nous avons finalement réussi à construire le bras en nous équipant de quatre servos_moteurs : un servo de base qui permettra de gérer horizontalement le bras et trois servos permettant une synchronisation horizontale. Enfin nous avons fixé le stylo au dernier servo pour pouvoir écrire sur l'ardoise.

De plus, nous avons trouvé une solution pour l'effacement des informations inscrites sur l'ardoise. Pour cela, nous nous sommes servis de deux servos moteurs situés de part et d'autre de l'ardoise. A l'aide d'une ficelle, nous avons fixés le levier d'effacement sur les servos qui par, des mouvements circulaires, seront capables d'effacer correctement l'heure toutes les 60 secondes.

Enfin nous nous sommes rendu compte que notre bras n'était pas stable lors de mouvements complexes, nous avons résolu le problème en modélisant une planche aux dimensions de notre robot à l'aide de la découpeuse laser au FabLab. Cette planche servira de support au bras et à l'ardoise.

Un aperçu de notre bras robotique une fois construit :

Projet bras.jpg


Application : horloge robotique

Et maintenant il est temps de passer à l'application finale, nous allons pour cela créer des fonctions de contrôle de servos permettant d'écrire sur l'ardoise. Ces fonctions seront gérés en temps réel via la gestion du temps conçu précédemment. Il suffira ensuite de gérer l'effacement toutes les minutes.

La première étape fût de choisir une position initiale,neutre au robot afin que celui-ci puisse ensuite se déplacer correctement. Nous avons ainsi fait en sorte qu'il soit placé au milieu juste au-dessus de l'ardoise.

Une fois cette position réalisée, nous avons, à partir des fonctions créés précédemment, créer quatre mouvement à partir du servo-moteurs de base, soit quatre différentes rotations. Ces rotations permettront au robot de pouvoir écrire sur les quatres différents quadrants de l'horloge à chaque nouvelle minute.

Ensuite, il a fallu développer une solution afin d'écrire toutes les heures possibles. Nous avons dû permettre au robot d'écrire les chiffres de 1 à 9 (leurs positions étant contrôlés par la fonction précédente).

Pour cela, nous avons créer des fonctions permettant de définir l'ensemble des mouvements possibles sur un 7-seg à partir d'une position fixe que nous avons choisi de placer en bas à gauche. De par ces différentes fonctions, il nous a été possible de créer les chiffres très simplement. Par exemple pour écrire 0, on utilise l'association d'un tiret_droite, de deux tirets vers le haut, d'un tiret à gauche et de deux traits descendants. Ce qui donne au niveau du robot : un placement en bas à droite puis une écriture sur les bons digits de notre 7-seg ainsi créé.

Par la suite, nous avons créer une fonction permettant d'écrire les deux points en synchronisant correctement les servos en position.

On obtient le rendu suivant après trois minutes écoulées :

Heure.jpg


Puis nous avons placé les deux servos dédiés à l'effacement de part et d'autre de l'ardoise en les fixant sur la planche en bois.

Maniv.jpg


Enfin nous avons dû géré la fin de l'effacement des deux moteurs correspondants. Nous avions initialement eu comme idée de placer deux fins de courses de part et d'autre de l'ardoise afin qu'il détecte la fin de l'effacement. Malheureusement, ces composants étant indisponibles, nous avons placé deux boutons poussoirs. Ces boutons envoient une information à l'arduino dès que l'effacement est terminé, celui-ci peut ainsi stopper le mouvement des servos correspondants.

Fin du projet

Rapport

Le rapport est disponible ici : Fichier:Rapport P27.pdf

Le code-source est disponible ici : Fichier:Projet fonctions.zip

Conclusion

Bien que notre application ne soit pas parfaitement optimale, nous sommes tout de même satisfait de notre travail.
Nous avons parfaitement répondu au cahier des charges en adaptant une méthode de programmation par Arduino sur les servos-moteur bioloid.
Enfin, notre application fonctionne très bien malgré quelques petits défauts : absence de RTC, pas de fin de courses. Nous avons commis quelques erreurs sur la gestion du matériel de notre projet, ce qui n'est qu'expérience pour la suite.
Du point de vue pédagogique, ce projet nous a permis de mettre en pratique les connaissances que nous avions en électronique/informatique (gestion de micro-contrôleur, circuits électroniques) mais également de découvrir de nouvelles choses (C++,comportement de l'arduino).