Table des matières:
2025 Auteur: John Day | [email protected]. Dernière modifié: 2025-01-23 14:46
LE PROBLÈME
Comme nous le savons, la tendance des espaces de coworking s'est accélérée au cours des dernières années, avec une technologie de pointe définissant le choix de l'espace de coworking spécifique qui correspond à vos besoins.
L'une des principales fonctionnalités proposées est les salles de réunion partagées proposées aux membres de l'espace de co-working, qui sont gérées par une plate-forme de calendrier (généralement) simple.
Un problème se reproduit car l'emploi du temps des gens a tendance à être dynamique.
On pourrait réserver une chambre en pensant qu'il pourrait en avoir besoin et ne voudrait pas manquer le créneau horaire.
Même si quelqu'un n'utiliserait pas ce créneau horaire, il ne prendra pas la peine de le notifier et de l'annuler pour le bien des autres, car, malheureusement, c'est la nature humaine.
COMMENT LE RÉSOUDRE ?
En utilisant la technologie IoT - en vérifiant le son et le mouvement dans une salle de réunion désignée, nous vérifions, à chaque intervalle de temps, si une salle est réservée et effectivement occupée ou non:
1. S'il n'est pas réservé, ne faites rien.
2. S'il est réservé, vérifiez s'il y a un mouvement ou un son détecté;
Si c'est le cas, ne faites rien.
Si rien n'a été détecté, envoyez un message d'avertissement (par e-mail) à l'utilisateur qui a réservé la chambre pour lui demander si la chambre est toujours utilisée. à moins que l'utilisateur ne déclare qu'il utilise toujours la chambre, le statut de la chambre passera à « Disponible ».
* Ici, nous avons intégré notre projet avec Google Calendar afin de le généraliser au maximum.
Étape 1: Matériel et protocoles nécessaires
1. Nous avons utilisé NOSEMCU pour pouvoir mettre à jour les choses de manière dynamique à l'aide de la connexion WIFI.
2. Capteur de microphone qui "lira" le bruit dans la pièce.
3. Capteur PIR qui vérifiera s'il y a un mouvement.
Pour l'utilisation du logiciel et du serveur, outre le code dans Arduino, nous avons utilisé Google Script et Zapier pour prendre en charge notre système en ligne. Vous pouvez voir le flux dans l'image ajoutée (et PDF).
Nous avons utilisé Zapier pour connecter des applications et automatiser nos flux de travail (comme IFTTT) et nous avons utilisé Google Script pour nous aider à communiquer avec Google Calendar. Le script que nous avons écrit produit l'e-mail du créateur de l'événement afin que nous puissions l'envoyer à Zapier et vérifie si l'utilisateur a demandé à conserver la salle (en enregistrant certaines informations dans Google Sheets) avant de supprimer l'événement.
Étape 2: connectez le microphone et le capteur PIR
Nous voulions vérifier les valeurs moyennes que le microphone envoie au NODEMCU lorsque les gens parlent (clairement, dans chaque pièce il y avait des bruits de fond différents). Nous avons fait quelques tests et nous nous sommes rendu compte que le niveau de bruit moyen dans la pièce dans laquelle nous travaillions est supérieur à 50.
Le capteur PIR ne donne que des valeurs HIGH ou LOW, nous n'avons donc vérifié que le niveau de sensibilité le plus précis pour la pièce que nous avons vérifiée. Ce guide a été assez utile.
NOS CONNEXIONS:
Microphone - comme sur l'image Capteur PIR: GND > GND, OUT > D7, VCC > VN (5V)
Étape 3: Créer le workflow dans Zapier
Afin de savoir si la salle est réellement vide ou encore en cours d'utilisation (et les utilisateurs sont en pause par exemple), nous souhaitons créer un flux qui l'assure, juste après que le NodeMCU ait déclenché un Webhook vers Zapier qui notifie que le la salle est vide:
(1) DÉCLENCHEUR - CATCH HOOKZapier attrape le Webhook (qui sera envoyé par le NODEMCU)
(2) ACTION - GETZapier envoie un autre Webhook pour obtenir les données de l'événement;> Il appelle (exécute) un GoogleScript - GetCurrentEmailEventID (explication à l'étape suivante), pour obtenir les données de l'événement actuel - nom de l'événement, ID de l'événement, e-mail de l'utilisateur.
(3) FILTRE - CONTINUER UNIQUEMENT SI
Passez à l'étape suivante uniquement s'il y a un événement (n'importe quel événement) en cours sur le calendrier (ROOM IS BUSY), sinon, s'arrête car la salle est vacante.
(4) ACTION - GMAILZapier envoie un e-mail, via Gmail, à l'utilisateur qui a réservé la chambre (obtenu cette information à l'étape 2)
(5) ACTION - RETARD POURLaissez à l'utilisateur le temps de répondre à l'e-mail.- Si l'utilisateur clique sur le lien: appelez (exécutez) le GoogleScript - ApproveCurrentEvent (par conséquent, la salle est supprimée de la liste "Pièces à supprimer", et le la pièce est toujours marquée comme occupée.)
(6) ACTION - GET Après 5 minutes, Zapier appelle (exécute) GoogleScript - DeleteCurrentEvent- Si l'utilisateur n'a pas cliqué sur le lien
Vérifie si l'identifiant de la salle est dans la liste 'Pièces à supprimer'
il supprime simplement l'événement.
Étape 4: Scripts Google
Comme nous avons intégré l'ensemble du système, GoogleScripts était le choix trivial d'un IDE. Ainsi, nous avons utilisé les bibliothèques Google pertinentes. Changerait en fonction de la plateforme de réservation de chambres.
(1) GetCurrentEmailEventID
Fonctionne par un appel Webhook.
Utilisation d'un certain décalage afin d'éliminer une éventuelle annulation manquée, obtenir les données d'événement en cours.
(2) ApprouverCurrentEvent
Fonctionne par un clic de l'utilisateur.
En cas d'approbation par un utilisateur que la salle est toujours utilisée, supprime l'ID d'événement des « Pièces à supprimer ». Nous avons utilisé une feuille Google, toute autre forme de liste pourrait être pertinente ici.
(3) Supprimer l'événement en cours
Fonctionne par un appel Webhook.
Recherche l'ID d'événement pertinent dans la liste (feuille Google) et supprime cet événement du calendrier.
Étape 5: Connectez le flux avec le code Arduino
Le code joint se connecte aux capteurs que nous avons vérifiés il y a quelques étapes au système en ligne (calendrier Google dans notre cas). Il vérifie si la salle est occupée et si ce n'est pas le cas, il envoie une requête HTTP (un Webhook) qui lance la requête de suppression d'événement sur Zapier.
Étape 6: Examen, conclusions et mise à l'échelle future
Le principal défi auquel nous avons dû faire face est de couvrir tous les cas limites lorsque nous décidons de libérer une salle de réunion. Nous avons ensuite dû créer une machine à états considérant tous les cas possibles, de telle sorte qu'aucune erreur ne se produise et que la salle ne soit définie comme disponible que lorsqu'elle le devrait.
Par exemple, si la salle est réservée pour un groupe qui n'est actuellement pas là (c'est-à-dire en pause, par exemple), mais en a encore besoin, NODEMCU détectera que la salle est libre > PROBLÈME.
Ensuite, notre solution consistait à envoyer par e-mail à l'utilisateur qui avait réservé la chambre (ce qui n'était pas simple à comprendre) un message lui offrant la possibilité de conserver la chambre.
Si l'utilisateur n'a pas répondu dans un délai donné (nous le fixons à 5 minutes, mais cela peut être modifié facilement), nous supprimons l'événement du calendrier (et libérons la salle).
De cette façon, nous avons finalement réussi à gérer tous les scénarios possibles et à créer un système fonctionnel.
LES LIMITES DE NOTRE SYSTÈME:
1. Les capteurs utilisés doivent être très précis et sensibles.
2. La taille de la pièce est limitée au rayon/à la plage du capteur.
3. Nous devrons compter sur la réactivité de l'utilisateur.
4. Notre système est construit à l'aide de plusieurs plateformes (agenda Google, Gmail, Zapier etc.) et devra utiliser leur service pour fonctionner.
5. La mise à l'échelle de ce service pour plusieurs salles (au lieu de dupliquer l'ensemble du système) nécessitera une gestion supplémentaire avec l'ID de la salle.
6. Le système est uniquement automatique et il n'y a pas d'option manuelle pour annuler une réservation de chambre.
DÉVELOPPEMENTS FUTURS:
Nous augmenterions certainement le système de deux manières:
1. Capacité à travailler avec n'importe quelle autre plate-forme de calendrier (ainsi toute entreprise d'espaces de co-working pourrait l'utiliser).
2. Capacité à gérer plusieurs pièces, étages et sites.
Nous pensons que ce type d'échelle prendra 2-3 mois pour généraliser, tester et ajouter plusieurs pièces (étages, etc.).
De plus, en utilisant une quantité illimitée d'argent et de ressources, nous utiliserions de meilleurs capteurs avec une plus grande portée, tout en les personnalisant en fonction de la pièce désignée - en tenant compte de la portée, du rayon, de la quantité de capteurs, etc. Une étape qui rendrait chaque système plus long à installer, évidemment.
Conseillé:
Lumière de salle de bain au milieu de la nuit : 5 étapes (avec photos)
Lumière de salle de bain au milieu de la nuit : Certains d'entre nous ressentent le besoin d'utiliser la salle de bain au milieu de la nuit. Si vous allumez une lumière, vous risquez de perdre votre vision nocturne. La lumière blanche ou bleue fait perdre l'hormone du sommeil, la mélatonine, ce qui rend plus difficile le retour au sommeil. Donc
Balance de salle de bain Arduino avec cellules de charge de 50 kg et amplificateur HX711 : 5 étapes (avec photos)
Balance de salle de bain Arduino avec cellules de charge de 50 kg et amplificateur HX711 : ce Instructable décrit comment fabriquer une balance à l'aide de pièces facilement disponibles sur étagère. Matériel nécessaire : Arduino - (cette conception utilise un Arduino Uno standard, d'autres versions ou clones d'Arduino devraient fonctionner aussi) HX711 sur le boa de rupture
Rappel de réunion du calendrier Outlook à écran tactile Nextion : 6 étapes
Rappel de réunion du calendrier Outlook de l'écran tactile Nextion : La raison pour laquelle j'ai commencé ce projet était que j'ai souvent manqué des réunions et j'ai pensé que j'avais besoin d'un meilleur système de rappel. Même si nous utilisons le calendrier Microsoft Outlook, j'ai passé la plupart de mon temps sur Linux/UNIX sur le même ordinateur. En travaillant avec
Suivi des toilettes de la salle de classe Makey Makey : 5 étapes
Makey Makey Classroom Restroom Tracker : Avez-vous déjà été occupé dans votre classe et perdu la trace de quel élève (ou si plusieurs) est allé aux toilettes ? J'enseigne l'informatique au lycée et je constate que les étudiants essaient souvent de quitter la salle de classe pour "utiliser les toilettes"
Moniteur de salle de serveur : 4 étapes
Moniteur de salle de serveurs : L'un des problèmes d'une salle de serveurs est la température. Avec différents équipements produisant de la chaleur, celle-ci augmente rapidement. Et si la climatisation tombe en panne, elle arrête tout rapidement. Pour prédire ces situations, nous pouvons acquérir un environnement parmi plusieurs