Robotics LAB DCMotor
Dependencies: mbed
Fork of Robotics_Lab_DCMotor by
Diff: main.cpp
- Revision:
- 3:0856a9fa97ec
- Parent:
- 2:9caf46a5fe5a
diff -r 9caf46a5fe5a -r 0856a9fa97ec main.cpp --- a/main.cpp Wed May 25 07:02:22 2016 +0000 +++ b/main.cpp Mon Mar 19 08:20:03 2018 +0000 @@ -1,23 +1,21 @@ -/*LAB_DCMotor*/ +/* LAB DCMotor */ #include "mbed.h" +//****************************************************************************** Define //The number will be compiled as type "double" in default //Add a "f" after the number can make it compiled as type "float" #define Ts 0.01f //period of timer1 (s) -#define Kp 0.0025f -#define Ki 0.008f + +//****************************************************************************** End of Define +//****************************************************************************** I/O +//PWM +//Dc motor PwmOut pwm1(D7); PwmOut pwm1n(D11); PwmOut pwm2(D8); PwmOut pwm2n(A3); -Serial bluetooth(D10,D2); -Serial pc(D1, D0); - -DigitalOut led1(A4); -DigitalOut led2(A5); - //Motor1 sensor InterruptIn HallA_1(A1); InterruptIn HallB_1(A2); @@ -25,175 +23,103 @@ InterruptIn HallA_2(D13); InterruptIn HallB_2(D12); -Ticker timer1; -void timer1_interrupt(void); -void CN_interrupt(void); +//LED +DigitalOut led1(A4); +DigitalOut led2(A5); -void init_TIMER(void); +//Timer Setting +Ticker timer; +//****************************************************************************** End of I/O + +//****************************************************************************** Functions +void init_timer(void); +void init_CN(void); void init_PWM(void); -void init_CN(void); -void init_err(void); - -int8_t stateA_1=0, stateB_1=0, stateA_2=0, stateB_2=0; -int8_t state_1 = 0, state_1_old = 0, state_2 = 0, state_2_old = 0; +void timer_interrupt(void); +void CN_interrupt(void); +//****************************************************************************** End of Functions -int v1Count = 0; -int v2Count = 0; +//****************************************************************************** Variables +// Servo +float servo_duty = 0.066; // 0.025~0.113(-90~+90) 0.069->0 degree +// motor 1 +int8_t HallA_state_1 = 0; +int8_t HallB_state_1 = 0; +int8_t motor_state_1 = 0; +int8_t motor_state_old_1 = 0; +int count_1 = 0; +float speed_1 = 0.0f; +float v_ref_1 = 80.0f; +float v_err_1 = 0.0f; +float v_ierr_1 = 0.0f; +float ctrl_output_1 = 0.0f; +float pwm1_duty = 0.0f; +//motor 2 +int8_t HallA_state_2 = 0; +int8_t HallB_state_2 = 0; +int8_t motor_state_2 = 0; +int8_t motor_state_old_2 = 0; +int count_2 = 0; +float speed_2 = 0.0f; +float v_ref_2 = 150.0f; +float v_err_2 = 0.0f; +float v_ierr_2 = 0.0f; +float ctrl_output_2 = 0.0f; +float pwm2_duty = 0.0f; +//****************************************************************************** End of Variables -float v1 = 0.0, v1_ref = 0.0; -float v1_err = 0.0, v1_ierr = 0.0, PIout_1 = 0.0, PIout_1_old = 0.0; -float v2 = 0.0, v2_ref = 0.0; -float v2_err = 0.0, v2_ierr = 0.0, PIout_2 = 0.0, PIout_2_old = 0.0; - -int main() { - - init_TIMER(); +//****************************************************************************** Main +int main() +{ + init_timer(); init_PWM(); init_CN(); - - bluetooth.baud(115200); //設定鮑率 - pc.baud(57600); - - - while(1) + while(1) { - if(pc.readable()) - { - bluetooth.putc(pc.getc()); - } - if(bluetooth.readable()) - { - pc.putc(bluetooth.getc()); - } } } +//****************************************************************************** End of Main -void timer1_interrupt(void) -{ - //Motor 1 - v1 = (float)v1Count * 100.0f / 12.0f * 60.0f / 29.0f; //unit: rpm - v1Count = 0; +//****************************************************************************** timer_interrupt +void timer_interrupt() +{ + // Motor1 + speed_1 = (float)count_1 * 100.0f / 12.0f * 60.0f / 29.0f; //rpm + count_1 = 0; + // Code for PI controller // - ///code for PI control/// - v1_err = v1_ref - v1; - v1_ierr = Ts*v1_err + v1_ierr; - PIout_1 = Kp*v1_err + Ki*v1_ierr; + /////////////////////////// - ///////////////////////// - - if(PIout_1 >= 0.5f)PIout_1 = 0.5f; - else if(PIout_1 <= -0.5f)PIout_1 = -0.5f; - pwm1.write(PIout_1 + 0.5f); + if(ctrl_output_1 >= 0.5f)ctrl_output_1 = 0.5f; + else if(ctrl_output_1 <= -0.5f)ctrl_output_1 = -0.5f; + pwm1_duty = ctrl_output_1 + 0.5f; + pwm1.write(pwm1_duty); TIM1->CCER |= 0x4; - - //Motor 2 - v2 = (float)v2Count * 100.0f / 12.0f * 60.0f / 29.0f; //unit: rpm - v2Count = 0; + // Motor2 + speed_2 = (float)count_2 * 100.0f / 12.0f * 60.0f / 29.0f; //rpm + count_2 = 0; + // Code for PI controller // - ///code for PI control/// - v2_err = v2_ref - v2; - v2_ierr = Ts*v2_err + v2_ierr; - PIout_2 = Kp*v2_err + Ki*v2_ierr; - - ///////////////////////// - - if(PIout_2 >= 0.5f)PIout_2 = 0.5f; - else if(PIout_2 <= -0.5f)PIout_2 = -0.5f; - pwm2.write(PIout_2 + 0.5f); - TIM1->CCER |= 0x40; + /////////////////////////// - switch(bluetooth.getc()) - { - case '1': - v1_ref = 30; - v2_ref = 30; - init_err(); - break; - case '2': - v1_ref = 40; - v2_ref = 40; - init_err(); - break; - case '3': - v1_ref = 50; - v2_ref = 50; - init_err(); - break; - case '4': - v1_ref = 60; - v2_ref = 60; - init_err(); - break; - case '5': - v1_ref = 70; - v2_ref = 70; - init_err(); - break; - case '6': - v1_ref = 80; - v2_ref = 80; - init_err(); - break; - case '7': - v1_ref = 100; - v2_ref = 100; - init_err(); - break; - case '8': - v1_ref = 0; - v2_ref = 0; - break; - } - - + if(ctrl_output_2 >= 0.5f)ctrl_output_2 = 0.5f; + else if(ctrl_output_2 <= -0.5f)ctrl_output_2 = -0.5f; + pwm2_duty = ctrl_output_2 + 0.5f; + pwm2.write(pwm2_duty); + TIM1->CCER |= 0x40; } +//****************************************************************************** End of timer_interrupt -void CN_interrupt(void) +//****************************************************************************** CN_interrupt +void CN_interrupt() { - //Motor 1 - stateA_1 = HallA_1.read(); - stateB_1 = HallB_1.read(); - - ///code for state determination/// - if(stateA_1==0&&stateB_1==0){ - state_1 = 1;} - else if(stateA_1==0&&stateB_1==1){ - state_1 = 2;} - else if(stateA_1==1&&stateB_1==1){ - state_1 = 3;} - else if(stateA_1==1&&stateB_1==0){ - state_1 = 4;} - - if(state_1 == 1) - { - if(state_1-state_1_old == -3) - v1Count=v1Count+1; - else if(state_1-state_1_old == -1) - v1Count=v1Count-1; - } - else if(state_1 == 2) - { - if(state_1-state_1_old == 1) - v1Count=v1Count+1; - else if(state_1-state_1_old == -1) - v1Count=v1Count-1; - } - else if(state_1 == 3) - { - if(state_1-state_1_old == 1) - v1Count=v1Count+1; - else if(state_1-state_1_old == -1) - v1Count=v1Count-1; - } - else if(state_1 == 4) - { - if(state_1-state_1_old == 1) - v1Count=v1Count+1; - else if(state_1-state_1_old == 3) - v1Count=v1Count-1; - } - state_1_old = state_1; + // Motor1 + // Read the current status of hall sensor + HallA_state_1 = HallA_1.read(); + HallB_state_1 = HallB_1.read(); + + ///code for state determination/// ////////////////////////////////// @@ -202,51 +128,14 @@ //v1Count +1 //Inverse //v1Count -1 - - - //Motor 2 - stateA_2 = HallA_2.read(); - stateB_2 = HallB_2.read(); - + + // Motor2 + // Read the current status of hall sensor + HallA_state_2 = HallA_2.read(); + HallB_state_2 = HallB_2.read(); + ///code for state determination/// - if(stateA_2==0&&stateB_2==0){ - state_2 = 1;} - else if(stateA_2==0&&stateB_2==1){ - state_2 = 2;} - else if(stateA_2==1&&stateB_2==1){ - state_2 = 3;} - else if(stateA_2==1&&stateB_2==0){ - state_2 = 4;} - if(state_2 == 1) - { - if(state_2-state_2_old == -3) - v2Count=v2Count+1; - else if(state_2-state_2_old == -1) - v2Count=v2Count-1; - } - else if(state_2 == 2) - { - if(state_2-state_2_old == 1) - v2Count=v2Count+1; - else if(state_2-state_2_old == -1) - v2Count=v2Count-1; - } - else if(state_2 == 3) - { - if(state_2-state_2_old == 1) - v2Count=v2Count+1; - else if(state_2-state_2_old == -1) - v2Count=v2Count-1; - } - else if(state_2 == 4) - { - if(state_2-state_2_old == 1) - v2Count=v2Count+1; - else if(state_2-state_2_old == 3) - v2Count=v2Count-1; - } - state_2_old = state_2; ////////////////////////////////// @@ -255,13 +144,17 @@ //Inverse //v2Count -1 } +//****************************************************************************** End of CN_interrupt -void init_TIMER(void) +//****************************************************************************** init_timer +void init_timer() { - timer1.attach_us(&timer1_interrupt, 10000);//10ms interrupt period (100 Hz) -} - -void init_PWM(void) + timer.attach_us(&timer_interrupt, 10000);//10ms interrupt period (100 Hz) +} +//****************************************************************************** End of init_timer + +//****************************************************************************** init_PWM +void init_PWM() { pwm1.period_us(50); pwm1.write(0.5); @@ -271,26 +164,27 @@ pwm2.write(0.5); TIM1->CCER |= 0x40; } +//****************************************************************************** End of init_PWM -void init_CN(void) +//****************************************************************************** init_CN +void init_CN() { + // Motor1 HallA_1.rise(&CN_interrupt); HallA_1.fall(&CN_interrupt); HallB_1.rise(&CN_interrupt); HallB_1.fall(&CN_interrupt); + HallA_state_1 = HallA_1.read(); + HallB_state_1 = HallB_1.read(); + + // Motor2 HallA_2.rise(&CN_interrupt); HallA_2.fall(&CN_interrupt); HallB_2.rise(&CN_interrupt); HallB_2.fall(&CN_interrupt); - stateA_1 = HallA_1.read(); - stateB_1 = HallB_1.read(); - stateA_2 = HallA_2.read(); - stateB_2 = HallB_2.read(); + HallA_state_2 = HallA_2.read(); + HallB_state_2 = HallB_2.read(); } -void init_err(void) -{ - v1_ierr = 0.0; - v2_ierr = 0.0; -} \ No newline at end of file +//****************************************************************************** End of init_CN \ No newline at end of file