mirror of
				https://github.com/RobotechLille/cdf2018-principal
				synced 2025-10-25 02:03:31 +02:00 
			
		
		
		
	Parcours total
This commit is contained in:
		
							parent
							
								
									041dae8e41
								
							
						
					
					
						commit
						9cdebaa915
					
				
					 4 changed files with 126 additions and 27 deletions
				
			
		|  | @ -8,6 +8,7 @@ | ||||||
| #include "debug.h" | #include "debug.h" | ||||||
| #include "motor.h" | #include "motor.h" | ||||||
| #include "movement.h" | #include "movement.h" | ||||||
|  | #include "securite.h" | ||||||
| 
 | 
 | ||||||
| pthread_t tMovement; | pthread_t tMovement; | ||||||
| struct position cons; | struct position cons; | ||||||
|  | @ -44,6 +45,8 @@ void configureMovement() | ||||||
| { | { | ||||||
|     stop(); |     stop(); | ||||||
| 
 | 
 | ||||||
|  |     configureSecurite(); | ||||||
|  | 
 | ||||||
|     nbCalcCons = 0; |     nbCalcCons = 0; | ||||||
|     pthread_mutex_init(&movCons, NULL); |     pthread_mutex_init(&movCons, NULL); | ||||||
| 
 | 
 | ||||||
|  | @ -93,16 +96,6 @@ void waitDestination() | ||||||
|     pthread_mutex_unlock(&movDoneMutex); |     pthread_mutex_unlock(&movDoneMutex); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void sendTo(float x, float y, float o) |  | ||||||
| { |  | ||||||
|     enableConsigne(); |  | ||||||
|     struct position pos = {x, y, o}; |  | ||||||
|     setDestination(&pos); |  | ||||||
|     waitDestination(); |  | ||||||
|     brake(); |  | ||||||
|     disableConsigne(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| float angleGap(float target, float actual) | float angleGap(float target, float actual) | ||||||
| { | { | ||||||
|     return fmod(target - actual + M_PI, 2 * M_PI) - M_PI; |     return fmod(target - actual + M_PI, 2 * M_PI) - M_PI; | ||||||
|  | @ -144,10 +137,11 @@ void* TaskMovement(void* pData) | ||||||
|         lastPosCalc = getPositionNewer(&connu, lastPosCalc); |         lastPosCalc = getPositionNewer(&connu, lastPosCalc); | ||||||
| 
 | 
 | ||||||
|         // Destination → ordre
 |         // Destination → ordre
 | ||||||
|  |         bool angleInsignifiant = isnan(cons.o); | ||||||
|         pthread_mutex_lock(&movCons); |         pthread_mutex_lock(&movCons); | ||||||
|         xDiff = cons.x - connu.x; |         xDiff = cons.x - connu.x; | ||||||
|         yDiff = cons.y - connu.y; |         yDiff = cons.y - connu.y; | ||||||
|         oEcart = angleGap(cons.o, connu.o); |         oEcart = angleInsignifiant ? 0 : angleGap(cons.o, connu.o); | ||||||
| 
 | 
 | ||||||
|         // Distance d'écart entre la position actuelle et celle de consigne
 |         // Distance d'écart entre la position actuelle et celle de consigne
 | ||||||
|         dDirEcart = hypotf(xDiff, yDiff); |         dDirEcart = hypotf(xDiff, yDiff); | ||||||
|  | @ -178,11 +172,18 @@ void* TaskMovement(void* pData) | ||||||
|         } |         } | ||||||
|         dErr = dRetenu ? 0 : dDirEcart; |         dErr = dRetenu ? 0 : dDirEcart; | ||||||
| 
 | 
 | ||||||
|  |         // Limitation par les valeurs des capteurs
 | ||||||
|  |         float avant, arriere; | ||||||
|  |         getDistance(&avant, &arriere); | ||||||
|  |         dErr = fmaxf(-arriere, fminf(avant, dErr)); | ||||||
|  | 
 | ||||||
|         // Calcul si on est arrivé
 |         // Calcul si on est arrivé
 | ||||||
|         pthread_mutex_lock(&movDoneMutex); |         pthread_mutex_lock(&movDoneMutex); | ||||||
|         clock_gettime(CLOCK_REALTIME, &pidNow); |         clock_gettime(CLOCK_REALTIME, &pidNow); | ||||||
|         movDoneBool = !dRetenu && !oRetenu && dDirEcart < D_CONS_THRESOLD && oEcart < O_CONS_THRESOLD; |         movDoneBool = !dRetenu && !oRetenu && dDirEcart < D_CONS_THRESOLD && oEcart < O_CONS_THRESOLD; | ||||||
|         pthread_cond_signal(&movDoneCond); |         if (movDoneBool) { | ||||||
|  |             pthread_cond_signal(&movDoneCond); | ||||||
|  |         } | ||||||
|         pthread_mutex_unlock(&movDoneMutex); |         pthread_mutex_unlock(&movDoneMutex); | ||||||
| 
 | 
 | ||||||
|         // Ordre → Volt
 |         // Ordre → Volt
 | ||||||
|  | @ -240,6 +241,7 @@ void deconfigureMovement() | ||||||
| { | { | ||||||
|     stop(); |     stop(); | ||||||
|     pthread_cancel(tMovement); |     pthread_cancel(tMovement); | ||||||
|  |     deconfigureSecurite(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void enableConsigne() | void enableConsigne() | ||||||
|  |  | ||||||
|  | @ -5,6 +5,8 @@ | ||||||
| #ifndef __MOVEMENT_H_ | #ifndef __MOVEMENT_H_ | ||||||
| #define __MOVEMENT_H_ | #define __MOVEMENT_H_ | ||||||
| 
 | 
 | ||||||
|  | #define ANGLE_INSIGNIFIANT NAN | ||||||
|  | 
 | ||||||
| #include "position.h" | #include "position.h" | ||||||
| 
 | 
 | ||||||
| void configureMovement(); | void configureMovement(); | ||||||
|  | @ -13,5 +15,6 @@ void setDestination(struct position* pos); | ||||||
| void* TaskMovement(void* pData); | void* TaskMovement(void* pData); | ||||||
| void enableConsigne(); | void enableConsigne(); | ||||||
| void disableConsigne(); | void disableConsigne(); | ||||||
|  | void waitDestination(); | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | @ -2,9 +2,9 @@ | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| 
 | 
 | ||||||
|  | #include "actionneurs.h" | ||||||
| #include "debug.h" | #include "debug.h" | ||||||
| #include "lcd.h" | #include "lcd.h" | ||||||
| #include "movement.h" |  | ||||||
| #include "motor.h" | #include "motor.h" | ||||||
| #include "parcours.h" | #include "parcours.h" | ||||||
| #include "points.h" | #include "points.h" | ||||||
|  | @ -32,6 +32,8 @@ void prepareParcours(bool orange) | ||||||
|     resetPoints(); |     resetPoints(); | ||||||
|     showPoints(); |     showPoints(); | ||||||
|     printRightLCD(LCD_LINE_2, isOrange ? "Org" : "Vrt"); |     printRightLCD(LCD_LINE_2, isOrange ? "Org" : "Vrt"); | ||||||
|  | 
 | ||||||
|  |     resetActionneurs(); | ||||||
|     enableConsigne(); |     enableConsigne(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -81,29 +83,88 @@ void stopParcours() | ||||||
|     debugSetActive(false); |     debugSetActive(false); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void gotoPoint(float x, float y, float o) | ||||||
|  | { | ||||||
|  |     if (isOrange) { | ||||||
|  |         x = M_PISTE_WIDTH - x; | ||||||
|  |         if (!isnan(o)) { | ||||||
|  |             o = M_PI - o; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     enableConsigne(); | ||||||
|  |     struct position pos = { x, y, o }; | ||||||
|  |     setDestination(&pos); | ||||||
|  |     waitDestination(); | ||||||
|  |     brake(); | ||||||
|  |     disableConsigne(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void recuperBalles() | ||||||
|  | { | ||||||
|  |     setLoquet(false); | ||||||
|  |     for (int i = 0; i < NB_BALLES; i++) { | ||||||
|  |         barilletSuivant(); | ||||||
|  |     } | ||||||
|  |     setLoquet(true); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void* TaskParcours(void* pdata) | void* TaskParcours(void* pdata) | ||||||
| { | { | ||||||
|     (void)pdata; |     (void)pdata; | ||||||
| 
 | 
 | ||||||
|     struct position dest1 = {0, 0, 0}; |     // Récupération des balles
 | ||||||
|     setDestination(&dest1); |     gotoPoint(X_RECUP_1, Y_RECUP_1, O_RECUP_1); | ||||||
|  |     setLoquet(false); | ||||||
|  |     recuperBalles(); | ||||||
| 
 | 
 | ||||||
|     sleep(1); |     // Lancement des balles
 | ||||||
|  |     gotoPoint(X_LANCER, Y_LANCER, O_LANCER); | ||||||
|  |     setPositionBalle(ejection); | ||||||
|  |     setPropulsion(true); | ||||||
|  |     pousserBalle(); | ||||||
|  |     for (int i = 0; i < NB_BALLES - 1; i++) { | ||||||
|  |         barilletSuivant(); | ||||||
|  |         pousserBalle(); | ||||||
|  |     } | ||||||
|  |     setPropulsion(false); | ||||||
|  |     setPositionBalle(attente); | ||||||
| 
 | 
 | ||||||
|     struct position dest2 = {0, 0, M_PI_2}; |     // Évitement des cubes
 | ||||||
|     setDestination(&dest2); |     gotoPoint(X_EVIT, Y_EVIT, O_EVIT); | ||||||
| 
 | 
 | ||||||
|     sleep(10); |     // Aller à l'abeille
 | ||||||
|  |     gotoPoint(X_ABEILLE, Y_ABEILLE, O_ABEILLE); | ||||||
|  | 
 | ||||||
|  |     // Récupération des balles
 | ||||||
|  |     gotoPoint(X_RECUP_2, Y_RECUP_2, O_RECUP_2); | ||||||
|  |     recuperBalles(); | ||||||
|  | 
 | ||||||
|  |     // Dépot des balles adverses
 | ||||||
|  |     gotoPoint(X_USE, Y_USE, O_USE); | ||||||
|  |     setPositionBalle(evacuation); | ||||||
|  |     barilletSuivant(); // TODO Peut-être pas utile en fonction
 | ||||||
|  |     // de quelle balle arrive en premier
 | ||||||
|  |     pousserBalle(); | ||||||
|  |     for (int i = 0; i < NB_BALLES / 2 - 1; i++) { | ||||||
|  |         barilletSkip(); | ||||||
|  |         pousserBalle(); | ||||||
|  |     } | ||||||
|  |     setPositionBalle(attente); | ||||||
|  | 
 | ||||||
|  |     // Lancement des balles
 | ||||||
|  |     gotoPoint(X_LANCER, Y_LANCER, O_LANCER); | ||||||
|  |     setPositionBalle(ejection); | ||||||
|  |     setPropulsion(true); | ||||||
|  |     barilletSuivant(); | ||||||
|  |     pousserBalle(); | ||||||
|  |     for (int i = 0; i < NB_BALLES / 2 - 1; i++) { | ||||||
|  |         barilletSkip(); | ||||||
|  |         pousserBalle(); | ||||||
|  |     } | ||||||
|  |     setPropulsion(false); | ||||||
|  |     setPositionBalle(attente); | ||||||
| 
 | 
 | ||||||
|     stop(); |     stop(); | ||||||
| 
 | 
 | ||||||
|     /*  */ |  | ||||||
|     /* struct position dest3 = {1000, 1000, 0}; */ |  | ||||||
|     /* setDestination(&dest3); */ |  | ||||||
|     /*  */ |  | ||||||
|     /* sleep(5); */ |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     return NULL; |     return NULL; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -2,8 +2,41 @@ | ||||||
| #define __PARCOURS_H__ | #define __PARCOURS_H__ | ||||||
| 
 | 
 | ||||||
| #include <stdbool.h> | #include <stdbool.h> | ||||||
|  | #include <math.h> | ||||||
|  | 
 | ||||||
|  | #include "movement.h" | ||||||
| 
 | 
 | ||||||
| #define TEMPS_PARCOURS 100 | #define TEMPS_PARCOURS 100 | ||||||
|  | #define NB_BALLES 8 | ||||||
|  | 
 | ||||||
|  | #define X_RECUP_1 1160 | ||||||
|  | #define Y_RECUP_1 210 | ||||||
|  | #define O_RECUP_1 -M_PI | ||||||
|  | 
 | ||||||
|  | #define X_LANCER X_RECUP_1 | ||||||
|  | #define Y_LANCER Y_RECUP_1 + 100 | ||||||
|  | #define O_LANCER 3 * M_PI_4 | ||||||
|  | 
 | ||||||
|  | #define X_RECUP_2 610 | ||||||
|  | #define Y_RECUP_2 50 | ||||||
|  | // ↑
 | ||||||
|  | #define O_RECUP_2 -M_PI_2 | ||||||
|  | 
 | ||||||
|  | #define X_EVIT X_RECUP_2 | ||||||
|  | #define Y_EVIT 1000 | ||||||
|  | #define O_EVIT ANGLE_INSIGNIFIANT | ||||||
|  | 
 | ||||||
|  | #define X_ABEILLE 210 | ||||||
|  | #define Y_ABEILLE 50 | ||||||
|  | // ↑
 | ||||||
|  | #define O_ABEILLE -M_PI_2 | ||||||
|  | 
 | ||||||
|  | #define X_USE 800 | ||||||
|  | // ↑
 | ||||||
|  | #define Y_USE 100 | ||||||
|  | // ↑
 | ||||||
|  | #define O_USE 0 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| void configureParcours(); | void configureParcours(); | ||||||
| void prepareParcours(bool orange); | void prepareParcours(bool orange); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue