Couleur-pi : 9 étapes
Couleur-pi : 9 étapes
Anonim
Couleur-pi
Couleur-pi

Cette instructable montre comment utiliser un Raspberry Pi pour contrôler vocalement une bande LED RVB, via un site Web, à l'aide des interfaces Web Speech API pour SpeechRecognition et SpeechSynthesis.

Cet exemple montre comment

  • Créez un site Web de base en utilisant Node.js sur
  • Utilisez les interfaces Web Speech API pour SpeechRecognition et SpeechSynthesis.
  • Utilisez le framework Cylon.js pour contrôler une bande LED RVB sur un Raspberry Pi
  • Communiquez via WSS (Secure Web sockets) depuis la page Web vers Cylon.js pour contrôler la couleur de la LED

Noter

  • Vous aurez besoin de haut-parleurs ou d'écouteurs pour entendre le synthétiseur vocal
  • Vous devrez donner accès à votre microphone pour que la reconnaissance vocale fonctionne
  • Parce que cet accès à votre microphone, le site doit être exécuté sous
  • La bibliothèque cylon-api-socketio ne prend pas en charge https pour le moment. J'ai une pull request en attente de fusion, mais d'ici là, vous devez remplacer le /node_modules/cylon-api-socketio/lib/api.js par le fichier dans ce référentiel
  • pi-blaster est nécessaire pour que cela fonctionne.

Étape 1: Équipement

  1. Raspberry Pi - J'ai utilisé un Raspberry Pi 2B que j'avais, mais vous pouvez obtenir un kit de démarrage Raspberry Pi 3 pour environ 100 CAD
  2. Bande lumineuse à LED RVB - Je jouais avec la bande lumineuse à LED Minger 32.8ft/10M 600leds RVB SMD 5050. Ceci est livré avec un contrôleur et une alimentation pour environ 40 CAD
  3. Connecteur Barrel Jack - J'en ai acheté un dans mon magasin d'électronique local, quelque chose comme ça. Assurez-vous simplement que cela correspond à votre alimentation
  4. Connecteurs/fils de cavalier - J'avais des câbles de connexion femelle à mâle et des fils de raccordement solides de calibre 22 qui traînaient
  5. Carte PCB de prototype sans soudure de planche à pain - quelque chose comme ça
  6. 3 résistances de 10kΩ
  7. 3 x MOSFET à canal N pour contrôler les LED - J'ai acheté des IRL3303 dans mon magasin d'électronique local. Il est important que la tension de seuil des portes soit un max. 3,3 V pour qu'il puisse être piloté par les broches RPi; généralement indiqué par un « L » (niveau logique) dans le nom.

Étape 2: Configuration du Raspberry Pi

Système opérateur

J'utilise normalement la dernière version de Raspbian. Téléchargez l'image et écrivez-la sur la carte SD. Si vous utilisez un ordinateur Windows, vous pouvez utiliser Win32 Disk Imager pour écrire l'image sur la carte SD.

Node.js

Installez la dernière version de Node.js. Au moment de la rédaction, j'utilise 8.9.1

curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash -

sudo apt-get install nodejs

Installer Git

sudo apt-get install git

Étape 3: Pi-blaster

Pi-blaster
Pi-blaster

pi-blaster active PWM sur les broches GPIO que vous demandez à un Raspberry Pi. La technique utilisée est extrêmement efficace: n'utilise pas le CPU et donne des impulsions très stables.

Cette modulation de largeur d'impulsion permet au Raspberry Pi de contrôler la luminosité de chacun des canaux rouge, vert et bleu pour la bande LED.

Tout d'abord, clonez le référentiel

cd /opt/

sudo git clone https://github.com/sarfata/pi-blaster.git sudo chown -R pi:pi pi-blaster

Ensuite, construisez et installez

cd /opt/pi-blaster./autogen.sh &&./configure && make && sudo make install

Enfin, configurez les broches que vous souhaitez utiliser

Sous le compte root, ou en utilisant sudo, créez et modifiez le fichier

/etc/default/pi-blaster

Ajoutez les lignes suivantes

DAEMON_OPTS=--gpio 23, 24, 25

Ces broches gpio doivent correspondre aux broches que vous connectez à votre bande LED.

REMARQUE: Il existe une différence entre le GPIO et le numéro de broche. Cet exemple utilise ce qui suit

LED - Bleu, GPIO-23, Broche - 16

LED - Rouge, GPIO-24, Broche - 18 LED - Verte, GPIO-25, Broche - 22

Ajustements supplémentaires

Démarrer pi-blaster

