Piloter un moteur avec un module IRF520N – Arduino

Nous allons ici utiliser un module IRF520N afin d’alimenter un moteur à courant continu.

Ce module permet d’activer des charges avec une demande d’intensité assez importante.

Le datasheet du transistor est disponible ici : IRF520N

Caractéristique du module :
– Alimentation: 3,3 ou 5 V
– Tension de sortie: 0 à 24 V
– Courant de sortie: 5 A maxi
– Dimensions: 34 x 26 x 23 mm

1er exemple :

Ce premier code permet de faire tourner le moteur, et l’arrêter toutes les secondes. Ce programme permet déjà de déterminer que le câblage de notre transistor est correct, et que le moteur est en bon état de fonctionnement.

Nous utilisons la sortie 3, qui permet d’effectuer une modification du rapport cyclique. Cette modification permettra dans le second code de faire tourner le moteur à différentes vitesses de rotation.

 

Câblage :

Code :

// Moteur branché sur l'interface 3
int moteur = 3;

void setup() {
// Definir le moteur en sortie
pinMode(moteur, OUTPUT);
}

void loop() {
// Alimenter le moteur
digitalWrite(moteur, HIGH);
// Pause 1 seconde
delay(1000);
// Eteindre le moteur
digitalWrite(moteur, LOW);
// Pause 1 seconde
delay(1000);
}

 


2ND exemple :

Dans le second programme, nous allons utiliser un potentiomètre permettant de faire varier la vitesse de rotation du moteur.

L’utilisation d’un potentiomètre est indiqué ici

Dans le code proposé, lors de mes essais,le potentiomètre variait entre 184 et 873. Mais quelques fois, ces valeurs augmentaient de quelques décimales.
J’ai donc imposé une valeur min et une valeur max pour le potentiomètre :

// Valeur min du potentiometre
if (Pot < 184)
{
Pot = 184;
}
// Valeur max du potentiometre
if (Pot > 873)
{
Pot = 873;
}

Nous allons utiliser un signal PWM. Vous pouvez consulter cet article qui explique le rôle d’un signal PWM.

La commande analogWrite permet d’envoyer le rapport cyclique au moteur. Cette valeur est comprise entre 0 et 255. Il faut donc définir une fonction permettant de traduire les valeurs des potentiomètres vers la valeur permettant d’alimenter le moteur.

La commande map effectuera donc un rapport proportionnel à partir des valeurs 0 => 0 et 1023 => 255. Or chez nous, le min et le max sont différents, donc 184 => 0 et 873 => 255

Commande map :

map(variable, ValeurMin, ValeurMax, versValeurMin, versValeurMax);

–> Lire la variable Pot
–> Valeur Min = 184  —- Valeur Max = 873
–> Valeur Min souhaitée = 0 —– Valeur Max souhaitée = 255

//Definir la valeur à envoyer au moteur : 184 => 0 et 873 => 255)
Valeur_Moteur = map(Pot, 184, 873, 0, 255);

 

Câblage :

 

Code :

int Pot;  //Initialise la variable qui va recueillir la valeur du potentiomètre

// Moteur branché sur l'interface 3
int Moteur = 3;

// Valeur pour le moteur (varie entre 0 et 255)
int Valeur_Moteur;

void setup() {

Serial.begin(9600); //Initialise la communication entre le PC et Arduino
pinMode(Moteur, OUTPUT);
}

void loop() {

//Lire la valeur du potentiomètre
Pot = analogRead(A0);

//Affiche la valeur du potentiomètre sur le moniteur série
Serial.print("Potentiometre : "); Serial.println(Pot);

// Valeur min du potentiometre
if (Pot < 184)
{
Pot = 184;
}
// Valeur max du potentiometre
if (Pot > 873)
{
Pot = 873;
}

//Definir la valeur à envoyer au moteur : 184 => 0 et 873 => 255)
Valeur_Moteur = map(Pot, 184, 873, 0, 255);

Serial.print("Moteur : "); Serial.println(Valeur_Moteur); //Affiche la valeur du potentiomètre sur le moniteur série

// Envoie de la valeur de sortie au moteur
analogWrite(Moteur, Valeur_Moteur);

delay(200);

}

Un commentaire

Rejoignez la conversation

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *

Ce site utilise Akismet pour réduire les indésirables. En savoir plus sur comment les données de vos commentaires sont utilisées.