﻿<?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=LavanyaSEBASTIAN</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=LavanyaSEBASTIAN"/>
	<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=Sp%C3%A9cial:Contributions/LavanyaSEBASTIAN"/>
	<updated>2026-04-06T19:04:40Z</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=12820</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12820"/>
		<updated>2024-05-14T14:14:27Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : &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;
=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>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12739</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12739"/>
		<updated>2024-04-19T14:39:57Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : /* Robot 1 */&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;
=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, à 880nm, 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;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12738</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12738"/>
		<updated>2024-04-19T14:36:11Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : &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 les deux cartes.&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;
=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, à 880nm, 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;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12737</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12737"/>
		<updated>2024-04-19T14:31:48Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : /* Robot 1 */&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 les deux cartes.&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;
=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, à 880nm, 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;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12736</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12736"/>
		<updated>2024-04-19T14:04:59Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : /* Odométrie */&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;
== 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;
=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, à 880nm, 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;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12652</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12652"/>
		<updated>2024-04-16T14:06:46Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : &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;
=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;
==Odométrie ==&lt;br /&gt;
&lt;br /&gt;
==Détection de ligne==&lt;br /&gt;
&lt;br /&gt;
==Asservissement==&lt;br /&gt;
&lt;br /&gt;
==Détection des cibles==&lt;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12649</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12649"/>
		<updated>2024-04-16T13:55:15Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : &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 des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les information 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 information 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 robot&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;
=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;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12647</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12647"/>
		<updated>2024-04-16T13:52:22Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : /* Présentation */&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 des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les information 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 information 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 robot&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;
==Décomposition des fonctions électroniques==&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;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12646</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12646"/>
		<updated>2024-04-16T13:43:54Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : &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 des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur :&lt;br /&gt;
#* il reçoit les information 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 information 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 étapes==&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 robot&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&lt;br /&gt;
#&lt;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12645</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12645"/>
		<updated>2024-04-16T13:31:04Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : &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 des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur&lt;br /&gt;
* il reçoit les information 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 information de position des ennemis&lt;br /&gt;
* il récupère les ennemis et les ramène à la base (prison)&lt;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12644</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12644"/>
		<updated>2024-04-16T13:25:44Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : &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;
# 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 des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
# Le sauveteur&lt;br /&gt;
* il reçoit les information 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 information de position des ennemis&lt;br /&gt;
* il récupère les ennemis et les ramène à la base (prison)&lt;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
	<entry>
		<id>https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12643</id>
		<title>RAMBOT</title>
		<link rel="alternate" type="text/html" href="https://bacasable.arpitania.eu//index.php?title=RAMBOT&amp;diff=12643"/>
		<updated>2024-04-16T13:25:26Z</updated>

		<summary type="html">&lt;p&gt;LavanyaSEBASTIAN : &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;
# 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 des obstacles qu'il rencontre (blessé à sauver ou ennemi à capturer)&lt;br /&gt;
&lt;br /&gt;
# Le sauveteur&lt;br /&gt;
* il reçoit les information 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;
&lt;br /&gt;
# Le blindé&lt;br /&gt;
* il reçoit les information de position des ennemis&lt;br /&gt;
* il récupère les ennemis et les ramène à la base (prison)&lt;/div&gt;</summary>
		<author><name>LavanyaSEBASTIAN</name></author>
		
	</entry>
</feed>