Gestion de LED RVB, 2014/2015, TD2

De Wiki d'activités IMA
Révision datée du 23 mars 2015 à 20:21 par Rlentieu (discussion | contributions) (Partie électronique)

Objectifs

Ce projet a pour objectif de réaliser un circuit de contrôle d'une LED 256 couleurs ainsi qu'une interface WEB permettant de faire varier sa couleur.

Première séance

Partie électronique

Au cours de cette séance, nous avons tout d'abord appréhender le sujet. Puis nous avons réaliser le tutoriel pour la prise en main du logiciel Altium Designer et la Nanoboard. Suite à cela, nous avons commencé à réaliser le schéma du montage


Nous savions que nous devions utiliser un filtre passe bas, nous avons donc décidé d'utiliser un filtre RC d'ordre 1. Pour connaître les valeurs de la résistance et de la capacité qu'il faut utiliser, nous avons fait un simple calcul afin d'obtenir une bande passante d'environ 15 Hz. Ainsi nous obtenons une résistance de 1Kohms et une capacité d'environ 10uF. Ce filtre va donc nous permettre de ne prendre en compte que les fréquences basses et au vu des valeurs choisies, nous n'aurons qu'une faible variation de fréquence.




Pour le schéma de construction de l'algorithme, nous avons réfléchi sur la meilleure manière de pouvoir lire les valeurs stockées en mémoire. Nous voulions ainsi utilisé un multiplexeur qui, selon un code envoyé va envoyer ce signal d'entrée vers une de ses sorties. Pour générer ce code, nous avons imaginé d'utiliser un compteur modulo 3 car nous n'allons utiliser que 3 des 4 sorties du multiplexeur.

Nous avons aussi essayé de traduire au mieux l'énoncé, nous avons donc défini le rapport cyclique comme étant la durée du temps "haut" divisé par la période T. Savoir cela va nous permettre de savoir ce que nous devrons modifier.


Nous avons aussi étudier la Led RVB et nous avons ainsi pu voir qu'elle était composée de 6 branches dont 4 Leds: 2 bleues, une rouge et une verte et de 2 cathodes: une pour la bleue et la rouge, l'autre pour l'autre bleue et la verte. Nous avons aussi vu que le courant passant dans la Led ne devait pas excéder 10 mA, ce qui correspond à une tension de sortie du filtre de 4V que nous pourrons faire varier afin de ne pas dépasser ces 10 mA.


Prévision pour la prochaine séance: montage du filtre RC afin de tester le générateur de signal PWM, continuer l'élaboration du schéma de câblage de la solution finale.

Partie informatique

Nous avons appris à configurer le port série avec un programme en langage C que nous avions récupéré sur le site, et modifié afin d’envoyer 3 entiers au lieu de 8. Nous avons allumé une LED placée sur une carte arduino reliée au port série de l'ordinateur. Puis nous avons mis en place un serveur Websocket ainsi qu'un programme répondant au Websocket afin de pouvoir modifier la couleur de la LED. Nous avons récupéré un modèle de page web , l'avons modifié afin de pouvoir y entrer 3 entiers correspondant au code couleur RVB. Ensuite nous avons établi la liaison entre la page web et le port série, et donc avons donc rendu possible la modification des couleurs de la LED à partir de la page WEB.


Prévision pour la prochaine séance: étude du langage de programmation JAVASCRIPT afin de créer les curseurs grâce auxquels nous pourrons modifier les valeurs d'intensité des couleurs de la LED.

Deuxième séance

Partie électronique

Durant cette séance, nous avons décidé de perfectionner notre montage car nous avions oublié une chose importante lors de la séance précédente: les différentes leds n'ont pas toutes la même tension de seuil, en effet les leds bleues ont une tension de seuil de 4V environ, la led rouge en a une de 2V, de même que la led verte. Il fallait donc modifier notre montage afin de ne pas prendre le risque de griller une led. Nous savons aussi que la tension délivrée par la nanoboard est de 3,3V, il fallait donc amplifier cette valeur pour les leds rouge et verte et la diminuer pour les leds bleues. Pour cela nous avons décidé d'utiliser un diviseur de tension afin d'obtenir une tension maximale de 2V. Ainsi nous avons utilisé 2 résistances: une de 200 ohms et une autre de 330 ohms.

Partie informatique

Pour cette deuxième séance, nous avons étudié le langage javascript afin de réaliser les curseurs de couleur sur la page WEB de l'application. Nous avons utilisé la bibliothèque javascript : jQuery, qui était utilisé dans l'exemple des cercles de couleurs fournis sur le site des sujets de ce projet. Nous avons récupéré un exemple de 3 sliders modifiant des paramètres de couleur RVB , qui correspond donc à nos besoins, utilisant la bibliothèque jQuery. Nous l'avons réadapter selon nos préférences en modifiant le sens et la taille.

Ensuite nous sommes passés à la liaison avec le WebSocket. On a alors récupéré la partie de code utilisé lors de la première séance (sur la page Web permettant de taper au clavier un code RVB) correspondant à la partie réseaux pour l'incruster au code des sliders de couleur. Les sliders permettent d'envoyer des caractères, il y a donc nécessité de convertir ces données en entier pour permettre à la LED de s'allumer et de changer de couleurs. Cette conversion ce fait dans la code de la Websocket, ainsi elle est réalisé après réception du message.

Nous avons alors procédé au test qui c'est montré concluant. Vint alors la dernière partie qui est celui de l'ajout d'un slider correspondant au clignotement de la diode. Pour ce faire, nous avons utilisé la fonction setTimeout qui permet de réaliser une fonction pendant un temps donné ( le temps donné sera notre temps de clignotement, donc le paramètres de notre 4ème slider). Après écriture de la fonction clignotement et test de cette dernière, on put constater que la diode clignoté bien à une vitesse réglable sur la page web. La partie application informatique est donc terminée lors de cette deuxième séance.

Troisième séance

Partie électronique

Partie informatique

Conclusion