﻿<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="fr">
	<id>https://bacasable.arpitania.eu//api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Amaury+G</id>
	<title>Learning Lab Environnements Connectés - Contributions de l’utilisateur [fr]</title>
	<link rel="self" type="application/atom+xml" href="https://bacasable.arpitania.eu//api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Amaury+G"/>
	<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Sp%C3%A9cial:Contributions/Amaury_G"/>
	<updated>2026-04-08T12:26:15Z</updated>
	<subtitle>Contributions de l’utilisateur</subtitle>
	<generator>MediaWiki 1.32.0</generator>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12844</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12844"/>
		<updated>2024-05-15T07:26:03Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Programmation des cartes==&lt;br /&gt;
* ESP32 :&lt;br /&gt;
::- Ajouter le support de la carte dans l'IDE Arduino en insérant ce lien dans Fichier → Préférences → URL de gestionnaire de carte supplémentaire : https://dl.espressif.com/dl/package_esp32_index.json&lt;br /&gt;
::- Dans Outils → Type de carte → Gestionnaire de cartes, rechercher et installer ESP32&lt;br /&gt;
::- Dans Outils → Type de carte sélectionner la carte ESP32&lt;br /&gt;
&lt;br /&gt;
* Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
Après ces modifications, nous avons constaté que :&lt;br /&gt;
:- Le moteur 1 est lié à la roue 3 et est inversé&lt;br /&gt;
:- Le moteur 2 est lié à la roue 1 dans le bon sens&lt;br /&gt;
:- Le moteur 3 est lié à la roue 2 et est inversé&lt;br /&gt;
:- Le moteur 4 est lié à la roue 4 dans le bon sens&lt;br /&gt;
&lt;br /&gt;
Par ailleurs, nous avons eu quelques difficultés avec le moteur 4. Celui-ci tournait lorsqu'il ne devait pas. Après avoir isolé les différentes parties du robot, le problème n'intervient plus. Nous en avons donc conclu un problème de faux contact.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt; : [[Fichier:Techniques Ingenieur.pdf]].&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo, et on va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
Suite à un problème de commande, nous avons du changer nos plan et partir sur une pince en impression 3D dont voici les plans. &amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:plan_pince_3D.zip]]&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet AOP pour comparateur : [[Fichier:tlc271a.pdf]]&lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
Schéma montage LED : [[Fichier:MontageLED.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Ensuite on réalise le montage avec le phototransistor accompagné d'un comparateur qui va nous permettre d'avoir une sortie 5V si l'objet n'est pas détecté ou 0V si il est détecté :&lt;br /&gt;
Schéma montage phototransistor + comparateur : [[Fichier:MontagePhototransisitor.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après plusieurs tests, on remarque que lorsque un objet sépare la diode du phototransistor, on a approximativement 0V aux bornes de la résistance. Lorsqu'il n'y a pas d'objet, on remarque que la tension aux bornes de la résistance est de plus de 100mV. Ainsi on choisie un seuil de 50mV pour le comparateur. On utilise un pont diviseur de tension pour obtenir cette tension :&lt;br /&gt;
Schéma montage pont diviseur : [[Fichier:PontDiv.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il nous faut 2 capteurs de ce type pour les 2 pinces qui seront sur les robots 2 et 3. Ainsi, on réalise ces montages sur 2 mini breadboard que l'on placera sur les robots avec les LED et phototransistors qui seront placés sur les pinces à l'aide de câbles plus long pour les excentrer des mini breadboard.&lt;br /&gt;
Image capteur sur mini breadboard : [[Fichier:Breadboard+capteur.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
L'objectif maintenant est de relier le capteur optique au servomoteur via une carte ESP32. On utilise une entrée analogique qui va lire la valeur en sortie du capteur (0V si présence d'objet et 5V si non présence). Lorsqu'on détecte le passage de 5V à 0V, on fait varier l'angle du servomoteur (ce qui fermera la pince).&lt;br /&gt;
&lt;br /&gt;
Code servo/capteur : [[Fichier: ServoCapteur]]&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;br /&gt;
&lt;br /&gt;
=Problèmes rencontrés=&lt;br /&gt;
&lt;br /&gt;
Lors de ce projet nous avons rencontré plusieurs obstacles. Tout d'abord pendant la première semaine nous avons fait un inventaire sur le matériel nécessaire et le matériel déjà présent. A la fin de la première semaine nous avions donc tout le matériel nécessaire à part une pince afin d'attraper nos objets ainsi que des capteurs de suivi de ligne et du scotch blanc afin de faire la ligne pour la maquette. Nous avons donc envoyé un mail à Matthieu Dumay qui n'a malheureusement pas était pris en compte pendant les trois semaines que nous avons eu entre les deux semaines de robotique malgré un mail de rappel de la commande. Lors de la deuxième semaine nous avons donc du improviser. Nous avons utiliser des feuilles blanches découpées en lamelles pour le suivi de ligne. Nous avons également trouvé de nouveaux capteurs de suivi de ligne. Et enfin nous avons choisi d'imprimer des pinces au lieu de les commander.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=Fichier:Breadboard%2Bcapteur.png&amp;diff=12835</id>
		<title>Fichier:Breadboard+capteur.png</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Fichier:Breadboard%2Bcapteur.png&amp;diff=12835"/>
		<updated>2024-05-14T15:13:31Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12834</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12834"/>
		<updated>2024-05-14T15:13:04Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Programmation des cartes==&lt;br /&gt;
* ESP32 :&lt;br /&gt;
::- Ajouter le support de la carte dans l'IDE Arduino en insérant ce lien dans Fichier → Préférences → URL de gestionnaire de carte supplémentaire : https://dl.espressif.com/dl/package_esp32_index.json&lt;br /&gt;
::- Dans Outils → Type de carte → Gestionnaire de cartes, rechercher et installer ESP32&lt;br /&gt;
::- Dans Outils → Type de carte sélectionner la carte ESP32&lt;br /&gt;
&lt;br /&gt;
* Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet AOP pour comparateur : [[Fichier:tlc271a.pdf]]&lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
Schéma montage LED : [[Fichier:MontageLED.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Ensuite on réalise le montage avec le phototransistor accompagné d'un comparateur qui va nous permettre d'avoir une sortie 5V si l'objet n'est pas détecté ou 0V si il est détecté :&lt;br /&gt;
Schéma montage phototransistor + comparateur : [[Fichier:MontagePhototransisitor.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après plusieurs tests, on remarque que lorsque un objet sépare la diode du phototransistor, on a approximativement 0V aux bornes de la résistance. Lorsqu'il n'y a pas d'objet, on remarque que la tension aux bornes de la résistance est de plus de 100mV. Ainsi on choisie un seuil de 50mV pour le comparateur. On utilise un pont diviseur de tension pour obtenir cette tension :&lt;br /&gt;
Schéma montage pont diviseur : [[Fichier:PontDiv.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il nous faut 2 capteurs de ce type pour les 2 pinces qui seront sur les robots 2 et 3. Ainsi, on réalise ces montages sur 2 mini breadboard que l'on placera sur les robots avec les LED et phototransistors qui seront placés sur les pinces à l'aide de câbles plus long pour les excentrer des mini breadboard.&lt;br /&gt;
Image capteur sur mini breadboard : [[Fichier:Breadboard+capteur.png]]&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;br /&gt;
&lt;br /&gt;
=Problèmes rencontrés=&lt;br /&gt;
&lt;br /&gt;
Lors de ce projet nous avons rencontré plusieurs obstacles. Tout d'abord pendant la première semaine nous avons fait un inventaire sur le matériel nécessaire et le matériel déjà présent. A la fin de la première semaine nous avions donc tout le matériel nécessaire à part une pince afin d'attraper nos objets ainsi que des capteurs de suivi de ligne et du scotch blanc afin de faire la ligne pour la maquette. Nous avons donc envoyé un mail à Matthieu Dumay qui n'a malheureusement pas était pris en compte pendant les trois semaines que nous avons eu entre les deux semaines de robotique malgré un mail de rappel de la commande. Lors de la deuxième semaine nous avons donc du improviser. Nous avons utiliser des feuilles blanches découpées en lamelles pour le suivi de ligne. Nous avons également trouvé de nouveaux capteurs de suivi de ligne. Et enfin nous avons choisi d'imprimer des pinces au lieu de les commander.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12833</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12833"/>
		<updated>2024-05-14T15:12:23Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Programmation des cartes==&lt;br /&gt;
* ESP32 :&lt;br /&gt;
::- Ajouter le support de la carte dans l'IDE Arduino en insérant ce lien dans Fichier → Préférences → URL de gestionnaire de carte supplémentaire : https://dl.espressif.com/dl/package_esp32_index.json&lt;br /&gt;
::- Dans Outils → Type de carte → Gestionnaire de cartes, rechercher et installer ESP32&lt;br /&gt;
::- Dans Outils → Type de carte sélectionner la carte ESP32&lt;br /&gt;
&lt;br /&gt;
* Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet AOP pour comparateur : [[Fichier:tlc271a.pdf]]&lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
Schéma montage LED : [[Fichier:MontageLED.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Ensuite on réalise le montage avec le phototransistor accompagné d'un comparateur qui va nous permettre d'avoir une sortie 5V si l'objet n'est pas détecté ou 0V si il est détecté :&lt;br /&gt;
Schéma montage phototransistor + comparateur : [[Fichier:MontagePhototransisitor.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après plusieurs tests, on remarque que lorsque un objet sépare la diode du phototransistor, on a approximativement 0V aux bornes de la résistance. Lorsqu'il n'y a pas d'objet, on remarque que la tension aux bornes de la résistance est de plus de 100mV. Ainsi on choisie un seuil de 50mV pour le comparateur. On utilise un pont diviseur de tension pour obtenir cette tension :&lt;br /&gt;
Schéma montage pont diviseur : [[Fichier:PontDiv.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il nous faut 2 capteurs de ce type pour les 2 pinces qui seront sur les robots 2 et 3. Ainsi, on réalise ces montages sur 2 mini breadboard que l'on placera sur les robots avec les LED et phototransistors qui seront placés sur les pinces à l'aide de câbles plus long pour les excentrer des mini breadboard.&lt;br /&gt;
Image capteur sur mini breadboard : [[Fichier:Breadboard.png]]&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;br /&gt;
&lt;br /&gt;
=Problèmes rencontrés=&lt;br /&gt;
&lt;br /&gt;
Lors de ce projet nous avons rencontré plusieurs obstacles. Tout d'abord pendant la première semaine nous avons fait un inventaire sur le matériel nécessaire et le matériel déjà présent. A la fin de la première semaine nous avions donc tout le matériel nécessaire à part une pince afin d'attraper nos objets ainsi que des capteurs de suivi de ligne et du scotch blanc afin de faire la ligne pour la maquette. Nous avons donc envoyé un mail à Matthieu Dumay qui n'a malheureusement pas était pris en compte pendant les trois semaines que nous avons eu entre les deux semaines de robotique malgré un mail de rappel de la commande. Lors de la deuxième semaine nous avons donc du improviser. Nous avons utiliser des feuilles blanches découpées en lamelles pour le suivi de ligne. Nous avons également trouvé de nouveaux capteurs de suivi de ligne. Et enfin nous avons choisi d'imprimer des pinces au lieu de les commander.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=Fichier:PontDiv.png&amp;diff=12830</id>
		<title>Fichier:PontDiv.png</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Fichier:PontDiv.png&amp;diff=12830"/>
		<updated>2024-05-14T15:04:48Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12829</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12829"/>
		<updated>2024-05-14T15:04:13Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet AOP pour comparateur : [[Fichier:tlc271a.pdf]]&lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
Schéma montage LED : [[Fichier:MontageLED.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Ensuite on réalise le montage avec le phototransistor accompagné d'un comparateur qui va nous permettre d'avoir une sortie 5V si l'objet n'est pas détecté ou 0V si il est détecté :&lt;br /&gt;
Schéma montage phototransistor + comparateur : [[Fichier:MontagePhototransisitor.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après plusieurs tests, on remarque que lorsque un objet sépare la diode du phototransistor, on a approximativement 0V aux bornes de la résistance. Lorsqu'il n'y a pas d'objet, on remarque que la tension aux bornes de la résistance est de plus de 100mV. Ainsi on choisie un seuil de 50mV pour le comparateur. On utilise un pont diviseur de tension pour obtenir cette tension :&lt;br /&gt;
Schéma montage pont diviseur : [[Fichier:PontDiv.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il nous faut 2 capteurs de ce type pour les 2 pinces qui seront sur les robots 2 et 3. Ainsi, on réalise ces montages sur 2 mini breadboard que l'on placera sur les robots avec les LED et phototransistors qui seront placés sur les pinces à l'aide de câbles plus long pour les excentrer des mini breadboard.&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;br /&gt;
&lt;br /&gt;
=Problèmes rencontrés=&lt;br /&gt;
&lt;br /&gt;
Lors de ce projet nous avons rencontré plusieurs obstacles. Tout d'abord pendant la première semaine nous avons fait un inventaire sur le matériel nécessaire et le matériel déjà présent. A la fin de la première semaine nous avions donc tout le matériel nécessaire à part une pince afin d'attraper nos objets ainsi que des capteurs de suivi de ligne et du scotch blanc afin de faire la ligne pour la maquette. Nous avons donc envoyé un mail à Matthieu Dumay qui n'a malheureusement pas était pris en compte pendant les trois semaines que nous avons eu entre les deux semaines de robotique malgré un mail de rappel de la commande. Lors de la deuxième semaine nous avons donc du improviser. Nous avons utiliser des feuilles blanches découpées en lamelles pour le suivi de ligne. Nous avons également trouvé de nouveaux capteurs de suivi de ligne. Et enfin nous avons choisi d'imprimer des pinces au lieu de les commander.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=Fichier:MontagePhototransisitor.png&amp;diff=12828</id>
		<title>Fichier:MontagePhototransisitor.png</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Fichier:MontagePhototransisitor.png&amp;diff=12828"/>
		<updated>2024-05-14T15:00:58Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12827</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12827"/>
		<updated>2024-05-14T15:00:31Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet AOP pour comparateur : [[Fichier:tlc271a.pdf]]&lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
Schéma montage LED : [[Fichier:MontageLED.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Ensuite on réalise le montage avec le phototransistor accompagné d'un comparateur qui va nous permettre d'avoir une sortie 5V si l'objet n'est pas détecté ou 0V si il est détecté :&lt;br /&gt;
Schéma montage phototransistor + comparateur : [[Fichier:MontagePhototransisitor.png]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après plusieurs tests, on remarque que lorsque un objet sépare la diode du phototransistor, on a approximativement 0V aux bornes de la résistance. Lorsqu'il n'y a pas d'objet, on remarque que la tension aux bornes de la résistance est de plus de 100mV. Ainsi on choisie un seuil de 50mV pour le comparateur. On utilise un pont diviseur de tension pour obtenir cette tension :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il nous faut 2 capteurs de ce type pour les 2 pinces qui seront sur les robots 2 et 3. Ainsi, on réalise ces montages sur 2 mini breadboard que l'on placera sur les robots avec les LED et phototransistors qui seront placés sur les pinces à l'aide de câbles plus long pour les excentrer des mini breadboard.&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;br /&gt;
&lt;br /&gt;
=Problèmes rencontrés=&lt;br /&gt;
&lt;br /&gt;
Lors de ce projet nous avons rencontré plusieurs obstacles. Tout d'abord pendant la première semaine nous avons fait un inventaire sur le matériel nécessaire et le matériel déjà présent. A la fin de la première semaine nous avions donc tout le matériel nécessaire à part une pince afin d'attraper nos objets ainsi que des capteurs de suivi de ligne et du scotch blanc afin de faire la ligne pour la maquette. Nous avons donc envoyé un mail à Matthieu Dumay qui n'a malheureusement pas était pris en compte pendant les trois semaines que nous avons eu entre les deux semaines de robotique malgré un mail de rappel de la commande. Lors de la deuxième semaine nous avons donc du improviser. Nous avons utiliser des feuilles blanches découpées en lamelles pour le suivi de ligne. Nous avons également trouvé de nouveaux capteurs de suivi de ligne. Et enfin nous avons choisi d'imprimer des pinces au lieu de les commander.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=Fichier:MontageLED.png&amp;diff=12826</id>
		<title>Fichier:MontageLED.png</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Fichier:MontageLED.png&amp;diff=12826"/>
		<updated>2024-05-14T14:57:54Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12825</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12825"/>
		<updated>2024-05-14T14:57:31Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet AOP pour comparateur : [[Fichier:tlc271a.pdf]]&lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
&lt;br /&gt;
Schéma montage LED : [[Fichier:MontageLED.png]]&lt;br /&gt;
Ensuite on réalise le montage avec le phototransistor accompagné d'un comparateur qui va nous permettre d'avoir une sortie 5V si l'objet n'est pas détecté ou 0V si il est détecté :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après plusieurs tests, on remarque que lorsque un objet sépare la diode du phototransistor, on a approximativement 0V aux bornes de la résistance. Lorsqu'il n'y a pas d'objet, on remarque que la tension aux bornes de la résistance est de plus de 100mV. Ainsi on choisie un seuil de 50mV pour le comparateur. On utilise un pont diviseur de tension pour obtenir cette tension :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il nous faut 2 capteurs de ce type pour les 2 pinces qui seront sur les robots 2 et 3. Ainsi, on réalise ces montages sur 2 mini breadboard que l'on placera sur les robots avec les LED et phototransistors qui seront placés sur les pinces à l'aide de câbles plus long pour les excentrer des mini breadboard.&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;br /&gt;
&lt;br /&gt;
=Problèmes rencontrés=&lt;br /&gt;
&lt;br /&gt;
Lors de ce projet nous avons rencontré plusieurs obstacles. Tout d'abord pendant la première semaine nous avons fait un inventaire sur le matériel nécessaire et le matériel déjà présent. A la fin de la première semaine nous avions donc tout le matériel nécessaire à part une pince afin d'attraper nos objets ainsi que des capteurs de suivi de ligne et du scotch blanc afin de faire la ligne pour la maquette. Nous avons donc envoyé un mail à Matthieu Dumay qui n'a malheureusement pas était pris en compte pendant les trois semaines que nous avons eu entre les deux semaines de robotique malgré un mail de rappel de la commande. Lors de la deuxième semaine nous avons donc du improviser. Nous avons utiliser des feuilles blanches découpées en lamelles pour le suivi de ligne. Nous avons également trouvé de nouveaux capteurs de suivi de ligne. Et enfin nous avons choisi d'imprimer des pinces au lieu de les commander.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=Fichier:Tlc271a.pdf&amp;diff=12824</id>
		<title>Fichier:Tlc271a.pdf</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Fichier:Tlc271a.pdf&amp;diff=12824"/>
		<updated>2024-05-14T14:34:24Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : Datasheet AOP pour comparateur&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Description ==&lt;br /&gt;
Datasheet AOP pour comparateur&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12823</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12823"/>
		<updated>2024-05-14T14:33:50Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet AOP pour comparateur : [[Fichier:tlc271a.pdf]]&lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Ensuite on réalise le montage avec le phototransistor accompagné d'un comparateur qui va nous permettre d'avoir une sortie 5V si l'objet n'est pas détecté ou 0V si il est détecté :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après plusieurs tests, on remarque que lorsque un objet sépare la diode du phototransistor, on a approximativement 0V aux bornes de la résistance. Lorsqu'il n'y a pas d'objet, on remarque que la tension aux bornes de la résistance est de plus de 100mV. Ainsi on choisie un seuil de 50mV pour le comparateur. On utilise un pont diviseur de tension pour obtenir cette tension :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il nous faut 2 capteurs de ce type pour les 2 pinces qui seront sur les robots 2 et 3. Ainsi, on réalise ces montages sur 2 mini breadboard que l'on placera sur les robots avec les LED et phototransistors qui seront placés sur les pinces à l'aide de câbles plus long pour les excentrer des mini breadboard.&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;br /&gt;
&lt;br /&gt;
=Problèmes rencontrés=&lt;br /&gt;
&lt;br /&gt;
Lors de ce projet nous avons rencontré plusieurs obstacles. Tout d'abord pendant la première semaine nous avons fait un inventaire sur le matériel nécessaire et le matériel déjà présent. A la fin de la première semaine nous avions donc tout le matériel nécessaire à part une pince afin d'attraper nos objets ainsi que des capteurs de suivi de ligne et du scotch blanc afin de faire la ligne pour la maquette. Nous avons donc envoyé un mail à Matthieu Dumay qui n'a malheureusement pas était pris en compte pendant les trois semaines que nous avons eu entre les deux semaines de robotique malgré un mail de rappel de la commande. Lors de la deuxième semaine nous avons donc du improviser. Nous avons utiliser des feuilles blanches découpées en lamelles pour le suivi de ligne. Nous avons également trouvé de nouveaux capteurs de suivi de ligne. Et enfin nous avons choisi d'imprimer des pinces au lieu de les commander.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12822</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12822"/>
		<updated>2024-05-14T14:26:57Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet AOP pour comparateur : &lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Ensuite on réalise le montage avec le phototransistor accompagné d'un comparateur qui va nous permettre d'avoir une sortie 5V si l'objet n'est pas détecté ou 0V si il est détecté :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après plusieurs tests, on remarque que lorsque un objet sépare la diode du phototransistor, on a approximativement 0V aux bornes de la résistance. Lorsqu'il n'y a pas d'objet, on remarque que la tension aux bornes de la résistance est de plus de 100mV. Ainsi on choisie un seuil de 50mV pour le comparateur. On utilise un pont diviseur de tension pour obtenir cette tension :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il nous faut 2 capteurs de ce type pour les 2 pinces qui seront sur les robots 2 et 3. Ainsi, on réalise ces montages sur 2 mini breadboard que l'on placera sur les robots avec les LED et phototransistors qui seront placés sur les pinces à l'aide de câbles plus long pour les excentrer des mini breadboard.&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;br /&gt;
&lt;br /&gt;
=Problèmes rencontrés=&lt;br /&gt;
&lt;br /&gt;
Lors de ce projet nous avons rencontré plusieurs obstacles. Tout d'abord pendant la première semaine nous avons fait un inventaire sur le matériel nécessaire et le matériel déjà présent. A la fin de la première semaine nous avions donc tout le matériel nécessaire à part une pince afin d'attraper nos objets ainsi que des capteurs de suivi de ligne et du scotch blanc afin de faire la ligne pour la maquette. Nous avons donc envoyé un mail à Matthieu Dumay qui n'a malheureusement pas était pris en compte pendant les trois semaines que nous avons eu entre les deux semaines de robotique malgré un mail de rappel de la commande. Lors de la deuxième semaine nous avons donc du improviser. Nous avons utiliser des feuilles blanches découpées en lamelles pour le suivi de ligne. Nous avons également trouvé de nouveaux capteurs de suivi de ligne. Et enfin nous avons choisi d'imprimer des pinces au lieu de les commander.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12817</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12817"/>
		<updated>2024-05-14T13:57:51Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Dans un premier temps on réalise le montage avec la LED infrarouge :&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12816</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12816"/>
		<updated>2024-05-14T13:56:08Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Capture_d'écran_2024-04-19_150732.png]]&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=Fichier:Osram_opto_semiconductor.pdf&amp;diff=12815</id>
		<title>Fichier:Osram opto semiconductor.pdf</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Fichier:Osram_opto_semiconductor.pdf&amp;diff=12815"/>
		<updated>2024-05-14T13:52:01Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : Datasheet LED infrarouge&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Description ==&lt;br /&gt;
Datasheet LED infrarouge&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12814</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12814"/>
		<updated>2024-05-14T13:51:18Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Capture_d'écran_2024-04-19_150732.png]]&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=Fichier:Osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf&amp;diff=12813</id>
		<title>Fichier:Osram opto semiconductor sfh 409 lead pb free prod-2891523.pdf</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Fichier:Osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523.pdf&amp;diff=12813"/>
		<updated>2024-05-14T13:45:42Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12812</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12812"/>
		<updated>2024-05-14T13:44:35Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:osram_opto_semiconductor_sfh_409_lead_pb_free_prod-2891523]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Par la suite, le phototransistor que l'on utilisait était trop sensible à la pollution par la lumière visible, on en a donc pris un nouveau :&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor_2 : [[Fichier:SFH_309_FA.pdf]]&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Capture_d'écran_2024-04-19_150732.png]]&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12811</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12811"/>
		<updated>2024-05-14T13:41:14Z</updated>

		<summary type="html">&lt;p&gt;Amaury G : /* Détection de saisie */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;=Présentation=&lt;br /&gt;
&lt;br /&gt;
==Mission des robots==&lt;br /&gt;
&lt;br /&gt;
Le but est d'assiéger une base ennemie tout en récupérant les blessés sur le chemin. Pour cela nous avons trois robots:&lt;br /&gt;
&lt;br /&gt;
# L'éclaireur : &lt;br /&gt;
#* il assiège les ennemis&lt;br /&gt;
#* il suit une ligne (suiveur) qui forme un escargot pour finir sur un drapeau qui signalera la fin du siège&lt;br /&gt;
#* il envoie les positions des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les informations de position des blessés&lt;br /&gt;
#* il récupère les blessés et les ramène à la base (hôpital)&lt;br /&gt;
# Le blindé :&lt;br /&gt;
#* il reçoit les informations de position des ennemis&lt;br /&gt;
#* il récupère les ennemis et les ramène à la base (prison)&lt;br /&gt;
&lt;br /&gt;
==Décomposition des actions élémentaires des robots==&lt;br /&gt;
&lt;br /&gt;
Dans l'idéal voici toutes les étapes à réaliser avec les robots:&lt;br /&gt;
# Les trois robots sont au camp de base&lt;br /&gt;
# Tant que pas d'obstacles : robot 1 fait sa &amp;quot;ronde&amp;quot; en suiveur de ligne&lt;br /&gt;
# Détecte un obstacle&lt;br /&gt;
# Identification blessé / ennemi&lt;br /&gt;
# Communication avec tous les robots&lt;br /&gt;
# Le robot 1 se déplace vers l'extérieur (pour laisser la place aux autres robots de passer)&lt;br /&gt;
# Le robot 2 ou 3 (suivant celui qui est nécessaire) s'active et va à la position du robot 1 (suivant la ligne)&lt;br /&gt;
# Il attrape l'individu&lt;br /&gt;
# Retour à la base et dépose de l'individu&lt;br /&gt;
# Envoie d'un signal au robot 1 pour qu'il se réactive &lt;br /&gt;
# Envoie l'information à l'utilisateur&lt;br /&gt;
# On reboucle sur l'étape 2&lt;br /&gt;
# On atteint le drapeau et c'est gagné&lt;br /&gt;
&lt;br /&gt;
Tout au long de la mission, l'utilisateur peut suivre le nombre de blessée rapatriés et d'ennemis capturés avec un interface.&lt;br /&gt;
&lt;br /&gt;
=Décomposition du travail=&lt;br /&gt;
&lt;br /&gt;
Tâches à réaliser par ordre de priorité : &lt;br /&gt;
# Contrôle des moteurs de la plateforme principale et des plateformes secondaires&lt;br /&gt;
# Odométrie et repérage dans l'espace&lt;br /&gt;
# Détection de ligne&lt;br /&gt;
# Asservissement&lt;br /&gt;
# Détection des cibles&lt;br /&gt;
# Identification&lt;br /&gt;
# Communication sans fil entre les robots et avec l'utilisateur &lt;br /&gt;
# Attrapage de la cible&lt;br /&gt;
# Interface utilisateur&lt;br /&gt;
&lt;br /&gt;
=Contrôle des moteurs=&lt;br /&gt;
&lt;br /&gt;
==Robot 1==&lt;br /&gt;
&lt;br /&gt;
La plateforme du robot 1 est constituée de 4 roues suédoises. D'après le wiki de l'année dernière un des moteurs (le moteur 3) ne tournait que dans un sens. La cause était un des pont en H qui avait cessé de fonctionner correctement. On a alors décidé de dessouder et ressouder un nouveau pont en H. Mais en dessoudant nous avons abîmé la carte alors nous avons dû nous accommoder et rajouter des fils. Ensuite nous avons testé les moteurs qui ont tous fonctionné dans un sens mais dans l'autre sens nous avons envoyé trop de courant d'un coup. Le driver a alors de nouveau grillé. Pour y remédier nous avons pris une deuxième carte électronique sur laquelle il y avait déjà un driver pour deux moteurs que nous avons alors connecté en soudant des fils entre elle est la carte principale sur laquelle il y a la teensy. C'est après beaucoup de difficultés que nous avons réussit a faire tourner les quatre roues.&lt;br /&gt;
&lt;br /&gt;
== Robot 2 et 3 ==&lt;br /&gt;
Afin de contrôler les déplacements des robots 2 et 3 nous avons utilisés le code suivant : [[Fichier:Essai_moteurs.zip]].&lt;br /&gt;
Voici la procédure à suivre pour vérifier et tester le fonctionnement des moteurs :&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
#Alimenter la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Téléverser ce code dans la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. &lt;br /&gt;
#Alimenter les moteurs via une batterie externe. &lt;br /&gt;
&lt;br /&gt;
Ce code contient : &lt;br /&gt;
:- La déclaration des constantes et variables utiles.&lt;br /&gt;
:- La défintion des fonctions MotorCCx (x correspondant au numéro du moteur) permettant de définir la vitesse et le sens de rotation de chaque moteur.&lt;br /&gt;
:- La fonction controleMoteur qui calcul l'orientation des roues.&lt;br /&gt;
:- La boucle principale permettant de vérifier que le robot avance, recule et tourne sur lui-même.&lt;br /&gt;
&lt;br /&gt;
La fonction controleMoteur s'appuie sur la matrice donnée par Technique de l'ingénieur, à la partie 3.1 de &amp;lt;em&amp;gt;Robotique mobile : conception, modélisation et commande&amp;lt;/em&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schema angles 3 roues.png|center]].&lt;br /&gt;
&lt;br /&gt;
==Odométrie==&lt;br /&gt;
L'odométrie consiste au calcul du déplacement du robot en fonction de la rotation de ses moteurs Elle est très complexe à mettre en place. On a donc décidé de trouver des alternatives car dans notre application l'odométrie n'est pas obligatoire.&lt;br /&gt;
&lt;br /&gt;
=Détection de ligne=&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur SparkFun Line sensor Breakout QRE1113. Il s'agit d'un capteur de réflexion. Lorsque la réflexion est minimale (couleur noir), il nous renvoie la valeur de la tension d'alimentation (autour de 3,3V ici). Pour pouvoir détecter correctement il faudra le mettre à 2mm du sol.&lt;br /&gt;
&lt;br /&gt;
Datasheet :  https://www.sparkfun.com/datasheets/Robotics/QR_QRE1113.GR.pdf &lt;br /&gt;
&lt;br /&gt;
Code : [[Fichier:Test ligne.zip]]&lt;br /&gt;
&lt;br /&gt;
=Asservissement de ligne=&lt;br /&gt;
Dans cette partie, nous expliquons la méthode utilisée pour que les différents robots puissent suivre la ligne noire.&lt;br /&gt;
&lt;br /&gt;
==Lien entre la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; et &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;==&lt;br /&gt;
Les capteurs de réflexion sont connectés à la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;. Nos moteurs sont contrôlés par la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;. Afin, d'envoyer les données mesurés par ces capteurs à la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt;, il est nécessaire de faire le lien via une connexion UART. &lt;br /&gt;
&lt;br /&gt;
Dans notre cas, nous avons utilisé les ports 16 et 17 de l'&amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt; qui correspondent à UART2, pour envoyer les commandes, nous avons donc utilisé Serial2 sur cette carte. &lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; c'est l'UART1  qui est connecté ; il faut donc utiliser le Serial1. &lt;br /&gt;
&lt;br /&gt;
Sur la carte &amp;lt;em&amp;gt;ESP32&amp;lt;/em&amp;gt;, il faut écrire : &lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
void setup() &lt;br /&gt;
{&lt;br /&gt;
  // put your setup code here, to run once:&lt;br /&gt;
  Serial2.begin(115200); // Initialize serial communication at 115200 baud&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Puis, dans la fonction concernée : &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
Serial2.write((int) thetaP); // Envoie du float à la carte teensy&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
De manière réciproque sur le code de la carte &amp;lt;em&amp;gt;Teensy&amp;lt;/em&amp;gt; :&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
   // send data only when you receive data:&lt;br /&gt;
  if (Serial1.available() &amp;gt; 0) {&lt;br /&gt;
    // read the incoming byte:&lt;br /&gt;
    thetatest = Serial1.read();&lt;br /&gt;
  }&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Envoie de données==&lt;br /&gt;
Une fois la connexion faite, nous avons du faire la conversion des valeurs. En effet, la fonction Serial.write() ne peut écrire qu'un octet. &lt;br /&gt;
Nous avons donc convertit les valeurs sur 12 bits récupérés par les 2 capteurs (grâce à &amp;lt;em&amp;gt;capteurD = analogRead(CAN1); &amp;lt;/em&amp;gt; en données d'un octet. &lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
thetaP = ((255.0 / 8190.0) * thetaP) + 127.5;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Codes utilisés==&lt;br /&gt;
[[Fichier:AsservissementLigneESP.zip]]&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
[[Fichier:Essai moteur v3.zip]]&lt;br /&gt;
&amp;lt;/br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=Détection des cibles=&lt;br /&gt;
La détection de cible consiste à repérer les cibles qui se trouvent à une certaine distance bien définie du robot, puis d'exécuter les actions nécessaires correspondantes. &lt;br /&gt;
Cela nécessite l'utilisation des capteurs afin de collecter les données de distance entre l'objet (cible) et le robot, puis lire les données recueillies afin d'appliquer les actions prédéfinies.&lt;br /&gt;
&lt;br /&gt;
Plusieurs possibilités ont été envisagées : &lt;br /&gt;
#Capteur ultrason : ce capteur était trop imprécis de près. Il permet de détecter des obstacles imposants, nous allons donc l'utiliser plus tard pour la détection d'amers. &lt;br /&gt;
#Télémètre infrarouge : Distance minimale de détection trop élevée (environ 10 cm).&lt;br /&gt;
#Capteur à effet Hall : Ne capte que des aimants et uniquement de près et dans la direction du champ magnétique, ce qui est inutile dans notre cadre d'utilisation. &lt;br /&gt;
#Capteur de lumière infrarouge : Distance maximale de détection trop élevée (plusieurs mètres).&lt;br /&gt;
#Capteur couleur : Ce capteur nous permet de capter des couleurs (blanc, bleu, rouge, vert) à une distance assez faible (environ 8cm). &lt;br /&gt;
&lt;br /&gt;
On a donc choisi le capteur de couleur. Malgré sa faible distance de détection, il est assez fiable et nous permet de simplifier l'identification des cibles. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
On utilise le capteur TCS3200&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
=Identification des cibles=&lt;br /&gt;
Une fois que le robot a détecté la présence de cibles à proximité, encore faut-il les identifier pour différencier les alliés des ennemis. Pour cela, on utilise un capteur de couleur, plus précisément le modèle TCS3200.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Datasheet : [[Fichier:TCS3200_(1).PDF]]&lt;br /&gt;
&lt;br /&gt;
Code Arduino_Uno : [[Fichier:Test_color_sensor_4.zip]]&lt;br /&gt;
&lt;br /&gt;
Code ESP32 THING : [[Fichier:Test_color_sensor_esp_1.zip]]&lt;br /&gt;
&lt;br /&gt;
On utilise le capteur pour identifier les objets rouges et les objets bleus. La mesure fonctionne jusqu'à environ 5cm.&lt;br /&gt;
&lt;br /&gt;
=Conception des cibles=&lt;br /&gt;
Les cibles ont été faites pour faciliter la préhension avec la pince&lt;br /&gt;
&lt;br /&gt;
=Système de Préhension=&lt;br /&gt;
&lt;br /&gt;
==Capture==&lt;br /&gt;
Les robots 2 et 3 doivent ramener une cible à leur base &amp;lt;br&amp;gt; &amp;lt;br&amp;gt;&lt;br /&gt;
Plusieurs solution ont été envisagées :&lt;br /&gt;
#Un électro-aimant : Efficace uniquement à très courte distance (autour de 1cm). Pour palier à cela on a envisagé de le mettre sous le robot mais cela cause des problèmes de demi-tour et d'empilement dans les zones de dépôts. De plus, il chauffe assez rapidement, alimenté sous 24V.&lt;br /&gt;
#Une spatule qui s'inclinerait, et qui passerait sous le personnage : problèmes de stabilité et de précision.&lt;br /&gt;
#Une pince : plus stable, nécessite un servo moteur, plus maniable.&lt;br /&gt;
&lt;br /&gt;
On a opté pour la pince qui semple être la solution la plus pratique et efficace pour notre cas. On a envisagé plusieurs méthodes : conception en lego, pièce en imprimante 3D ou tout simplement un achat. C'est cette dernière solution qui a eu notre préférence.  On a choisit une pince adapté à notre servo; On va la modifié pour qu'elle corresponde aux dimension de la cible.&lt;br /&gt;
&lt;br /&gt;
Modèle de la pince : Kitronik Klaw MK2 Robotic Gripper Kit.&lt;br /&gt;
&lt;br /&gt;
On va utiliser le servo moteur suivant : MicroServo99 qui a une amplitude de 180° &amp;lt;br&amp;gt;&lt;br /&gt;
Code : [[Fichier:Servo.zip]]&lt;br /&gt;
&lt;br /&gt;
==Détection de saisie==&lt;br /&gt;
Il va nous falloir détecter la présence de cible dans la pince pour activer sa fermeture. Pour cela nous avons décider d'utiliser un capteur optique qui arrêtera le robot lorsque la cible est détectée et fermera la pince.&lt;br /&gt;
&lt;br /&gt;
Nous n'avons pas trouvé de capteurs correspondant à nos besoins, nous avons donc décidé d'en concevoir un par nous même. On utilise pour cela un émetteur fonctionnant avec une LED émettant dans l'infrarouge, à 950nm, et d'un récepteur fonctionnant avec un phototransistor, ayant un maximum de sensibilité vers 900nm.&lt;br /&gt;
&lt;br /&gt;
Datasheet LED : [[Fichier:SFH485P.pdf]]&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor : [[Fichier:OFT-3301.pdf]]&lt;br /&gt;
&lt;br /&gt;
Par la suite, le phototransistor que l'on utilisait était trop sensible à la pollution par la lumière visible, on en a donc pris un nouveau :&lt;br /&gt;
&lt;br /&gt;
Datasheet phototransistor_2 : [[Fichier:SFH_309_FA.pdf]]&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Capture_d'écran_2024-04-19_150732.png]]&lt;br /&gt;
&lt;br /&gt;
=Communication Wi-Fi=&lt;br /&gt;
Notre cahier des charges inclut la nécessité de communication entre les trois machines ainsi que l'utilisateur. Deux choix s'offrent à nous, la communication Bluetooth ou bien la communication Wi-Fi. Après avoir vu les échecs essuyés par les groupes des années précédentes quand ils essayaient d'utiliser cette technologie, nous avons décidé d'utiliser la communication Wi-Fi. &lt;br /&gt;
&lt;br /&gt;
==Connexion à la carte ESP32==&lt;br /&gt;
La première marche à franchir est de réussir à connecter les robots à un point d'accès Wi-Fi. Pour cela, la carte ESP32 dispose d'un module qui le permet. &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Voilà le code: [[Fichier:Connexion_wifi.zip]] &amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Ce dernier est assez simple. Dans un premier temps, on appelle une fonction permettant de rechercher et d'afficher dans la console tous les points d'accès Wi-Fi disponibles dans les environs de la carte. Ensuite, en remplaçant les valeurs des variables ssid et password par le nom du réseau et le mot de passe pour y accéder, on peut s'y connecter et récupérer l'adresse IP de la carte sur ledit réseau.&lt;br /&gt;
 Teensy :&lt;br /&gt;
::- Installer le support de la carte dans l'IDE Arduino via ce [https://www.pjrc.com/teensy/td_download.html lien]&lt;br /&gt;
&lt;br /&gt;
==Interface utilisateur==&lt;br /&gt;
Pour mettre en forme les deux informations sur le nombre de soldats sauvés et capturés et assurer un retour utilisateur clair, nous avons décidé de créer une page internet qui va mettre en forme les données susmentionnées.&lt;br /&gt;
&lt;br /&gt;
=Attention=&lt;br /&gt;
&lt;br /&gt;
Pour l'année prochaine, la carte électronique pour la teensy, les drivers et les moteurs de la plateforme principale serait a changer si possible vu comment elle est soudée. Le mieux serait de la refaire et de la commander.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=Télémètre ultrason=&lt;br /&gt;
&lt;br /&gt;
On utilise un télémètre ultrason pour les robots 2 et 3 dans 2 circonstances :&lt;br /&gt;
&lt;br /&gt;
-Quand les robots reviennent à la base, ils détectent un amer (plafond) qui leur signale de bifurquer vers leur base.&lt;br /&gt;
&lt;br /&gt;
-Dans la base, ils détectent un amer qui leur indique de faire demi-tour&lt;/div&gt;</summary>
		<author><name>Amaury G</name></author>
		
	</entry>
</feed>