Archives

stepper.setMaxSpeed : Clé du Contrôle de Vitesse dans AccelStepper pour moteur pas à pas

.

Dans cette vidéo, nous explorons des fonctionnalités avancées de la bibliothèque AccelStepper pour Arduino, en mettant l’accent sur la fonction stepper.setMaxSpeed(). Cette fonction est essentielle pour contrôler avec précision la vitesse d’un moteur pas-à-pas. Nous expliquons comment elle permet d’ajuster dynamiquement la vitesse maximale du moteur, offrant ainsi un contrôle fin et réactif, adapté à une multitude d’applications.

Sommaire : 

.

Vous apprendrez que, bien que setMaxSpeed() définisse la vitesse cible, la vitesse réelle peut être influencée par d’autres facteurs, tels que la charge du moteur et la tension d’alimentation. De plus, nous explorerons l’interaction entre setMaxSpeed() et setAcceleration(), montrant comment ces deux fonctions travaillent de concert pour assurer un démarrage et un arrêt en douceur du moteur, évitant ainsi les saccades et garantissant un mouvement fluide.

Ce contrôle précis de la vitesse est particulièrement crucial dans des domaines tels que la robotique de précision, les imprimantes 3D et les équipements automatisés, où la régularité du mouvement influence directement la qualité du résultat.

En lien avec le code fourni, nous démontrerons comment la vitesse du moteur est ajustée en temps réel via un potentiomètre, offrant un contrôle interactif et adaptable, crucial pour des applications nécessitant une réponse rapide et précise. Cette vidéo est une ressource pour tous ceux qui cherchent à comprendre et à maîtriser le contrôle des moteurs pas-à-pas dans leurs projets de robotique et d’automatisation.

.
Quels détails techniques caractérisent la méthode stepper.setMaxSpeed dans Arduino ?

La méthode stepper.setMaxSpeed dans Arduino définit la vitesse maximale du moteur pas-à-pas en pas par seconde. Les développeurs l’utilisent pour un contrôle précis de la vitesse, crucial dans des applications comme les imprimantes 3D. La vitesse doit correspondre aux capacités du moteur. Une vitesse trop élevée risque de provoquer des sauts de pas. Le pilote de moteur influe aussi sur la vitesse maximale. On appelle généralement cette méthode en début de programme ou avant un mouvement spécifique. Elle fonctionne bien avec stepper.setAcceleration et stepper.moveTo.

↩️

.
Pouvez-vous résumer comment intégrer stepper.setMaxSpeed dans un programme Arduino pour contrôler un moteur pas-à-pas ?

Incluez la bibliothèque AccelStepper. Initialisez ensuite le moteur avec AccelStepper stepper. Définissez la vitesse maximale avec stepper.setMaxSpeed(valeur). Utilisez stepper.run() pour activer le mouvement. Adaptez la vitesse selon le projet.

↩️

.

Quel paramètre faut-il fournir à stepper.setMaxSpeed et comment est-il mesuré ?

Pour la méthode stepper.setMaxSpeed, le paramètre nécessaire est la vitesse maximale du moteur. Cette vitesse est mesurée en ‘pas par seconde’ (pps), une unité indiquant combien de pas individuels le moteur peut faire en une seconde. La valeur doit être un nombre positif, adaptée aux spécifications techniques du moteur pour assurer un fonctionnement optimal et sécurisé.

↩️

.

.

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
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
Interface Série pour Régulation de Moteur Brushless avec Contrôleur BLD-300B

.

📜 Description : Dans cette vidéo, nous allons explorer un programme Arduino conçu pour contrôler la vitesse d’un moteur brushless en utilisant un contrôleur BLD-300B. Le code utilise la communication série pour recevoir des valeurs de vitesse entre 0 et 255, qui sont ensuite appliquées au moteur via ce contrôleur spécifique.

🔍 À propos du Contrôleur BLD-300B : Le BLD-300B est un contrôleur de moteur brushless qui permet une régulation fine de la vitesse et du couple du moteur. Il est souvent utilisé dans des applications industrielles et de robotique pour un contrôle précis.

🔑 Points clés :

1️⃣ Utilisation du Contrôleur BLD-300B : Nous utilisons le contrôleur BLD-300B pour une meilleure régulation de la vitesse du moteur.

2️⃣ Configuration de la broche PWM : La broche 9 de la carte Arduino est configurée comme sortie pour le signal PWM.

3️⃣ Communication Série : Le programme utilise la communication série pour recevoir les valeurs de vitesse du moteur.

4️⃣ Validation des Entrées : Le code vérifie si les valeurs reçues sont dans la plage autorisée (0-255) avant de les appliquer.

