Skip to main content

Machine à Cocktail


UE 803 - Optimisation et Contrôle des Procédés - Master 2 - Ingénierie Chimique

Projet Expérimental Arduino

Dans le cadre de cette UE, nous devons réaliser un projet de régulation par prototypage utilisant principalement un micro contrôleur Arduino et des capteurs / actionneurs.

Après quelques séances de brainstorming et échange d'idées, nous avons décidé d'opter pour la conception d'une machine à cocktail connecté via assistant vocal. Des pompes gèreraient le débit des boissons et un capteur pour la détection d'un gobelet serait ajouté.

Nous avons passé en revu plusieurs projets de système de pompage utilisant Arduino ou un connecteur Nano-IoT et avons donc pu dresser une liste du matériel complet pour mener à bien ce projet.


Projet distributeurs de boissons

Objectif : Réaliser un distributeur de cocktails à partir de 7 boissons (et donc 7 pompes) qui nous permettrait de faire différents mélanges. Le distributeur serait connecté au cloud via un Nano-IoT et contrôlé vocalement par Alexa.

Matériel électronique :

  • 7 pompes
  • 7 relays (ou switch)
  • fils de connexions 
  • Un nano 33 IoT
  • Une carte arduino
  • Une platine
  • Câble d'alimentation
  • Câble usb relié à l'arduino
  • Câble usb relié l'IoT
  • Un capteur sonar (distance)
  • 4 Boutons poussoirs
  • 4 Résistances

Matériel de construction :

  • Tuyaux
  • Planches de bois
  • Vis
  • 7 Bouteilles vides 1,5L

Premier Brouillon :

E5FDD8EB-1023-4CA2-8194-BBFAAA3D98E0.jpeg

____________________________________________________________________________________________________________

Semaine 6 au 13 Décembre :

Une fois tout le matériel reçu, la première étape du projet a été de mettre en place une stratégie pour monter et faire fonctionner les pompes :

  • Mettre en place le schéma de branchement des pompes
  • Faire un état des lieux des fils nécessaires (bruts, embout femelle, embout male).
  • Dénudé la quantité de fils nécessaire
  • Trouver la borne + et la borne - des pompes en utilisant un multimètre

Après plusieurs recherches et la consultation de plusieurs sites web et pages github, le branchement suivant reliant la pompe, le relay et l'arduino a été déterminé comme celui qui serait utilisé :

Capture d’écran 2023-02-05 à 00.53.39.png

L'utilisation d'un relay est essentiel si nous voulons être capable de faire varier l'intensité de la pompe ou sa durée de fonctionnement. En effet la pompe est par défaut une entité booléenne : allumée ou éteinte.

Soudure des fils à nos 7 pompes :

Capture d’écran 2023-02-05 à 01.00.21.png

Branchement des fils de connexions aux 7 relays : 

Branchement final des pompes aux relay puis sur la carte Arduino :


Semaine 2 Janvier :

Une fois les pompes câblés correctement et branchées, nous devons commencer à programmer nos commandes de boissons, car sinon les pompes sont activés en continues quand connecté à l’alimentation. Nous recherchons donc des exemples de codes qui montrent comment activer une pompe pour un délais précis et initialiser notre setup en fonction du nombre de pompe utilisées.

Un de nos premiers exemple de code utilisé est celui-ci :

Nous arrivons donc maintenant à activer une pompe et contrôler sa durer d’activation. Le but est d’ensuite ajouter toutes nos pompes et crée des fonctions qui gèrent l’activation de 2 pompes en même temps gérer par une seule fonction « boisson »pour réaliser les mélanges de nos cocktails.

Nous cherchons également en parallèle comment se branche et fonctionne notre capteur sonar de distance. En effet après plusieurs recherches nous nous sommes rendu compte que notre capteur ne possède pas les branchements décrit habituellement dans la littérature et autres projet libre d’accès. 

image-1675907441791.jpeg

En effet, dans nos nombreuses recherches de fonctionnement du capteur nous retrouvions tout le temps le capteur ci-dessus. Qui possède quatre branchements : Vcc qui correspond au voltage 3,3 ou 5V, GND qui correspond comme l'indique son nom à la terre (ou ground). Et finalement les branchements Trig et Echo où Trig correspond au transmetteur soit la partie de gauche qui va émettre des impulsions qui seront arrêtées et renvoyé par l'objet qui fait face au capteur. Ces impulsions renvoyées sont captées par le récepteur qui correspond à l'Echo (partie de droite).

Cependant, nous ne sommes pas exactement dans ce cas-là.

image-1675908242903.png

Ici, les sorties Trig et Echo sont remplacés par la sortie SIG qui fait office de branchement pour le transmetteur et le récepteur et sera branché sur le pin digital dans notre cas le pin 10. La sortie NC (ou "not connected") est comme l'indique son nom une sortie qui n'a pas besoin d'être relié à quoi que ce soit. GND et VCC sont des branchements qui se font à l'identique de ce qui a été expliqué précédemment. Le branchement de notre capteur est donc simplifié mais il a fallu faire un travail d’identification pour assurer une connexion.

Branchement capteur :


