Mesure du courant à l'aide d'un capteur de courant Allegro ACS758 et d'un écran OLED SSD1306 pour Arduino
Ce tutoriel vous guidera à travers le processus de mesure du courant à l'aide du capteur Allegro ACS758 et vous montrera comment afficher les résultats sur un écran OLED SSD1306. Le projet consistera à mesurer le courant circulant dans un circuit et à représenter visuellement ces données sur l'écran OLED, permettant une surveillance facile. Vous apprendrez comment connecter les composants, écrire le code et comprendre comment tout fonctionne ensemble.


Si vous souhaitez comprendre le code et son fonctionnement, assurez-vous de regarder la vidéo pour des explications plus détaillées (dans la vidéo à 02:45).
Le matériel expliqué
Les principaux composants de ce projet comprennent le capteur de courant Allegro ACS758 et l'écran OLED SSD1306. L'ACS758 est un capteur de courant à effet Hall qui mesure le courant circulant dans un conducteur avec une grande précision et fournit une tension de sortie proportionnelle à ce courant. Il peut supporter des courants allant jusqu'à 200 A et fonctionne sous une alimentation de 3,3 V ou 5 V.
L'afficheur OLED SSD1306 est un écran compact et peu gourmand en énergie qui communique via I2C. Il est couramment utilisé dans les projets Arduino en raison de sa facilité d'intégration et de sa capacité à afficher clairement des graphiques et du texte. Ensemble, ces composants créent un outil puissant pour surveiller le courant dans diverses applications.
Détails de la fiche technique
| Fabricant | Allegro Microsystems |
|---|---|
| Numéro de pièce | ACS758ECB-200U |
| Tension logique/E/S | 3,3 V / 5 V |
| Tension d'alimentation | 5 V |
| Courant de sortie (par canal) | 200 A |
| Courant de crête (par canal) | 200 A |
| Directives sur la fréquence PWM | Sans objet |
| Seuils logiques d'entrée | 0.3 V (basse), 2.7 V (haute) |
| Chute de tension / RDS(en conduction)/ saturation | 0,05 V |
| Limites thermiques | -40 à 125 °C |
| Paquet | SOIC à 8 broches |
| Notes / variantes | Modèles bidirectionnels et unidirectionnels disponibles |
- Assurez-vous que le capteur ACS758 est correctement orienté pour des mesures précises.
- Utilisez un dissipateur thermique si l'appareil fonctionne près des limites maximales de courant pour éviter la surchauffe.
- Découplez l'alimentation du capteur pour un fonctionnement stable.
- Vérifiez les connexions de câblage pour éviter les entrées flottantes qui pourraient entraîner des lectures erronées.
- Calibrez la sortie du capteur pour assurer des mesures de courant précises.
Instructions de câblage

