Archives

Démarrage sûr et contrôle d’angle avec AccelStepper pour moteur pas à pas

.

Découvrez comment piloter un moteur pas à pas de manière précise et flexible avec notre code basé sur la bibliothèque AccelStepper. Conçu pour éviter les déclenchements intempestifs grâce à une gestion intelligente des rebonds, ce code vous offre une maîtrise totale sur la rotation de votre moteur.

Sommaire :

 

Rotation sur mesure :

Avec notre code, vous avez le contrôle total sur la rotation de votre moteur. La variable valeur_de_la_rotation est votre outil principal pour définir l’angle de rotation souhaité. Vous envisagez une double rotation complète ? Réglez-la à 720 degrés. Vous avez besoin d’une précision chirurgicale pour un projet spécifique ? Aucun problème, ajustez-la à 10 degrés ou même moins. Cette flexibilité vous permet d’adapter le comportement du moteur à une multitude de scénarios, qu’il s’agisse d’une application industrielle nécessitant des rotations répétitives ou d’un projet artistique où chaque degré compte.

Adaptabilité du moteur :

Grâce à l’utilisation de la bibliothèque AccelStepper, ce code offre une flexibilité remarquable pour s’adapter à différents types de moteurs pas à pas et leurs drivers. En combinant les variables DEGRES_PAR_PAS et MICRO_PAS, il est possible d’ajuster le comportement du moteur avec précision. Par exemple, si vous utilisez un moteur conçu pour 400 pas par tour, ce qui équivaut à 0.9 degrés par pas, il suffit d’ajuster la variable DEGRES_PAR_PAS à 0.9. De même, pour un moteur standard à 200 pas par tour, qui équivaut à 1.8 degrés par pas, modifiez cette variable à 1.8. La variable MICRO_PAS joue également un rôle crucial en permettant de définir le niveau de micro-stepping de votre driver. Cela contribue à une plus grande précision et flexibilité dans le contrôle de votre moteur pas à pas, rendant l’utilisation d’AccelStepper essentielle pour un démarrage sûr et un contrôle d’angle précis

.

séparateur-redohm-001

 

AccelStepper stepper(AccelStepper::DRIVER, impulsion, direction) :

Cette ligne de code crée une instance de l’objet AccelStepper, qui est utilisée pour contrôler le moteur pas à pas.

  • AccelStepper : Il s’agit du nom de la classe fournie par la bibliothèque AccelStepper. Cette classe offre diverses fonctionnalités pour contrôler les moteurs pas à pas, comme la gestion de l’accélération et de la vitesse.
  • stepper : C’est le nom de l’objet que vous créez. Cet objet représente votre moteur pas à pas et vous permettra de le contrôler en appelant différentes méthodes sur cet objet.
  • AccelStepper::DRIVER : Ce paramètre indique que vous utilisez le mode « DRIVER » pour AccelStepper. Ce mode est utilisé lorsque vous contrôlez un moteur pas à pas avec un pilote externe, ce qui est commun pour les configurations de moteurs pas à pas plus complexes. Dans ce mode, vous ne fournissez que les pins d’impulsion et de direction à l’objet AccelStepper.
  • impulsion : C’est le pin Arduino connecté à la broche d’impulsion (step) du pilote de votre moteur pas à pas. Chaque impulsion envoyée sur ce pin fera avancer le moteur d’un pas.
  • direction : C’est le pin Arduino connecté à la broche de direction du pilote de votre moteur pas à pas. Le signal envoyé sur ce pin détermine la direction dans laquelle le moteur tournera.

↩️

stepper.setCurrentPosition() :

Est une fonction importante pour le contrôle précis des moteurs pas à pas, permettant aux développeurs de définir ou de redéfinir le point de référence à partir duquel les mouvements du moteur sont calculés. Cette capacité de réinitialisation est particulièrement utile dans les applications automatisées et robotiques où la position exacte et la répétabilité des mouvements sont cruciales.

Réinitialisation de la Position du Compteur de Pas :

  • Lorsque vous exécutez stepper.setCurrentPosition(0);, vous dites essentiellement à la bibliothèque AccelStepper de considérer la position actuelle du moteur comme la position « 0 » du compteur de pas.
  • Cela n’affecte pas physiquement la position du moteur, mais modifie la valeur de référence interne utilisée par le contrôleur pour suivre la position du moteur.

Considérations Techniques :

  • Précision : Crucial pour les applications où la position exacte du moteur doit être connue, comme dans les systèmes de positionnement ou les appareils de précision.
  • Implications de Réinitialisation : Après l’appel de cette méthode, toute commande de mouvement telle que moveTo() ou move() interprétera la position actuelle du moteur comme étant « 0 ». Tous les mouvements futurs seront donc relatifs à cette nouvelle position de référence.

↩️

stepper.setAcceleration() :

La méthode setAcceleration() de la bibliothèque AccelStepper est utilisée pour définir la valeur d’accélération du moteur pas à pas. L’accélération est la vitesse à laquelle le moteur change sa vitesse. Elle est exprimée en pas par seconde au carré (pas/s^2).

  • Paramètre : La fonction prend un seul argument, qui est la valeur d’accélération souhaitée. Dans l’exemple donné, 2000 signifie que l’accélération du moteur est réglée sur 2000 pas par seconde au carré.
  • Comportement : Lorsque cette fonction est appelée, elle ne fait pas bouger le moteur immédiatement. Elle définit simplement la manière dont le moteur accélère pour atteindre sa vitesse maximale (définie par setMaxSpeed()) et comment il décélère pour s’arrêter. Une accélération plus élevée signifie que le moteur atteindra sa vitesse maximale plus rapidement.
  • Utilisation : Cette fonction est généralement appelée dans la section setup() du code Arduino pour initialiser l’accélération du moteur. Elle est particulièrement utile pour éviter les à-coups ou les vibrations qui peuvent survenir si le moteur démarre ou s’arrête brusquement.

Exemple d’utilisation :

La fonction stepper.setAcceleration(2000); est utilisée pour définir comment le moteur pas à pas accélère et décélère. Une accélération appropriée permet d’éviter les vibrations et d’assurer un mouvement fluide du moteur. Dans cet exemple, l’accélération est réglée sur 2000 pas par seconde au carré, ce qui signifie que le moteur augmentera ou diminuera sa vitesse à ce taux jusqu’à ce qu’il atteigne sa vitesse maximale ou s’arrête.

↩️

.

Pour tout problème de téléchargement ou pour nous suivre sur les réseaux sociaux voici les plateformes  sur lesquelles nous éditons.
Cliquez sur celles qui vous intéressent .

Facebook Twitter Youtube 

Grabcad Thingiverse Cults  

Retour au menu tuto