Prototyp eines Kapazitätsmessgerätes - AZ-Delivery

L'article suivant nous a été envoyé par le lecteur Miguel Torres Gordo. Amusez-vous bien à le lire et profitez-en !

Voici le prototype pour mesurer la capacité d'un condensateur avec ATMega328p. Comme la plupart des gens le savent, les broches numériques du microcontrôleur ont une tension de sortie de 5 volts. Nous utiliserons cette tension et la fonction ADC des broches analogiques pour effectuer les calculs nécessaires et déterminer ainsi la capacité des condensateurs.

Tout d'abord, un bref détail sur la charge des condensateurs. Le circuit le plus simple pour charger un condensateur et sa courbe de charge sont :

Panneau de commutation et courbe de charge

Si nous connectons un condensateur à une tension, nous pouvons déterminer le temps nécessaire à 63,2% de la tension d'alimentation en utilisant l'équation

T = R * C

T est la constante de temps en secondes, R est la résistance en ohms du circuit et C est la valeur du condensateur en farads.

Comment pouvez-vous alors déterminer le temps qu'il faut pour charger à 63,2 % ? La réponse est : à l'aide de l'ADC dans les ports analogiques, car 63,2 % de 5 volts sont 3,16 volts. Le circuit simplifié est le suivant :

Circuit simplifié

Le projet dispose d'un commutateur pour sélectionner la mesure des condensateurs dans les plages µF-nF ou nF-pF, ainsi que d'un écran OLED pour afficher les mesures.

Matériaux

Circuit du projet

Circuit

Circuit de mesure pour les valeurs élevées (F-nF), sélection de la broche D6 avec le commutateur

On commence à charger le condensateur avec la broche A2 à travers la résistance de 10K, en même temps on démarre un timer et on mesure la tension sur la broche A0.  On sait que la tension fournie par les broches est de 5 V. Ainsi, avec l'ADC, on sait que 5 V est égal à la valeur numérique 1023 et que 63,2% de 5 V est égal à 3,16 V, ce qui est égal à 648. Lorsque la lecture de la broche A0 atteint 648, on active l'alimentation et on arrête le timer. Divisez ensuite le temps utilisé par la résistance de 10K pour trouver la valeur du condensateur, puis déchargez le condensateur.

Circuit de mesure pour petites valeurs (nF-pF), sélection de la broche D5 avec le commutateur

Pour les valeurs faibles, on utilise la charge mesurée sur les broches A3 et A0 respectivement. On applique la tension de 5V à la broche A3 via la résistance de 220 ohms et on commence à charger le condensateur. On utilise l'ADC de la broche A0. Si la valeur est inférieure à 976, cela signifie que la valeur du condensateur est dans la gamme des pF. On fait les calculs nécessaires avec la mesure et la plage d'erreur de la résistance interne du Nano V3.0 avec la résistance externe.

Si la valeur sur A0 est supérieure à 976, alors nous réglons la broche A0 pour fournir 5V à la sortie et la broche A3 pour lire la tension. On compte le temps en microsecondes et si dans un temps de 400 ms la tension n'atteint pas 5V, on fait les calculs de la capacité du condensateur avec la valeur de la résistance pull-up interne, la mesure du temps et la valeur de conversion de l'ADC de la mesure de tension en A3. Si le résultat de la valeur est supérieur à 1000, la mesure se fait en µF, s'il est inférieur, elle se fait en pF.

Code source