5️⃣ Feedback Utilisateur : Des messages sont affichés sur le moniteur série pour informer l’utilisateur de l’état actuel du système.

N’oubliez pas de 👍 aimer la vidéo, de 🔔 vous abonner et de 💬 laisser un commentaire si vous avez des questions ou des suggestions !

📅 Date : 04/10/2023
🛠️ Version de l’IDE Arduino : 2.2.1
👨‍💻 Réalisé par : Hervé Mazelin pour RedOhm

 

Informations complémentaires :

Sur une carte Arduino, le signal PWM (Pulse Width Modulation, ou Modulation de Largeur d’Impulsion en français) est généralement utilisé pour simuler un signal analogique à l’aide d’une sortie numérique. Les cartes Arduino ont des broches spécifiques capables de générer des signaux PWM, souvent marquées avec un symbole « ~ » à côté du numéro de la broche.

La fonction analogWrite() est utilisée pour envoyer un signal PWM à une broche spécifique. Cette fonction prend deux arguments : le numéro de la broche et la valeur du rapport cyclique, qui est généralement un nombre entre 0 et 255. Par exemple, analogWrite(9, 127) enverra un signal PWM avec un rapport cyclique d’environ 50% à la broche 9.

Le microcontrôleur sur la carte Arduino génère le signal PWM en alternant rapidement la broche entre les états haut et bas, en modifiant la durée pendant laquelle la broche reste à chaque état selon la valeur du rapport cyclique spécifié. Par exemple, une valeur de 127 sur une échelle de 0 à 255 fera en sorte que la broche soit à l’état haut environ 50% du temps et à l’état bas les 50% restants.

Le signal PWM sur Arduino est souvent utilisé pour contrôler la vitesse des moteurs, régler la luminosité des LEDs, ou même générer des sons simples. Cependant, il est important de noter que même si cela peut simuler un comportement analogique, le signal généré est en réalité toujours numérique (état haut ou bas), et certains dispositifs peuvent nécessiter un filtrage supplémentaire pour fonctionner correctement avec un signal PWM.

 

Facebook Twitter  Youtube

Grabcad Thingiverse Cults  

Retour au sommaire

 

Surveillance de Potentiomètre avec Résolution ADC de 14 bits sur Arduino UNO R4

.

Ce code Arduino a été spécialement conçu pour surveiller les valeurs d’un potentiomètre connecté à la broche A0 d’une carte Arduino UNO R4. L’une des caractéristiques uniques de ce code est l’utilisation d’une résolution de 14 bits pour le convertisseur analogique-numérique (ADC). Cette résolution supérieure permet des lectures plus précises et détaillées, ce qui est particulièrement utile dans des applications comme le contrôle de moteurs de précision, l’instrumentation scientifique et la surveillance environnementale.

🎯 Fonctionnalités clés :

🔌 Initialisation de la Communication Série : Le code commence par initialiser la communication série à un débit de 9600 bauds. Cette fonctionnalité est essentielle pour des applications comme la télémétrie où les données doivent être transmises à distance.

🔒 Vérification de la Communication Série : Le code s’assure que la communication série est bien établie avant de procéder à toute lecture ou écriture. C’est particulièrement utile pour des applications médicales où la fiabilité des données est cruciale.

🎛 Configuration de la Résolution ADC : Le code utilise la fonction analogReadResolution() pour configurer l’ADC à une résolution de 14 bits. Cette haute résolution est bénéfique dans des applications comme l’automatisation industrielle où une précision extrême est nécessaire.

📊 Lecture et Affichage des Valeurs : Le code lit ensuite la valeur analogique du potentiomètre et l’affiche dans le moniteur série en deux formats : décimal et binaire. Cette fonctionnalité peut être utile dans des applications d’audio de haute qualité où la représentation précise des données est requise.

⏳ Intervalle de Lecture : Le code effectue une pause de 500 millisecondes entre chaque lecture, ce qui est suffisant pour des applications comme l’agriculture de précision où les conditions peuvent changer lentement.

📋 Informations de Version :

  • 👨‍💻 Développeur : Hervé Mazelin pour RedOhm
  • 🛠 Version de l’IDE Arduino utilisée : 2.2.1
  • 📅 Date de réalisation : 07/10/2023

Ce code est idéal pour toute personne cherchant à obtenir des lectures analogiques précises pour des applications nécessitant une grande précision. Il est particulièrement adapté pour des domaines comme le contrôle de moteurs, la mesure médicale, l’instrumentation scientifique, et bien d’autres applications où la précision est cruciale.

 

Facebook Twitter  Youtube