Semaine 9 Janvier :

Nous avons pu réaliser les branchements du capteur et les avons reliés correctement à l’Arduino. Nous devons désormais adapter notre code afin de spécifier les fonctions liées au fonctionnement du capteur mais aussi ajouter une nouvelle condition sur l’activation des pompes : les pompes ne peuvent s’activer que si le capteur détecte une présence proche à moins ou égale à 2cm de distance du récepteur du capteur.

Nous nous penchons également sur le Nano-IoT fait pour relier notre système au service cloud de Arduino afin de créer des boutons digitaux (web ou application mobile) contrôlable manuellement ou par assistanats vocaux grâce à la configuration de ces boutons digitaux en skills Alexa.

Pour ce faire nous commençons à souder les branches en or fournis avec note Nano-IoT 33 pour pouvoir faire des branchement. Une fois fait, il est connecté sur une platine et branché par un câble USB à l’ordinateur pour la création des boutons et du code associé.

Nano IoT :

34B6E483-08D7-480A-90D2-EE965D0259BE.jpeg

Après soudures :

2F2815E8-E910-4515-ACC3-BE066C38A889.jpeg


Nous cherchons dans la documentation Arduino le nom des connexions disponible sur notre connecteur bluetooth car ils ne sont pas inscrit sur notre appareil :

2B07D775-6F24-4E1E-8E08-EA6E8641929C.jpeg

Une fois les soudures réalisées et la documentation en notre possession, nous pouvons tenter de recréer les connexions réalisées précédemment sur l’Arduino avec une pompe sur le Nano-IoT afin de commencer à comprendre le fonctionnement du service cloud. Nous souhaitons avoir 7 boissons, donc 7 boutons, qui vont activer des jeux de pompes différentes, nous créerons donc nos boutons auxquels nous relions des variables booléenne (TRUE or FASLE) qui gèrent l’état des boutons « Appuyer ou Étein » et devons coder dans la partie du code auto généré par Arduino Cloud pour contrôler l’action réaliser après activation des boutons.

Après plusieurs recherches sur le fonctionnement d’Arduino Cloud et du IoT nous associons notre appareil à leur application, et nous nous connectons à un réseau wifi privé et sécurisé. Nous pouvons alors créer  nos « things » qui sont nos variables qui vont gérer l’allumage des pompes et donc la création des boissons. Nous commençons d’abord à travailler avec une seule pompe et sans capteur pour bien comprendre comment marche cet appareil.

FEE60C75-FF17-4028-9576-8D470311D99D.jpeg

Nous avons alors crée nos 4 variables pour 4 boissons, et n’allons travailler que sur la boisson 1 avec une seule pompe pour l’instant. Nous pouvons alors passer à la suite et créer nos boutons virtuels, on associe alors les variables créees précédemment à chaque boutons. Nos variables sont définies comme booléenne, read & write et sa valeur est actualisée à chaque changement d’état du bouton. 

DC21B1EE-C296-4F5B-BCB7-A71FD00259AC.jpeg5C2C349E-FE02-4B65-BEEE-6C7C6D5F7EDA.jpeg

Arduino Cloud nous auto crée alors une partie de code où nous avons plus qu’a ajouter nos fonctions de contrôle des pompes. Dans la photo ci-dessous le code n’est pas correcte, mais nous avons utilisé le code montré précédemment, utilisé pour la carte Arduino. Nous avons vérifié la syntaxe et télévisé le code sans aucun problème. Les boutons devraient donc marcher.

8E4D8E0E-82CC-457E-9273-A2CB7F596361.jpeg

Par la suite nous créons donc les skills Alexa nécessaires pour le contrôle vocal de l’activation des boutons crées précédemment, codé et associé à l’IoT.

B626C6BA-F19C-413E-B9D7-300C41C33F20.jpeg

Le code marche sur l’arduino, les boutons sont reliés au variables, le code transféré à l’IoT à la bonne syntaxe compatible Cloud Agent et le téléversement se fait « succesfully » et sans erreur, malheureusement impossible de connecter le IoT au cloud. Il reste « Hors ligne » en permanence. Normalement après le téléversement, le IoT est sensé se connecter immédiatement au cloud et être « Online », nous avons vu une connexion de 1 seconde puis déconnexion immédiate. Après plusieurs recherche il se peut que le réseau cloud de Arduino soit en maintenance ou inaccessible. Nous avons essayé plusieurs réseau différents par la suite, et malgré le téléversement réussi et une connexion privé, notre IoT ne se connecte pas au Cloud, impossible donc d’activer les boutons sur le site web et encore moins à distance avec Alexa.

Après de nombreuses tentatives infructueuses cette semaine, et le fait que ni l’université ni le fablab ne possèdent de réseau wifi privé auquel nous pourrions nous connecter pour présenter la machine lors du rendu final, nous décidons d’abandonner l’idée de contrôle par assistant vocal ou de boutons virtuels. Il faut alors trouver une autre solution.

Semaine 16 Janvier :

Nous arrivons plus ou moins à faire marcher le capteur et une pompe, mais pour l’instant nous n’arrivons pas à spécifier la condition && du fonctionnement des 2 pompes en même temps que le capteur. Nous travaillons donc a améliorer le code et tenté de trouver une version qui fonctionne.

