Créer les fonctions pour piloter les moteurs à différentes vitesses.
Avant de commencer, vous devez :
Se référer à la mise en route du PAMI pour plus de détails
Lorsque vous avez testé le bon fonctionnement des moteurs, vous vous êtes assuré qu'avec une tension de 3,3V sur la broche « vitesse » (ou « Enable »), le moteur tourne à pleine vitesse. Avec 0V, il s’arrête.
Mais pour le faire tourner à la moitié de sa vitesse, envoyer une tension de 1,5V ne fera pas l’affaire. Il faut voir le L293 comme un composant tout ou rien. Le moyen de piloter une vitesse intermédiaire avec ce type de composant est d’alterner, sur de très courtes périodes, des commandes à plein régime et des commandes à 0. Si les périodes sont assez courtes, le moteur lisse ces commandes. Pour réaliser ceci, le type de signal employé est un signal à modulation de largeur d'impulsion (appelé PWM en anglais).
Voici un exemple de signal envoyant une commande de 10% au moteur.
Voici un autre exemple de signal envoyant une commande de 90% au moteur.
Les microcontrôleurs proposent des modules pour générer ce type de signaux. Deux paramètres sont importants :
Le fonctionnement exact du module PWM va dépendre de votre microcontrôleur. Nous vous conseillons fortement de lire le chapitre associé dans la fiche technique de votre microcontrôleur (ici celle du RP2040) et le SDK en C (ici celui du RP2040). Lisez bien les documents dans cet ordre !
Initialisez les broches de sens en sortie, configurez la broche « Enable » en PWM.
Idéalement nous aimerions configurer notre fonction PWM à une fréquence comprise entre 20 kHz et 40 kHz, ce qui limite les sifflements du moteur. Seulement, notre pont en H est un peu vieux et le fabriquant conseille de ne pas dépasser 5 kHz. Configurez alors la fonction PWM à une fréquence de 5 kHz. Pour cela, vous avez en général deux paramètres sur lesquels jouer :
Commencez par déterminer la valeur de rebouclage du PWM avec la formule suivante : Rebouclage=FmicrocontrôleurFdésirée Si votre valeur de rebouclage est plus grande que celle admise par votre microcontrôleur, alors vous devrez diviser votre fréquence en entrée du PWM.
Dans notre cas, F_microcontrôleur = 125 MHz, F_désirée = 5 kHz. Nous trouvons une valeur de rebouclage à 25 000. cette valeur est admissible par le module PWM qui est sur 16 bits (max 65 535).
Le module PWM du RP2040 fonctionne sur 16 bits. 16 bits permet de coder des nombres de 0 à 65535. Tel que nous avons initialisé le module PWM, nous profitons que d’une partie de la plage des 16 bits.
Vitesse souhaitée | Commande |
---|---|
0 % | 0 |
10 % | 2500 |
50 % | 12500 |
90 % | 22500 |
100 % | 25000 |
Voici qui est vrai pour le module PWM, mais pour notre fonction qui gère la commande de la vitesse du moteur, nous souhaitons gérer une subtilité supplémentaire : le sens du moteur.
Nous aurons donc deux fonctions publiques.
La fonction d’initialisation, qui configure les broches de sens et les modules PWM.
La fonction pour envoyer une commande de vitesse. Cette fonction comporte plusieurs subtilités :
Dans le fichier .h, définissez une constante MOTEUR_COMMANDE_MAX, qui vous servira à la fois dans votre code d’initialisation et de pilotage des moteurs et dans votre code de démonstration.
Attention, pour utiliser le module PWM, vous devez éditer votre fichier CMakeLists.txt pour ajouter hardware_pwm dans « target_ling_libraries », comme ceci :
target_link_libraries(PAMI_Cours_Moteurs ... hardware_pwm ... )
Dans la partie initialisation, initialiser les moteurs avec :
Moteur_init();
Et juste après, commandez-les à 90% :
Moteur_set_commande(MOTEUR_A, 58982) ; Moteur_set_commande(MOTEUR_B, 58982) ;
Si les moteurs ne tournent pas :
Module PWM/Voie <=> broche du microcontrôleur <=> broche de la carte
Les moteurs ont une plage morte proche de 0 V. En fonction de la qualité des moteurs, cette plage morte peut aller assez haut. Ne soyez pas surpris si à 0,1V, vos moteurs ne tournent pas.
Si les moteurs tournent, c’est le moment de régler vos fonctions sens_moteurs(). Ajustez vos fonctions pour qu’avec une vitesse positive, les 2 moteurs fassent avancer le robot.
Dans la boucle principale insérez ce bout de code :
float t = Temps_get_temps_ms() / 3000. ; Moteur_set_commande(MOTEUR_A, sin(t)) ; Moteur_set_commande(MOTEUR_B, sin(t)) ;
Avec ce bout de code, votre robot avance et recule comme s’il accélérait progressivement.
Voir la branche « Moteur » du dépot
Aller, courage ! Encore une étape et nous pourrons entrer dans le vif du sujet.