Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
main.cpp@13:34f7f783ad24, 2016-02-05 (annotated)
- Committer:
- mborchers
- Date:
- Fri Feb 05 16:06:44 2016 +0000
- Revision:
- 13:34f7f783ad24
- Parent:
- 12:221c9e02ea96
L?ngsregelung ausgelagert
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
mborchers | 0:8a6003b8bb5b | 1 | #include <mbed.h> |
mborchers | 0:8a6003b8bb5b | 2 | #include "rtos.h" |
mborchers | 0:8a6003b8bb5b | 3 | #include "Periphery/SupportSystem.h" |
mborchers | 0:8a6003b8bb5b | 4 | #include "Misc/SystemTimer.h" |
mborchers | 3:391c4639bc7d | 5 | #include "Controller/QuadratureController.h" |
mborchers | 13:34f7f783ad24 | 6 | #include "Controller/MachineDirectionController.h" |
mborchers | 0:8a6003b8bb5b | 7 | |
mborchers | 0:8a6003b8bb5b | 8 | #define PI 3.14159265 |
mborchers | 0:8a6003b8bb5b | 9 | |
mborchers | 13:34f7f783ad24 | 10 | Serial serialXbee(p28,p27), serialMinnow(p13, p14); |
mborchers | 13:34f7f783ad24 | 11 | PwmOut drivePWM(p22), steerPWM(p21); |
mborchers | 0:8a6003b8bb5b | 12 | I2C i2c(p9, p10); |
mborchers | 0:8a6003b8bb5b | 13 | |
mborchers | 13:34f7f783ad24 | 14 | DigitalOut serialLED(LED1), ledTwo(LED2), ledThree(LED3), heartbeatLED(LED4); |
mborchers | 0:8a6003b8bb5b | 15 | |
mborchers | 13:34f7f783ad24 | 16 | DigitalIn buttonOne(p25), buttonTwo(p26), buttonThree(p29), buttonFour(p30); |
mborchers | 0:8a6003b8bb5b | 17 | |
mborchers | 0:8a6003b8bb5b | 18 | IMU_RegisterDataBuffer_t *IMU_registerDataBuffer; |
mborchers | 0:8a6003b8bb5b | 19 | RadioDecoder_RegisterDataBuffer_t *RadioDecoder_registerDataBuffer; |
mborchers | 0:8a6003b8bb5b | 20 | |
mborchers | 4:f0be27a5a83a | 21 | QuadratureController *quadratureController; |
mborchers | 13:34f7f783ad24 | 22 | MachineDirectionController *machineDirectionController; |
mborchers | 4:f0be27a5a83a | 23 | |
mborchers | 0:8a6003b8bb5b | 24 | // Queues von der Bahnplanung |
mborchers | 0:8a6003b8bb5b | 25 | Queue<float, 2> quadrature_queue; |
mborchers | 0:8a6003b8bb5b | 26 | Queue<float, 2> machine_direction_queue; |
mborchers | 0:8a6003b8bb5b | 27 | float steering_angle_minnow_queue; |
mborchers | 0:8a6003b8bb5b | 28 | float velocity_minnow_queue; |
mborchers | 0:8a6003b8bb5b | 29 | |
mborchers | 0:8a6003b8bb5b | 30 | |
mborchers | 0:8a6003b8bb5b | 31 | // Queues von dem Maussensor |
mborchers | 0:8a6003b8bb5b | 32 | Queue<float, 2> imu_queue_velocity; |
mborchers | 0:8a6003b8bb5b | 33 | Queue<float, 2> imu_queue_steering_angle; |
mborchers | 0:8a6003b8bb5b | 34 | float steering_angle_imu_queue; |
mborchers | 0:8a6003b8bb5b | 35 | float velocity_imu_queue; |
mborchers | 0:8a6003b8bb5b | 36 | |
mborchers | 10:f92664a22d02 | 37 | void hearbeat_thread(void const *args); |
mborchers | 10:f92664a22d02 | 38 | |
mborchers | 0:8a6003b8bb5b | 39 | void serial_thread(void const *args) { |
mborchers | 10:f92664a22d02 | 40 | size_t length = 20; |
mborchers | 10:f92664a22d02 | 41 | char receive_buffer[length]; |
mborchers | 10:f92664a22d02 | 42 | char* ptr = (char*) receive_buffer; |
mborchers | 10:f92664a22d02 | 43 | char* end = ptr + length; |
mborchers | 10:f92664a22d02 | 44 | char c, x = 22; |
mborchers | 7:c5940ae7773a | 45 | float f; |
mborchers | 0:8a6003b8bb5b | 46 | while (true) { |
mborchers | 10:f92664a22d02 | 47 | if (ptr != end) { |
mborchers | 10:f92664a22d02 | 48 | c = serialMinnow.getc(); |
mborchers | 10:f92664a22d02 | 49 | *ptr++ = c; |
mborchers | 10:f92664a22d02 | 50 | } else { |
mborchers | 10:f92664a22d02 | 51 | ptr = (char*)receive_buffer; |
mborchers | 7:c5940ae7773a | 52 | } |
mborchers | 13:34f7f783ad24 | 53 | serialLED = !serialLED; |
mborchers | 10:f92664a22d02 | 54 | |
mborchers | 12:221c9e02ea96 | 55 | if (c == '\r') { |
mborchers | 13:34f7f783ad24 | 56 | sscanf(receive_buffer, "[%c]=%f\r", &x, &f); |
mborchers | 12:221c9e02ea96 | 57 | ptr = (char*)receive_buffer; |
mborchers | 12:221c9e02ea96 | 58 | } |
mborchers | 10:f92664a22d02 | 59 | |
mborchers | 10:f92664a22d02 | 60 | if (x == 'v') { |
mborchers | 12:221c9e02ea96 | 61 | machine_direction_queue.put(&f); |
mborchers | 12:221c9e02ea96 | 62 | |
mborchers | 13:34f7f783ad24 | 63 | ledTwo = true; |
mborchers | 10:f92664a22d02 | 64 | // Buffer wieder auf Anfang setzen |
mborchers | 10:f92664a22d02 | 65 | ptr = (char*)receive_buffer; |
mborchers | 10:f92664a22d02 | 66 | x = 22; |
mborchers | 10:f92664a22d02 | 67 | } else if (x == 'g') { |
mborchers | 13:34f7f783ad24 | 68 | f = -1*f; |
mborchers | 12:221c9e02ea96 | 69 | quadrature_queue.put(&f); |
mborchers | 13:34f7f783ad24 | 70 | ledThree = true; |
mborchers | 10:f92664a22d02 | 71 | // Buffer wieder auf Anfang setzen |
mborchers | 10:f92664a22d02 | 72 | ptr = (char*)receive_buffer; |
mborchers | 10:f92664a22d02 | 73 | x = 22; |
mborchers | 10:f92664a22d02 | 74 | } |
mborchers | 10:f92664a22d02 | 75 | |
mborchers | 7:c5940ae7773a | 76 | //Thread::wait(100); |
mborchers | 0:8a6003b8bb5b | 77 | } |
mborchers | 0:8a6003b8bb5b | 78 | } |
mborchers | 0:8a6003b8bb5b | 79 | |
mborchers | 13:34f7f783ad24 | 80 | void redirect_machine_direction_controller(void const *args) { |
mborchers | 13:34f7f783ad24 | 81 | machineDirectionController->cylic_control(); |
mborchers | 0:8a6003b8bb5b | 82 | } |
mborchers | 0:8a6003b8bb5b | 83 | |
mborchers | 4:f0be27a5a83a | 84 | void redirect_quadrature_controller(void const *args) { |
mborchers | 4:f0be27a5a83a | 85 | quadratureController->cylic_control(); |
mborchers | 4:f0be27a5a83a | 86 | } |
mborchers | 4:f0be27a5a83a | 87 | |
mborchers | 0:8a6003b8bb5b | 88 | int main() { |
mborchers | 0:8a6003b8bb5b | 89 | serialMinnow.baud(115200); |
mborchers | 0:8a6003b8bb5b | 90 | |
mborchers | 0:8a6003b8bb5b | 91 | drivePWM.period_ms(20); |
mborchers | 0:8a6003b8bb5b | 92 | steerPWM.period_ms(20); |
mborchers | 0:8a6003b8bb5b | 93 | |
mborchers | 0:8a6003b8bb5b | 94 | SystemTimer *millis = new SystemTimer(); |
mborchers | 0:8a6003b8bb5b | 95 | |
mborchers | 0:8a6003b8bb5b | 96 | SupportSystem *supportSystem = new SupportSystem(0x80, &i2c); |
mborchers | 3:391c4639bc7d | 97 | |
torstenwylegala | 6:aa27bc8c58f5 | 98 | quadratureController = new QuadratureController(&steerPWM, &quadrature_queue, &imu_queue_steering_angle); |
mborchers | 13:34f7f783ad24 | 99 | machineDirectionController = new MachineDirectionController(&drivePWM, &machine_direction_queue, &imu_queue_velocity); |
mborchers | 0:8a6003b8bb5b | 100 | |
mborchers | 1:7eddde9fba60 | 101 | Thread machineDirectionControl(serial_thread); |
mborchers | 10:f92664a22d02 | 102 | Thread hearbeatThread(hearbeat_thread); |
mborchers | 0:8a6003b8bb5b | 103 | |
mborchers | 13:34f7f783ad24 | 104 | RtosTimer machine_direction_control_timer(redirect_quadrature_controller); |
mborchers | 4:f0be27a5a83a | 105 | RtosTimer quadrature_control_timer(redirect_quadrature_controller); |
mborchers | 0:8a6003b8bb5b | 106 | |
mborchers | 0:8a6003b8bb5b | 107 | // Konfiguration AMF-IMU |
mborchers | 0:8a6003b8bb5b | 108 | // [0]: Conversation Factor |
mborchers | 0:8a6003b8bb5b | 109 | // [1]: Sensor Position X |
mborchers | 0:8a6003b8bb5b | 110 | // [2]: Sensor Position Y |
mborchers | 0:8a6003b8bb5b | 111 | // [3]: Sensor Position Angle |
torstenwylegala | 5:4319a748181a | 112 | float configData[4] = {0.002751114f, 167.0f, 0.0f, 271.5f}; |
mborchers | 13:34f7f783ad24 | 113 | |
mborchers | 13:34f7f783ad24 | 114 | supportSystem->writeImuConfig(configData); |
mborchers | 0:8a6003b8bb5b | 115 | |
mborchers | 0:8a6003b8bb5b | 116 | bool timer_started = false; |
mborchers | 0:8a6003b8bb5b | 117 | |
mborchers | 12:221c9e02ea96 | 118 | steering_angle_minnow_queue = 0; |
mborchers | 2:bf739d7d9f8f | 119 | quadrature_queue.put(&steering_angle_minnow_queue); |
mborchers | 2:bf739d7d9f8f | 120 | |
mborchers | 12:221c9e02ea96 | 121 | velocity_minnow_queue = 0; |
mborchers | 2:bf739d7d9f8f | 122 | machine_direction_queue.put(&velocity_minnow_queue); |
mborchers | 12:221c9e02ea96 | 123 | |
mborchers | 12:221c9e02ea96 | 124 | machine_direction_control_timer.start(10); |
mborchers | 12:221c9e02ea96 | 125 | quadrature_control_timer.start(10); |
mborchers | 0:8a6003b8bb5b | 126 | |
mborchers | 0:8a6003b8bb5b | 127 | while(true) { |
mborchers | 0:8a6003b8bb5b | 128 | IMU_registerDataBuffer = supportSystem->getImuRegisterDataBuffer(); |
mborchers | 0:8a6003b8bb5b | 129 | RadioDecoder_registerDataBuffer = supportSystem->getRadioDecoderRegisterDataBuffer(); |
mborchers | 0:8a6003b8bb5b | 130 | |
mborchers | 0:8a6003b8bb5b | 131 | uint16_t rc_percentage = RadioDecoder_registerDataBuffer->channelActiveTime[0]; |
mborchers | 0:8a6003b8bb5b | 132 | uint8_t rc_valid = RadioDecoder_registerDataBuffer->channelValid[0]; |
mborchers | 0:8a6003b8bb5b | 133 | |
mborchers | 0:8a6003b8bb5b | 134 | uint16_t drive_percentage = RadioDecoder_registerDataBuffer->channelActiveTime[1]; |
mborchers | 0:8a6003b8bb5b | 135 | uint8_t drive_valid = RadioDecoder_registerDataBuffer->channelValid[1]; |
mborchers | 0:8a6003b8bb5b | 136 | |
mborchers | 0:8a6003b8bb5b | 137 | uint16_t steer_percentage = RadioDecoder_registerDataBuffer->channelActiveTime[2]; |
mborchers | 0:8a6003b8bb5b | 138 | uint8_t steer_valid = RadioDecoder_registerDataBuffer->channelValid[2]; |
mborchers | 0:8a6003b8bb5b | 139 | |
mborchers | 0:8a6003b8bb5b | 140 | |
mborchers | 0:8a6003b8bb5b | 141 | if (rc_percentage > (uint16_t) 1800 && rc_valid != 0) { |
mborchers | 0:8a6003b8bb5b | 142 | // oben => Wettbewerb |
mborchers | 0:8a6003b8bb5b | 143 | supportSystem->setLightManagerRemoteLight(false, true); |
mborchers | 0:8a6003b8bb5b | 144 | if (!timer_started) { |
mborchers | 0:8a6003b8bb5b | 145 | timer_started = true; |
mborchers | 0:8a6003b8bb5b | 146 | machine_direction_control_timer.start(10); |
mborchers | 0:8a6003b8bb5b | 147 | quadrature_control_timer.start(10); |
mborchers | 0:8a6003b8bb5b | 148 | } |
mborchers | 0:8a6003b8bb5b | 149 | } else if (rc_percentage > (uint16_t) 1200 && rc_valid != 0) { |
mborchers | 0:8a6003b8bb5b | 150 | // unten => RC-Wettbewerb |
mborchers | 0:8a6003b8bb5b | 151 | supportSystem->setLightManagerRemoteLight(true, true); |
mborchers | 0:8a6003b8bb5b | 152 | if (drive_valid) { |
mborchers | 0:8a6003b8bb5b | 153 | drivePWM.pulsewidth_us(drive_percentage); |
mborchers | 0:8a6003b8bb5b | 154 | } |
mborchers | 0:8a6003b8bb5b | 155 | if (steer_valid) { |
mborchers | 0:8a6003b8bb5b | 156 | steerPWM.pulsewidth_us(steer_percentage); |
mborchers | 0:8a6003b8bb5b | 157 | } |
mborchers | 0:8a6003b8bb5b | 158 | if (timer_started) { |
mborchers | 0:8a6003b8bb5b | 159 | timer_started = false; |
mborchers | 0:8a6003b8bb5b | 160 | machine_direction_control_timer.stop(); |
mborchers | 0:8a6003b8bb5b | 161 | quadrature_control_timer.stop(); |
mborchers | 0:8a6003b8bb5b | 162 | } |
mborchers | 0:8a6003b8bb5b | 163 | } else if (rc_percentage > (uint16_t) 800 && rc_valid != 0) { |
mborchers | 0:8a6003b8bb5b | 164 | // mitte => RC-Training |
mborchers | 0:8a6003b8bb5b | 165 | supportSystem->setLightManagerRemoteLight(true, true); |
mborchers | 0:8a6003b8bb5b | 166 | if (drive_valid) { |
mborchers | 0:8a6003b8bb5b | 167 | drivePWM.pulsewidth_us(drive_percentage); |
mborchers | 0:8a6003b8bb5b | 168 | } |
mborchers | 0:8a6003b8bb5b | 169 | if (steer_valid) { |
mborchers | 0:8a6003b8bb5b | 170 | steerPWM.pulsewidth_us(steer_percentage); |
mborchers | 0:8a6003b8bb5b | 171 | } |
mborchers | 0:8a6003b8bb5b | 172 | if (timer_started) { |
mborchers | 0:8a6003b8bb5b | 173 | timer_started = false; |
mborchers | 0:8a6003b8bb5b | 174 | machine_direction_control_timer.stop(); |
mborchers | 0:8a6003b8bb5b | 175 | quadrature_control_timer.stop(); |
mborchers | 0:8a6003b8bb5b | 176 | } |
mborchers | 0:8a6003b8bb5b | 177 | } |
mborchers | 0:8a6003b8bb5b | 178 | |
mborchers | 0:8a6003b8bb5b | 179 | velocity_imu_queue = IMU_registerDataBuffer->velocityXFilteredRegister; |
mborchers | 0:8a6003b8bb5b | 180 | imu_queue_velocity.put(&velocity_imu_queue); |
mborchers | 0:8a6003b8bb5b | 181 | |
mborchers | 0:8a6003b8bb5b | 182 | float radius = IMU_registerDataBuffer->velocityXFilteredRegister/IMU_registerDataBuffer->velocityAngularFilteredRegister; |
mborchers | 0:8a6003b8bb5b | 183 | |
mborchers | 0:8a6003b8bb5b | 184 | steering_angle_imu_queue = atan(0.205/radius)*180/PI; |
mborchers | 0:8a6003b8bb5b | 185 | imu_queue_steering_angle.put(&steering_angle_imu_queue); |
mborchers | 0:8a6003b8bb5b | 186 | |
mborchers | 0:8a6003b8bb5b | 187 | |
mborchers | 2:bf739d7d9f8f | 188 | //serialMinnow.printf("%ld, ", difference_millis); |
mborchers | 7:c5940ae7773a | 189 | //serialMinnow.printf("%f, ", velocity_minnow_queue); |
mborchers | 7:c5940ae7773a | 190 | //serialMinnow.printf("%f, ", steering_angle_minnow_queue); |
mborchers | 7:c5940ae7773a | 191 | //serialMinnow.printf("%d, ", IMU_registerDataBuffer->curveRadiusRegister); |
mborchers | 7:c5940ae7773a | 192 | //serialMinnow.printf("%f, ", IMU_registerDataBuffer->velocityAngularRegister); |
mborchers | 7:c5940ae7773a | 193 | //serialMinnow.printf("%f, ", IMU_registerDataBuffer->velocityAngularFilteredRegister); |
mborchers | 7:c5940ae7773a | 194 | //serialMinnow.printf("%f, ", IMU_registerDataBuffer->velocityXRegister); |
mborchers | 7:c5940ae7773a | 195 | //serialMinnow.printf("%f\r\n", IMU_registerDataBuffer->velocityXFilteredRegister); |
mborchers | 13:34f7f783ad24 | 196 | Thread::wait(10); |
mborchers | 0:8a6003b8bb5b | 197 | } |
mborchers | 0:8a6003b8bb5b | 198 | } |
mborchers | 10:f92664a22d02 | 199 | |
mborchers | 10:f92664a22d02 | 200 | void hearbeat_thread(void const *args) { |
mborchers | 10:f92664a22d02 | 201 | while(true) { |
mborchers | 13:34f7f783ad24 | 202 | heartbeatLED = !heartbeatLED; |
mborchers | 10:f92664a22d02 | 203 | Thread::wait(100); |
mborchers | 10:f92664a22d02 | 204 | } |
mborchers | 10:f92664a22d02 | 205 | } |