Cette semaine nous commençons également à avancer sur la structure : nous avons fait un état des lieux et avons défini que nous avions besoin d’un bac pour récuperer le liquide sous le verre, d’une partie haute qui dispense le liquide et qu’un « réservoir » qui contiendrais nos bouteilles et doit etre accessible pour les changer ou faire une maintenance des équipements. Le capteur, les pompes et le arduino avec la platine ce trouveraient à l’interieur de la machine, au dessus des bouteilles d’ou sont pompé les liquides.

Un premier croquis est suggéré :

3379ACB8-FF14-49C7-A7A4-4A0B2CC6F944.jpeg

Le bac d’écoulement du liquide au cas où des goutes couleraient à coté lors de la distribution de boisson est assez indépendant de la machine et peut être rajouté seule, nous commençons donc a réfléchir à un design de conception pour commencer par cette pièce, étant donné que le code n’est pas définitif nous ne préférons pas avancer de suite sur la structure définitive.

Le bac d’écoulement était initialement prévu en bois tout comme le reste de a structure de la machine mais ce matériaux n’est pas hydrophobe et se gorgera d’eau s’il est en contact avec. A la fin de cette séance fablab nous décidons donc de partir sur du plastique PMMA de 3mm d’épaisseur et de couleur noir (pas transparent car nous verrions le liquide à travers, ce qui n’est pas très esthétique dans ce cas). Nous commençons donc par réaliser une fichier vectoriel 2D grâce au logiciel Inkscape afin de dessiner les bordures de nos pièces en vue d’une découpe laser. Dans un premier temps nous optons pour un porte gobelet de 10x10cm et avons réaliser le fichier suivant pour la découpeuse laser :

image-1675948538444.png


Semaine 23 Janvier :

Coté code, nous arrivons finalement à faire fonctionner une pompe d'après la condition de distance sur le capteur que nous avions spécifié à moins de 3 cm. Nous pouvons alors tenter de reproduire les branchements pour toutes nos pompes et commencer à structurer notre code avec les pompes correspondant aux boissons souhaitées.

IMG_4309.jpeg

Faisant face à des problèmes pour travailler avec le Nano-Iot comme nous le souhaitions, nous avons cherché en parallèle une alternative pour proposer nos différentes boissons. Et pour cela, nous avons décidé de travailler avec des boutons poussoirs. C'est aussi à ce moment qu'il nous a semblé judicieux de nous limiter dans le nombre de pompes en passant de  7 à 4 pompes ce qui nous permettait aussi d'avoir un plus petit montage à réaliser pour notre design. 

Capture d’écran 2023-02-09 à 03.45.42.png

Remarque : Un fil GND (Noir) et un fil 5V (Blanc) sont reliés de l'arduino vers la platine respectivement sur la bande moins et la bande plus. Tous les fils devant être reliés au GND seront donc sur la ligne des moins et ceux devant être reliés au 5V seront sur la ligne des plus.

Nous arrivons à réaliser un premier montage pour activer une pompe à l'aide d'un bouton, mais nous éprouvons quelques problèmes pour le code pour apposer la condition && entre le capteur et le bouton. En effet, nous souhaitons que la pompe s'active si et uniquement si l'obstacle se trouve à moins de 3 cm du capteur et si le bouton a été activé.

En essayant une condition if ((bouton == 0) && (cm<3)), nous remarquons que le bouton n'est pas pris en compte dans l'activation de la pompe. Pour finalement faire fonctionner nos deux conditions, il nous a fallu déclarer nos conditions comme des variables "boolean" dites aussi "tout ou rien". C'est ce qu'il est possible de voir en rouge dans le code correspondant au montage (a).

Cela nous permet d'indiquer à l'arduino que nous avons deux états pour chacune de nos variables : état 0 où le bouton n'a pas été activé et où le capteur ne repère un obstacle à moins de 3 cm et l'état 1 où le bouton est activé et le capteur identifie bien un obstacle à moins de 3 cm.

const int pingPin = 7;
const int pumpPin2 = 2; // // le relais est connecté à la broche  de la carte Adruino
const int bouton1 = 3;

boolean boutonappuye1;
boolean proche;

void setup() {
  // initialize serial communication:

  Serial.begin(9600);

  // The PING))) is triggered by a HIGH pulse of 2 or more microseconds.
  // Give a short LOW pulse beforehand to ensure a clean HIGH pulse:
  pinMode(pumpPin2, OUTPUT);
  pinMode(bouton1,INPUT);

}