Voici le code source du sketch pour l'IDE Arduino (Télécharger):

 / * Miguel Torres Gordo - Compacteur Compteur * /
 
 // écran d'écran OLED
 #include
 #include
 #include
 #include
 
 #define écran_width 128       // Écran de largeur OLED
 #define Screen_Height 32       // écran hauteur moulé
 
 // objet de classe adafruit_ssd1306
 Adafruit_ssd1306 affichage(Screen_Width, Screen_Height, &Câble, -1); // -1 Si partager la broche de réinitialisation Arduino
 
 // bascule pour sélectionner des valeurs à mesurer
 int Bombepf=5;
 int Scalène=6;
 
 // valeurs élevées //
 #define analogpin A0
 #define charge A2
 #define décharge A1
 #define Resistorvalue 10000.0f // Valeur de résistance 10k pour charger le condensateur
 
 non signé longue Heure de début;
 non signé longue temps écoulé;
 flotter microfarades;                
 flotter nanofarads;
 
 // Basse valeurs //
 const int Out_pin = A3;
 const int In_pin = Août;  
 const flotter In_stray_cap_to_gnd = 50.28;     // valeur avec 220 résistances
                                               
 const flotter In_cap_to_gnd  = In_stray_cap_to_gnd;
 const flotter R_pullup = 30.0;  
 const int Max_adc_value = 1023;
 
 annuler mettre en place() {
   En série.commencer(9600);
   retard(100);
   En série.imprimeur("Initialiser l'affichage OLED");
 
   // Démarrer l'affichage OLED à l'adresse 0x3C
   si (!affichage.commencer(SSD1306_SWITCHCAPVCC, 0x3c)) {
  En série.imprimeur(F("Écran OLED non trouvé"));
  pour(;;); // ne procédez pas, boucle pour toujours
  }
 
   punaise(Bombepf, SAISIR);
   punaise(Scalène, SAISIR);
 
   punaise(Out_pin, SORTIR);
   punaise(In_pin, SORTIR);
   punaise(épicerie publique, SORTIR);    
 }
 
 annuler boucle() {
 
   / **************************** Valeurs élevées: Échelle 4F - 100nf **************** ************************** /
 
   si (digitalread(Scalène)) {
   
     punaise(Out_pin, SORTIR);
     denadewrite(Out_pin, MEUGLER);         // a3 comme gnd
     punaise(analogique, SAISIR);           // A0 Lire la tension
   
     denadewrite(épicerie publique, HAUTE);  
     Heure de début = micros();
 
     tandis que (analograde(analogique) < 648) {   }     // le condensateur est chargé
 
     temps écoulé = micros() - Heure de début;
     microfarades = ((flotter)temps écoulé / résistorvalue);
     
     si (microfarades > 1) {
 
    affichage.cleardisplay();                                 // tampon propre
    affichage.setexteriser(1);                                 // Taille du texte
    affichage.colstextcolor(Ssd1306_white);                   // texte couleur
    affichage.setcursor(1, 2);                               // position du texte
    affichage.imprimeur("Échelle: 4f-100nf");
    affichage.setcursor(1, 12);
    affichage.imprimeur(microfarades);
    affichage.setcursor(50, 12);
    affichage.imprimeur("UF");
    affichage.affichage();                                     // Afficher le texte à l'écran
    retard(500);
 
    } autre {
 
    nanofarads = microfarades * 783;
    affichage.cleardisplay();                                 // tampon propre
    affichage.setexteriser(1);                                 // Taille du texte
    affichage.colstextcolor(Ssd1306_white);                   // texte couleur
    affichage.setcursor(1, 2);                                      // position du texte
    affichage.imprimeur("Échelle: 4f-100nf");
    affichage.setcursor(1, 12);
    affichage.imprimeur(nanofarads);
    affichage.setcursor(50, 12);
    affichage.imprimeur("nf");
    affichage.affichage();                                     // Afficher le texte à l'écran
    retard(500);
 
    }
   
     denadewrite(épicerie publique, MEUGLER);            
     punaise(déchargement, SORTIR);            
     denadewrite(déchargement, MEUGLER);         // décharge du condensateur
   
     tandis que (analograde(analogique) > 0) {   }     // attend jusqu'à ce que le capacitor soit libéré
 
     punaise(déchargement, SAISIR);             // Cela définit la goupille sur une impédance élevée
   
     affichage.setexteriser(1);                                 // Taille du texte
     affichage.colstextcolor(Ssd1306_white);                   // texte couleur
     affichage.setcursor(1, 22);                               // position du texte
     affichage.imprimeur("Décharge .....");     // message à afficher
     affichage.affichage();                                     // Afficher le texte à l'écran
     retard(1000);
 
   
  }
 
   / ***************************** Échelle de faible valeurs 1NF - 1pf **************** ************ /
 
   si (digitalread(Bombepf)) {
     
     punaise(épicerie publique, SAISIR);
     punaise(déchargement, SAISIR);       // Configurez les ports avec une impédance élevée car il n'est pas utilisé
 
     punaise(In_pin, SAISIR);
     denadewrite(Out_pin, HAUTE);
     int valourdine = analograde(In_pin);
     denadewrite(Out_pin, MEUGLER);
 
     si (valourdine < 976) {
       
       punaise(In_pin, SORTIR);
 
       flotter capacitance = ((flotter)valourdine * In_cap_to_gnd / (flotter)(Max_adc_value - valourdine))/2;                        
           
       affichage.ClearDisplay();                                 // tampon propre
       affichage.setexteriser(1);                                 // Taille du texte
       affichage.colstextcolor(Ssd1306_white);                   // texte couleur
       affichage.setcursor(1, 2);                               // position du texte
       affichage.imprimeur("Échelle: 1NF-1PF"); // message à afficher
       affichage.setcursor(1, 12); // position du texte
       affichage.imprimeur(capacitance); // valeur à afficher
       affichage.setcursor(50, 12);
       affichage.imprimeur("PF");
       affichage.affichage();                                     // Afficher le texte à l'écran
       retard(200);
 
    } autre {
 
       punaise(In_pin, SORTIR);
       retard(1);
       punaise(Out_pin, Input_Pullup);
       non signé longue u1 = micros();
       non signé longue t;
       int digval;
 
       faire {
         digval = digitalread(Out_pin);
         non signé longue u2 = micros();
         t = u2 > u1 ? u2 - u1 : u1 - u2;
      } tandis que ((digval < 1) && (t < 400000L));
 
       punaise(Out_pin, SAISIR);
       valourdine = analograde(Out_pin);
       denadewrite(In_pin, HAUTE);
       int décharge = (int)(t / 1000l) * 5;
       
       retard(décharge);  
       
       punaise(Out_pin, SORTIR);  
       denadewrite(Out_pin, MEUGLER);
       denadewrite(In_pin, MEUGLER);
 
       flotter capacitance = -(flotter)t / R_pullup / Journal(1.0 - (flotter)valourdine / (flotter)Max_adc_value);
       
       si (capacitance > 1000.0) {
         affichage.ClearDisplay();                                 // tampon propre
         affichage.setexteriser(1);                                 // Taille du texte
         affichage.colstextcolor(Ssd1306_white);                   // texte couleur
         affichage.setcursor(1, 2);                               // position du texte
         affichage.imprimeur("Échelle: 1NF-1PF");
         affichage.setcursor(1, 12);
         affichage.imprimeur(capacitance/1000.0, 3);
         affichage.setcursor(50, 12);
         affichage.imprimeur("UF");
         affichage.affichage();                                     // Afficher le texte à l'écran
         
         retard(200);    
       
      } autre {
         affichage.ClearDisplay();                                
         affichage.setexteriser(1);                                
         affichage.colstextcolor(Ssd1306_white);                  
         affichage.setcursor(1, 2);                              
         affichage.imprimeur("Échelle: 1NF-1PF");
         affichage.setcursor(1, 12);
         affichage.imprimeur(capacitance, 3);
         affichage.setcursor(50, 12);
         affichage.imprimeur("PF");
         affichage.affichage();                                    
         
         retard(200);
      }
    }        
     tandis que (micros() % 1000 != 0);
  }
 }

