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
- Committer:
- bbbobbbieo
- Date:
- 2015-03-26
- Revision:
- 6:ed97e4324202
- Parent:
- 4:18f5328ff5a3
- Child:
- 7:f21986164bf1
File content as of revision 6:ed97e4324202:
//#include "mbed.h" #include "TFC.h" #include <iostream> #include <stdio.h> //#include "serialib.h" const float AGGRESSIVE = .55; const float MODERATE =.48; const float CONSERVATIVE =.39; const float STOP =0; const float PROTECTION_THRESHOLD_UPPER =.7; const float PROTECTION_THRESHOLD_LOWER =-.7; const float TURN_FORWARD_ACCEL =0.045; const float TURN_BACKWARD_ACCEL =0.025; const float SERVO_CAN_MOVE_IN_ONE_FRAME =0.1; const float SERVO_MAX =.5; const int BLACK_THRESHOLD =63; const int LINE_SCAN_LENGTH =128; DigitalOut myled(LED1); int main() { //run this before anything TFC_Init(); //variables float current_servo_position = 0; float previous_servo_position = 0; float current_left_motor_speed = 0; float current_right_motor_speed = 0; float proportional = 0; float last_proportional = 0; float integral = 0; float derivative = 0; float output = 0; // gains on prop, int, der // subject to change, need to fine tune float kp = 1.8960; float ki = 0.6170; float kd = 1.5590; bool rear_motor_enable_flag = true; bool linescan_ping_pong = false; bool linescan_enable = true; int black_values_list[LINE_SCAN_LENGTH]; int black_value_count = 0; int black_center_value = 0; int sum_black = 0; int violence_level = 0; int accelList[3]; int lastAccessed = 0; int centers_List[50]; int center_now = 63; int center_past_1 = 63; int center_past_2 = 63; int center_past_3 = 63; int center_past_4 = 63; //int best_guess_center = 64; int position = 0; int set_point = 63; int previous_error = 0; int error = 0; for(int i = 0; i < 50; i++) centers_List[i] = 63; float left_counter =0; float right_counter =0; bool turn_left=false; bool turn_right=false; //servo is offset zero by some bullshit number float bullshit_offset = .074; // major loop while(1) { // initial motor stuff if(rear_motor_enable_flag) { TFC_HBRIDGE_ENABLE; // checking behavior level violence_level = int(TFC_GetDIP_Switch()); if (violence_level==3) { current_left_motor_speed = -(AGGRESSIVE); current_right_motor_speed = AGGRESSIVE; } else if (violence_level==2) { current_left_motor_speed = -(MODERATE); current_right_motor_speed = (MODERATE); } else if (violence_level==1) { current_left_motor_speed = -(CONSERVATIVE); current_right_motor_speed = CONSERVATIVE; } else if (violence_level==0) { current_left_motor_speed = STOP; current_right_motor_speed = STOP; } else { current_left_motor_speed = STOP; current_right_motor_speed = STOP; } // protection block if(current_left_motor_speed >= PROTECTION_THRESHOLD_UPPER) current_left_motor_speed= PROTECTION_THRESHOLD_UPPER; if(current_right_motor_speed >= PROTECTION_THRESHOLD_UPPER) current_right_motor_speed = PROTECTION_THRESHOLD_UPPER; if(current_left_motor_speed <= PROTECTION_THRESHOLD_LOWER) current_left_motor_speed = PROTECTION_THRESHOLD_LOWER; if(current_right_motor_speed <= PROTECTION_THRESHOLD_LOWER) current_right_motor_speed = PROTECTION_THRESHOLD_LOWER; TFC_SetMotorPWM(current_left_motor_speed, current_right_motor_speed); }// end motor enabled else { TFC_HBRIDGE_DISABLE; }// end motor disabled // camera stuff if (linescan_enable) { if (TFC_LineScanImageReady !=0) { if (linescan_ping_pong) { //checking channel 0 //checking center pixel, displays aprox value on leds uint8_t shitnum = 1; // checking for center line (single line) for (uint16_t i=15; i<113; i++) { if ((*(TFC_LineScanImage0+i) < 450)) { black_values_list[black_value_count] = i; black_value_count++; } } for(int i=0; i<black_value_count; i++) { sum_black += black_values_list[i]; } //update history center_past_4= center_past_3; center_past_3= center_past_2; center_past_2= center_past_1; center_past_1= center_now; //if (black_value_count>2) center_now = sum_black / black_value_count; uint8_t num = 0; if(center_now > 15 && center_now < 27) num = 1; else if(center_now >= 27 && center_now < 54) num = 2; else if(center_now > 60 && center_now < 70) num = 15; else if(center_now >= 54 && center_now < 81) num = 4; else if(center_now >= 81 && center_now < 113) num = 8; else num = 0; // get rid of garbage data sets if (black_value_count<2) num = 0; TFC_SetBatteryLED(num); // best guess of center based on weighted average of history black_center_value = center_now; // turn left // hit wall a little bit on the right if (num==8 and right_counter <.2 ) { //turn away a little bit for each frame that is wall if (left_counter >-.5) left_counter -=.1; turn_left=true; turn_right=false; } // turn left real hard // wall is close to center on right if (num==4 and right_counter <.2) { left_counter=-0.56; turn_left=true; turn_right=false; } // turn right // hit wall a little bit on the left else if (num==1 and left_counter >-.2) { //turn away a little bit for each frame that is wall if (right_counter <.5) right_counter +=.1; turn_left=false; turn_right=true; } // turn left hard // wall is close to center on left else if (num==2 and left_counter >-.2) { right_counter =.56; turn_left=false; turn_right=true; } // going straight yesssss else if (turn_right == false and turn_left == false) { TFC_SetServo(0,(0.0+ bullshit_offset)); } else{} //dealwiththeshit // set servo and motors according to how much left we need to turn if(turn_left) { turn_right = false; TFC_SetServo(0,left_counter); // normalize to center each frame left_counter += .01; if (left_counter > (0+ bullshit_offset)) turn_left = false; TFC_SetMotorPWM(current_left_motor_speed+(.1*left_counter), current_right_motor_speed+(.3*left_counter)); } // set servo and motors according to how much right we need to turn if(turn_right) { turn_left =false; TFC_SetServo(0,right_counter); // normalize to center each frame right_counter -= .01; if (right_counter < (0+ bullshit_offset)) turn_right = false; TFC_SetMotorPWM(current_left_motor_speed-(.3*right_counter), current_right_motor_speed-(.1*right_counter)); } // clearing values for next image processing round black_value_count = 0; sum_black = 0; // end image processing linescan_ping_pong = false; } // end checking channel 0 else { //checking channel 1 linescan_ping_pong = true; } TFC_LineScanImageReady = 0; // since we used it, we reset the flag }// end imageready }// end linescan stuff } // end major loop }// end main