mirror of
https://github.com/RobotechLille/cdf2018-principal
synced 2025-10-24 17:53:31 +02:00
Réécriture du système de consigne
This commit is contained in:
parent
63bf4ee3c3
commit
9802230d13
11 changed files with 438 additions and 179 deletions
|
@ -127,6 +127,7 @@ void* TaskMotor(void* pData)
|
||||||
r = MOTOR_SATURATION_MAX;
|
r = MOTOR_SATURATION_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef ENABLE_RATE_LIMITER
|
||||||
// Rate limiter pour éviter que l'accélération soit trop brusque
|
// Rate limiter pour éviter que l'accélération soit trop brusque
|
||||||
float maxUp = RATE_LIMITER_UP * dt;
|
float maxUp = RATE_LIMITER_UP * dt;
|
||||||
float maxDown = RATE_LIMITER_UP * dt;
|
float maxDown = RATE_LIMITER_UP * dt;
|
||||||
|
@ -141,6 +142,7 @@ void* TaskMotor(void* pData)
|
||||||
} else if (rVolt - r > maxDown) {
|
} else if (rVolt - r > maxDown) {
|
||||||
r = rVolt - maxDown;
|
r = rVolt - maxDown;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
setMoteurTensionRaw(l, r, lFor, rFor);
|
setMoteurTensionRaw(l, r, lFor, rFor);
|
||||||
break;
|
break;
|
||||||
|
@ -193,7 +195,6 @@ int brake()
|
||||||
pthread_mutex_lock(&motCons);
|
pthread_mutex_lock(&motCons);
|
||||||
motState = braking;
|
motState = braking;
|
||||||
pthread_mutex_unlock(&motCons);
|
pthread_mutex_unlock(&motCons);
|
||||||
printf("192 Brake\n");
|
|
||||||
rawBrake();
|
rawBrake();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,9 +10,11 @@
|
||||||
#define INVERSE_L_MOTOR
|
#define INVERSE_L_MOTOR
|
||||||
// #define INVERSE_R_MOTOR
|
// #define INVERSE_R_MOTOR
|
||||||
|
|
||||||
|
#define ENABLE_RATE_LIMITER
|
||||||
|
|
||||||
// V/s
|
// V/s
|
||||||
#define RATE_LIMITER_UP 6
|
#define RATE_LIMITER_UP 6
|
||||||
#define RATE_LIMITER_DOWN 1
|
#define RATE_LIMITER_DOWN 24
|
||||||
|
|
||||||
#define TESTINATOR
|
#define TESTINATOR
|
||||||
// #define TLE5206
|
// #define TLE5206
|
||||||
|
|
|
@ -12,13 +12,11 @@
|
||||||
|
|
||||||
pthread_t tMovement;
|
pthread_t tMovement;
|
||||||
struct position cons;
|
struct position cons;
|
||||||
pthread_mutex_t movCons;
|
|
||||||
pthread_mutex_t movEnableMutex;
|
// Si une nouvelle instruction est disponible
|
||||||
pthread_cond_t movEnableCond;
|
pthread_mutex_t movInstructionMutex;
|
||||||
bool movEnableBool;
|
pthread_cond_t movInstructionCond;
|
||||||
pthread_mutex_t movDoneMutex;
|
bool movInstructionBool;
|
||||||
pthread_cond_t movDoneCond;
|
|
||||||
bool movDoneBool;
|
|
||||||
|
|
||||||
float xDiff;
|
float xDiff;
|
||||||
float yDiff;
|
float yDiff;
|
||||||
|
@ -35,10 +33,6 @@ float lErrPrev;
|
||||||
float rErrPrev;
|
float rErrPrev;
|
||||||
unsigned int nbCalcCons;
|
unsigned int nbCalcCons;
|
||||||
|
|
||||||
struct timespec pidStart;
|
|
||||||
struct timespec pidNow;
|
|
||||||
struct timespec pidEcoule;
|
|
||||||
|
|
||||||
void configureMovement()
|
void configureMovement()
|
||||||
{
|
{
|
||||||
stop();
|
stop();
|
||||||
|
@ -47,14 +41,10 @@ void configureMovement()
|
||||||
configureSecurite();
|
configureSecurite();
|
||||||
|
|
||||||
nbCalcCons = 0;
|
nbCalcCons = 0;
|
||||||
pthread_mutex_init(&movCons, NULL);
|
|
||||||
|
|
||||||
pthread_mutex_init(&movEnableMutex, NULL);
|
pthread_mutex_init(&movInstructionMutex, NULL);
|
||||||
pthread_cond_init(&movEnableCond, NULL);
|
pthread_cond_init(&movInstructionCond, NULL);
|
||||||
movEnableBool = false;
|
movInstructionBool = false;
|
||||||
pthread_mutex_init(&movDoneMutex, NULL);
|
|
||||||
pthread_cond_init(&movDoneCond, NULL);
|
|
||||||
movDoneBool = false;
|
|
||||||
|
|
||||||
pthread_create(&tMovement, NULL, TaskMovement, NULL);
|
pthread_create(&tMovement, NULL, TaskMovement, NULL);
|
||||||
|
|
||||||
|
@ -73,24 +63,24 @@ void configureMovement()
|
||||||
registerDebugVar("lErr", f, &lErr);
|
registerDebugVar("lErr", f, &lErr);
|
||||||
registerDebugVar("rErr", f, &rErr);
|
registerDebugVar("rErr", f, &rErr);
|
||||||
registerDebugVar("nbCalcCons", d, &nbCalcCons);
|
registerDebugVar("nbCalcCons", d, &nbCalcCons);
|
||||||
|
|
||||||
disableConsigne();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void setDestination(struct position* pos)
|
void setDestination(struct position* pos)
|
||||||
{
|
{
|
||||||
pthread_mutex_lock(&movCons);
|
pthread_mutex_lock(&movInstructionMutex);
|
||||||
memcpy(&cons, pos, sizeof(struct position));
|
memcpy(&cons, pos, sizeof(struct position));
|
||||||
pthread_mutex_unlock(&movCons);
|
movInstructionBool = true;
|
||||||
|
pthread_cond_signal(&movInstructionCond);
|
||||||
|
pthread_mutex_unlock(&movInstructionMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
void waitDestination()
|
void waitDestination()
|
||||||
{
|
{
|
||||||
pthread_mutex_lock(&movDoneMutex);
|
pthread_mutex_lock(&movInstructionMutex);
|
||||||
while (!movDoneBool) {
|
while (movInstructionBool) {
|
||||||
pthread_cond_wait(&movDoneCond, &movDoneMutex);
|
pthread_cond_wait(&movInstructionCond, &movInstructionMutex);
|
||||||
}
|
}
|
||||||
pthread_mutex_unlock(&movDoneMutex);
|
pthread_mutex_unlock(&movInstructionMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
float angleGap(float target, float actual)
|
float angleGap(float target, float actual)
|
||||||
|
@ -114,126 +104,90 @@ void* TaskMovement(void* pData)
|
||||||
unsigned int lastPosCalc = 0;
|
unsigned int lastPosCalc = 0;
|
||||||
struct position connu;
|
struct position connu;
|
||||||
|
|
||||||
oRetenu = true;
|
|
||||||
dRetenu = true;
|
|
||||||
|
|
||||||
float lErrInteg = 0;
|
|
||||||
float rErrInteg = 0;
|
|
||||||
|
|
||||||
clock_gettime(CLOCK_REALTIME, &pidStart);
|
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
// Attend instruction
|
||||||
|
printf("Wait instruction\n");
|
||||||
|
pthread_mutex_lock(&movInstructionMutex);
|
||||||
|
while (!movInstructionBool) {
|
||||||
|
pthread_cond_wait(&movInstructionCond, &movInstructionMutex);
|
||||||
|
} // Début de l'instruction
|
||||||
|
|
||||||
// Test if enabled
|
printf("Oriente dir\n");
|
||||||
pthread_mutex_lock(&movEnableMutex);
|
// Oriente vers direction
|
||||||
while (!movEnableBool) {
|
// TODO Marche arrière
|
||||||
pthread_cond_wait(&movEnableCond, &movEnableMutex);
|
do {
|
||||||
}
|
|
||||||
|
|
||||||
// Wait for new calculation if not calculated yet
|
lastPosCalc = getPositionNewer(&connu, lastPosCalc);
|
||||||
lastPosCalc = getPositionNewer(&connu, lastPosCalc);
|
|
||||||
|
|
||||||
// Destination → ordre
|
xDiff = cons.x - connu.x;
|
||||||
bool angleInsignifiant = isnan(cons.o);
|
yDiff = cons.y - connu.y;
|
||||||
pthread_mutex_lock(&movCons);
|
oDirEcart = angleGap(atan2(yDiff, xDiff), connu.o);
|
||||||
xDiff = cons.x - connu.x;
|
float oErrRev = oDirEcart * DISTANCE_BETWEEN_WHEELS / WHEEL_PERIMETER;
|
||||||
yDiff = cons.y - connu.y;
|
float lVolt = -oErrRev * P;
|
||||||
oEcart = angleInsignifiant ? 0 : angleGap(cons.o, connu.o);
|
float rVolt = oErrRev * P;
|
||||||
|
setMoteurTension(lVolt, rVolt);
|
||||||
|
|
||||||
// Distance d'écart entre la position actuelle et celle de consigne
|
nbCalcCons++;
|
||||||
dDirEcart = hypotf(xDiff, yDiff);
|
} while (fabsf(oDirEcart) > O_DIR_ECART_MIN);
|
||||||
// Écart entre l'angle actuel et celui orienté vers la position de consigne
|
brake();
|
||||||
// Si l'angle se trouve à gauche du cercle trigo, on le remet à droite
|
usleep(500 * 1000);
|
||||||
// et on inverse la direction
|
|
||||||
/* oDirEcart = angleGap180(atan2(yDiff, xDiff), connu.o, &dDirEcart); */
|
|
||||||
oDirEcart = angleGap(atan2(yDiff, xDiff), connu.o);
|
|
||||||
pthread_mutex_unlock(&movCons);
|
|
||||||
|
|
||||||
// Si on est loin de la consigne, l'angle cible devient celui orienté vers la consigne
|
printf("Avance dir\n");
|
||||||
float dDirEcartAbs = fabsf(dDirEcart);
|
// Avance vers direction
|
||||||
if (dDirEcartAbs > D_DIR_ECART_MAX) {
|
do {
|
||||||
oRetenu = true;
|
|
||||||
// Si on est proche de la consigne, l'angle cible devient celui voulu par la consigne
|
|
||||||
} else if (dDirEcartAbs < D_DIR_ECART_MIN) {
|
|
||||||
oRetenu = false;
|
|
||||||
}
|
|
||||||
oErr = oRetenu ? oDirEcart : oEcart;
|
|
||||||
|
|
||||||
float oDirEcartAbs = fabsf(oDirEcart);
|
lastPosCalc = getPositionNewer(&connu, lastPosCalc);
|
||||||
// Si l'écart avec l'angle orienté vers la consigne est grand, la distance cible devient 0
|
|
||||||
// pour se réorienter vers l'angle de la consigne
|
xDiff = cons.x - connu.x;
|
||||||
if (oDirEcartAbs > O_DIR_ECART_MAX) {
|
yDiff = cons.y - connu.y;
|
||||||
dRetenu = true;
|
dDirEcart = hypotf(xDiff, yDiff);
|
||||||
// Si l'écart avec l'angle orienté vers la consigne est petit, la distance cible devient
|
oDirEcart = angleGap(atan2(yDiff, xDiff), connu.o);
|
||||||
// la distance entre la position actuelle et la consigne
|
|
||||||
} else if (oDirEcartAbs < O_DIR_ECART_MIN) {
|
|
||||||
dRetenu = false;
|
|
||||||
}
|
|
||||||
dErr = dRetenu ? 0 : dDirEcart;
|
|
||||||
|
|
||||||
// Limitation par les valeurs des capteurs
|
|
||||||
#ifdef ENABLE_SECURITE
|
#ifdef ENABLE_SECURITE
|
||||||
float avant, arriere;
|
float distDevant, distDerriere;
|
||||||
getDistance(&avant, &arriere);
|
getDistance(&distDevant, &distDerriere);
|
||||||
dErr = fmaxf(-arriere, fminf(avant, dErr));
|
float maxEcart = fmax(0, distDevant - SECURITE_MARGE);
|
||||||
|
float minEcart = fmin(0, -distDerriere + SECURITE_MARGE);
|
||||||
|
dErr = fmin(maxEcart, fmax(minEcart, dDirEcart));
|
||||||
|
#else
|
||||||
|
dErr = dDirEcart;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Calcul si on est arrivé
|
float dErrRev = dErr / WHEEL_PERIMETER;
|
||||||
pthread_mutex_lock(&movDoneMutex);
|
float oErrRev = O_GAIN * oDirEcart * DISTANCE_BETWEEN_WHEELS / WHEEL_PERIMETER;
|
||||||
clock_gettime(CLOCK_REALTIME, &pidNow);
|
|
||||||
movDoneBool = !oRetenu && fabs(oEcart) < O_ECART_MAX;
|
|
||||||
if (movDoneBool) {
|
|
||||||
pthread_cond_signal(&movDoneCond);
|
|
||||||
}
|
|
||||||
pthread_mutex_unlock(&movDoneMutex);
|
|
||||||
|
|
||||||
// Ordre → Volt
|
lErr = dErrRev - oErrRev;
|
||||||
// Nombre de rotation nécessaire sur les deux roues dans le même sens pour arriver à la distance voulue
|
rErr = dErrRev + oErrRev;
|
||||||
float dErrRev = dErr / WHEEL_PERIMETER;
|
float lVolt = lErr * P;
|
||||||
// Nombre de rotation nécessaire sur les deux roues dans le sens inverse pour arriver à l'angle voulu
|
float rVolt = rErr * P;
|
||||||
float oErrRev = oErr * DISTANCE_BETWEEN_WHEELS / WHEEL_PERIMETER;
|
setMoteurTension(lVolt, rVolt);
|
||||||
|
|
||||||
// Si on est en avancement on applique une grande priorité au retour sur la ligne
|
nbCalcCons++;
|
||||||
if (!dRetenu && oRetenu) {
|
} while (fabsf(dDirEcart) > D_DIR_ECART_MIN);
|
||||||
oErrRev *= O_GAIN;
|
brake();
|
||||||
|
usleep(500 * 1000);
|
||||||
|
|
||||||
|
printf("Orientation finale\n");
|
||||||
|
// Orientation finale (si nécessaire)
|
||||||
|
if (!isnan(cons.o)) {
|
||||||
|
do {
|
||||||
|
|
||||||
|
lastPosCalc = getPositionNewer(&connu, lastPosCalc);
|
||||||
|
oDirEcart = angleGap(cons.o, connu.o);
|
||||||
|
float oErrRev = oDirEcart * DISTANCE_BETWEEN_WHEELS / WHEEL_PERIMETER;
|
||||||
|
float lVolt = -oErrRev * P;
|
||||||
|
float rVolt = oErrRev * P;
|
||||||
|
setMoteurTension(lVolt, rVolt);
|
||||||
|
|
||||||
|
nbCalcCons++;
|
||||||
|
} while (fabsf(oDirEcart) > O_DIR_ECART_MIN);
|
||||||
|
brake();
|
||||||
|
usleep(500 * 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
lErr = dErrRev - oErrRev;
|
movInstructionBool = false; // Fin de l'instruction
|
||||||
rErr = dErrRev + oErrRev;
|
pthread_cond_signal(&movInstructionCond);
|
||||||
|
pthread_mutex_unlock(&movInstructionMutex);
|
||||||
// PID
|
|
||||||
// Calcul du temps écoulé par rapport à la dernière mesure
|
|
||||||
clock_gettime(CLOCK_REALTIME, &pidNow);
|
|
||||||
if ((pidNow.tv_nsec - pidStart.tv_nsec) < 0) {
|
|
||||||
pidEcoule.tv_sec = pidNow.tv_sec - pidStart.tv_sec - 1;
|
|
||||||
pidEcoule.tv_nsec = pidNow.tv_nsec - pidStart.tv_nsec + 1000000000UL;
|
|
||||||
} else {
|
|
||||||
pidEcoule.tv_sec = pidNow.tv_sec - pidStart.tv_sec;
|
|
||||||
pidEcoule.tv_nsec = pidNow.tv_nsec - pidStart.tv_nsec;
|
|
||||||
}
|
|
||||||
// Enregistrement de cette mesure comme la dernière mesure
|
|
||||||
pidStart.tv_sec = pidNow.tv_sec;
|
|
||||||
pidStart.tv_nsec = pidNow.tv_nsec;
|
|
||||||
float timeStep = pidEcoule.tv_sec + pidEcoule.tv_nsec * 1E-9;
|
|
||||||
|
|
||||||
// Calcul des facteurs dérivé et intégrale
|
|
||||||
lErrInteg += (lErr + lErrPrev) / 2 * timeStep;
|
|
||||||
float lErrDeriv = (lErr - lErrPrev) / timeStep;
|
|
||||||
lErrPrev = lErr;
|
|
||||||
|
|
||||||
rErrInteg += (rErr + rErrPrev) / 2 * timeStep;
|
|
||||||
float rErrDeriv = (rErr - rErrPrev) / timeStep;
|
|
||||||
rErrPrev = rErr;
|
|
||||||
|
|
||||||
// Calcul de la commande
|
|
||||||
float lVolt = P * lErr + I * lErrInteg + D * lErrDeriv;
|
|
||||||
float rVolt = P * rErr + I * rErrInteg + D * rErrDeriv;
|
|
||||||
|
|
||||||
// Envoi de la commande
|
|
||||||
setMoteurTension(lVolt, rVolt);
|
|
||||||
|
|
||||||
nbCalcCons++;
|
|
||||||
pthread_mutex_unlock(&movEnableMutex);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -246,22 +200,3 @@ void deconfigureMovement()
|
||||||
deconfigureSecurite();
|
deconfigureSecurite();
|
||||||
deconfigureMotor();
|
deconfigureMotor();
|
||||||
}
|
}
|
||||||
|
|
||||||
void enableConsigne()
|
|
||||||
{
|
|
||||||
printf("251 enableConsigne\n");
|
|
||||||
pthread_mutex_lock(&movEnableMutex);
|
|
||||||
clock_gettime(CLOCK_REALTIME, &pidNow);
|
|
||||||
movEnableBool = true;
|
|
||||||
pthread_cond_signal(&movEnableCond);
|
|
||||||
pthread_mutex_unlock(&movEnableMutex);
|
|
||||||
}
|
|
||||||
|
|
||||||
void disableConsigne()
|
|
||||||
{
|
|
||||||
printf("261 disableConsigne\n");
|
|
||||||
pthread_mutex_lock(&movEnableMutex);
|
|
||||||
movEnableBool = false;
|
|
||||||
// No signal here, will be disabled on next run
|
|
||||||
pthread_mutex_unlock(&movEnableMutex);
|
|
||||||
}
|
|
||||||
|
|
|
@ -7,7 +7,10 @@
|
||||||
|
|
||||||
#define ANGLE_INSIGNIFIANT NAN
|
#define ANGLE_INSIGNIFIANT NAN
|
||||||
|
|
||||||
// #define ENABLE_SECURITE
|
#define ENABLE_SECURITE
|
||||||
|
|
||||||
|
#define SECURITE_MARGE 300
|
||||||
|
|
||||||
|
|
||||||
#include "position.h"
|
#include "position.h"
|
||||||
|
|
||||||
|
@ -15,8 +18,6 @@ void configureMovement();
|
||||||
void deconfigureMovement();
|
void deconfigureMovement();
|
||||||
void setDestination(struct position* pos);
|
void setDestination(struct position* pos);
|
||||||
void* TaskMovement(void* pData);
|
void* TaskMovement(void* pData);
|
||||||
void enableConsigne();
|
|
||||||
void disableConsigne();
|
|
||||||
void waitDestination();
|
void waitDestination();
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include "motor.h"
|
#include "motor.h"
|
||||||
#include "parcours.h"
|
#include "parcours.h"
|
||||||
#include "points.h"
|
#include "points.h"
|
||||||
|
#include "securite.h"
|
||||||
#include "position.h"
|
#include "position.h"
|
||||||
|
|
||||||
pthread_t tParcours;
|
pthread_t tParcours;
|
||||||
|
@ -34,7 +35,6 @@ void prepareParcours(bool orange)
|
||||||
printRightLCD(LCD_LINE_2, isOrange ? "Org" : "Vrt");
|
printRightLCD(LCD_LINE_2, isOrange ? "Org" : "Vrt");
|
||||||
|
|
||||||
resetActionneurs();
|
resetActionneurs();
|
||||||
enableConsigne();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void startParcours()
|
void startParcours()
|
||||||
|
@ -73,7 +73,6 @@ int updateParcours()
|
||||||
void stopParcours()
|
void stopParcours()
|
||||||
{
|
{
|
||||||
pthread_cancel(tParcours);
|
pthread_cancel(tParcours);
|
||||||
disableConsigne();
|
|
||||||
stop();
|
stop();
|
||||||
|
|
||||||
resetLCD();
|
resetLCD();
|
||||||
|
@ -85,17 +84,18 @@ void stopParcours()
|
||||||
|
|
||||||
void gotoPoint(float x, float y, float o)
|
void gotoPoint(float x, float y, float o)
|
||||||
{
|
{
|
||||||
if (isOrange) {
|
/* if (isOrange) { */
|
||||||
x = M_PISTE_WIDTH - x;
|
/* x = M_PISTE_WIDTH - x; */
|
||||||
if (!isnan(o)) {
|
/* if (!isnan(o)) { */
|
||||||
o = M_PI - o;
|
/* o = M_PI - o; */
|
||||||
}
|
/* } */
|
||||||
|
/* } */
|
||||||
|
if (!isOrange) {
|
||||||
|
o = -o;
|
||||||
}
|
}
|
||||||
enableConsigne();
|
|
||||||
struct position pos = { x, y, o };
|
struct position pos = { x, y, o };
|
||||||
setDestination(&pos);
|
setDestination(&pos);
|
||||||
waitDestination();
|
waitDestination();
|
||||||
disableConsigne();
|
|
||||||
brake();
|
brake();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,6 +112,40 @@ void* TaskParcours(void* pdata)
|
||||||
{
|
{
|
||||||
(void)pdata;
|
(void)pdata;
|
||||||
|
|
||||||
|
float vitBase = 1.5;
|
||||||
|
float secuBase = 500;
|
||||||
|
|
||||||
|
for (int i = 0; i <= 3000; i++) {
|
||||||
|
float av, ar;
|
||||||
|
getDistance(&av, &ar);
|
||||||
|
if (av < secuBase || ar < secuBase) {
|
||||||
|
brake();
|
||||||
|
} else {
|
||||||
|
setMoteurTension(vitBase, vitBase);
|
||||||
|
}
|
||||||
|
usleep(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* TaskParcoursLoquet(void* pdata)
|
||||||
|
{
|
||||||
|
(void)pdata;
|
||||||
|
|
||||||
|
gotoPoint(350, 0, 1.05*M_PI/3.0);
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
setLoquet(false);
|
||||||
|
setLoquet(true);
|
||||||
|
}
|
||||||
|
gotoPoint(0, 0, 0);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* TaskParcoursVrai(void* pdata)
|
||||||
|
{
|
||||||
|
(void)pdata;
|
||||||
|
|
||||||
// Récupération des balles
|
// Récupération des balles
|
||||||
gotoPoint(X_RECUP_1, Y_RECUP_1, O_RECUP_1);
|
gotoPoint(X_RECUP_1, Y_RECUP_1, O_RECUP_1);
|
||||||
setLoquet(false);
|
setLoquet(false);
|
||||||
|
|
|
@ -37,28 +37,21 @@ int main()
|
||||||
configureDebug();
|
configureDebug();
|
||||||
configureCF();
|
configureCF();
|
||||||
configureIMU();
|
configureIMU();
|
||||||
printf("40\n");
|
|
||||||
configureActionneurs();
|
configureActionneurs();
|
||||||
printf("41\n");
|
|
||||||
configurePosition();
|
configurePosition();
|
||||||
printf("44\n");
|
|
||||||
configureMovement();
|
configureMovement();
|
||||||
printf("46\n");
|
|
||||||
startDebug();
|
startDebug();
|
||||||
printf("48\n");
|
|
||||||
|
|
||||||
debugSetActive(true);
|
debugSetActive(true);
|
||||||
sleep(1);
|
sleep(1);
|
||||||
printf("46\n");
|
/* struct position pos = {350, 0, -0.95*M_PI/3.0 }; */
|
||||||
enableConsigne();
|
struct position pos = {100000, 0, 0 };
|
||||||
struct position pos = { 0, -100, -M_PI };
|
|
||||||
setDestination(&pos);
|
setDestination(&pos);
|
||||||
printf("50\n");
|
|
||||||
waitDestination();
|
waitDestination();
|
||||||
printf("52\n");
|
for (;;) {
|
||||||
disableConsigne();
|
setLoquet(false);
|
||||||
printf("54\n");
|
setLoquet(true);
|
||||||
brake();
|
}
|
||||||
printf("Done\n");
|
printf("Done\n");
|
||||||
|
|
||||||
// Bloque jusqu'à l'arrivée d'un signal
|
// Bloque jusqu'à l'arrivée d'un signal
|
||||||
|
|
72
chef/src/testAvance.c
Normal file
72
chef/src/testAvance.c
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <signal.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <time.h> // random seed
|
||||||
|
#include <unistd.h> // sleep
|
||||||
|
#include <wiringPi.h>
|
||||||
|
|
||||||
|
#include "CF.h"
|
||||||
|
#include "actionneurs.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "i2c.h"
|
||||||
|
#include "ihm.h"
|
||||||
|
#include "imu.h"
|
||||||
|
#include "movement.h"
|
||||||
|
#include "motor.h"
|
||||||
|
#include "position.h"
|
||||||
|
|
||||||
|
pthread_mutex_t sRunning;
|
||||||
|
|
||||||
|
void endRunning(int signal)
|
||||||
|
{
|
||||||
|
(void)signal;
|
||||||
|
pthread_mutex_unlock(&sRunning);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
|
||||||
|
if (wiringPiSetup() < 0) {
|
||||||
|
fprintf(stderr, "Impossible d'initialiser WiringPi\n");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
initI2C();
|
||||||
|
srand(time(NULL));
|
||||||
|
|
||||||
|
configureDebug();
|
||||||
|
configureCF();
|
||||||
|
configureIMU();
|
||||||
|
configureActionneurs();
|
||||||
|
configurePosition();
|
||||||
|
configureMovement();
|
||||||
|
startDebug();
|
||||||
|
|
||||||
|
debugSetActive(true);
|
||||||
|
sleep(1);
|
||||||
|
/* struct position pos = {350, 0, -0.95*M_PI/3.0 }; */
|
||||||
|
struct position pos = {100000, 0, 0 };
|
||||||
|
setDestination(&pos);
|
||||||
|
waitDestination();
|
||||||
|
for (;;) {
|
||||||
|
setLoquet(false);
|
||||||
|
setLoquet(true);
|
||||||
|
}
|
||||||
|
printf("Done\n");
|
||||||
|
|
||||||
|
// Bloque jusqu'à l'arrivée d'un signal
|
||||||
|
pthread_mutex_init(&sRunning, NULL);
|
||||||
|
signal(SIGINT, endRunning);
|
||||||
|
signal(SIGTERM, endRunning);
|
||||||
|
signal(SIGQUIT, endRunning);
|
||||||
|
pthread_mutex_lock(&sRunning);
|
||||||
|
pthread_mutex_lock(&sRunning);
|
||||||
|
|
||||||
|
deconfigureMovement();
|
||||||
|
deconfigurePosition();
|
||||||
|
deconfigureActionneurs();
|
||||||
|
deconfigureIMU();
|
||||||
|
deconfigureCF();
|
||||||
|
deconfigureDebug();
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
71
chef/src/testOrange.c
Normal file
71
chef/src/testOrange.c
Normal file
|
@ -0,0 +1,71 @@
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <signal.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <time.h> // random seed
|
||||||
|
#include <unistd.h> // sleep
|
||||||
|
#include <wiringPi.h>
|
||||||
|
|
||||||
|
#include "CF.h"
|
||||||
|
#include "actionneurs.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "i2c.h"
|
||||||
|
#include "ihm.h"
|
||||||
|
#include "imu.h"
|
||||||
|
#include "movement.h"
|
||||||
|
#include "motor.h"
|
||||||
|
#include "position.h"
|
||||||
|
|
||||||
|
pthread_mutex_t sRunning;
|
||||||
|
|
||||||
|
void endRunning(int signal)
|
||||||
|
{
|
||||||
|
(void)signal;
|
||||||
|
pthread_mutex_unlock(&sRunning);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
|
||||||
|
if (wiringPiSetup() < 0) {
|
||||||
|
fprintf(stderr, "Impossible d'initialiser WiringPi\n");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
initI2C();
|
||||||
|
srand(time(NULL));
|
||||||
|
|
||||||
|
configureDebug();
|
||||||
|
configureCF();
|
||||||
|
configureIMU();
|
||||||
|
configureActionneurs();
|
||||||
|
configurePosition();
|
||||||
|
configureMovement();
|
||||||
|
startDebug();
|
||||||
|
|
||||||
|
debugSetActive(true);
|
||||||
|
sleep(1);
|
||||||
|
struct position pos = {350, 0, -0.95*M_PI/3.0 };
|
||||||
|
setDestination(&pos);
|
||||||
|
sleep(3);
|
||||||
|
for (;;) {
|
||||||
|
setLoquet(false);
|
||||||
|
setLoquet(true);
|
||||||
|
}
|
||||||
|
printf("Done\n");
|
||||||
|
|
||||||
|
// Bloque jusqu'à l'arrivée d'un signal
|
||||||
|
pthread_mutex_init(&sRunning, NULL);
|
||||||
|
signal(SIGINT, endRunning);
|
||||||
|
signal(SIGTERM, endRunning);
|
||||||
|
signal(SIGQUIT, endRunning);
|
||||||
|
pthread_mutex_lock(&sRunning);
|
||||||
|
pthread_mutex_lock(&sRunning);
|
||||||
|
|
||||||
|
deconfigureMovement();
|
||||||
|
deconfigurePosition();
|
||||||
|
deconfigureActionneurs();
|
||||||
|
deconfigureIMU();
|
||||||
|
deconfigureCF();
|
||||||
|
deconfigureDebug();
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
72
chef/src/testRecule.c
Normal file
72
chef/src/testRecule.c
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <signal.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <time.h> // random seed
|
||||||
|
#include <unistd.h> // sleep
|
||||||
|
#include <wiringPi.h>
|
||||||
|
|
||||||
|
#include "CF.h"
|
||||||
|
#include "actionneurs.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "i2c.h"
|
||||||
|
#include "ihm.h"
|
||||||
|
#include "imu.h"
|
||||||
|
#include "movement.h"
|
||||||
|
#include "motor.h"
|
||||||
|
#include "position.h"
|
||||||
|
|
||||||
|
pthread_mutex_t sRunning;
|
||||||
|
|
||||||
|
void endRunning(int signal)
|
||||||
|
{
|
||||||
|
(void)signal;
|
||||||
|
pthread_mutex_unlock(&sRunning);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
|
||||||
|
if (wiringPiSetup() < 0) {
|
||||||
|
fprintf(stderr, "Impossible d'initialiser WiringPi\n");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
initI2C();
|
||||||
|
srand(time(NULL));
|
||||||
|
|
||||||
|
configureDebug();
|
||||||
|
configureCF();
|
||||||
|
configureIMU();
|
||||||
|
configureActionneurs();
|
||||||
|
configurePosition();
|
||||||
|
configureMovement();
|
||||||
|
startDebug();
|
||||||
|
|
||||||
|
debugSetActive(true);
|
||||||
|
sleep(1);
|
||||||
|
/* struct position pos = {350, 0, -0.95*M_PI/3.0 }; */
|
||||||
|
struct position pos = {-100000, 0, 0 };
|
||||||
|
setDestination(&pos);
|
||||||
|
waitDestination();
|
||||||
|
for (;;) {
|
||||||
|
setLoquet(false);
|
||||||
|
setLoquet(true);
|
||||||
|
}
|
||||||
|
printf("Done\n");
|
||||||
|
|
||||||
|
// Bloque jusqu'à l'arrivée d'un signal
|
||||||
|
pthread_mutex_init(&sRunning, NULL);
|
||||||
|
signal(SIGINT, endRunning);
|
||||||
|
signal(SIGTERM, endRunning);
|
||||||
|
signal(SIGQUIT, endRunning);
|
||||||
|
pthread_mutex_lock(&sRunning);
|
||||||
|
pthread_mutex_lock(&sRunning);
|
||||||
|
|
||||||
|
deconfigureMovement();
|
||||||
|
deconfigurePosition();
|
||||||
|
deconfigureActionneurs();
|
||||||
|
deconfigureIMU();
|
||||||
|
deconfigureCF();
|
||||||
|
deconfigureDebug();
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
77
chef/src/testRot.c
Normal file
77
chef/src/testRot.c
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
#include <pthread.h>
|
||||||
|
#include <signal.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <time.h> // random seed
|
||||||
|
#include <unistd.h> // sleep
|
||||||
|
#include <wiringPi.h>
|
||||||
|
|
||||||
|
#include "CF.h"
|
||||||
|
#include "actionneurs.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "i2c.h"
|
||||||
|
#include "ihm.h"
|
||||||
|
#include "imu.h"
|
||||||
|
#include "movement.h"
|
||||||
|
#include "motor.h"
|
||||||
|
#include "position.h"
|
||||||
|
|
||||||
|
pthread_mutex_t sRunning;
|
||||||
|
|
||||||
|
void endRunning(int signal)
|
||||||
|
{
|
||||||
|
(void)signal;
|
||||||
|
pthread_mutex_unlock(&sRunning);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
|
||||||
|
if (wiringPiSetup() < 0) {
|
||||||
|
fprintf(stderr, "Impossible d'initialiser WiringPi\n");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
initI2C();
|
||||||
|
srand(time(NULL));
|
||||||
|
|
||||||
|
configureDebug();
|
||||||
|
configureCF();
|
||||||
|
configureIMU();
|
||||||
|
printf("40\n");
|
||||||
|
configureActionneurs();
|
||||||
|
printf("41\n");
|
||||||
|
configurePosition();
|
||||||
|
printf("44\n");
|
||||||
|
configureMovement();
|
||||||
|
printf("46\n");
|
||||||
|
startDebug();
|
||||||
|
printf("48\n");
|
||||||
|
|
||||||
|
debugSetActive(true);
|
||||||
|
sleep(1);
|
||||||
|
printf("46\n");
|
||||||
|
struct position pos = { 0, 0, M_PI_2 };
|
||||||
|
setDestination(&pos);
|
||||||
|
printf("50\n");
|
||||||
|
waitDestination();
|
||||||
|
printf("52\n");
|
||||||
|
printf("54\n");
|
||||||
|
brake();
|
||||||
|
printf("Done\n");
|
||||||
|
|
||||||
|
// Bloque jusqu'à l'arrivée d'un signal
|
||||||
|
pthread_mutex_init(&sRunning, NULL);
|
||||||
|
signal(SIGINT, endRunning);
|
||||||
|
signal(SIGTERM, endRunning);
|
||||||
|
signal(SIGQUIT, endRunning);
|
||||||
|
pthread_mutex_lock(&sRunning);
|
||||||
|
pthread_mutex_lock(&sRunning);
|
||||||
|
|
||||||
|
deconfigureMovement();
|
||||||
|
deconfigurePosition();
|
||||||
|
deconfigureActionneurs();
|
||||||
|
deconfigureIMU();
|
||||||
|
deconfigureCF();
|
||||||
|
deconfigureDebug();
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
|
@ -1,6 +1,7 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "CF.h"
|
#include "CF.h"
|
||||||
#include "securite.h"
|
#include "securite.h"
|
||||||
|
@ -19,6 +20,6 @@ int main(int argc, char* argv[])
|
||||||
for (;;) {
|
for (;;) {
|
||||||
getDistance(&f, &b);
|
getDistance(&f, &b);
|
||||||
printf("Av: %6f Ar: %6f\n", f, b);
|
printf("Av: %6f Ar: %6f\n", f, b);
|
||||||
sleep(1);
|
usleep(60 * 1000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue