Cours:SaéSBC : Différence entre versions

De troyesGEII
Aller à : navigation, rechercher
(bras robotique)
(bras robotique)
Ligne 11 : Ligne 11 :
 
<source lang=cpp>
 
<source lang=cpp>
 
//fichier pro
 
//fichier pro
 +
LIBS += -L/opt/electronique/bbBlue/sysroot/lib/arm-linux-gnueabihf -l:libusb-1.0.so -l:libudev.so.1 -l:libpcre16.so -l:libglib-2.0.so.0 -l:libpcre.so.3
 +
 
INCLUDEPATH += /opt/electronique/bbBlue/sysroot/usr/include/libusb-1.0/
 
INCLUDEPATH += /opt/electronique/bbBlue/sysroot/usr/include/libusb-1.0/
  

Version du 4 janvier 2022 à 10:43

bras robotique

Objectif : déplacer le bras pour saisir une balle.

Ex Pixy :

//fichier pro
LIBS += -L/opt/electronique/bbBlue/sysroot/lib/arm-linux-gnueabihf -l:libusb-1.0.so -l:libudev.so.1 -l:libpcre16.so -l:libglib-2.0.so.0 -l:libpcre.so.3

INCLUDEPATH += /opt/electronique/bbBlue/sysroot/usr/include/libusb-1.0/


// sans doute dans un .h
...
#include "pixy/libpixyusb2/include/libpixyusb2.h"
...
    Pixy2        pixy;
....
// sans doute dans un .cpp
...
    int Result = pixy.init();
    if (Result<0) qDebug()<<"pb initialisation pixy !!!";
....
      pixy.ccc.getBlocks();
      if (pixy.ccc.numBlocks)
      {
        qDebug()<<"Detected "<< pixy.ccc.numBlocks <<" block(s)\n";
        for (int blockIndex = 0; blockIndex < pixy.ccc.numBlocks; blockIndex++)
        {
            qDebug()<<pixy.ccc.blocks[blockIndex].m_x<<" "<<pixy.ccc.blocks[blockIndex].m_y;
        }
      }

Lecture de code barre

Pb de verrouillage numérique

Si lors de la lecture d'un code barre les chiffres n'apparaissent pas, il faut :

  • ouvrir le fichier /etc/rc.local dans un éditeur:
    • nano /etc/rc.local
  • ajouter les lignes suivantes avant exit 0
for tty in /dev/tty[1-9]*;
do
setleds -D +num < $tty > /dev/null
done
    • sauvegarder : control+w
    • quitter : control+x
  • redémarrer la carte
    • reboot

Lecture de fichier CSV

Classes à utiliser :

  • QFile
    • méthode readline
  • QString
    • méthode split

Documents

Media:PromoDUT2021.zip

Conserver le focus clavier sur la zone de saisie

  • Ajouter une zone de saisie dans l'interface : QLineEdit
  • rendre active cette zone : ui->lineEdit->activateWindow();
  • garder le focus sur cette zone : ui->lineEdit->setFocusPolicy(Qt::StrongFocus);
  • empêcher la prise du focus clavier par d'autres widgets :
    • sur chaque widget
    • ui->unWidget->setFocusPolicy(Qt::NoFocus);

Domotique

MQTT pour Qt : https://doc.qt.io/QtMQTT/qtmqtt-index.html

MQTT pour Arduino : https://pubsubclient.knolleary.net

NanoPi avec NodeRed ou QT

Adresses IP pour cartes Arduino : 10.98.9.XXX avec XXX = 211, 212, 213, 214 ou 215. Changer également l'adresse MAC pour la différencier des autres cartes.

Balancing Robot

Indications pour démarrer

Projet QTCreator pour commencer : Media:balancingBot_Minimal.zip

Il faudra configurer un kit de cross-compilation :

  • Appareil mobile : linux générique (ip=192.168.7.2, login=root, mdp=geii)
  • Racine du système : /opt/electronique/bbBlue/sysroot
  • Version de QT : pointer /opt/electronique/bbBlue/qt5/bin/qmake
  • Compilateurs : pointer l'executable du compilateur situé dans l'arborescence de /opt/electronique/bbBlue/

Aide pour régulation PID : lire http://www.ferdinandpiette.com/blog/2011/08/implementer-un-pid-sans-faire-de-calculs/

Guide de progression

  1. Configurer le projet pour qu'il compile et s'exécute sur la carte du robot
  2. Analyser le code - inutile de rentrer trop dans le détail, mais comprendre l'articulation des classes utilisées dans le main.
  3. Afficher la valeur d'angle du gyroscope en temps réel avec qDebug()
  4. Implémenter une classe pour un régulateur PID qui interviendra entre le gyroscope et les moteurs. Vous pourrez commencer par un régulateur proportionnel uniquement et compléter ensuite.
  5. Implémenter une application graphique PC communiquant en tcp avec le robot permettant
    1. d'afficher les valeurs du gyroscope,
    2. de démarrer/éteindre le PID,
    3. de modifier les valeurs du PID,
    4. ...