void loop() {
  // establish variables for duration of the ping, and the distance result
  // in inches and centimeters:
  long duration, inches, cm;

  // The same pin is used to read the signal from the PING))): a HIGH pulse
  // whose duration is the time (in microseconds) from the sending of the ping
  // to the reception of its echo off of an object.
  pinMode(pingPin, OUTPUT);
  digitalWrite(pingPin, LOW);
  delayMicroseconds(2);
  digitalWrite(pingPin, HIGH);
  delayMicroseconds(5);
  digitalWrite(pingPin, LOW);
  pinMode(pingPin, INPUT);
  duration = pulseIn(pingPin, HIGH);
  

  // convert the time into a distance
  inches = microsecondsToInches(duration);
  cm = microsecondsToCentimeters(duration);

  Serial.print(cm);
  Serial.print("cm");
  Serial.println();

  boutonappuye1 = digitalRead(bouton1);
  Serial.println(boutonappuye1);
  proche = (cm<3);
 
  if (boutonappuye1 && proche)
  {
  digitalWrite(pumpPin2, LOW);// la pompe à eau remplit la bouteille
  } 
  else {
  digitalWrite(pumpPin2, HIGH); // la pompe à eau s'arrête

  } 
}

long microsecondsToInches(long microseconds) {
  // According to Parallax's datasheet for the PING))), there are 73.746
  // microseconds per inch (i.e. sound travels at 1130 feet per second).
  // This gives the distance travelled by the ping, outbound and return,
  // so we divide by 2 to get the distance of the obstacle.
  // See: https://www.parallax.com/package/ping-ultrasonic-distance-sensor-downloads/
  return microseconds / 74 / 2;
}

long microsecondsToCentimeters(long microseconds) {
  // The speed of sound is 340 m/s or 29 microseconds per centimeter.
  return microseconds / 29 / 2;
}

Remarque : Ce code fonctionne de telle manière qu'il indique que lorsque le capteur détecte un obstacle à moins de 3 cm et le bouton est appuyé alors la pompe est allumé. Cependant d'après le code c'est l'inverse qui devrait se passer puisqu'il est indiqué que la pompe est en "LOW". Nous expliquons cela par le fait que des branchements sont inversés et inversent donc la consigne.

A partir de ce premier code, nous pouvons donc activer les pompes lorsque la condition du capteur et du bouton est respecté et si l'on s'éloigne assez du capteur ou si nous arrêtons d'appuyé sur le bouton alors la pompe s'arrête. 

Nous souhaitions qu'une fois que le bouton n'est pas besoin d'être pressé en continue pour obtenir notre boisson. nous avons rajouter des "delay" pour activer les pompes un temps donné. Dans ce cas, le capteur et le bouton restent bloqués en position 1 tant que le delay n'est pas arrivé à termes, cela signifie que nous ne pouvons pas arrêter la pompe lorsque  les deux conditions sont réunis une fois. 

Coté design nous choisissons une version un peu plus définitive du modèle final de la machine et faisons l’inventaire des planches et tailles de planches nécessaires : 

A6A57DB5-E45D-4DE3-9E75-5794C6B8F9B5.jpeg

Nous prévoyons donc d’utiliser une planche intermédiaire en hauteur afin de fixé les pompes à coté de l’arduino et de dédier un espace spécifique pour les bouteilles et les tubes. Cependant, nous voyons d’or et déjà que nous n’allons pas avoir assez de tube en plastique fournis. Effectivement nous n’avons qu’un seul mètre de tube pour un total de 4 pompes au final, dont 1 tube dois descendre tout au fond de la bouteille, et l’autre ressortir au point d’écoulement du liquide sur la machine. Nous faisons donc le choix de sacrifier de la longueur de file dans le fond de certaines bouteilles. 


Semaine 30 Janvier :

Plusieurs étapes du projet sont réalisées cette semaine, nous travaillons à la fois sur la finalisation de notre code et de notre montage pour quatre pompes et quatre boutons, mais aussi sur la construction de la structure et sur le site que nous avons souhaité réaliser afin de présenter nos boissons. 

Réalisation du site :

Pour finaliser le projet il nous a fallu trouver la meilleure interface afin de rendre le distributeur ergonomique et facile d’utilisation. Nous avons donc décidé de commencer une maquette. Comme il était complexe de faire un design directement sur la machine nous avons pensé faire un menu virtuel.  Nous sommes tout d’abord partis sur une carte virtuelle avec le menu lié à un QR Code sur la machine. 

image-1676086202959.png

Après réflexions nous avons décidé de voir encore plus loin en créant un site permettant d’avoir accès aux menus.  Le site s’appelle Flamme & Co, un nom qui nous embarque dans une ambiance chaleureuse avec « Flamme » et rafraichissante avec « Co » (pour coktail), et qui nous fait voyager : Flamenco (Flamme & Co). Le site est composé de l’accueil où l’on peut trouver les différentes informations clés sur la marque.

image-1676086322871.png

image-1676086290787.png

D’autre part dans l’onglet « Commandes en ligne » on peut retrouver et choisir les différentes boissons proposées.

image-1676086355274.png

Pour rendre accessible le site, nous avons souhaité installer un QR code sur notre machine afin d'y avoir directement accès et pouvoir découvrir le détails des boissons proposées. 

Code et montage :

Le montage et le code ayant été réalisé pour une pompe liée à un bouton et au capteur, la suite était donc d'appliquer tout cela à quatre pompes et quatre boutons afin d'avoir deux cocktails et deux boissons à proposer. 

En suivant le même montage que celui pour une pompe et un bouton, nous avons donc réussi à le reproduire avec nos trois pompes et boutons supplémentaires. 

