summaryrefslogtreecommitdiff
path: root/2005/i/robert/src/asserv/asserv.cc
diff options
context:
space:
mode:
Diffstat (limited to '2005/i/robert/src/asserv/asserv.cc')
-rw-r--r--2005/i/robert/src/asserv/asserv.cc201
1 files changed, 193 insertions, 8 deletions
diff --git a/2005/i/robert/src/asserv/asserv.cc b/2005/i/robert/src/asserv/asserv.cc
index 2489235..9a3a2c4 100644
--- a/2005/i/robert/src/asserv/asserv.cc
+++ b/2005/i/robert/src/asserv/asserv.cc
@@ -25,28 +25,29 @@
#include "asserv.hh"
+
/// Constructeur
Asserv::Asserv (const Config & config, Receiver & receiver)
- :proto_(*this), log("asserv")
+ :proto_(*this), log_("asserv")
{
// Rechargement des paramètres
loadConfig();
//Ouverture du port série
- proto.open(ttyName_);
+ proto_.open(ttyName_);
//Initialisation de l'AVR
reset();
}
/// Destructeur XXX Voir si il sert à quelque chose
-Ãsserv::~Asserv(void)
+Asserv::~Asserv(void)
{
}
/// Reset de l'AVR
-Asserv::reset(void)
+void Asserv::reset(void)
{
// Reset AVR
- proto_.send()
+ proto_.send('z');
// Envoie des données de conf sur l'AVR
setFooting(footing_);
setEpsilon(epsilon_);
@@ -106,13 +107,13 @@ void Asserv::fuckTheWall(double speed)
proto_.send('f',"b", v);
}
-void Asserv::setSpeed(double xSpeed, double, ySpeed)
+void Asserv::setSpeed(double xSpeed, double ySpeed)
{
// Conversion mm/s->Pas/Period
int vx = mms2ppp(xSpeed);
int vy = mms2ppp(ySpeed);
// Envoie vers l'AVR
- proto_.send('s',"bb", xSpeed, ySpeed);
+ proto_.send('s',"bb", vx, vy);
}
// XXX Faut mettre le format en config
@@ -122,7 +123,191 @@ void Asserv::setPwm(double xPwm, double yPwm)
int xp = rCycl2Pwm(xPwm);
int yp = rCycl2Pwm(yPwm);
// Envoie sur l'AVR
- proto_.send('w',"ww",xPwm, yPwm);
+ proto_.send('w',"ww",xp, yp);
+}
+
+/// Statistiques
+void Asserv::statCounter(double period)
+{
+ pCounter_ = period;
+ // Convertion s->Period
+ int p = s2period(period); // XXX manque un cast, vérifier tout les cast
+ // Envoie sur l'AVR
+ proto_.send('C', "b", p);
+}
+
+void Asserv::statPosition(double period)
+{
+ pPosition_ = period;
+ // Convertion s->Period
+ int p = s2period(period);
+ // Envoie sur l'AVR
+ proto_.send('X', "b", p);
+}
+
+void Asserv::statMotor(double period)
+{
+ pMotor_ = period;
+ // Convertion s->Period
+ int p = s2period(period);
+ // Envoie sur l'AVR
+ proto_.send('S', "b", p);
+}
+
+void Asserv::statPwm(double period)
+{
+ pPwm_ = period;
+ // Convertion s->Period
+ int p = s2period(period);
+ // Envoie sur l'AVR
+ proto_.send('W', "b", p);
+}
+
+void Asserv::statTiming(double period)
+{
+ pTiming_ = period;
+ // Convertion s->Period
+ int p = s2period(period);
+ // Envoie sur l'AVR
+ proto_.send('T', "b", p);
+}
+
+void Asserv::statInPort(double period)
+{
+ pStatInPort_ = period;
+ // Convertion s->Period
+ int p = s2period(period);
+ // Envoie sur l'AVR
+ proto_.send('P', "b", p);
+}
+
+/// Change les paramètres
+void Asserv::setXPos(double xPos)
+{
+ // XXX Faut conserver la valeur?
+ // Conversion mm->pas
+ int p = mm2pasD(xPos);
+ // Envoie à l'AVR
+ proto_.send('p',"bd", 'x', p); // XXX C'est bon ça??
+}
+
+void Asserv::setYPos(double yPos)
+{
+ // XXX Faut conserver la valeur?
+ // Conversion mm->pas
+ int p = mm2pasD(yPos);
+ // Envoie à l'AVR
+ proto_.send('p',"bd", 'y', p); // XXX C'est bon ça??
+}
+
+void Asserv::setAngle(double angle)
+{
+ // XXX Faut conserver la valeur?
+ // Conversion mm->pas
+ int a = mm2pasW(angle); //XXX Vérifier si c'est W ou D
+ // Envoie à l'AVR
+ proto_.send('p',"bd", 'y', a); // XXX C'est bon ça??
+}
+
+void Asserv::setFooting(int16_t footing)
+{
+ footing_ = footing;
+ // Envoie à l'AVR
+ proto_.send('p',"bw", 'f', footing);
+}
+
+void Asserv::setEpsilon(double epsilon)
+{
+ epsilon_ = epsilon;
+ // XXX Conversion ici
+ // Envoie à l'AVR
+ proto_.send('p',"bd", 'e', (int)epsilon);
}
+void Asserv::setKp(double Kp)
+{
+ kp_ = Kp;
+ // Envoie à l'AVR
+ // XXX Conversion ici
+ proto_.send('p',"bw", 'p', (int)Kp); // XXX Vérifier les commandes pour tout
+}
+
+void Asserv::setKi(double Ki)
+{
+ ki_ = Ki;
+ // XXX Conversion ici
+ // Envoie à l'AVR
+ proto_.send('p',"bw", 'i',(int) Ki);
+}
+
+void Asserv::setKd(double Kd)
+{
+ kd_ = Kd;
+ // Envoie à l'AVR
+ // XXX Conversion ici
+ proto_.send('p',"bw", 'd', (int) Kd); /// XXX Vérifier la commande
+}
+
+void Asserv::setAccel(double accel)
+{
+ // Conversion mmps2ppperiod
+ int a = mmps2ppperiod(accel);
+ // envoie vers l'AVR
+ proto_.send('p',"bb", 'a', a);
+}
+
+void Asserv::setMaxSpeed(double maxSpeed)
+{
+ // Conversion mm->ppp
+ int p = mms2ppp(maxSpeed);
+ // Envoie à l'AVR
+ proto_.send('p',"bb", 'm', p); // XXX C'est bon ça??
+}
+
+/// implémentation du proto::Receiver
+void Asserv::receive(char command, const Proto::Frame &frame)
+{
+ // XXX Truc à mettre
+}
+
+/// Charge les données de la classe config
+void Asserv::loadConfig(void)
+{
+ // XXX Faire des truc ici
+}
+/// Fonctions de conversion
+int Asserv::mm2pasW(double dist)
+{
+ return static_cast<int>(dist/mmPpas_); // XXX Ca pue
+}
+
+int Asserv::mm2pasD(double dist)
+{
+ return static_cast<int>(dist/mmPpas_); // XXX Du cul
+}
+
+int Asserv::radTo256(double angle)
+{
+ return static_cast<int>((angle/2*3.14/*pi*/)*256); // XXX En fait tout pue
+}
+
+int Asserv::mms2ppp(double vitesse)
+{
+ return static_cast<int>(vitesse*(sPperiod_/mmPpas_)); // XXX Ouvrez les fenêtres
+}
+
+int Asserv::rCycl2Pwm(double rCycl)
+{
+ return static_cast<int>(rCycl*pwmMax_); // XXX Ouvrez la clim
+}
+
+int Asserv::s2period(double period)
+{
+ return static_cast<int>(period/sPperiod_);
+}
+
+int Asserv::mmps2ppperiod(double accel)
+{
+ return static_cast<int>(accel*(sPperiod_*sPperiod_/mmPpas_)); // XXX Ca y est on est tous mort
+}