Bob's Output Board : Différence entre versions

De L'abscisse - FabLab et Hackerspace de Dijon
Aller à : navigation, rechercher
m
 
(57 révisions intermédiaires par 3 utilisateurs non affichées)
Ligne 1 : Ligne 1 :
{{redac}}
+
[[Fichier:BOB_LOGO.png|200px|thumb|Le logo du projet]]
 +
[[Fichier:Une_interface_BOB_v2.jpeg|200px|thumb|Une interface BOB v2 réalisée au FabLab]]
 +
[[Fichier:BOB démo ventilateur.jpeg|200px|thumb|BOB assurant le contrôle d'un ventilateur]]
 +
==Présentation==
  
==Présentation==
 
 
Le projet BOB est une interface permettant la commande d'éléments de puissance (éclairages, moteurs, etc...) fonctionnant en courant continu par un raspberry, arduino, etc...  
 
Le projet BOB est une interface permettant la commande d'éléments de puissance (éclairages, moteurs, etc...) fonctionnant en courant continu par un raspberry, arduino, etc...  
 
Il consiste en une carte proposant 8 sorties.
 
Il consiste en une carte proposant 8 sorties.
 
La carte BOB se commande en logique 0 / 5V autorisant sa commande directe par un arduino, mais également par un Raspberry, malgré la logique 3.3V de ce dernier.
 
La carte BOB se commande en logique 0 / 5V autorisant sa commande directe par un arduino, mais également par un Raspberry, malgré la logique 3.3V de ce dernier.
  
On peut connecter autant de cartes BOB à la suite que nécessaire pour obtenir le nombre de sorties requises.
+
On peut virtuellement connecter autant de cartes BOB à la suite que nécessaire pour obtenir le nombre de sorties requises. Dans la pratique, ce nombre est limité par la longueur des fils possible (des fils trop longs induisent des parasites sur les signaux de commande), et le courant que peut délivrer l'appareil de contrôle. Sur un raspberry, il est possible de chainer 4 BOB sans problèmes (en maintenant des fils courts), un nombre plus important nécessitera l'ajout d'un buffer entre le raspberry et les BOBs.
  
L'ensemble des éléments du projets sont disponibles sur la page gitorious de BOB.[https://gitorious.org/bobsoutputboard]
+
L'ensemble des éléments du projets, incluant le schéma et le typon (projet KICAD), sont disponibles sur la page GitLab de BOB.[https://gitlab.com/bobsoutputboard]
  
[[Fichier:Pcbbob.png]]
+
==Coût==
  
==Coût==
+
20€ de composants + PCB + Arduino/RasberryPi
20€ + PCB
 
  
 
==Niveau de difficulté==
 
==Niveau de difficulté==
Ligne 20 : Ligne 21 :
  
 
==Hardware==
 
==Hardware==
La carte est construite d'un circuit intégré 74HC595, qui contrôle 8 transistors MOSFETs, assurant chacun la commutation d'une sortie.
+
 
Chaque sortie peut supporter un courant inférieur à un ampère, être protégé par fusible réarmable (polyswitch), et posséder une led indiquant son état.
+
===Présentation===
Plusieurs cartes BOB peuvent être connectées en cascades.
+
 
 +
[[Fichier:Pcbbob.png|200px|thumb|Le typon de la version 1]]
 +
 
 +
La carte est construite autour d'un circuit intégré 74HC595, qui contrôle 8 transistors MOSFETs, assurant chacun la commutation d'une sortie.
 +
 
 +
Chaque sortie peut supporter un courant de l'ordre d'un ampère), est protégé par fusible réarmable (polyswitch), et dispose d'une LED indiquant son état.
 +
Il est possible d'augmenter facilement le courant maximum disponible en étamant les pistes des puissances, et en remplaçant les polyswitchs par des modèles à plus fort courant.
  
 
La carte BOB possède plusieurs connecteurs
 
La carte BOB possède plusieurs connecteurs
* 2 connecteurs à 8 broches en haut de la carte, permettant son interfaçage avec l'appareil de contrôle et les autres cartes BOB : BOBLink
+
* 2 connecteurs à 8 broches en haut de la carte : BOBLinkIn (en haut) et BOBLinkOut (en dessous).
 
* 8 borniers latéraux : chaque bornier correspond à une sortie  
 
* 8 borniers latéraux : chaque bornier correspond à une sortie  
* 1 bornier en bas : alimentation de puissance ( tension continue, dont la valeur maximale autorisée est dépend des polyswitch, mosfets et diodes.
+
* 1 bornier en bas : alimentation de puissance ( tension continue ).
  
 
Le pinout des connecteurs de BOBLink est le suivant (BOB vue de face, connecteur de contrôle en haut, pin de gauche à droite) :
 
Le pinout des connecteurs de BOBLink est le suivant (BOB vue de face, connecteur de contrôle en haut, pin de gauche à droite) :
Ligne 38 : Ligne 45 :
 
*'''SCLR''': reset des données, 0V pour reset
 
*'''SCLR''': reset des données, 0V pour reset
 
*'''D'''  : donnée d'entrée pour le connecteur d'entrée, de sortie pour le connecteur de sortie.
 
*'''D'''  : donnée d'entrée pour le connecteur d'entrée, de sortie pour le connecteur de sortie.
 +
Chacun de ces signaux correspond directement aux signaux du même nom dans la documentation du circuit intégré 74HC595
 +
 +
Plusieurs cartes BOB peuvent être connectées en cascades, pour cela, on relie le connecteur BOBLinkOut d'une carte au BOBLinkIn de la suivante.
 +
 +
===Caractéristiques===
 +
* 8 sorties par cartes.
 +
* Consommation typique ( rail Vcc ) : 10mA
 +
* Tension maximale commutable : 50V (limitée par les diodes)
 +
* Courant maximal cummutable par sortie : 1A
 +
 +
===Versions===
 +
 +
* v1 : Projet initial
 +
* v2 : Ajout d'un filtre sur l'entrée de validation RCK afin de minimiser l'influence des parasites electro-magnétiques, et de trous de fixation
 +
 +
===Composants===
 +
 +
Pour fabriquer une BOB v2, les composants suivants sont nécessaires :
 +
* 1 x Circuit intégré 74HC595
 +
* 1 x Support de circuit intégré 16 broches ( optionnel, utile si l'on veut pouvoir remplacer le CI )
 +
* 1 x Réseau de résistance SIL 10kOhms
 +
* 1 x Condensateur céramique 0.47 µF (capable de supporter au moins 5v)
 +
* 1 x résistance de 1kOhms
 +
* 1 x Condensateur de 10nF
 +
* 8 x LEDs  5mm ou 3 mm
 +
* 8 x Résistances 2.7kOhms 1/4W (la valeur exact importe peut, mais influence la luminosité des LEDs)
 +
* 8 x Transistors MOSFET IRF620
 +
* 8 x Diodes de redressement 1N5401 à 1N5407
 +
* 8 x Polyswitch (optionnel, permet la protection des sorties, sinon les remplacer par des shunts)
 +
* 9 x Bornier 2 broches
 +
* Au moins 16 unités de barrette sécable
 +
* Un PCB vierge d'au moins 75mm de coté.
 +
 +
===Construction===
 +
 +
Une fois le PCB [[Réalisation_de_circuits_imprimés|réalisé]] à partir du typon disponible dans le projet Kicad
  
==Software==
+
==Utilisation avec une carte  Arduino==
===Arduino===
 
Utilisation de la librarie BOB [https://gitorious.org/bobsoutputboard/arduinobob]
 
Pour l'instant, une seule carte BOB supportée à la fois
 
  
Exemple :  
+
===Câblage===
  #include <BOB.h>
+
 
 +
Seule la première interface BOB doit être reliée à l'arduino.
 +
Relier respectivement ses broches VCC et GND aux broches VCC et GND de l'arduino.
 +
Relier ensuite les 5 autres broches de l'interface BOB à 5 sorties numériques de l'arduino.
 +
 
 +
===Programme===
 +
Utilisation de la  [https://gitlab.com/bobsoutputboard/arduinobob librarie BOB pour arduino] :
 +
Son installation est simple, il suffit de copier le dossier BOB dans le répertoire des librairies Arduino (~/sketchbook/libraries/)
 +
 
 +
  #include <BOB.h> //A ajouter au début du fichier
 
   
 
   
  //Création d'une instance de la classe BOB
+
  BOB bob(7,6,5,4,3,1); //On déclare 1 bob connecté aux pins 7,6,5,4,3 de l'arduino (les pins sont dans l'ordre du connecteur BOBLink)
  //Spécifier en paramètres les pins de l'arduino reliés aux pins de la carte BOB dans l'ordre suivant :
 
// G RCK SCK SCLR D
 
BOB bob(7,6,5,4,3);
 
 
   
 
   
  void setup() {   
+
  void setup() {
 +
  bob.write(0,0b10100101); //La méthode write permet d'écrire toutes les sorties d'un bob en même temps (le premier bob a pour numéro 0)
 
  }
 
  }
 
   
 
   
  //la fonction writePin permet de contrôler les sorties de la carte BOB
+
   
//son usage est le suivant :
 
// writePin(numéroSortie, ETAT)
 
//où ETAT vaut LOW ou HIGH, et numéroSortie est le numéro de la sortie à piloter de 0 à 7
 
 
  void loop() {
 
  void loop() {
  delay(1000);
+
  delay(1000);
  bob.writePin(5,LOW);
+
  bob.writePin(0,2,HIGH); //La méthode writePin permet de changer l'état d'une seule sortie, ici troisième sortie ( numéro 2 ) de la première BOB ( numéro 0 )
  bob.writePin(2,HIGH);
+
  bob.writePin(0,5,LOW);
  delay(1000);
+
  delay(1000);
  bob.writePin(5,HIGH);
+
  bob.writePin(0,5,HIGH);
  bob.writePin(2,LOW);
+
  bob.writePin(0,2,LOW);
 
  }
 
  }
  
===Raspberry===
+
==Utilisation avec un Raspberry Pi==
====Le Daemon bobControl====
+
Les logiciels permettant l'utilisation d'un ou plusieurs BOB depuis un Raspberry Pi sont disponibles sur la page suivante : https://gitlab.com/bobsoutputboard/raspberrybob
 +
 
 +
Leur fonctionnement nécessite d'avoir installé WiringPi sur votre Raspberry Pi. La procédure d'installation de WiringPi est décrite sur la page suivante : http://wiringpi.com/download-and-install/
 +
===Câblage===
 +
Seule la première interface BOB doit être reliée au Raspberry.
 +
Relier respectivement ses broches VCC et GND aux broches VCC(+5V) et GND du raspberry.
 +
Relier ensuite les 5 autres broches de l'interface BOB à 5 GPIO du raspberry.
 +
Le câblage que nous utilisons est le suivant (dans l'ordre des pins de BOB):
 +
* N/A non connecté
 +
* VCC  sur la broche 2  du Raspberry
 +
* GND  sur la broche 6  du Raspberry
 +
* G    sur la broche 3  du Raspberry (GPIO 2)
 +
* RCK  sur la broche 5  du Raspberry (GPIO 3)
 +
* SCK  sur la broche 7  du Raspberry (GPIO 4)
 +
* SCLR sur la broche 8  du Raspberry (GPIO 14)
 +
* D    sur la broche 10 du Raspberry (GPIO 15)
 +
 
 +
Ce câblage possède l'avantage de n'utiliser que les 10 broches supérieures du connecteur du Raspberry, mais nécessite de désactiver la sortie UART du Raspberry, qui utilise les broches 8 et 10. Pour cela, il suffit de commenter la ligne suivante du fichier /etc/inittab en ajoutant un # devant :
 +
  T0:23:respawn:/sbin/getty -L ttyAMA0 115200 vt100
 +
Un redémarrage du Raspberry est nécessaire pour appliquer la modification
 +
 
 +
===Installation===
 +
Installer WiringPi :
 +
$ cd
 +
$ git clone git://git.drogon.net/wiringPi
 +
$ cd wiringPi
 +
$ ./build
 +
 
 +
Récupérer l'intégralité des fichiers présents sur la page GitLab:
 +
$ cd
 +
$ git clone git clone https://gitlab.com/bobsoutputboard/raspberrybob.git
 +
 
 +
Pour utiliser la démo bobMeter, installer également libasound2-dev :
 +
$ sudo apt-get install libasound2-dev
 +
 
 +
Lancer la compilation  dans le dossier créé :
 +
$ cd raspberrybob
 +
$ make
 +
 
 +
 
 +
Modifier éventuellement la ligne 16 du fichier init-script pour qu'elle corresponde à votre câblage :
 +
  OPTS="--gpioG=2 --gpioRCK=3 --gpioSCK=4 --gpioSCLR=14 --gpioD=15 --bob-number=1"
 +
Les options dont le nom commence par ''gpio'' doivent prendre un numéro de GPIO en paramètre. Chacune correspond à un pin de la carte BOB. Ces options permettent d'indiquer au daemon BobControl quels GPIO permettent le dialogue avec les interfaces BOB.
 +
 
 +
Lancer ensuite l'installation
 +
$ sudo make install
 +
 
 +
Il est possible de tester le fonctionnement avec les scripts dont le nom commence par ''test''.
 +
 
 +
En cas de nécessité, la désinstallation de tous les programmes liés à BOB peut être réalisée avec la commande suivante :
 +
$ sudo make uninstall
 +
 
 +
===Le daemon bobControl===
 +
 
 +
Ce logiciel tourne en arrière-plan, et assure l'envoi des ordres aux carte BOBs.
 +
 
 +
Il suffit d'écrire dans le fichier /dev/bob l'état de chaque sortie, et bobControl effectue les opérations nécessaires, une fois le fichier refermé.
 +
 
 +
Le mécanisme [[http://fr.wikipedia.org/wiki/Inotify Inotify]] est utilisé pour détecter toute écriture du fichier /dev/bob.
 +
 
 +
Chaque sortie est matérialisée dans le fichier /dev/bob par un caractère 0 ou 1.
 +
 
 +
Le nombre de caractère présents dans le fichier reflète donc le nombre total de sorties (cette valeur dépend du paramètre ''bob-number'' saisi précédemment lors de
 +
l'édition du fichier ''init-script'')
 +
 
 +
Tout caractère différent de 0 ou 1 est ignoré.
 +
 
 +
Si le nombre de caractère n'est pas conforme, bobControl supprime les caractères en excédent, ou ajoute des caractères 0.
 +
 
 +
Écrire ''stop'' au début du fichier /dev/bob provoque l'arrêt du démon, après avoir désactivé toutes les sorties des BOBs connectées.
 +
 
 +
Il est possible de lire à tout moment ce fichier, pour obtenir le dernier état supposé des sorties (la liaison ''BOBLink'' étant unidirectionnel, il est impossible d'en connaitre l'état réel).
 +
 
 +
Exemple :
 +
  $ echo "01010101" > /dev/bob
 +
Active la moitié des sorties sur la première interface BOB.
 +
 
 +
$ echo "0000000011111111" > /dev/bob
 +
Désactive toutes les sorties de la première interface BOB, et active celle de la seconde BOB (si présente)
 +
 
 +
===La commande bob===
 +
 
 +
La commande ''bob'' offre un accès simplifié pour manipuler indépendamment chaque sortie sans passer par le fichier /dev/bob
 +
 
 +
Sa syntaxe est calquée sur celle de la [[http://wiringpi.com/the-gpio-utility/ commande gpio du projet wiringPi]] :
 +
 
 +
$ bob readall
 +
Affiche un résumé du dernier état supposé des sorties.
 +
 
 +
$ bob output-number
 +
Affiche le nombre total de sorties disponibles
 +
 
 +
$ bob read outputNumber
 +
Affiche l'état supposé de la sortie de numéro ''outputNumber''
 +
 
 +
$ bob write outputNumber value
 +
Pilote la sortie de numéro ''outputNumber'', met son état à ''value'' (0 ou 1).
 +
 
 +
$ bob toggle outputNumber
 +
Inverse l'état de la sortie  de numéro ''outputNumber''
 +
 
 +
$ bob writeall value
 +
Pilote toute les sorties, met leur état à ''value'' (0 ou 1).
 +
 
 +
===Le VU-mètre bobMeter===
 +
 
 +
Permet de contrôler les sorties d'un bob en mode VU-mètre en fonction du son ambiant :
 +
Ce programme nécessite de doter le Raspberry d'une entée audio ( par exemple une webcam USB )
 +
 
 +
On recherche le nom du périphérique audio:
 +
$ arecord -l
 +
 
 +
Exemple avec une webcam Microsoft LifeCam NX-3000 connectée au Raspberry :
 +
$ arecord -l
 +
**** List of CAPTURE Hardware Devices ****
 +
card 1: NX3000 [Microsoft LifeCam NX-3000], device 0: USB Audio [USB Audio]
 +
Subdevices: 1/1
 +
Subdevice #0: subdevice #0
 +
 
 +
Ici le numéro de la carte est 1.
 +
 
 +
Se placer dans le dossier dédié au programmes de la carte BOB :
 +
$ cd ~/raspberrybob
 +
 
 +
Lancer le programme bobMeter en précisant la carte d'entrée à utiliser sous la forme hw:X :
 +
$ ./bobMeter hw:1
 +
 
 +
Le programme bobMeter démarre, pilote la première carte BOB disponible, et affiche un VU-mètre en console, dont chaque barre verticale correspond au seuil d'activation d'une des sorties de la carte BOB :
 +
$ ./bobMeter hw:1
 +
Capture interface prepared
 +
buffer allocated, size : 2048
 +
Let's go !
 +
[==|====|====    |                    |                                      ]
 +
 
 +
 
 +
==L'interface web BOBINE (Bob's Output Board Interface for Network Extension) ==
 +
 
 +
L'interface BOBINE permet de contrôler simplement un ou plusieurs BOB avec une interface web.
 +
 
 +
[[Fichier:BOBINE.PNG]]
 +
 
 +
C'est un simple script en PHP, qui utilise le programme BOB.
 +
Il lit les ports, et permet d'en changer l'état.
 +
 
 +
Le code est visible sur GitLab à l'adresse:
 +
[https://gitlab.com/bobsoutputboard/bobine/]
 +
 
 +
===Installation===
 +
Installer sur le raspberry un serveur Apache avec support du php :
 +
  sudo apt-get install apache2 php5
 +
 
 +
Si ce n'est aps déjà le cas, installer GIT :
 +
  sudo apt-get install git
 +
 
 +
Récupérer le code PHP de Bobine
 +
  git clone https://gitlab.com/bobsoutputboard/bobine.git
 +
 
 +
Le copier dans /var/www/
 +
  sudo cp bobine/* /var/www/
 +
 
 +
Supprimer la page de test du serveur Apache
 +
  sudo rm /var/www/index.html
 +
 
 +
C'est bon, vous pouvez désormais saisir l'adresse IP du Raspberry dans votre navigateur, et prendre le contrôle de votre BOB depuis votre smartphone !
 +
 
 +
Yogi: toute collaboration serait la bienvenue pour avancer sur cette partie.
 +
HTML/PHP/CSS vous voulez donner un coup de main ?  -> belin.nicolas@gmail.com
 +
 
 +
==Liens==
 +
 
 +
Présentation sommaire de BOB sur le site de Pila : http://pila.fr/wordpress/?p=739
  
====La commande bob====
+
Page GitLab du projet BOB : https://gitlab.com/bobsoutputboard
  
 
==Auteurs==
 
==Auteurs==
Ligne 77 : Ligne 291 :
 
*Yogi
 
*Yogi
  
[[Catégorie:HackLab]] [[Catégorie:Fiches Pratiques]]  [[Catégorie:Les projets du HackLab]]
+
[[Catégorie:Électronique/HackLab]] [[Catégorie:Fiches Pratiques]]  [[Catégorie:Les projets du HackLab]] [[Catégorie:Arduino]] [[Catégorie:Montages Raspberry Pi]]

Version actuelle datée du 4 février 2017 à 14:21

Le logo du projet
Une interface BOB v2 réalisée au FabLab
BOB assurant le contrôle d'un ventilateur

Présentation

Le projet BOB est une interface permettant la commande d'éléments de puissance (éclairages, moteurs, etc...) fonctionnant en courant continu par un raspberry, arduino, etc... Il consiste en une carte proposant 8 sorties. La carte BOB se commande en logique 0 / 5V autorisant sa commande directe par un arduino, mais également par un Raspberry, malgré la logique 3.3V de ce dernier.

On peut virtuellement connecter autant de cartes BOB à la suite que nécessaire pour obtenir le nombre de sorties requises. Dans la pratique, ce nombre est limité par la longueur des fils possible (des fils trop longs induisent des parasites sur les signaux de commande), et le courant que peut délivrer l'appareil de contrôle. Sur un raspberry, il est possible de chainer 4 BOB sans problèmes (en maintenant des fils courts), un nombre plus important nécessitera l'ajout d'un buffer entre le raspberry et les BOBs.

L'ensemble des éléments du projets, incluant le schéma et le typon (projet KICAD), sont disponibles sur la page GitLab de BOB.[1]

Coût

20€ de composants + PCB + Arduino/RasberryPi

Niveau de difficulté

Orange.png

Hardware

Présentation

Le typon de la version 1

La carte est construite autour d'un circuit intégré 74HC595, qui contrôle 8 transistors MOSFETs, assurant chacun la commutation d'une sortie.

Chaque sortie peut supporter un courant de l'ordre d'un ampère), est protégé par fusible réarmable (polyswitch), et dispose d'une LED indiquant son état. Il est possible d'augmenter facilement le courant maximum disponible en étamant les pistes des puissances, et en remplaçant les polyswitchs par des modèles à plus fort courant.

La carte BOB possède plusieurs connecteurs

  • 2 connecteurs à 8 broches en haut de la carte : BOBLinkIn (en haut) et BOBLinkOut (en dessous).
  • 8 borniers latéraux : chaque bornier correspond à une sortie
  • 1 bornier en bas : alimentation de puissance ( tension continue ).

Le pinout des connecteurs de BOBLink est le suivant (BOB vue de face, connecteur de contrôle en haut, pin de gauche à droite) :

  • N/A : ce pin n'est relié à rien, mais est transmis à la carte BOB suivante.
  • VCC : alimentation de la carte en +5V
  • GND : masse de la carte
  • G  : contrôle de désactivation des sorties : 0V = sorties activée, 5V = sorties désactivées
  • RCK : contrôle de validation des données : sur front montant (0V -> 5V) les données transmises sont appliquées aux sorties
  • SCK : horloge : sur front montant, provoque le décalage des données.
  • SCLR: reset des données, 0V pour reset
  • D  : donnée d'entrée pour le connecteur d'entrée, de sortie pour le connecteur de sortie.

Chacun de ces signaux correspond directement aux signaux du même nom dans la documentation du circuit intégré 74HC595

Plusieurs cartes BOB peuvent être connectées en cascades, pour cela, on relie le connecteur BOBLinkOut d'une carte au BOBLinkIn de la suivante.

Caractéristiques

  • 8 sorties par cartes.
  • Consommation typique ( rail Vcc ) : 10mA
  • Tension maximale commutable : 50V (limitée par les diodes)
  • Courant maximal cummutable par sortie : 1A

Versions

  • v1 : Projet initial
  • v2 : Ajout d'un filtre sur l'entrée de validation RCK afin de minimiser l'influence des parasites electro-magnétiques, et de trous de fixation

Composants

Pour fabriquer une BOB v2, les composants suivants sont nécessaires :

  • 1 x Circuit intégré 74HC595
  • 1 x Support de circuit intégré 16 broches ( optionnel, utile si l'on veut pouvoir remplacer le CI )
  • 1 x Réseau de résistance SIL 10kOhms
  • 1 x Condensateur céramique 0.47 µF (capable de supporter au moins 5v)
  • 1 x résistance de 1kOhms
  • 1 x Condensateur de 10nF
  • 8 x LEDs 5mm ou 3 mm
  • 8 x Résistances 2.7kOhms 1/4W (la valeur exact importe peut, mais influence la luminosité des LEDs)
  • 8 x Transistors MOSFET IRF620
  • 8 x Diodes de redressement 1N5401 à 1N5407
  • 8 x Polyswitch (optionnel, permet la protection des sorties, sinon les remplacer par des shunts)
  • 9 x Bornier 2 broches
  • Au moins 16 unités de barrette sécable
  • Un PCB vierge d'au moins 75mm de coté.

Construction

Une fois le PCB réalisé à partir du typon disponible dans le projet Kicad

Utilisation avec une carte Arduino

Câblage

Seule la première interface BOB doit être reliée à l'arduino. Relier respectivement ses broches VCC et GND aux broches VCC et GND de l'arduino. Relier ensuite les 5 autres broches de l'interface BOB à 5 sorties numériques de l'arduino.

Programme

Utilisation de la librarie BOB pour arduino : Son installation est simple, il suffit de copier le dossier BOB dans le répertoire des librairies Arduino (~/sketchbook/libraries/)

#include <BOB.h>  //A ajouter au début du fichier

BOB bob(7,6,5,4,3,1);  //On déclare 1 bob connecté aux pins 7,6,5,4,3 de l'arduino (les pins sont dans l'ordre du connecteur BOBLink)

void setup() {
  bob.write(0,0b10100101);  //La méthode write permet d'écrire toutes les sorties d'un bob en même temps (le premier bob a pour numéro 0)
}


void loop() {
  delay(1000);
  bob.writePin(0,2,HIGH);  //La méthode writePin permet de changer l'état d'une seule sortie, ici troisième sortie ( numéro 2 ) de la première BOB ( numéro 0 )
  bob.writePin(0,5,LOW);
  delay(1000);
  bob.writePin(0,5,HIGH);
  bob.writePin(0,2,LOW);
}

Utilisation avec un Raspberry Pi

Les logiciels permettant l'utilisation d'un ou plusieurs BOB depuis un Raspberry Pi sont disponibles sur la page suivante : https://gitlab.com/bobsoutputboard/raspberrybob

Leur fonctionnement nécessite d'avoir installé WiringPi sur votre Raspberry Pi. La procédure d'installation de WiringPi est décrite sur la page suivante : http://wiringpi.com/download-and-install/

Câblage

Seule la première interface BOB doit être reliée au Raspberry. Relier respectivement ses broches VCC et GND aux broches VCC(+5V) et GND du raspberry. Relier ensuite les 5 autres broches de l'interface BOB à 5 GPIO du raspberry. Le câblage que nous utilisons est le suivant (dans l'ordre des pins de BOB):

  • N/A non connecté
  • VCC sur la broche 2 du Raspberry
  • GND sur la broche 6 du Raspberry
  • G sur la broche 3 du Raspberry (GPIO 2)
  • RCK sur la broche 5 du Raspberry (GPIO 3)
  • SCK sur la broche 7 du Raspberry (GPIO 4)
  • SCLR sur la broche 8 du Raspberry (GPIO 14)
  • D sur la broche 10 du Raspberry (GPIO 15)

Ce câblage possède l'avantage de n'utiliser que les 10 broches supérieures du connecteur du Raspberry, mais nécessite de désactiver la sortie UART du Raspberry, qui utilise les broches 8 et 10. Pour cela, il suffit de commenter la ligne suivante du fichier /etc/inittab en ajoutant un # devant :

 T0:23:respawn:/sbin/getty -L ttyAMA0 115200 vt100

Un redémarrage du Raspberry est nécessaire pour appliquer la modification

Installation

Installer WiringPi :

$ cd
$ git clone git://git.drogon.net/wiringPi
$ cd wiringPi
$ ./build

Récupérer l'intégralité des fichiers présents sur la page GitLab:

$ cd
$ git clone git clone https://gitlab.com/bobsoutputboard/raspberrybob.git

Pour utiliser la démo bobMeter, installer également libasound2-dev :

$ sudo apt-get install libasound2-dev

Lancer la compilation dans le dossier créé :

$ cd raspberrybob
$ make


Modifier éventuellement la ligne 16 du fichier init-script pour qu'elle corresponde à votre câblage :

 OPTS="--gpioG=2 --gpioRCK=3 --gpioSCK=4 --gpioSCLR=14 --gpioD=15 --bob-number=1"

Les options dont le nom commence par gpio doivent prendre un numéro de GPIO en paramètre. Chacune correspond à un pin de la carte BOB. Ces options permettent d'indiquer au daemon BobControl quels GPIO permettent le dialogue avec les interfaces BOB.

Lancer ensuite l'installation

$ sudo make install

Il est possible de tester le fonctionnement avec les scripts dont le nom commence par test.

En cas de nécessité, la désinstallation de tous les programmes liés à BOB peut être réalisée avec la commande suivante :

$ sudo make uninstall

Le daemon bobControl

Ce logiciel tourne en arrière-plan, et assure l'envoi des ordres aux carte BOBs.

Il suffit d'écrire dans le fichier /dev/bob l'état de chaque sortie, et bobControl effectue les opérations nécessaires, une fois le fichier refermé.

Le mécanisme [Inotify] est utilisé pour détecter toute écriture du fichier /dev/bob.

Chaque sortie est matérialisée dans le fichier /dev/bob par un caractère 0 ou 1.

Le nombre de caractère présents dans le fichier reflète donc le nombre total de sorties (cette valeur dépend du paramètre bob-number saisi précédemment lors de l'édition du fichier init-script)

Tout caractère différent de 0 ou 1 est ignoré.

Si le nombre de caractère n'est pas conforme, bobControl supprime les caractères en excédent, ou ajoute des caractères 0.

Écrire stop au début du fichier /dev/bob provoque l'arrêt du démon, après avoir désactivé toutes les sorties des BOBs connectées.

Il est possible de lire à tout moment ce fichier, pour obtenir le dernier état supposé des sorties (la liaison BOBLink étant unidirectionnel, il est impossible d'en connaitre l'état réel).

Exemple :

 $ echo "01010101" > /dev/bob

Active la moitié des sorties sur la première interface BOB.

$ echo "0000000011111111" > /dev/bob

Désactive toutes les sorties de la première interface BOB, et active celle de la seconde BOB (si présente)

La commande bob

La commande bob offre un accès simplifié pour manipuler indépendamment chaque sortie sans passer par le fichier /dev/bob

Sa syntaxe est calquée sur celle de la [commande gpio du projet wiringPi] :

$ bob readall

Affiche un résumé du dernier état supposé des sorties.

$ bob output-number

Affiche le nombre total de sorties disponibles

$ bob read outputNumber

Affiche l'état supposé de la sortie de numéro outputNumber

$ bob write outputNumber value

Pilote la sortie de numéro outputNumber, met son état à value (0 ou 1).

$ bob toggle outputNumber

Inverse l'état de la sortie de numéro outputNumber

$ bob writeall value

Pilote toute les sorties, met leur état à value (0 ou 1).

Le VU-mètre bobMeter

Permet de contrôler les sorties d'un bob en mode VU-mètre en fonction du son ambiant : Ce programme nécessite de doter le Raspberry d'une entée audio ( par exemple une webcam USB )

On recherche le nom du périphérique audio:

$ arecord -l 

Exemple avec une webcam Microsoft LifeCam NX-3000 connectée au Raspberry :

$ arecord -l 
**** List of CAPTURE Hardware Devices ****
card 1: NX3000 [Microsoft LifeCam NX-3000], device 0: USB Audio [USB Audio]
Subdevices: 1/1
Subdevice #0: subdevice #0

Ici le numéro de la carte est 1.

Se placer dans le dossier dédié au programmes de la carte BOB :

$ cd ~/raspberrybob

Lancer le programme bobMeter en précisant la carte d'entrée à utiliser sous la forme hw:X :

$ ./bobMeter hw:1

Le programme bobMeter démarre, pilote la première carte BOB disponible, et affiche un VU-mètre en console, dont chaque barre verticale correspond au seuil d'activation d'une des sorties de la carte BOB :

$ ./bobMeter hw:1
Capture interface prepared
buffer allocated, size : 2048
Let's go !
[==|====|====     |                    |                                       ]


L'interface web BOBINE (Bob's Output Board Interface for Network Extension)

L'interface BOBINE permet de contrôler simplement un ou plusieurs BOB avec une interface web.

BOBINE.PNG

C'est un simple script en PHP, qui utilise le programme BOB. Il lit les ports, et permet d'en changer l'état.

Le code est visible sur GitLab à l'adresse: [2]

Installation

Installer sur le raspberry un serveur Apache avec support du php :

 sudo apt-get install apache2 php5

Si ce n'est aps déjà le cas, installer GIT :

 sudo apt-get install git

Récupérer le code PHP de Bobine

 git clone https://gitlab.com/bobsoutputboard/bobine.git

Le copier dans /var/www/

 sudo cp bobine/* /var/www/

Supprimer la page de test du serveur Apache

 sudo rm /var/www/index.html

C'est bon, vous pouvez désormais saisir l'adresse IP du Raspberry dans votre navigateur, et prendre le contrôle de votre BOB depuis votre smartphone !

Yogi: toute collaboration serait la bienvenue pour avancer sur cette partie. HTML/PHP/CSS vous voulez donner un coup de main ? -> belin.nicolas@gmail.com

Liens

Présentation sommaire de BOB sur le site de Pila : http://pila.fr/wordpress/?p=739

Page GitLab du projet BOB : https://gitlab.com/bobsoutputboard

Auteurs

  • Pila
  • Yogi