Outils pour utilisateurs

Outils du site


petit_pendule_de_furuta_software

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentesRévision précédente
Prochaine révision
Révision précédente
petit_pendule_de_furuta_software [2022/09/05 07:39] – ↷ Liens modifiés en raison d'un déplacement. sergepetit_pendule_de_furuta_software [2023/05/22 14:38] (Version actuelle) – [Cartel] Benjamin Labomedia
Ligne 11: Ligne 11:
 **{{tagpage>bestiaire_ia|Toutes les pages sur le Bestiaire Intelligence Artificielle}}** **{{tagpage>bestiaire_ia|Toutes les pages sur le Bestiaire Intelligence Artificielle}}**
 </WRAP> </WRAP>
 +====== Mode d'emploi ======
 +Phallocratie n°2 - le pendule de Furuta est presque plug and play, pour l'allumer, il faut mettre le bouton d'alimentation situé à l'arrière de la boite sur "1"
  
 +Ensuite, une fois l'ordi démarré, on accède à des écrans interactifs :
 +
 +{{ ::img_20230522_154329.jpg |}}
 +
 +{{ ::img_20230522_154353.jpg |}}
 +Il existe 2 modes de fonctionnement : le mode Training qui rejoue l’entraînement du pendule et le mode Testing où le modèle déjà entrainé est utilisé pour maintenir la tige à la verticale
 +
 +Via ce menu, il est aussi possible d'éteindre la Pi proprement
 +
 +{{ ::img_20230522_154429.jpg |}}
 +Pour ce mode, on peut démarrer ou arrêter l'entrainement
 +
 +{{ ::img_20230522_154411.jpg |}}
 +Pour ce mode, on peut démarrer ou arrêter le test du modèle
 +
 +====== Cartel ======
 +Phallocratie même n°2 est un pendule de Furuta réalisé par Serge Pierre dans le cadre des activités de la Labomedia.
 +
 +Le pendule de Furuta, ou pendule rotationnel inversé, se compose d'un bras entraîné qui tourne dans le plan horizontal et d'un pendule attaché à ce bras qui est libre de tourner dans le plan vertical. Il a été inventé en 1992 au Tokyo Institute of Technology par Katsuhisa Furuta et ses collègues.
 +
 +Ce robot illustre particulièrement bien ce que l'on appelle "l'apprentissage par renforcement" dans le domaine de l'intelligence artificielle. En intelligence artificielle donc, plus précisément en apprentissage automatique, l'apprentissage par renforcement consiste, pour un agent autonome (robot, etc.), à apprendre à partir d'expériences, de façon à optimiser une récompense quantitative au cours du temps, positive ou négative. En répétant les expériences, le robot progresse.
 +
 +Ce mode d'apprentissage provient de La boîte de Skinner (« Skinner box ») qui est un dispositif expérimental inventé par B. F. Skinner au début des années 1930 dans le but de simplifier l'étude des mécanismes de conditionnement. Il inventa cet appareil pour tester les capacités des rongeurs et des pigeons à subir un conditionnement opérant, c’est-à-dire faisant intervenir le comportement de l'animal et le renforcement de celui-ci par des stimuli renforçateurs (obtenir de la nourriture lorsque l'on fait la bonne action par exemple).
 +
 +Phallocratie même n°2, pour maintenir sa tige à la verticale, a ainsi appris pendant plusieurs jours, plusieurs sessions d'entrainement ont été réalisées avant de garder la version "102" présentée ici.
 +
 +Ce dispositif permet soit de démontrer le fonctionnement du pendule avec l''entraînement réalisé (Mode Testing), soit de rejouer l’entraînement en se déplaçant éventuellement dans les phases de cet entraînement (mode Training).
 +
 +Réalisation : Serge Pierre avec l'aide d'adhérent-es de la Labomedia
 +Documentation : https://ressources.labomedia.org/Accueil?do=search&id=accueil&q=furuta
 +
 +{{ ::cartel_phallocratie_meme_n_2.odt |}} {{ :cartel_phallocratie_meme_n_2.pdf |}}
 +
 +=====Les sources du projet=====
 +  * **[[https://github.com/sergeLabo/furuta/tree/main/petit_furata|Petit Pendule de Furuta tout en Python]]**, 2 encodeurs optique US DIGITAL 1000 points.
 +{{ :media_16:petit_furuta_structure_code.png?400 |}}
 ===== GPIO d'un Pi3 B+ ou d'un Pi4===== ===== GPIO d'un Pi3 B+ ou d'un Pi4=====
 {{ :media_15:raspi_gpio_wiki.png?400 |}} {{ :media_15:raspi_gpio_wiki.png?400 |}}
Ligne 44: Ligne 82:
  
 ====Câblage sur la Pi==== ====Câblage sur la Pi====
-{{:media_10:branchement_pi-1.png?400|}}+{{ :media_10:branchement_pi-1.png?400 |}}
  
 ====Tension d'entrée des GPIO sur la PI==== ====Tension d'entrée des GPIO sur la PI====
Ligne 76: Ligne 114:
 https://www.raspberryme.com/comment-utiliser-un-encodeur-rotatif-avec-le-raspberry-pi/\\ https://www.raspberryme.com/comment-utiliser-un-encodeur-rotatif-avec-le-raspberry-pi/\\
  
-**Latence des callbacks** +====Latence des callbacks==== 
-Dans certains transitoires avec des rotations sur les codeurs rapides, les callbacks ne sont pas traités en temps réelsce qui provoque de la latence. Un décalage de plus de 2 minutes a été constaté+Une Raspberry Pi peut gérer des callbacks jusqu'à 20kHzsans erreur et sans latence.\\ 
 +Un codeur de 1000 points au tour appelle 2000 callbacks sur le canal A (montée et descente des tops), et autant sur le canal B. Soir des callbaks à 4000 Hz à un tour par seconde.\\ 
 +Un codeur de 4000 points appelle des callbacks à 16 000 Hz à un tour par seconde.\\
  
 +Soit 20 kHz pour les 2 codeurs à un tour par seconde. Mais certain transitoires vont plus vite que 1 tour par seconde. Les callbacks sont empilé sur une pile qui a été estimée à 2 mn après quelques heures d'apprentissage. Les actions moteur sont alors du n'importe quoi.
  
-====Branchement sur ESP32 et Com en SPI avec Raspi==== +===Solution=== 
-**Essais infructueux --> Abandon**+**Le codeur de 4000 points du balancier a été remplacé par un codeur 1000 points**.\\ 
 +La fréquence a 1 tour par seconde devient 8 kHz: ce qui fait une grosse marge par rapport à 20 kHz.
  
-{{:media_16:branchements_esp32.png?500|}}{{:media_16:com_spi_esp32_pi.png?400|}}+La précision est tout à fait suffisantele point zéro est défini à -/+ 1 ou 2 ou 3 points, c'est très sensible.
  
-===Activation du SPI=== +=====Recherche sur ESP32===== 
-[[https://www.raspberryme.com/activer-linterface-spi-sur-le-raspberry-pi/#Methode_2_-_Utilisation_de_la_Configuration_Raspberry_Pi|Activation du SPI]] Aller dans Menu, Settings, Enable SPI, puis [[https://www.raspberryme.com/activer-linterface-spi-sur-le-raspberry-pi/#Etape_2_-_Verifier_si_SPI_est_active_facultatif|Vérifier si SPI est activé]]+====Branchement sur ESP32 et Com en SPI avec Raspi==== 
 +{{:media_16:branchements_esp32.png?300|}}{{:media_16:com_spi_esp32_pi.png?200|}}
  
 ===Ressources=== ===Ressources===
   * **[[https://www.best-microcontroller-projects.com/rotary-encoder.html|best-microcontroller-projects.com]]** Rotary Encoder: Immediately Tame your Noisy Encoder! Find out how to Instantly Stop Switch Bounce using one of 2 software methods. Easily get Reliable Operation from your Encoder.   * **[[https://www.best-microcontroller-projects.com/rotary-encoder.html|best-microcontroller-projects.com]]** Rotary Encoder: Immediately Tame your Noisy Encoder! Find out how to Instantly Stop Switch Bounce using one of 2 software methods. Easily get Reliable Operation from your Encoder.
   * Voir la page dédiée: **[[rotary_encoder_controller]]**   * Voir la page dédiée: **[[rotary_encoder_controller]]**
-=====Codeurs à Effet Hall de pandauto.com===== 
-**Ces codeurs sont construits sur une puce AS5048A** 
- 
-==== ZoetropeLabs propose une lib pour Arduino====  
-  * **[[https://github.com/ZoetropeLabs/AS5048A-Arduino|AS5048A-Arduino de ZoetropeLabs]]** 
- 
-Télécharger le projet: aller dans le dossier AS5048A-Arduino-master/lib, compresser en zip le dossier AS5048A.\\ 
-Dans Arduino IDE, allez à Sketch --> Include Library --> Add ZIP Library --> ajouter le zip de AS5048A 
- 
-Exemple: 
- 
-<code C++> 
-#include <AS5048A.h> 
-AS5048A angleSensor(10); 
-void setup() 
-{       Serial.begin(115200); 
- angleSensor.init();      } 
-void loop() 
-{       delay(10); 
- word val = angleSensor.getRawRotation(); 
-        Serial.println(val, DEC);                } 
-</code> 
- 
-====Ressources==== 
-  * **[[https://fr.wikipedia.org/wiki/Serial_Peripheral_Interface|Serial Peripheral Interface]]** Une liaison SPI est un bus de données série synchrone baptisé ainsi par Motorola, au milieu des années 1980 qui opère en mode full-duplex. 
-  * https://pinout.xyz/pinout/spi# 
-  * **[[spi_documentation_1|]]** 
-  * **[[communication_protocole_spi]]** 
-  * **[[https://fr.aliexpress.com/item/1005003038741007.html?gatewayAdapt=glo2fra&spm=a2g0o.order_detail.0.0.48537d56yRtx7c|aliexpress.com]]** Capteur d'angle Hall rotatif, sortie de Communication SPI 0-360 degrés, alimentation 5V DC 
-Doc probable pour le SPI du capteur à effet hall chinois : [[https://fr.aliexpress.com/item/4001028228270.html | page aliexpress ]] 
-Il semblerait que le circuit dans le coder est peut être celui-ci, car le datagramme SPI est très similaire : [[ https://ams.com/documents/20143/36005/AS5048_DS000298_4-00.pdf/910aef1f-6cd3-cbda-9d09-41f152104832 | datasheet ]]\\ 
-Il faudrait donc voir, car pour lire une données théoriquement il faut envoyer une commande READ qui permet de recevoir simultanément la valeur au moment du READ précédent.\\ 
-On devrait avoir 16 bits à lire :  
-- 1 bit de parité 
-- 1 bit error flag 
-- 14 bits indiquant l'angle absolue sur 14 bits.\\ 
-Lorsqu'on lit les données SPI dans les 2 octets, il y a donc les 6 derniers bits du premier octet à concaténé avec les 8 bits du second octet pour reconstituer le mot de 14 bits.\\ 
- 
  
 {{tag> bestiaire_ia petit_pendule_furuta raspberry_pi raspbian sb }} {{tag> bestiaire_ia petit_pendule_furuta raspberry_pi raspbian sb }}
petit_pendule_de_furuta_software.1662363565.txt.gz · Dernière modification : 2022/09/05 07:39 de serge