mirror of
https://github.com/RobotechLille/cdf2018-principal
synced 2025-10-24 17:53:31 +02:00
Essai de calibrage en position
This commit is contained in:
parent
d0d3e7f244
commit
5f6e9b3ee5
3 changed files with 105 additions and 0 deletions
42
chef/src/calibrage.c
Normal file
42
chef/src/calibrage.c
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "calibrage.h"
|
||||||
|
|
||||||
|
#include "movement.h"
|
||||||
|
#include "dimensions.h"
|
||||||
|
#include "securite.h"
|
||||||
|
#include "motor.h"
|
||||||
|
#include "common.h"
|
||||||
|
|
||||||
|
void calibrer(bool orange)
|
||||||
|
{
|
||||||
|
struct position pos = {0, 0, 0};
|
||||||
|
setPosition(&pos);
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Calibrage contre mur court
|
||||||
|
/* pos.o = orange ? M_PI_2 : -M_PI_2; */
|
||||||
|
setDestination(&pos);
|
||||||
|
waitDestination();
|
||||||
|
disableAsservissement();
|
||||||
|
|
||||||
|
float frontL, frontR, backL, backR;
|
||||||
|
struct movAvg diffL, diffR;
|
||||||
|
initMovAvg(&diffL, CALIBRAGE_MOVAVG_SIZE);
|
||||||
|
initMovAvg(&diffR, CALIBRAGE_MOVAVG_SIZE);
|
||||||
|
for (int i = 0; i < CALIBRAGE_TEMPS_ACQUISITION; i += SENSOR_SAMPLING_INTERVAL) {
|
||||||
|
getAllDistance(&frontL, &frontR, &backL, &backR);
|
||||||
|
addMovAvg(&diffL, frontL - CALIBRAGE_DISTANCE_Y);
|
||||||
|
addMovAvg(&diffR, frontR - CALIBRAGE_DISTANCE_Y);
|
||||||
|
setMoteurTension(diffL.current * D_KP, diffR.current * D_KP);
|
||||||
|
usleep(SENSOR_SAMPLING_INTERVAL * 1000);
|
||||||
|
}
|
||||||
|
// Les moteurs n'auront peut-être pas atteint le point voulu exactement,
|
||||||
|
// on enregistre alors la différence
|
||||||
|
float diff = (diffL.current + diffR.current) / 2;
|
||||||
|
pos.y = diff;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
16
chef/src/calibrage.h
Normal file
16
chef/src/calibrage.h
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
#ifndef __CALIBRAGE_H_
|
||||||
|
#define __CALIBRAGE_H_
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
// Constantes
|
||||||
|
|
||||||
|
#define CALIBRAGE_TEMPS_ACQUISITION 30000
|
||||||
|
#define CALIBRAGE_DISTANCE_X 300
|
||||||
|
#define CALIBRAGE_DISTANCE_Y 300
|
||||||
|
#define CALIBRAGE_MOVAVG_SIZE 4
|
||||||
|
|
||||||
|
// Public
|
||||||
|
void calibrer(bool orange);
|
||||||
|
|
||||||
|
#endif
|
47
chef/src/testCalibrage.c
Normal file
47
chef/src/testCalibrage.c
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
#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 "actionneurs.h"
|
||||||
|
#include "calibrage.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "i2c.h"
|
||||||
|
#include "motor.h"
|
||||||
|
#include "movement.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();
|
||||||
|
configurePosition();
|
||||||
|
configureMovement();
|
||||||
|
debugSetActive(true);
|
||||||
|
startDebug();
|
||||||
|
|
||||||
|
calibrer(false);
|
||||||
|
|
||||||
|
deconfigureMovement();
|
||||||
|
deconfigurePosition();
|
||||||
|
deconfigureDebug();
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue