Home / Tutoriels / Capteurs / Utiliser le capteur de débit d’eau

Utiliser le capteur de débit d’eau

Vous venez d’acheter un capteur de débit d’eau chez YoupiLab. Merci pour votre fidélité.

Les points à développer :

  • C’est quoi un capteur de débit d’eau ?
  • Câblage avec Arduino
  • Le simple code pour tester

C’est quoi un récepteur de débit d’eau?

Le capteur de débit d’eau se compose d’un corps de vanne en plastique, d’un rotor à eau et d’un capteur à effet Hall. Lorsque l’eau traverse le rotor, le rotor roule et sa vitesse change avec un débit différent. Le capteur à effet Hall émet le signal d’impulsion correspondant.

Ce type de capteur peut être trouvé sur différents diamètres, pression d’eau (MPa) et plages de débit (L / m). Assurez-vous de choisir celui qui répondra à vos besoins. Le capteur que je possède a un diamètre de 20 mm, une pression d’eau <1,75 MPa et une plage de débit de ~ 30 L / m.

Dans ce tutoriel, nous utiliserons le moniteur série pour imprimer le débit d’eau en litres par heure et le total des litres écoulés depuis le démarrage.

Alors, commençons!

 

Câblage avec Arduino

Pour ce tutoriel, vous aurez besoin de:

Le circuit :

Les connexions sont assez faciles, voir l’image ci-dessus avec le schéma du circuit de test.

Le simple code pour tester

NB : Software

Windows10

Arduino 1.6.9

/*

Capteur de débit de liquide

Mesurez le débit de liquide / eau en utilisant ce code.

Connectez Vcc et Gnd du capteur à arduino, et la

ligne de signal à la broche numérique arduino 2.

 */

 

byte statusLed    = 13;

 

byte sensorInterrupt = 0;  // 0 = digital pin 2

byte sensorPin       = 2;

 

// The hall-effect flow sensor outputs approximately 4.5 pulses per second per

// litre/minute of flow.

float calibrationFactor = 4.5;

 

volatile byte pulseCount; 

 

float flowRate;

unsigned int flowMilliLitres;

unsigned long totalMilliLitres;

 

unsigned long oldTime;

 

void setup()

{

 

  // Initialize a serial connection for reporting values to the host

  Serial.begin(9600);

  

  // Set up the status LED line as an output

  pinMode(statusLed, OUTPUT);

  digitalWrite(statusLed, HIGH);  // We have an active-low LED attached

 

  pinMode(sensorPin, INPUT);

  digitalWrite(sensorPin, HIGH);

 

  pulseCount        = 0;

  flowRate          = 0.0;

  flowMilliLitres   = 0;

  totalMilliLitres  = 0;

  oldTime           = 0;

 

  // The Hall-effect sensor is connected to pin 2 which uses interrupt 0.

  // Configured to trigger on a FALLING state change (transition from HIGH

  // state to LOW state)

  attachInterrupt(sensorInterrupt, pulseCounter, FALLING);

}

 

/**

 * Main program loop

 */

void loop()

{

  

   if((millis() – oldTime) > 1000)    // Only process counters once per second

  {

    // Disable the interrupt while calculating flow rate and sending the value to

    // the host

    detachInterrupt(sensorInterrupt);

       

    // Because this loop may not complete in exactly 1 second intervals we calculate

    // the number of milliseconds that have passed since the last execution and use

    // that to scale the output. We also apply the calibrationFactor to scale the output

    // based on the number of pulses per second per units of measure (litres/minute in

    // this case) coming from the sensor.

    flowRate = ((1000.0 / (millis() – oldTime)) * pulseCount) / calibrationFactor;

   

    // Note the time this processing pass was executed. Note that because we’ve

    // disabled interrupts the millis() function won’t actually be incrementing right

    // at this point, but it will still return the value it was set to just before

    // interrupts went away.

    oldTime = millis();

   

    // Divide the flow rate in litres/minute by 60 to determine how many litres have

    // passed through the sensor in this 1 second interval, then multiply by 1000 to

    // convert to millilitres.

    flowMilliLitres = (flowRate / 60) * 1000;

   

    // Add the millilitres passed in this second to the cumulative total

    totalMilliLitres += flowMilliLitres;

     

    unsigned int frac;

    

    // Print the flow rate for this second in litres / minute

    Serial.print(« Flow rate: « );

    Serial.print(int(flowRate));  // Print the integer part of the variable

    Serial.print(« L/min »);

    Serial.print(« \t »);               // Print tab space

 

    // Print the cumulative total of litres flowed since starting

    Serial.print(« Output Liquid Quantity: « );       

    Serial.print(totalMilliLitres);

    Serial.println(« mL »);

    Serial.print(« \t »);               // Print tab space

            Serial.print(totalMilliLitres/1000);

            Serial.print(« L »);

   

 

    // Reset the pulse counter so we can start incrementing again

    pulseCount = 0;

   

    // Enable the interrupt again now that we’ve finished sending output

    attachInterrupt(sensorInterrupt, pulseCounter, FALLING);

  }

}

 

/*

Insterrupt Service Routine

 */

void pulseCounter()

{

  // Increment the pulse counter

  pulseCount++;

}

Merci pour votre attention !

About nonfonjuniorm_lf80ckk1

Check Also

Le régulateur LM317

Vous venez de prendre un régulateur LM317 chez YoupiLab. Merci pour votre fidélité. Voici le …

Laisser un commentaire

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