IMG_4399.jpeg

Le code suivant nous permet d'activer nos quatre pompes avec quatre boutons. 

const int pingPin = 10;

const int pumpPin2 = 2; // // le relais est connecté à la broche  de la carte Adruino
const int pumpPin3 = 3; // // le relais est connecté à la broche  de la carte Adruino
const int pumpPin4 = 4; // // le relais est connecté à la broche  de la carte Adruino
const int pumpPin5 = 5; // // le relais est connecté à la broche  de la carte Adruino

const int bouton1 = 6;
const int bouton2 = 7;
const int bouton3 = 8;
const int bouton4 = 9;

boolean boutonappuye1;
boolean boutonappuye2;
boolean boutonappuye3;
boolean boutonappuye4;

boolean proche;

void setup() {
  // initialize serial communication:

  Serial.begin(9600);

  // The PING))) is triggered by a HIGH pulse of 2 or more microseconds.
  // Give a short LOW pulse beforehand to ensure a clean HIGH pulse:
  pinMode(pumpPin2, OUTPUT);
  pinMode(pumpPin3, OUTPUT);
  pinMode(pumpPin4, OUTPUT);
  pinMode(pumpPin5, OUTPUT);
;
  pinMode(bouton1,INPUT);
  pinMode(bouton2,INPUT);
  pinMode(bouton3,INPUT);
  pinMode(bouton4,INPUT);

}

void loop() {
  // establish variables for duration of the ping, and the distance result
  // in inches and centimeters:
  long duration, inches, cm;

  // The same pin is used to read the signal from the PING))): a HIGH pulse
  // whose duration is the time (in microseconds) from the sending of the ping
  // to the reception of its echo off of an object.
  pinMode(pingPin, OUTPUT);
  digitalWrite(pingPin, LOW);
  delayMicroseconds(2);
  digitalWrite(pingPin, HIGH);
  delayMicroseconds(5);
  digitalWrite(pingPin, LOW);
  pinMode(pingPin, INPUT);
  duration = pulseIn(pingPin, HIGH);
  

  // convert the time into a distance
  inches = microsecondsToInches(duration);
  cm = microsecondsToCentimeters(duration);

  Serial.print(cm);
  Serial.print("cm");
  Serial.println();

  boutonappuye1 = digitalRead(bouton1);
  Serial.println(boutonappuye1);
  boutonappuye2 = digitalRead(bouton2);
  Serial.println(boutonappuye2);
  boutonappuye3 = digitalRead(bouton3);
  Serial.println(boutonappuye3);
  boutonappuye4 = digitalRead(bouton4);
  Serial.println(boutonappuye4);
  proche = (cm<5);
  if (boutonappuye1 && proche)
  {
  
  digitalWrite(pumpPin2, LOW);// la pompe à eau remplit la bouteille
  digitalWrite(pumpPin3, LOW);// la pompe à eau remplit la bouteille
  delay(5000);
  digitalWrite(pumpPin2, HIGH); // la pompe à eau s'arrête
  digitalWrite(pumpPin3, HIGH);// la pompe à eau s'arrête

} 
  else {
  digitalWrite(pumpPin2, HIGH); // la pompe à eau s'arrête
  digitalWrite(pumpPin3, HIGH);// la pompe à eau s'arrête
 
  } 

  if (boutonappuye2 && proche)
  {
  
  digitalWrite(pumpPin5, LOW);// la pompe à eau remplit la bouteille
  delay(5000);

  } 
  
  else {
  digitalWrite(pumpPin5, HIGH);// la pompe à eau s'arrête
 
  } 
  if (boutonappuye3 && proche){
  
  digitalWrite(pumpPin4, LOW);// la pompe à eau remplit la bouteille
  delay(5000);
  digitalWrite(pumpPin4, HIGH);// la pompe à eau s'arrête

  } 
  else {
 
  digitalWrite(pumpPin4, HIGH); // la pompe à eau s'arrête
}
  if (boutonappuye4 && proche) {
  
  digitalWrite(pumpPin2, LOW);// la pompe à eau remplit la bouteille
  delay(5000);
  digitalWrite(pumpPin2, HIGH);// la pompe à eau s'arrête

  } 
  else {
 
  digitalWrite(pumpPin2, HIGH); // la pompe à eau s'arrête
  }
}

long microsecondsToInches(long microseconds) {
  // According to Parallax's datasheet for the PING))), there are 73.746
  // microseconds per inch (i.e. sound travels at 1130 feet per second).
  // This gives the distance travelled by the ping, outbound and return,
  // so we divide by 2 to get the distance of the obstacle.
  // See: https://www.parallax.com/package/ping-ultrasonic-distance-sensor-downloads/
  return microseconds / 74 / 2;
}

long microsecondsToCentimeters(long microseconds) {
  // The speed of sound is 340 m/s or 29 microseconds per centimeter.
  return microseconds / 29 / 2;
}

