Table des matières:
- Étape 1: Démonstration
- Étape 2: Ressources utilisées
- Étape 3: Schéma fonctionnel
- Étape 4: schéma
- Étape 5: LM386 - Épinglage
- Étape 6: AmpOp - Différentiel (soustracteur)
- Étape 7: AmpOp - Inverter Adder
- Étape 8: Érable Mini - Pinage
- Étape 9: Maple Mini - Épinglage - a/D utilisé dans la capture
- Étape 10: Assemblage
- Étape 11: Graphique avec les données obtenues
- Étape 12: Calcul de la valeur RMS
- Étape 13: Code source
- Étape 14: Fichiers
2025 Auteur: John Day | [email protected]. Dernière modifié: 2025-01-13 06:57
Aujourd'hui, nous utiliserons le STM32 Maple Mini pour effectuer une lecture AC. Dans notre exemple, nous obtiendrons la valeur RMS du réseau électrique. Ceci est très utile pour ceux qui souhaitent surveiller le réseau électrique pour l'Internet des objets. Nous allons ensuite créer une application utilisant la puissance de calcul du Maple Mini, appliquer un circuit électronique capable de permettre l'acquisition d'un signal 127Vac, ainsi qu'appliquer le calcul de la moyenne quadratique (RMS) sur les échantillons.
Étape 1: Démonstration
Dans notre montage aujourd'hui, nous avons le STM32, en plus de notre circuit analogique pour faire l'entrée de 110. Pour éviter les chocs, isolez la résistance qui entre par 110.
Le circuit est assez sensible. J'arrive avec 110, mais je le réduis 168 fois à l'aide du diviseur de tension et le mets dans l'amplificateur opérationnel, qui a plusieurs fonctions.
Nous avons également des condensateurs en option pour le filtrage de la source. Si votre source est de bonne qualité, vous n'avez pas besoin de les utiliser.
L'entrée AD est calculée grâce à l'oscilloscope, dans lequel vous voyez une sinusoïde, qui n'est pas 110 (mais elle est bien formée). Une autre chose est que la tension dans notre réseau électrique n'est pas de 110 (elle est en fait de 127 volts). Mais comme nous subissons un stabilisateur, il va s'ajuster à 115V.
La valeur affichée sur le moniteur série est celle qui est calculée en RMS, c'est-à-dire celle identifiée par le Fluke Meter.
Étape 2: Ressources utilisées
• Cavaliers
• Un mini à l'érable
• Protoboard
• Un amplificateur LM386
• Une source symétrique (+ 5V et -5V)
• Un trimpot multi-tours 10k (ou potentiomètre)
• Quatre condensateurs en polyester 100nF
• Trois résistances de 10k
• Quatre résistances de 470k
• Une résistance 5k6
• Une diode Zener 1n4728A
Étape 3: Schéma fonctionnel
Étape 4: schéma
Il s'agit d'un circuit que j'ai développé sur la base des spécifications que je pense être les meilleures pour cette mesure, mais il existe plusieurs autres exemples que l'on peut trouver sur Internet.
Étape 5: LM386 - Épinglage
Le LM386 dispose de deux amplificateurs pour le conditionnement ou l'amplification du signal.
Étape 6: AmpOp - Différentiel (soustracteur)
Étape 7: AmpOp - Inverter Adder
Étape 8: Érable Mini - Pinage
Broches marquées sur:
Rouge >> Tolérance 3V3
Vert >> Tolérance 5V
Étape 9: Maple Mini - Épinglage - a/D utilisé dans la capture
Je souligne ici que le pin que j'ai utilisé est le D11 qui (dans la nomenclature de la STMicroelectronics) est le PA0.
Étape 10: Assemblage
Pour notre circuit, vous aurez besoin d'une source symétrique, comme celle que nous avons créée pour ce projet. Sinon, vous aurez besoin de deux sources.
Étape 11: Graphique avec les données obtenues
Étape 12: Calcul de la valeur RMS
Étape 13: Code source
Code source - Définitions et constantes
Au début, nous avons défini la lecture de la broche comme D11, ainsi que les différentes constantes utilisées dans les calculs.
#define leituraTensao D11 //AD CH0 no pino PA0 //valor teórico divisor de tensão = 168.85714285714285714286 const float fatorDivisor = 168.40166345742404792461; //valor teórico do ganho de amplificação = 1.0 const float fatorAmplificador = 1.0; //Valor usado na multiplicação da leitura const float fatorMultiplicao = fatorDivisor * fatorAmplificador; //Valor teórico da Tensão de alimentação Vcc = 3.3V const float Vcc = 3.3; //valor teórico do offset do amplificador = Vcc / 2.0; const float offSet = 1,66; //fator teórico da conversão do AD = 3.3 / 4095.0 const float fatorAD = Vcc / 4095.0; const int amostras = 71429; //resulta em 1, 027 segundos para cada atualização //const int amostras = 35715; //resulta em 0, 514 segundos para cada atualização
Code source - Variables globales
Maintenant, nous définissons quelques variables globales.
flottant Vrms = 0,0; //armazena o valor rms da tensãofloat Vmax = 0.0; //armazena ou valeur maximale détectée float Vmin = 10000.0; //armazena o valor minimo detectado float Vmed = 0.0; //armazena o valor medio entre Vmáx e Vmín
Code source - Configuration ()
Démarrez le port série à 1Mbps. Nous avons ajusté le port AD en entrée et attendu 5 secondes avant de commencer à collecter des données. Le temps d'attente est facultatif.
void setup() { Serial.begin(1000000); // initie un port série avec 1 Mbps pinMode (leituraTensao, INPUT); //justa a porta do AD como entrada delay (5000); //aguarda 5s antes de iniciar a coleta. (optionnel) }
Code source - Loop () - Démarre les variables de collecte de données
Dans la boucle, nous avons la variable pour l'itération. Ici, nous stockons également les lectures de AD en 0.0 et redémarrons la variable VRMS également en 0.0.
boucle vide() { int i = 0; //variable pour iteração float leitura = 0.0; //armazena comme leituras font AD Vrms = 0.0; //reinicia a variável Vrms
Code source - Capture et exécute les calculs individuels pour chaque échantillon
A ce stade, si i est plus petit que l'échantillon, nous commençons un cycle d'échantillonnage jusqu'à ce que i atteigne le nombre d'échantillons. Nous exécutons analogRead pour lire le port analogique et calculons la somme des carrés des tensions de lecture. Enfin, nous incrémentons l'itérateur.
while (i < amostras) { //inicia um ciclo de amostragem até que i alcance on número de amostras leitura = analogRead(leituraTensao); //lê a porta analógica //Serial.println(leitura); //Descomente se quiser ver o sinal bruto do AD Vrms = Vrms + pow(((leitura * fatorAD) - offSet), 2.0); //calcule un soma dos quadrados das tensões lidas i++; //incrémenter l'itération }
Code source - Calculs généraux des échantillons et identification du maximum, du minimum et de la moyenne
Nous appliquons le fait de multiplication pour déterminer la valeur réelle des tensions. Nous détectons si la valeur est maximale ou minimale, et nous calculons la moyenne des valeurs maximales et minimales actuelles.
//Aplicando fator de multiplicação para determinar o valor real das tensões Vrms = (sqrt(Vrms / amostras)) * fatorMultiplicao; //détecte sa valeur et sa valeur maximale si (Vrms > Vmax) { Vmax = Vrms; } //détecte sa valeur minimale si (Vrms < Vmin) { Vmin = Vrms; } //calcula a média dos valores máximo e mínimo atuais Vmed = (Vmax + Vmin) / 2.0;
Code source - Options de sortie
Nous avons trois options pour "tracer" la valeur de sortie. Nous avons une sortie formatée sur le traceur série Arduino IDE, comme CSV ou Jason.
//saída formatada pour traceur série IDE Arduino Serial.print(Vrms, 3); Serial.print(", "); Serial.print(Vmax, 3); Serial.print(", "); Serial.print(Vmin, 3); Serial.print(", "); Serial.println(Vmed, 3); /* //saída formatada como json Serial.print("{"instante(ms)\":"); Serial.print(millis()); Serial.print(", "); Serial.print("\"Vrms(V)\":"); Serial.print(Vrms, 3); Serial.print(", "); Serial.print("\"Vmax(V)\":"); Serial.print(Vmax, 3); Serial.print(", "); Serial.print("\"Vmin(V)\":"); Serial.print(Vmin, 3); Serial.print(", "); Serial.print("\"Vmed(V)\":"); Serial.print(Vmed, 3); Serial.println("}"); */ /* //saída formatada como CSV Serial.print(millis()); Serial.print(", "); Serial.print(Vrms, 3); Serial.print(", "); Serial.print(Vmax, 3); Serial.print(", "); Serial.print(Vmin, 3); Serial.print(", "); Serial.println(Vmed, 3); */ }
Étape 14: Fichiers
Téléchargez les fichiers:
INO