Compare commits
7 commits
1b78a1dc58
...
207eca79fe
Author | SHA1 | Date | |
---|---|---|---|
207eca79fe | |||
a57bcd371a | |||
|
692fe481b4 | ||
d53117d8bc | |||
afc4639e8b | |||
d549d76830 | |||
7943230190 |
8 changed files with 153 additions and 3 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -1 +1,3 @@
|
||||||
site/
|
site/
|
||||||
|
.direnv
|
||||||
|
.envrc
|
||||||
|
|
|
@ -1,3 +0,0 @@
|
||||||
# Projets
|
|
||||||
|
|
||||||
Des détails sur des projets en cours et passés de HackENS.
|
|
BIN
docs/projects/agb_galois.jpeg
Normal file
BIN
docs/projects/agb_galois.jpeg
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.7 MiB |
148
docs/projects/boite_agb.md
Normal file
148
docs/projects/boite_agb.md
Normal file
|
@ -0,0 +1,148 @@
|
||||||
|
# Boîte COF de l'AGB
|
||||||
|
|
||||||
|
_Maurice, Sel, catvayor. Octobre 2024_
|
||||||
|
|
||||||
|
|
||||||
|
Pour l'AG budget d'octobre 2024, HackENS a produit un contrôleur
|
||||||
|
de projecteur pour [le site de l'AGB](http://agb.hackens.org)
|
||||||
|
à mettre entre les mains (responsables, voyons) du COF.
|
||||||
|
|
||||||
|
Le COF avait donc accès à la configuration d'un projecteur (motorisation,
|
||||||
|
luminosité, couleur) et à un effet "color bump".
|
||||||
|
|
||||||
|
![Boîte en octobre 2024](boite_oct24.jpg)
|
||||||
|
|
||||||
|
|
||||||
|
## Réalisation
|
||||||
|
|
||||||
|
L'idée de départ est la suivante : un panneau de contrôle sans fil pour le COF,
|
||||||
|
relié via l'API de Maurice aux projecteurs de l'AGB. Maurice a fourni une
|
||||||
|
batterie (108 Wh !!) et via BiBi HackENS a récupéré des Raspberry Pi Zero,
|
||||||
|
qui sont idéales pour ce genre de projet.
|
||||||
|
|
||||||
|
On a identifié 3 domaines lors du développement (on était 3, quel hasard) :
|
||||||
|
|
||||||
|
- la mécanique/électronique : une boîte qui tient, avec joystick
|
||||||
|
et boutons;
|
||||||
|
|
||||||
|
- le software sur le contrôleur : comment programmer la Raspi et comment on
|
||||||
|
communique avec l'API de l'AGB;
|
||||||
|
|
||||||
|
- les hooks dans l'API de l'AGB, notamment rajouter le contrôle du projecteur
|
||||||
|
dans les services offerts, ainsi que le système d'autorisation.
|
||||||
|
|
||||||
|
La distinction n'était pas toujours très claire toutefois : est-ce que la soudure,
|
||||||
|
la détermination des pinout relève du point 1 ou 2 ? Est-ce que la trigo pour
|
||||||
|
contrôler le projecteur de manière intuitive relève du contrôleur local ou de
|
||||||
|
l'API ? On a travaillé principalement sur ces 3 points séparément
|
||||||
|
mais on s'est entraidé donc les frontières floues entre ces points n'ont pas
|
||||||
|
posé de problèmes.
|
||||||
|
|
||||||
|
### Mécanique (Sel)
|
||||||
|
|
||||||
|
L'aspect le plus important de la boîte est son haut, avec le panneau de
|
||||||
|
contrôle. Avec des pièces d'arcade qui traînaient, on était sûrs au début de
|
||||||
|
mettre un joystick et deux boutons. Aussi, un potentiomètre semblait une
|
||||||
|
option tentante. Mais installer un potentiomètre peut introduire de la
|
||||||
|
complexité : _a priori_ la Raspi Pico ne peut pas lire la résistance du
|
||||||
|
potentiomètre directement car elle n'a que des entrées numériques...
|
||||||
|
|
||||||
|
La boîte fait environ 20cm x 20cm x 11cm, les dimensions étant choisies
|
||||||
|
surtout pour contenir la (grosse) batterie de Maurice tout en ayant assez de
|
||||||
|
hauteur pour installer les contrôles.
|
||||||
|
|
||||||
|
Initialement j'ai voulu réaliser une boîte beaucoup trop ambitieuse à la CNC,
|
||||||
|
où les "murs" sont biseautés à 45° chacun avant d'être collés. Un étrange
|
||||||
|
bug de soft limit sur la CNC a empêché l'usinage des pièces. Avec un peu trop
|
||||||
|
d'enthousiasme, j'ai alors essayé d'usiner cela à la défonceuse. C'était une
|
||||||
|
__très__ mauvaise idée, comme en témoignent 4 pauvres chutes de bois encore
|
||||||
|
à hackENS.
|
||||||
|
|
||||||
|
J'ai donc dû tout reprendre de 0 le dimanche pour le mardi, avec un design plus
|
||||||
|
simple : 4 murs rectangulaires, avec deux paires égales car découpées ensemble.
|
||||||
|
Les murs sont collés ensemble, et une planche de contreplaqué usinée à la CNC
|
||||||
|
(bouton par bouton, pour éviter partiellement le bug) tient les contrôles :
|
||||||
|
les 2 boutons, le joystick, un commutateur ON/OFF et un encodeur. En effet,
|
||||||
|
après avoir trouvé un encodeur numérique, qui donne par l'état de 8
|
||||||
|
interrupteurs l'angle de son axe, on a décidé de l'ajouter à la place du
|
||||||
|
potentiomètre.
|
||||||
|
|
||||||
|
Le fond de la boîte a un rebord pour s'aligner sans jeu en dessous
|
||||||
|
des murs, mais la boîte est fermée par 2 équerres dans tous les cas. Des pieds
|
||||||
|
en caoutchouc s'assurent que la boîte ne glisse pas, même maltraitée, et permet
|
||||||
|
aux équerres de ne pas racler le sol.
|
||||||
|
|
||||||
|
![la boîte, ouverte](boite_ouverte_oct24.jpg)
|
||||||
|
|
||||||
|
### Software embarqué (catvayor)
|
||||||
|
|
||||||
|
Pour le software embarqué, la raspberry était sous NixOS, avec une unité systemd
|
||||||
|
pour interfacer les commandes avec l'API de l'AGB. La config NixOS complète est
|
||||||
|
[ici](https://git.dgnum.eu/HackENS/hackens-org-configurations/src/commit/fecddb1f7720d40cacdcfd7b7e91d4f9c0289184/machines/agb02),
|
||||||
|
elle n'a rien de particulièrement mystèrieux, mise à part l'import du module pour
|
||||||
|
faire une image prête à booter pour la carte SD. La connection internet se faisait
|
||||||
|
par WiFi en l'absence d'autre possibilité, qui pendant l'agb aura été fourni par
|
||||||
|
mon partage de connection, car la solution prévue qui passait par une autre Raspberry Pi
|
||||||
|
n'a pas fonctionné. Pour pouvoir débugguer en live, on l'avait mis sur le VPN d'Hackens,
|
||||||
|
ce qui n'aura pas été utile pour débugguer, mais pour autre chose.
|
||||||
|
|
||||||
|
L'interface entre les commandes et le serveur de l'agb se fait en C++, avec `libgpiod`
|
||||||
|
pour lire les entrées des commandes, et un socket C pour envoyer les commandes
|
||||||
|
correspondantes. Initialement, on voulait utiliser les endpoints HTTPS, mais
|
||||||
|
on a remarqué une lenteur considérable de curl sur la Raspberry,
|
||||||
|
ammenant le temps de réponse à 700ms (on n'a pas pris le temps d'identifier la source
|
||||||
|
du problème). L'authentification par token était alors impossible et on a choisi
|
||||||
|
de modifier de serveur pour recevoir un flux de json par un simple socket, ouvert
|
||||||
|
que sur le VPN.
|
||||||
|
|
||||||
|
Petit point à noter: certains des pins de la raspberry pi ont des usages particulier,
|
||||||
|
ce qui peut poser problème si on les utilise, notamment, la Rraspberry ne bootait que si
|
||||||
|
le décodeur était dans la bonne position, sinon les pins I2C sont mis à GND, ce qui gêne
|
||||||
|
manifestement le boot.
|
||||||
|
|
||||||
|
### API de l'AGB (Maurice)
|
||||||
|
|
||||||
|
L'API est un petit programme rust pour le backend et une application django pour
|
||||||
|
l'authentification et le frontend. Le code source est public:
|
||||||
|
[https://git.dgnum.eu/HackENS/ragb](https://git.dgnum.eu/HackENS/ragb). Pour
|
||||||
|
mettre à jour la base de données interne d'états des projecteurs on utilise des
|
||||||
|
requêtes POST (ou une socket tcp over wireguard pour la boîte). La notification des clients (pages du frontend ouvertes ainsi que
|
||||||
|
le boîtier de contrôle DMX, cf plus tard) d'un changement de l'état de la base
|
||||||
|
de donnée est réalisé via un SSE
|
||||||
|
([https://fr.wikipedia.org/wiki/Server-sent_events](https://fr.wikipedia.org/wiki/Server-sent_events)).
|
||||||
|
Voici un exemple typique de message que l'on peut recevoir sur le SSE:
|
||||||
|
```
|
||||||
|
data: {"type":"Color","address":129,"value":{"red":0,"green":0,"blue":0}}
|
||||||
|
|
||||||
|
data:
|
||||||
|
{"type":"Motor","pan":164,"tilt":97,"focus":173,"white_button":0,"black_button":false,"bump_color":{"red":246,"green":49,"blue":49}}
|
||||||
|
```
|
||||||
|
|
||||||
|
Pour expérimenter un peu vous pouvez consulter la documentation de l'api:
|
||||||
|
[https://agb.hackens.org/api-docs/](https://agb.hackens.org/api-docs/) et lire
|
||||||
|
le SSE avec la commande `curl -ns https://agb.hackens.org/api/sse`
|
||||||
|
|
||||||
|
|
||||||
|
### Le contrôle DMX des projecteurs
|
||||||
|
|
||||||
|
Pour le contrôle des projecteur on utilise le protocole standard de PLS: le
|
||||||
|
[DMX-512](https://fr.wikipedia.org/wiki/DMX_%28%C3%A9clairage%29). Il s'agit d'un bus série assez simple: Le contrôleur envoie des
|
||||||
|
paquets de 512 octets sur le bus et les projecteurs lisent une partie de ce
|
||||||
|
paquet pour savoir dans quel état se mettre (la partie du paquet correspondant à
|
||||||
|
chaque projecteur est déterminé par _l'addresse_ du projecteur). Une fois les
|
||||||
|
projecteurs installés et raccordés au bus il nous reste à connecter un boîtier
|
||||||
|
de contrôle usb (le [Entec DMX USB
|
||||||
|
PRO](https://www.enttec.com/product/dmx-usb-interfaces/dmx-usb-pro-professional-1u-usb-to-dmx512-converter/)) à une raspberry pi qui écoute le SSE et traduit les changement de couleur. Le script réalisant l'opération est dispo [ici](https://git.dgnum.eu/HackENS/hackens-org-configurations/src/commit/da09ce104af8c83343e0987299b2df2102f33f97/machines/agb01/script.py). Une particularité de ce script est qu'il est capable de s'adapter entre les AGB à des changement de setup lumière grâce au fichier [https://agb.hackens.org/api-docs/patch.json](https://agb.hackens.org/api-docs/patch.json) qui décrit l'installation lumière.
|
||||||
|
|
||||||
|
#### Amélioration possible: Ajout de messages en batch dans le SSE
|
||||||
|
|
||||||
|
Pour le bump, le SSE envoie un message par addresse DMX pour signaler le
|
||||||
|
changement de couleur. Ainsi le boîtier de commande DMX change de façon
|
||||||
|
séquentielle toutes les couleurs et c'est LEENNNNNNNT. Il faut absoluement pour
|
||||||
|
la prochaine fois ajouter un type de message "batch" dans le SSE pour que le
|
||||||
|
changement de plusieurs couleur soit atomique et simultané.
|
||||||
|
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
![Installation en Galois](agb_galois.jpeg)
|
BIN
docs/projects/boite_oct24.jpg
Normal file
BIN
docs/projects/boite_oct24.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.5 MiB |
BIN
docs/projects/boite_ouverte_oct24.jpg
Normal file
BIN
docs/projects/boite_ouverte_oct24.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.3 MiB |
|
@ -7,8 +7,11 @@ theme:
|
||||||
nav:
|
nav:
|
||||||
- Projets:
|
- Projets:
|
||||||
- Borne d'arcade: projects/arcade.md
|
- Borne d'arcade: projects/arcade.md
|
||||||
|
- Boîte AGB: projects/boite_agb.md
|
||||||
- Outils:
|
- Outils:
|
||||||
- Perceuse à colonne: tools/perceuse_colonne.md
|
- Perceuse à colonne: tools/perceuse_colonne.md
|
||||||
|
- Ponceuse: tools/ponceuse.md
|
||||||
|
- Imprimante 3D: tools/imprimante3d.md
|
||||||
- CNC: tools/cnc.md
|
- CNC: tools/cnc.md
|
||||||
- Chimie:
|
- Chimie:
|
||||||
- Solvants: chemistry/solvants.md
|
- Solvants: chemistry/solvants.md
|
||||||
|
|
Loading…
Reference in a new issue