Nous nous sommes rendus compte lorsque nous avons voulu faire fonctionner notre montage avec les quatre pompes que la pompe 4 ne fonctionnait pas. Nous l'avons testée toute seule et elle ne fonctionnait toujours pas. En essayant de la changer avec une des trois autres pompes qui nous restait nous avions toujours le même problème et sommes resté assez longtemps bloqué dessus. 

Au final en essayant de refaire deux montages séparés avec deux pompes sur des platines différentes puis de les assembler ensemble sur une seule platine et un seule arduino, nous avons fini par avoir un montage fonctionnel associé à un code fonctionnel.

En parallèle, nous travaillons sur le montage de la structure :

Prise de mesures réelles et découpes des 1er planches. Nous cherchons le materiel le plus adapté pour crée le cadre de notre machine. Nous avons choisi du bois car léger et facile d’accès et facilement découpable et donc assemblable. Nous avons opté pour du bois de 7mm afin d’assurer l’intégrité de la machine.

Plusieurs options : rails, clous, colle, découpage pour entrelacement du bois, vis… 

Peu de vis avaient une taille adapté à notre taille de bois, en effet soit elles étaient au bon diamètre mais trop longues, soit à la bonne longueur mais beaucoup trop large. (suite...)

Nous travaillons donc avec la découpeuse laser pour les découpes concernant le bac de récupération, les planches de la structure (pour les façonner à la bonne taille et faire les trous nécessaires pour faire passer nos éléments comme les tuyaux reliés aux pompes par exemple). La machine à gravure est aussi utilisée pour notre le QR code amenant à notre site, mais aussi pour la plaquette comportant le nom de notre groupe et nos noms.

Nous nous sommes énormément aidé de la découpeuse laser pour couper nos planches. Nous avons utilisé 7 planches principales ;

-3 planches de 22,5 x 50 cm, une en arrière qui peut s’ouvrir, les deux autres sur les côtés.

-1 planche de 22,5 x 45,4 cm, pour placer notre équipement, pompes, arduino, breadboard. 

-2 planches de 22,5 x 30 cm, une pour placer nos bouteilles et l’autre pour placer notre capteur sonore.

-1 planche de 22,5 x 13,1 cm, pour placer la carte électronique.

Nous avons également découpé des trous pour faire passer nos tuyaux en travers, 4 trous ont été fait et chacun d’eux a un diamètre de 0,9 cm, quant à nos pompes nous avons décidé de les coller directement sur la planche où nous avons placer la breadboard et l’arduino. 

 Un cinquième trou de 1,8 cm de diamètre a été conçu pour que nous puissions réunir tous nos tuyaux 

image-1676371420213.png

image-1675948608881.png

06AE8498-E19F-45A9-9C8A-79219CDA755F.jpeg

Semaine du 6 Février :

Pour réaliser notre machine, nous avons décidé de partir sur 4 boissons différentes : eau, jus de pomme, Coca et Whisky. Nous avons donc utilisé 4 pompes différentes et 4 boutons poussoirs. Notre but était d’avoir au moins un mélange parmi les différentes boissons, nous avons donc opté pour un mélange whisky coca qui est contrôlé par un seul bouton quant aux trois autres boutons eux vont permettre de donner les boissons sans mélange ; eau, jus de pomme, Coca.

Concernant le code, comme nous avions besoin d'un capteur déclenchant une action nous avions donc fait en sorte de mettre en place deux conditions pour que notre machine fonctionne. Appuyer sur le bouton est obligatoire pour utiliser la machine mais aussi cette condition doit être accompagnée par une autre condition qui est d'être à une distance bien spécifique du capteur sonar pour que le gobelet se remplisse. Si les deux conditions ne sont pas respectées alors rien ne s’écoule des tuyaux.

Pour une question de simplicité d’accès et d’esthétique nous avons soudé les boutons poussoirs sur une carte électronique (circuit imprimé). 

WhatsApp Image 2023-02-09 at 19.32.38.jpeg

Il nous faut ensuite y souder des fils de connexions qui pourront ensuite être reliés à la platine. Attention à être attentif aux placements des fils en comparant l'endroit et l'envers. En effet, en suivant le montage initial, nous savons que le fil GND est en haut à droite, le fil 5V est en haut à gauche et le fil pour le pin digital est à en bas à droite. Donc pour souder correctement en gardant ces emplacements, ils nous faut souder notre fil noir (GND) en haut à gauche, le fil blanc (5V) en haut à droite et le fil bleu (digital) en bas à gauche. Comme montré dans la photo ci-dessous :

WhatsApp Image 2023-02-09 at 19.32.45.jpeg

Nous pouvons ensuite relier les fils à la platine. 

WhatsApp Image 2023-02-09 at 19.32.51.jpeg

Il est donc possible de voir l'agencement de nos pompes et de leurs tuyaux dans notre machine. Les bouteilles se trouvant en dessous de la planche. (photo ?). 

Jeudi 9 Février :

Le jour de la présentation, les dernières retouches sont faites ; le montage du bac d’écoulement, les dernières planches sont mises en place.

Nous effectuons nos gravures pour le QR code et celle de présentation du projet.

image-1676371489723.png

image-1676371496281.png