démarrage du service sudo pi-blaster

Redémarrer pi-blaster

redémarrage du service sudo pi-blaster

Arrête le pi-blaster

arrêt de pi-blaster de service sudo

Démarrer pi-blaster automatiquement au démarrage

sudo systemctl activer pi-blaster

Avertissements et autres mises en garde

Les broches utilisées par pi-blaster seront configurées comme sorties. Ne branchez rien sur une entrée ou vous pourriez le détruire ! Ce démon utilise le générateur matériel PWM du raspberry pi pour obtenir des timings précis. Cela pourrait interférer avec la sortie de votre carte son.

Étape 4: Configuration de l'exemple de code

Cloner l'exemple de code

1. Configurez un dossier de base dans lequel installer

cd/opt

sudo mkdir com.jonhaydock sudo chown pi:pi com.jonhaydockcd com.jonhaydock

2. Clonez l'exemple de dépôt git

git clone

ou

git clone [email protected]:haydockjp/colour-pi.git

3. Installer les dépendances

cd couleur-pi

npm installer

Cela peut prendre 2-3 minutes

4. Ce projet doit communiquer via HTTPS et WSS. À l'heure actuelle, cylon-api-socketio ne prend pas en charge les connexions SSL. Il existe une demande d'extraction ouverte pour ajouter ce support, mais jusqu'à ce qu'il soit fusionné, il existe un fichier de correctif dans ce référentiel. Exécutez la commande suivante après l'installation de npm

git checkout node_modules/cylon-api-socketio/lib/api.js

Étape 5: Créez un certificat SSL auto-signé

1. Créez un fichier de clé privée

cd /opt/com.jonhaydock/color-pi/certs

openssl genrsa -out color-pi-key.pem 2048

2. Créer un CSR (Certificate Signing Request)

openssl req -new -key color-pi-key.pem -out color-pi-csr.pem

À ce stade, vous serez invité à fournir des informations pour la demande de certificat. Comme il s'agit d'un certificat auto-signé, c'est à vous de décider avec quelle précision vous remplissez les détails. Voici un exemple

Nom du pays (code à 2 lettres) [AU]:CA

Nom de l'État ou de la province (nom complet) [un État]: Nom de la localité de la Colombie-Britannique (par exemple, la ville) : Nom de l'organisation de Vancouver (par exemple, la société) [Internet Widgits Pty Ltd]: Nom de l'unité organisationnelle de couleur Pi (par exemple, la section) : Nom commun (par exemple, FQDN du serveur ou VOTRE nom) :colour-pi Adresse e-mail :[email protected]

Un mot de passe de défi :

Un nom de société facultatif :

Dans cet exemple, appuyez simplement sur Entrée pour laisser le mot de passe de défi vide

3. Générez le certificat

openssl x509 -req -days 1095 -in color-pi-csr.pem -signkey color-pi-key.pem -out color-pi-cert.pem

4. Pour plus de sécurité, nous allons également créer un fichier de paramètres Diffie Hellman

openssl dhparam -out dh_2048.pem 2048

Cela peut prendre 15-20 minutes

Étape 6: Câblage du circuit

Câblage du circuit
Câblage du circuit
Câblage du circuit
Câblage du circuit
Câblage du circuit
Câblage du circuit
Câblage du circuit
Câblage du circuit

Alimentation de la bande LED

La bande LED est alimentée en 12 volts. Le Raspberry Pi n'est capable de produire que 3,3 V ou 5 V et n'est pas capable de produire à proximité des amplis nécessaires pour piloter autant de LED.

Il est important de ne pas connecter l'alimentation 12 volts au Raspberry Pi. Les transistors MOSFET à canal N sont utilisés pour séparer le 3.3v sur les broches RPi et le 12v de l'alimentation LED.

Le MOSFET a trois broches Gate, Drain et Source. Si vous n'êtes pas sûr de savoir quel google pour la fiche technique du transistor que vous utilisez, par ex. IRL3303

Nous allons connecter le Pin du Raspberry Pi au Gate, le fil LED au Drain et une masse commune à la Source. Lorsque la broche monte, la tension entre le drain et la source activera la porte et connectera la porte à la source.

Nous allons également mettre des résistances de 10kΩ à travers la porte et la source, de sorte que lorsque la broche RPi est haute, nous pouvons protéger la broche en réduisant le courant qui la traverse.

Effectuez les étapes suivantes à vos risques et périls. Je ne prends aucune responsabilité pour tout ce qui pourrait mal tourner

Il y a une image frite et une photo du circuit réel ci-dessus.