Grabcad Thingiverse Cults  

Retour au sommaire

 

Tutoriel Arduino : Compteur de Vitesse Analogique avec Écran TFT !

.

Ce programme est conçu pour fonctionner avec une carte Arduino et un écran TFT. Son objectif principal est d’afficher un compteur de vitesse sur l’écran TFT, simulant ainsi un tableau de bord analogique, comme celui que l’on pourrait trouver dans une voiture ou une moto.

  1. Fonctionnement de base :
    • Le programme lit une valeur analogique (provenant d’un capteur ou d’un potentiomètre connecté à la broche A9 de l’Arduino) qui est censée représenter une vitesse.
    • Cette valeur analogique est ensuite mappée (ou convertie) en une valeur de vitesse allant de 0 à une vitesse maximale définie (dans ce cas, Vitesse_max est définie à 150).
    • Le programme utilise la vitesse déduite pour ajuster une aiguille sur l’écran TFT. Cette aiguille indique la vitesse actuelle, similaire à un compteur de vitesse analogique. Outre l’aiguille, le programme affiche la vitesse exacte numériquement sur l’écran.
  2. Caractéristiques visuelles :
    • L’écran TFT affiche un cercle représentant le compteur de vitesse, avec des marques (ou graduations) pour indiquer différentes vitesses. Ces marques sont espacées de 10 unités de vitesse et sont accompagnées de chiffres pour faciliter la lecture.
    • Une aiguille pivote autour du centre du cercle, indiquant la vitesse actuelle.
  3. Mise à jour dynamique :
    • Le programme vérifie en continu la valeur analogique lue. Il met à jour l’affichage de l’aiguille et de la valeur numérique en conséquence.
    • Le programme évite les mises à jour inutiles pour réduire les clignotements sur l’écran. »Il met à jour l’affichage seulement quand la vitesse change.

Pourquoi le système de coordonnées sur un écran TFT diffère-t-il de la convention mathématique? Comment cela impacte-t-il la programmation sur ces écrans?

Lorsque nous parlons du cercle trigonométrique standard en mathématiques, il commence avec 0° à droite (sur l’axe des abscisses positif) et augmente dans le sens antihoraire.

Cependant, dans de nombreux systèmes de graphiques informatiques, y compris la plupart des écrans TFT pilotés par Arduino, le système de coordonnées est différent :

  1. Origine (0,0) : L’origine du système de coordonnées se trouve généralement dans le coin supérieur gauche de l’écran, et non au centre.
  2. Direction positive de l’axe Y : Dans la plupart des systèmes trigonométriques, l’axe Y est positif vers le haut. Mais dans de nombreux systèmes graphiques, l’axe Y est positif vers le bas.
  3. Sens de rotation : En trigonométrie, l’angle augmente dans le sens antihoraire. Cependant, sur les écrans TFT, c’est différent. L’axe Y positif change la direction. Les objets tournent dans le sens horaire.

Ces différences peuvent rendre la translation des concepts mathématiques trigonométriques dans le monde du graphisme informatique un peu déroutante au début. C’est pourquoi, par exemple, le cercle trigonométrique commence souvent à un angle différent, comme 135° pour le compteur dans le code que nous avons examiné, afin d’avoir le point de départ à l’endroit souhaité.

Ainsi, lors de la programmation pour des écrans TFT ou d’autres systèmes de graphiques informatiques, nous devons prendre en compte ces différences et ajuster les calculs en conséquence.

Pourquoi est-il nécessaire de convertir les degrés en radians lors de l’utilisation de fonctions trigonométriques sur Arduino?

Sur Arduino, la nécessité de traduire les degrés en radians n’est pas due à une limitation spécifique de la plate-forme Arduino elle-même, mais plutôt à la manière dont les fonctions trigonométriques standard, telles que sin() et cos(), sont définies dans la plupart des langages de programmation, y compris le C++ utilisé par l’Arduino.

Voici quelques raisons pour lesquelles les radians sont utilisés pour les fonctions trigonométriques :

Définition mathématique : En mathématiques, le radian est la mesure standard pour les angles. C’est une unité sans dimension qui représente le rapport entre la longueur d’un arc et le rayon du cercle. Cette propriété rend les radians plus fondamentaux et naturels pour décrire les angles dans le contexte des mathématiques.

Simplicité des formules : De nombreuses formules en trigonométrie, en analyse et en physique sont plus simples lorsqu’elles sont exprimées en radians. Par exemple, la dérivée de sin(x) est cos(x) seulement si x est en radians.

Facebook Twitter Youtube

Grabcad Thingiverse Cults  

Page d'accueil du site