Nous avons rencontré un problème avant la présentation, la breadboard a cessé de fonctionner, nous étions obligés de refaire les branchements, deux des pompes utilisées n’étaient pas assez puissante, le tuyau utilisé avait une longueur de 1 m ce qui n’était pas assez long (par exemple nous n’avons pas pu faire rentrer complètement nos tuyaux dans les bouteilles ; conséquence très peu de liquide sortait du tuyau.)

Nous devons aussi adapter le code au vu de la puissance des pompes. Nous rappelons que les pompes 2 et 3 ne sont pas assez puissante pour pomper n'importe quel liquide. Et nous devons nous rattraper uniquement en utilisant les pompes 4 et 5 correspondant respectivement au whisky et au jus de pomme.

const int pingPin = 10;

const int pumpPin2 = 2; // // le relais est connecté à la broche  de la carte Adruino
const int pumpPin3 = 3; // // le relais est connecté à la broche  de la carte Adruino
const int pumpPin4 = 4; // // le relais est connecté à la broche  de la carte Adruino
const int pumpPin5 = 5; // // le relais est connecté à la broche  de la carte Adruino

const int bouton1 = 6;
const int bouton2 = 7;
const int bouton3 = 8;
const int bouton4 = 9;

boolean boutonappuye1;
boolean boutonappuye2;
boolean boutonappuye3;
boolean boutonappuye4;

boolean proche;

void setup() {
  // initialize serial communication:

  Serial.begin(9600);

  // The PING))) is triggered by a HIGH pulse of 2 or more microseconds.
  // Give a short LOW pulse beforehand to ensure a clean HIGH pulse:
  pinMode(pumpPin2, OUTPUT);
  pinMode(pumpPin3, OUTPUT);
  pinMode(pumpPin4, OUTPUT);
  pinMode(pumpPin5, OUTPUT);
;
  pinMode(bouton1,INPUT);
  pinMode(bouton2,INPUT);
  pinMode(bouton3,INPUT);
  pinMode(bouton4,INPUT);

}


void loop() {
  // establish variables for duration of the ping, and the distance result
  // in inches and centimeters:
  long duration, inches, cm;

  // The same pin is used to read the signal from the PING))): a HIGH pulse
  // whose duration is the time (in microseconds) from the sending of the ping
  // to the reception of its echo off of an object.
  pinMode(pingPin, OUTPUT);
  digitalWrite(pingPin, LOW);
  delayMicroseconds(2);
  digitalWrite(pingPin, HIGH);
  delayMicroseconds(5);
  digitalWrite(pingPin, LOW);
  pinMode(pingPin, INPUT);
  duration = pulseIn(pingPin, HIGH);
  

  // convert the time into a distance
  inches = microsecondsToInches(duration);
  cm = microsecondsToCentimeters(duration);

  Serial.print(cm);
  Serial.print("cm");
  Serial.println();

  boutonappuye1 = digitalRead(bouton1);
  Serial.println(boutonappuye1);
  boutonappuye2 = digitalRead(bouton2);
  Serial.println(boutonappuye2);
  boutonappuye3 = digitalRead(bouton3);
  Serial.println(boutonappuye3);
  boutonappuye4 = digitalRead(bouton4);
  Serial.println(boutonappuye4);
  
  proche = (cm<3);
  digitalWrite(pumpPin2, HIGH);
  digitalWrite(pumpPin3, HIGH);
  digitalWrite(pumpPin4, HIGH);
  digitalWrite(pumpPin5, HIGH);
  
  if (boutonappuye1 && proche)
  {
  
  digitalWrite(pumpPin4, LOW);// la pompe à whisky remplit le verre
  delay(10000);
  digitalWrite(pumpPin4, HIGH);// la pompe à whisky s'arrête
  digitalWrite(pumpPin2, LOW);// la pompe à coca remplit le verre
  delay(40000);
  digitalWrite(pumpPin2, HIGH);// la pompe à coca s'arrête
  } 
  else {
 
  digitalWrite(pumpPin4, HIGH); // la pompe à eau s'arrête
  digitalWrite(pumpPin2, HIGH);// la pompe à eau s'arrête
 
  } 

  if (boutonappuye2 && proche)
  {
  
  digitalWrite(pumpPin5, LOW);// la pompe à jus de pomme est amené au verre
  delay(60000);
  digitalWrite(pumpPin5, HIGH);
  } 
  
  else {
  digitalWrite(pumpPin5, HIGH);// la pompe s'arrête
 
  } 
  if (boutonappuye3 && proche){
  
  digitalWrite(pumpPin3, LOW);// la pompe à eau remplit le verre
  delay(10000);
  digitalWrite(pumpPin3, HIGH);// la pompe à eau s'arrête
  } 
  
  else {
 
  digitalWrite(pumpPin3, HIGH); // la pompe à eau s'arrête
}
  if (boutonappuye4 && proche) {
  
  digitalWrite(pumpPin2, LOW);// la pompe à coca remplit le verre
  delay(5000);
  digitalWrite(pumpPin2, HIGH);// la pompe à coca s'arrête
  } 
  
  else {
 
  digitalWrite(pumpPin2, HIGH); // la pompe à coca s'arrête
  }
}