Je recommanderais de le faire pendant que l'alimentation est coupée pour le RPi et la bande LED

Mettre en place les circuits transistors, un par canal de couleur

  1. Insérez l'un des transistors dans la planche à pain comme indiqué sur le schéma
  2. Insérez l'une des résistances de 10 kΩ entre les broches de drain et de source du transistor. C'est la première et la dernière broche
  3. Utilisez un fil pour connecter la broche source (dernière broche) à la terre sur la planche à pain
  4. Répétez les étapes 1 à 3 encore deux fois, de sorte que vous ayez trois ensembles - un par couleur (rouge, vert et bleu)

Connectez les broches RPi à la carte

  1. Connectez la broche 16 à la broche de porte (première broche) du premier transistor - ce sera le canal de la LED bleue
  2. Connectez la broche 18 à la broche Gate (première broche) du premier transistor - Ce sera le canal LED rouge
  3. Connectez la broche 20 à l'une des lignes de masse sur le côté de la planche à pain
  4. Connectez la broche 22 à la broche de porte (première broche) du premier transistor - ce sera le canal de la LED verte

J'ai utilisé des couleurs de fil assorties aux LED: bleu, rouge et vert. j'ai utilisé du noir pour le sol

Connectez la prise baril

  1. Connectez un fil blanc à l'extrémité + de la prise cylindrique
  2. Connectez un fil noir à l'extrémité - de la prise cylindrique
  3. Connectez le fil noir à la même ligne de masse sur la planche à pain que le RPi Pin 20 a été connecté à
  4. Connectez le fil blanc à la ligne + sur la planche à pain

Connexion de la bande LED

Ma bande LED était livrée avec un connecteur d'une taille suffisamment bonne pour qu'il puisse être temporairement branché sur la planche à pain. J'ai poussé le connecteur dans la maquette et l'ai câblé au test du circuit.

  1. Le premier transistor connecté à la broche 16. J'ai fait passer un fil bleu de la broche de drainage (broche du milieu) au fil bleu sur le connecteur de bande LED
  2. Le deuxième transistor connecté à la broche 18. J'ai fait passer un fil rouge du

    Égoutter

    broche (broche du milieu) au fil rouge sur le connecteur de la bande LED

  3. Le troisième transistor connecté à la broche 22. J'ai fait passer un fil vert du

    Égoutter

    broche (broche du milieu) au fil vert sur le connecteur de bande LED

  4. Enfin, j'ai fait passer un fil blanc de la ligne + sur la planche à pain qui était connectée à la prise baril, au fil blanc sur le connecteur de la bande LED.

Puissance

Après avoir vérifié le circuit, vous devriez être prêt à allumer le Raspberry Pi et à brancher l'alimentation 12v à la prise cylindrique.

Étape 7: Code côté serveur

Code côté serveur
Code côté serveur

Exécuter le code côté serveur

cd /opt/com.jonhaydock/color-pi

démarrage sudo npm

Cela démarrera le serveur Web et commencera à écouter les requêtes HTTPS et WSS.

REMARQUE: N'oubliez pas de faire fonctionner pi-blaster en premier

Variables d'environnement

Le port par défaut du site Web est 443, mais vous pouvez le remplacer en définissant une variable d'environnement avant de démarrer le code. Par exemple

exporter COULEUR_PI_PORT=2443

Le port de socket Web par défaut est 1443, mais vous pouvez le remplacer en définissant une variable d'environnement avant de démarrer le code. Par exemple

exporter COULEUR_PI_WSS_PORT=3443

Remarque: Comme le socket Web est géré par cylon.js et non par le site Web principal, ils doivent être sur des ports différents

Les broches utilisées pour le bleu (broche 16), le vert (broche 18) et le rouge (broche 22) peuvent également être remplacées. Par exemple

exporter COULEUR_PI_PIN_BLUE=36

exporter COLOUR_PI_PIN_RED=38 exporter COLOUR_PI_PIN_GREEN=40

Remarque: ceux-ci doivent correspondre aux broches physiques que vous avez utilisées. Si vous les modifiez, vous devrez également mettre à jour les GPIO définis dans le fichier /etc/default/pi-blaster. Par exemple

DAEMON_OPTS=--gpio 16, 20, 21

Le code du serveur principal se trouve dans le fichier app.js. Ce fichier démarre le serveur Web HTTPS et, via le framework Cylon.js, utilise socket.io pour écouter les requêtes de socket Web sur un port distinct.