Pour câbler le capteur de courant Allegro ACS758 et l'écran OLED SSD1306, commencez par connecter l'alimentation. Connectez la broche VCC de l'ACS758 à la sortie 5V de votre Arduino, et reliez la broche GND à la masse (GND) de l'Arduino. La broche de sortie du signal (Vout) de l'ACS758 doit être connectée à l'entrée analogique A0 de l'Arduino.
Ensuite, pour l'écran OLED SSD1306, connectez la broche VCC à la sortie 5V de l'Arduino et la broche GND à la masse. Connectez la broche SDA de l'OLED à la broche SDA de l'Arduino (A4 sur la plupart des cartes Arduino) et la broche SCL de l'OLED à la broche SCL (A5 sur la plupart des cartes Arduino). Assurez-vous que toutes les connexions sont sécurisées pour un fonctionnement fiable.
Exemples de code et guide pas à pas
#define VIN A0 // define the Arduino pin A0 as voltage input (V in)
const float VCC = 5.0; // supply voltage 5V or 3.3V
const int model = 2; // enter the model (see below)Dans le code, la variableVINest affecté à la broche analogique A0, qui lira la tension du capteur ACS758. LeVCCLa variable règle la tension d'alimentation, et lamodelLa variable définit quel modèle ACS758 est utilisé, ce qui affecte la sensibilité et les calculs de la tension de sortie.
void loop() {
float voltage_raw = (5.0 / 1023.0) * analogRead(VIN); // Read the voltage from sensor
float current = voltage / FACTOR; // Calculate the current based on voltage
}À l'intérieur duloop()fonction, le code lit la tension brute du capteur en utilisantanalogRead(VIN)et le convertit en une valeur de courant en fonction de la sensibilité définie. Cela permet de surveiller en temps réel le courant circulant dans le circuit.
if(abs(voltage) > cutOff) {
display.clearDisplay();
robojaxText("Current:", 0, 22, 2, false);
}Cette instruction conditionnelle vérifie si la valeur absolue de la tension est supérieure à lacutOfflimit. Si vrai, il efface l'affichage et met à jour l'écran OLED avec la mesure de courant actuelle. Cela garantit que seules les valeurs de courant significatives sont affichées, évitant l'encombrement de l'affichage.
Démonstration / À quoi s'attendre
Lorsque vous exécutez le programme, l'écran OLED affichera le courant mesuré en temps réel. S'il n'y a pas de courant, l'écran affichera le message Aucun courant. Assurez-vous que les connexions sont correctes pour éviter des problèmes tels que l'inversion de polarité, qui pourrait entraîner des mesures inexactes (dans la vidéo à 05:30).
/*
* Arduino Sketch for Allegro ACS758 Current Sensor with SSD1306 OLED Display
* can be used with 128x64 or 128x32 OLED displays with SSD1306 chip
* this sensor can measure current at a range of up to 200A
* It operates with 3.3V or 5V
* This video requires you to watch the following 2 videos before using this code:
* 1- ACS758 Sensor https://www.youtube.com/watch?v=SiHfjzcqnU4
* 2- SSD1306 OLED Display https://www.youtube.com/watch?v=UmYiHTOz-5k
*
* View the video instructions for this code at https://youtu.be/aHg9UrK9s9c
* Written by Ahmad Shamshiri for Robojax Video channel www.Robojax.com
* Date: June 24, 2018, at 21:44 in Ajax, Ontario, Canada
* Permission granted to share this code given that this
* note is kept with the code.
* Disclaimer: This code is "AS IS" and for educational purposes only.
* This code has been downloaded from https://robojax.com
*
*/
#include <SPI.h>
#include <Wire.h>
#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h>
#define OLED_RESET 4
Adafruit_SSD1306 display(OLED_RESET);
#define NUMFLAKES 10
#define XPOS 0
#define YPOS 1
#define DELTAY 2
#define LOGO16_GLCD_HEIGHT 64
#define LOGO16_GLCD_WIDTH 128
static const unsigned char PROGMEM logo16_glcd_bmp[] =
{ B00000000, B11000000,
B00000001, B11000000,
B00000001, B11000000,
B00000011, B11100000,
B11110011, B11100000,
B11111110, B11111000,
B01111110, B11111111,
B00110011, B10011111,
B00011111, B11111100,
B00001101, B01110000,
B00011011, B10100000,
B00111111, B11100000,
B00111111, B11110000,
B01111100, B11110000,
B01110000, B01110000,
B00000000, B00110000 };
#if (SSD1306_LCDHEIGHT != 64)
#error("Height incorrect, please fix Adafruit_SSD1306.h!");
#endif
///*** ACS758 settings starts
#define VIN A0 // define the Arduino pin A0 as voltage input (V in)
const float VCC = 5.0;// supply voltage 5V or 3.3V. If using PCB, set to 5V only.
const int model = 2; // enter the model (see below)
float cutOffLimit = 1.00;// reading cutt off current. 1.00 is 1 Amper
/*
"ACS758LCB-050B",// for model use 0
"ACS758LCB-050U",// for model use 1
"ACS758LCB-100B",// for model use 2
"ACS758LCB-100U",// for model use 3
"ACS758KCB-150B",// for model use 4
"ACS758KCB-150U",// for model use 5
"ACS758ECB-200B",// for model use 6
"ACS758ECB-200U"// for model use 7
sensitivity array is holding the sensitivity of the ACS758
current sensors. Do not change.
*/
float sensitivity[] ={
40.0,// for ACS758LCB-050B
60.0,// for ACS758LCB-050U
20.0,// for ACS758LCB-100B
40.0,// for ACS758LCB-100U
13.3,// for ACS758KCB-150B
16.7,// for ACS758KCB-150U
10.0,// for ACS758ECB-200B
20.0,// for ACS758ECB-200U
};
/*
* Quiescent output voltage is a factor of VCC that appears at the output
* when the current is zero.
* For bidirectional sensors it is 0.5 x VCC
* For unidirectional sensors it is 0.12 x VCC
* For model ACS758LCB-050B, the B at the end represents Bidirectional (polarity doesn't matter)
* For model ACS758LCB-100U, the U at the end represents Unidirectional (polarity must match)
* Do not change.
*/
float quiescent_Output_voltage [] ={
0.5,// for ACS758LCB-050B
0.12,// for ACS758LCB-050U
0.5,// for ACS758LCB-100B
0.12,// for ACS758LCB-100U
0.5,// for ACS758KCB-150B
0.12,// for ACS758KCB-150U
0.5,// for ACS758ECB-200B
0.12,// for ACS758ECB-200U
};
const float FACTOR = sensitivity[model]/1000;// set sensitivity for selected model
const float QOV = quiescent_Output_voltage [model] * VCC;// set quiescent Output voltage for selected model
float voltage;// internal variable for voltage
float cutOff = FACTOR/cutOffLimit;// convert current cut off to mV
//**** ACS758 settings ends
void setup() {
Serial.begin(9600);
// by default, we'll generate the high voltage from the 3.3v line internally! (neat!)
display.begin(SSD1306_SWITCHCAPVCC, 0x3C); // initialize with the I2C addr 0x3D (for the 128x64)
// init done
}
void loop() {
//Robojax.com ACS758 Current Sensor values start
float voltage_raw = (5.0 / 1023.0)* analogRead(VIN);// Read the voltage from sensor
voltage = voltage_raw - QOV + 0.003 ;// 0.007 is a value to make voltage zero when there is no current
float current = voltage / FACTOR;
if(abs(voltage) > cutOff ){
Serial.print("V: ");
Serial.print(voltage,3);// print voltage with 3 decimal places
Serial.print("V, I: ");
Serial.print(current,2); // print the current with 2 decimal places
Serial.println("A");
display.clearDisplay();
robojaxText("V:", 0, 0, 2, false);
String voltageS = String(voltage);// get voltage and convert it to string for display
robojaxText(voltageS +"V", 20, 0, 2, false);
robojaxText("Current:", 0, 22, 2, false);
String currentS = String(current);// get current and convert it to string for display
robojaxText(currentS +"A", 0, 40, 3, false);
display.display();
}else{
Serial.println("No Current");
display.clearDisplay();
robojaxText("No Current", 0, 0, 2, false);
display.display();
}
//Robojax.com ACS758 Current Sensor values end
delay(500);
}
/*
* robojaxText(String text, int x, int y,int size, boolean d)
* text is the text string to be printed
* x is the integer x position of the text
* y is the integer y position of the text
* size is the text size, 1, 2, 3 etc
* d is either true or false. Use true to display immediately.
*/
void robojaxText(String text, int x, int y,int size, boolean d) {
display.setTextSize(size);
display.setTextColor(WHITE);
display.setCursor(x,y);
display.println(text);
if(d){
display.display();
}
delay(100);
}
Ce dont vous pourriez avoir besoin
-
AmazonAcheter OLED 128x32 sur Amazonamzn.to
-
Amazon
-
AliExpressAchetez SSD1306 OLED 128x32 sur AliExpresss.click.aliexpress.com
Ressources et références
Aucune ressource pour le moment.
Fichiers📁
Bibliothèques Arduino (zip)
-
SSD1306-OLED-Adafruit_SSD1306-master
robojax-SSD1306-OLED-Adafruit_SSD1306-master.zip0.02 MB
Fichier Fritzing
-
OLED Mono 0,56 pouce 128x32
OLED Mono 0.56 inch 128x32.fzpz0.01 MB -
Affichage OLED monochrome SSD1306 0,96in 128x64 I2C
SSD1306 0.96in 128x64 I2C Monochrome OLED Display.fzpz0.01 MB
Manuel de l'Utilisateur
-
Manuel SSD1306 OLED
robojax-SSD1306-OLED-manual.pdf1.79 MB