long microsecondsToInches(long microseconds) {
  // According to Parallax's datasheet for the PING))), there are 73.746
  // microseconds per inch (i.e. sound travels at 1130 feet per second).
  // This gives the distance travelled by the ping, outbound and return,
  // so we divide by 2 to get the distance of the obstacle.
  // See: https://www.parallax.com/package/ping-ultrasonic-distance-sensor-downloads/
  return microseconds / 74 / 2;
}

long microsecondsToCentimeters(long microseconds) {
  // The speed of sound is 340 m/s or 29 microseconds per centimeter.
  return microseconds / 29 / 2;
}

Il nous faut donc 1 minute d'activité de notre pompe 5 pour pouvoir remplir à moitié notre verre de 33 cl, ce qui corroborent notre hypothèse que les pompes ne sont pas assez performantes. 

Mardi 14 février :

Nous sommes revenus ce mardi pour apporter quelques finitions au projet.

Il fallait notamment refermer la structure avec la planche du haut pour pouvoir cacher les branchements.

Au vu des problèmes de pompes, nous avions comme objectif de changer les pompes 2 et 3 qui ne fonctionnaient pas assez contre d'autres qui seraient éventuellement assez puissantes. En testant les 3 pompes supplémentaires qui n'étaient pas initialement utilisées, aucunes d'entre elles ne permettaient de pomper du liquide. 

La décision a été prise de se limiter à deux pompes fonctionnelles et donc deux boutons. Le montage final comporte deux pompes, la pompe 4 relié au coca et la 5 au jus de pomme. Le coca est servi lorsque nous appuyons sur le bouton 1 et le bouton 2 est pour le jus de pomme.

image-1676708098393.13.23.png

En testant à nouveau les pompes, nous avons décidé de changer les temps de "delay", car en effet pour un temps de fonctionnement de 25000 ms ou 25 s, nous avons environ 12,5 cl de boisson versé, ce qui nous a semblé adapté pour différents volume de verre. 

const int pingPin = 10;

const int pumpPin4 = 4; // // le relais est connecté à la broche  de la carte Adruino
const int pumpPin5 = 5; // // le relais est connecté à la broche  de la carte Adruino

const int bouton1 = 6;
const int bouton2 = 7;

boolean boutonappuye1;
boolean boutonappuye2;

boolean proche;

void setup() {
  // initialize serial communication:

  Serial.begin(9600);

  // The PING))) is triggered by a HIGH pulse of 2 or more microseconds.
  // Give a short LOW pulse beforehand to ensure a clean HIGH pulse:

  pinMode(pumpPin4, OUTPUT);
  pinMode(pumpPin5, OUTPUT);
;
  pinMode(bouton1,INPUT);
  pinMode(bouton2,INPUT);

}


void loop() {
  // establish variables for duration of the ping, and the distance result
  // in inches and centimeters:
  long duration, inches, cm;

  // The same pin is used to read the signal from the PING))): a HIGH pulse
  // whose duration is the time (in microseconds) from the sending of the ping
  // to the reception of its echo off of an object.
  pinMode(pingPin, OUTPUT);
  digitalWrite(pingPin, LOW);
  delayMicroseconds(2);
  digitalWrite(pingPin, HIGH);
  delayMicroseconds(5);
  digitalWrite(pingPin, LOW);
  pinMode(pingPin, INPUT);
  duration = pulseIn(pingPin, HIGH);
  

  // convert the time into a distance
  inches = microsecondsToInches(duration);
  cm = microsecondsToCentimeters(duration);

  Serial.print(cm);
  Serial.print("cm");
  Serial.println();

  boutonappuye1 = digitalRead(bouton1);
  Serial.println(boutonappuye1);
  boutonappuye2 = digitalRead(bouton2);
  Serial.println(boutonappuye2);
  
  proche = (cm<5);
 
  
  if (boutonappuye1 && proche)
  {
  
  digitalWrite(pumpPin4, LOW);// la pompe à eau remplit la bouteille
  delay(25000);
  digitalWrite(pumpPin4, HIGH);// la pompe s'arrête

  } 
  
  else {
 digitalWrite(pumpPin4, HIGH);// la pompe s'arrête
 
  } 

  if (boutonappuye2 && proche)
  {
  
  digitalWrite(pumpPin5, LOW);// la pompe à coca remplit la bouteille
  delay(25000);
  digitalWrite(pumpPin5, HIGH);// la pompe s'arrête

  } 
  
  else {
 digitalWrite(pumpPin5, HIGH);// la pompe s'arrête
 
  } 
}

long microsecondsToInches(long microseconds) {
  // According to Parallax's datasheet for the PING))), there are 73.746
  // microseconds per inch (i.e. sound travels at 1130 feet per second).
  // This gives the distance travelled by the ping, outbound and return,
  // so we divide by 2 to get the distance of the obstacle.
  // See: https://www.parallax.com/package/ping-ultrasonic-distance-sensor-downloads/
  return microseconds / 74 / 2;
}

long microsecondsToCentimeters(long microseconds) {
  // The speed of sound is 340 m/s or 29 microseconds per centimeter.
  return microseconds / 29 / 2;
}