Pour accéder au site Web, vous devez ouvrir un navigateur Web sur votre ordinateur principal (je ne l'ai testé que dans Chrome) et utiliser l'adresse IP du Raspberry Pi, par ex.

10.0.1.2/

Vous pouvez trouver votre adresse IP à partir de la ligne de commande Raspberry Pi.

ifconfig

Le serveur Web servira tout contenu sous le dossier public. Il affiche par défaut la page index.html.

Cylon.js crée un point de terminaison auquel vous pouvez connecter Socket.io.

10.0.1.2:1443/api/robots/color-pi

Vous pouvez envoyer un message set_colour via le socket pour définir les valeurs Rouge, Vert et Bleu

device.emit('set_colour', r, g, b)

Qui appelle la commande set_colour, qui appelle la fonction setColour dans app.js. Cette fonction règle les niveaux de luminosité, pour chacune des valeurs R, V et B, entre 0 et 255. Où 0 est éteint et 255 est entièrement allumé.

par exemple.

Rouge r=255, g=0, b=0

Vert r=0, g=255, b=0 Bleu r=0, g=0, b=255 Blanc r=255, g=255, b=255 Noir / Off r=0, g=0, b=0

Étape 8: Code du site Web

Code du site Web
Code du site Web

Général

Le site Web utilise la reconnaissance vocale pour sélectionner des couleurs dans une liste prédéfinie. Pour ajouter une couleur à la liste, éditez le fichier sur le serveur: public/data/colours.json

par exemple.

"red":"#FF0000", Lorsqu'une couleur est trouvée ou sélectionnée dans la liste déroulante, la zone de sortie sera définie sur cette couleur et un message sera envoyé via socket.io au Raspnerry Pi, qui définira les LED sur la même couleur.

REMARQUE: selon la qualité de vos LED, vous pouvez ou non voir une couleur similaire. Certains sont plus faciles à dupliquer que d'autres

Lorsque vous chargez le site Web pour la première fois, comme vous utilisez un certificat SSL auto-signé, vous devrez le reconnaître dans le navigateur. Vous devriez voir une alerte de sécurité concernant le certificat.

Reconnaissance vocale

Cette boîte a une icône de microphone. Si vous cliquez sur l'icône lorsqu'elle est verte, elle commencera à écouter les couleurs. Pendant qu'il écoute, il devient rouge. Il écoutera pendant un court laps de temps, puis s'arrêtera. Cliquer sur l'icône du microphone lorsqu'elle est rouge l'empêchera également d'écouter.

Comme ce site doit accéder à votre microphone, vous devrez lui donner l'autorisation lorsque vous y serez invité.

REMARQUE: vous avez besoin d'un microphone pour cette partie. J'utilise celui de ma webcam.

Transcription provisoire

Cette boîte suit les suppositions des mots que vous dites, au fur et à mesure que vous les dites.

Transcription finale

Cette boîte suit l'estimation finale de ce que vous avez dit.

Couleurs connues

Ceci est une liste de toutes les couleurs que la page connaît. Il est créé à partir du fichier colours.json. Si vous sélectionnez l'une de ces couleurs, la page prononcera la couleur et définira la couleur de sortie.

REMARQUE: Vous avez besoin de haut-parleurs ou d'un casque pour entendre le discours

Couleurs trouvées

Cette page Web ne prend actuellement en charge que la correspondance de la couleur. Si le ou les mots que vous avez prononcés dans le microphone correspondent au nom d'une couleur connue, ou si vous sélectionnez une couleur dans la liste Couleur connue, elle sera ajoutée ici en tant que journal.

Sortir

La dernière couleur trouvée sera affichée ici. La valeur Color Hex (par exemple #7cb9e8) et la valeur RVB (par exemple 124, 185, 232) seront affichées sous forme de texte et l'arrière-plan de la case au milieu sera défini sur la couleur réelle.

Cette couleur est également envoyée au Raspberry Pi et vous devriez voir la couleur de la bande LED changer.

REMARQUE: si vous ne voyez pas le changement de couleur de la LED, essayez de redémarrer pi-blaster et/ou l'application node.js

redémarrage du service sudo pi-blaster

démarrage sudo npm

Voix connues

Cette boîte affiche une liste de « Voix connues » de la synthèse vocale prise en charge. La sélection de l'une de ces voix changera la voix et la langue que vous entendrez, et elle prononcera le nom de la voix.

Cela changera également la langue de la reconnaissance vocale pour qu'elle soit la même que celle choisie dans la liste.

Étape 9: Enfin

Image
Image

Voici un exemple de ce que vous devriez voir.

S'il vous plaît laissez-moi savoir si vous avez un problème et je peux mettre à jour si nécessaire.