ARES
/
Timer
Time is good
Fork of Robot2016_2-0 by
main.cpp@27:ae68960316f1, 2016-01-21 (annotated)
- Committer:
- IceTeam
- Date:
- Thu Jan 21 14:25:03 2016 +0000
- Revision:
- 27:ae68960316f1
- Parent:
- 25:6c5c453602ff
- Child:
- 28:142ebc5410f3
Test robot aller-retour avec un obstacle et mpc=75
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
sype | 0:ad9600df4a70 | 1 | #include "Odometry.h" |
IceTeam | 17:e32b4b54fc04 | 2 | /** Dependencies : |
IceTeam | 17:e32b4b54fc04 | 3 | Map/Point.h |
IceTeam | 17:e32b4b54fc04 | 4 | Map/define.h |
IceTeam | 17:e32b4b54fc04 | 5 | Map/Obstacles/Obstacle.h |
IceTeam | 19:b2f3757fd7ee | 6 | |
IceTeam | 19:b2f3757fd7ee | 7 | Test en cours : |
IceTeam | 19:b2f3757fd7ee | 8 | * Un obstacle seulement |
IceTeam | 19:b2f3757fd7ee | 9 | * Radius du robot réduit à 1 (defines.cpp) |
IceTeam | 19:b2f3757fd7ee | 10 | * Nombreux |
IceTeam | 17:e32b4b54fc04 | 11 | */ |
IceTeam | 13:5355aed288b0 | 12 | #include "Map/Map.h" |
sype | 0:ad9600df4a70 | 13 | |
sype | 0:ad9600df4a70 | 14 | #define dt 10000 |
sype | 10:ae3178aa94e9 | 15 | #define ATTENTE 0 |
sype | 10:ae3178aa94e9 | 16 | #define GO 1 |
sype | 10:ae3178aa94e9 | 17 | #define STOP 2 |
sype | 0:ad9600df4a70 | 18 | |
sype | 10:ae3178aa94e9 | 19 | InterruptIn mybutton(USER_BUTTON); |
sype | 10:ae3178aa94e9 | 20 | DigitalIn button(USER_BUTTON); |
sype | 2:abdf8c6823a1 | 21 | DigitalOut led(LED1); |
sype | 0:ad9600df4a70 | 22 | Ticker ticker; |
sype | 10:ae3178aa94e9 | 23 | //Serial pc(USBTX, USBRX); |
sype | 10:ae3178aa94e9 | 24 | Serial pc(PA_9, PA_10); |
IceTeam | 21:077bc7634b90 | 25 | Serial logger (PA_9, PA_10); |
sype | 10:ae3178aa94e9 | 26 | RoboClaw roboclaw(460800, PA_11, PA_12); |
sype | 10:ae3178aa94e9 | 27 | Odometry odo(63.2, 63.3, 252, 4096, roboclaw); |
sype | 10:ae3178aa94e9 | 28 | |
sype | 10:ae3178aa94e9 | 29 | int i = 0; |
sype | 0:ad9600df4a70 | 30 | |
sype | 0:ad9600df4a70 | 31 | void update_main(void); |
sype | 2:abdf8c6823a1 | 32 | void init(void); |
sype | 10:ae3178aa94e9 | 33 | void pressed(void); |
sype | 10:ae3178aa94e9 | 34 | void unpressed(void); |
sype | 0:ad9600df4a70 | 35 | |
IceTeam | 9:e39b218ab20d | 36 | /** Debut du programme */ |
sype | 0:ad9600df4a70 | 37 | int main(void) |
sype | 10:ae3178aa94e9 | 38 | { |
sype | 10:ae3178aa94e9 | 39 | double angle_v = 2*PI/5; |
sype | 10:ae3178aa94e9 | 40 | double distance_v = 200.0; |
IceTeam | 13:5355aed288b0 | 41 | std::vector<SimplePoint> path; |
IceTeam | 13:5355aed288b0 | 42 | Map map; |
IceTeam | 13:5355aed288b0 | 43 | |
sype | 2:abdf8c6823a1 | 44 | init(); |
IceTeam | 18:0f1fefe78266 | 45 | //Construction des obstacles |
IceTeam | 17:e32b4b54fc04 | 46 | map.build(); |
IceTeam | 27:ae68960316f1 | 47 | map.AStar(0, 1000, 1400, 1000, 75); |
IceTeam | 14:a394e27b8cb2 | 48 | path = map.path; |
IceTeam | 14:a394e27b8cb2 | 49 | |
IceTeam | 18:0f1fefe78266 | 50 | for(int i=0; i<path.size();i++) { |
IceTeam | 13:5355aed288b0 | 51 | odo.GotoXYT(path[i].x, path[i].y, 0); |
IceTeam | 18:0f1fefe78266 | 52 | } |
IceTeam | 27:ae68960316f1 | 53 | |
IceTeam | 27:ae68960316f1 | 54 | map.AStar(0, 1000, 0, 1000, 75); |
IceTeam | 27:ae68960316f1 | 55 | path = map.path; |
IceTeam | 27:ae68960316f1 | 56 | |
IceTeam | 27:ae68960316f1 | 57 | for(int i=0; i<path.size();i++) { |
IceTeam | 27:ae68960316f1 | 58 | odo.GotoXYT(path[i].x, path[i].y, PI); |
IceTeam | 27:ae68960316f1 | 59 | } |
IceTeam | 27:ae68960316f1 | 60 | |
IceTeam | 13:5355aed288b0 | 61 | //odo.GotoXYT(500, 50, 0); |
sype | 10:ae3178aa94e9 | 62 | //odo.GotoXYT(200, 0, 0); |
sype | 10:ae3178aa94e9 | 63 | //odo.GotoXYT(0, 0, 0); |
sype | 10:ae3178aa94e9 | 64 | |
sype | 10:ae3178aa94e9 | 65 | //odo.GotoThet(-PI/2); |
sype | 10:ae3178aa94e9 | 66 | wait(2000); |
sype | 10:ae3178aa94e9 | 67 | //odo.GotoXYT(2250,500,0); |
sype | 2:abdf8c6823a1 | 68 | while(1); |
sype | 2:abdf8c6823a1 | 69 | } |
sype | 2:abdf8c6823a1 | 70 | |
sype | 2:abdf8c6823a1 | 71 | void init(void) |
sype | 0:ad9600df4a70 | 72 | { |
sype | 10:ae3178aa94e9 | 73 | pc.baud(9600); |
sype | 2:abdf8c6823a1 | 74 | pc.printf("Hello from main !\n\r"); |
sype | 10:ae3178aa94e9 | 75 | wait_ms(500); |
sype | 10:ae3178aa94e9 | 76 | |
IceTeam | 27:ae68960316f1 | 77 | odo.setPos(0, 1000, 0); |
sype | 2:abdf8c6823a1 | 78 | roboclaw.ForwardM1(ADR, 0); |
sype | 2:abdf8c6823a1 | 79 | roboclaw.ForwardM2(ADR, 0); |
sype | 10:ae3178aa94e9 | 80 | |
sype | 10:ae3178aa94e9 | 81 | while(button); |
sype | 10:ae3178aa94e9 | 82 | wait(1); |
sype | 10:ae3178aa94e9 | 83 | mybutton.fall(&pressed); |
sype | 10:ae3178aa94e9 | 84 | mybutton.rise(&unpressed); |
sype | 0:ad9600df4a70 | 85 | ticker.attach_us(&update_main,dt); // 100 Hz |
sype | 0:ad9600df4a70 | 86 | } |
sype | 0:ad9600df4a70 | 87 | |
sype | 0:ad9600df4a70 | 88 | void update_main(void) |
sype | 0:ad9600df4a70 | 89 | { |
sype | 0:ad9600df4a70 | 90 | odo.update_odo(); |
sype | 10:ae3178aa94e9 | 91 | //pc.printf("X : %3.2f\tY : %3.2f\tTheta : %3.2f\n\r", odo.getX(), odo.getY(), odo.getTheta()*180/PI); |
sype | 2:abdf8c6823a1 | 92 | //if(pc.readable()) if(pc.getc()=='l') led = !led; |
sype | 0:ad9600df4a70 | 93 | } |
sype | 10:ae3178aa94e9 | 94 | |
sype | 10:ae3178aa94e9 | 95 | void pressed(void) |
sype | 10:ae3178aa94e9 | 96 | { |
sype | 10:ae3178aa94e9 | 97 | if(i==0) { |
sype | 10:ae3178aa94e9 | 98 | roboclaw.ForwardM1(ADR, 0); |
sype | 10:ae3178aa94e9 | 99 | roboclaw.ForwardM2(ADR, 0); |
sype | 10:ae3178aa94e9 | 100 | //pc.printf("X : %3.2f\tY : %3.2f\tTheta : %3.2f\n\r", odo.getX(), odo.getY(), odo.getTheta()*180/PI); |
sype | 10:ae3178aa94e9 | 101 | i++; |
sype | 10:ae3178aa94e9 | 102 | } |
sype | 10:ae3178aa94e9 | 103 | } |
sype | 10:ae3178aa94e9 | 104 | |
sype | 10:ae3178aa94e9 | 105 | void unpressed(void) |
sype | 10:ae3178aa94e9 | 106 | { |
sype | 10:ae3178aa94e9 | 107 | if(i==1) { |
sype | 10:ae3178aa94e9 | 108 | i--; |
sype | 10:ae3178aa94e9 | 109 | } |
sype | 10:ae3178aa94e9 | 110 | } |