Photos du projet

Structure de projet

Poudre

47μF

47μF décharge

100 μF

100 μF décharge


Merci à Miguel Torres Gordo pour cette contribution.

Für arduinoGrundlagen elektronik

8 commentaires

Robert Baptist

Robert Baptist

Andreas, Vielen Dank fur die Antwort. und Grusse an Miguel.
RB

Andreas Wolter

Andreas Wolter

@Robert Baptist: ich habe das an den Autoren weitergegeben und folgendes von ihm zurück erhalten:

Der Wert 783 in der Skizze des Schaltungsaufbaus ist die Anpassung, die ich mit verschiedenen Werten vornehmen musste, um den richtigen Wert der Kondensatoren zu erhalten, da die Messwerte für Kondensatoren mit sehr niedrigen Werten in nF sind und die Toleranzen der elektronischen Komponenten es unmöglich machen, dass man Werte mit der idealen Umrechnung von 1 µF = 1000 nF erhält.

Der Wert der internen Pull-up-Widerstände des Arduino sind 10K, aber ich denke, worauf Sie sich beziehen, sind die Werte der Konstanten R_PULLUP = 30.0 und IN_STRAY_CAP_TO_GND = 50.28. Diese Werte werden verwendet, um die Berechnungen der Kondensatorwerte (mit dem Selektor für niedrige Kondensatorwerte) am ADC auzulesen mit der Spannungen an Pin A3 mit einem Serienwiderstand von 220 Ohm und A0.

Robert Baptist

Robert Baptist

Guten Tag.
Woher (und warum) kommt der Wert 783 in der Linie 92 nanoFarads = microFarads * 783 in diesem “Prototyp eines Kapazitätsmessgerätes” Projekt ? Warum nicht 1000?
Welche sind die Einheiten für den Pull-Widerstand und die parasitäre Kapazität ?Kohm und pF?
Danke fuer die Erklarung.

Andreas Wolter

Andreas Wolter

Danke für den Hinweis zum Schaltplan. Der wurde von uns aktualisiert.

Grüße,
Andreas Wolter

Andreas Wolter

Andreas Wolter

@Wolfgang Rind: ich vermute, dass die Bibliothek für das Display nicht installiert wurde. Dazu müssen Sie den Bibliothekenverwalter öffnen (Werkzeuge → Bibliotheken verwalten… oder STRG+UMSCHALT+i). In das Suchfeld SSD1306 eingeben und die Bibliothek Adafruit_SSD1306 installieren. Falls es nicht gleich automatisch mit installiert wird, muss auch Adafruit_GFX installiert werden. Dann sollte es funktionieren. Ich ergänze das im Beitrag.

Grüße,
Andreas Wolter

Wolfgang Rind

Wolfgang Rind

Hallo, Ursache gefunden, SSD1306 2.4.7 installiert und im Schaltplan ist die Verdrahtung vom Bereichs Schalter verkehrt, blau und braun sind vertauscht.

Wolfgang Rind

Wolfgang Rind

Hallo, habe den Sketch geladen, bei der Überprüfung kommt die Fehlermeldung:
exit status 1
‘SSD1306_WHITE’ was not declared in this scope
was muss ich Ändern?

DIYLAB

DIYLAB

Hallo zusammen,
hier wäre dann z.B. noch der größere Bruder dieses Projekts, ein LCR-Meter mit dem Nano:
https://github.com/gavinlyonsrepo/LCR_meter
Falls ihr eh beim Basteln seid ;)

Viele Grüße
DIYLAB
www.diylab.de

Laisser un commentaire

Tous les commentaires sont modérés avant d'être publiés

Articles de blog recommandés

  1. ESP32 jetzt über den Boardverwalter installieren - AZ-Delivery
  2. Internet-Radio mit dem ESP32 - UPDATE - AZ-Delivery
  3. Arduino IDE - Programmieren für Einsteiger - Teil 1 - AZ-Delivery
  4. ESP32 - das Multitalent - AZ-Delivery