Britney Dorval
/
Yusheng-final_project_robot
Code for robot
Fork of Yusheng-final_project by
stepper_motors.h
- Committer:
- csharer
- Date:
- 2016-11-10
- Revision:
- 6:ae3e6aefe908
- Parent:
- 4:2512939c10f0
- Child:
- 11:dc410a980771
File content as of revision 6:ae3e6aefe908:
//stepper_motors.h //Author: Carter Sharer //Date: 10/10/2016 //STEPPER MOTORS #define ZERO_SPEED 10000000 //65535 #define MAX_ACCEL 7 #define ENABLE 0 #define DISABLE 1 Ticker timer_M1, timer_M2; //Timers for speed Control // MOTOR 1 DigitalOut step_M1(MOTOR1_STEP); DigitalOut dir_M1(MOTOR1_DIR); DigitalOut enable(MOTOR_ENABLE); //enable for both motors int16_t speed_M1; //Speed of motor 1 //MOTOR 2 DigitalOut step_M2(MOTOR2_STEP); DigitalOut dir_M2(MOTOR2_DIR); int16_t speed_M2; //Speed of motor 2 int16_t motor1, motor2; //Motor Position int pos_M1 = 0, pos_M2 = 0; // ============================================================================= // === Interrupt Service Soutine === // ============================================================================= //ISR to step motor 1 void ISR1(void) { //Step Motor step_M1 = 1; wait_us(1); step_M1 = 0; //Update Motor Postion if(dir_M1) pos_M1++; else pos_M1--; } //ISR to step motor 2 void ISR2(void) { //Step Motor step_M2 = 1; wait_us(1); step_M2 = 0; //Update Motor Position if(dir_M2) pos_M2++; else pos_M2--; } //Set motor 1 speed. Speed [-100, 0, +100] = [Max Reverse, Stop, Max Forward] void setMotor1Speed(int16_t speed) { long timer_period; speed = CAP(speed, MAX_CONTROL_OUTPUT); //Calculate acceleration from the desired speed int16_t desired_accel = speed_M1 - speed; if(desired_accel > MAX_ACCEL) speed_M1 -= MAX_ACCEL; //Change speed of motor by max acceleration else if(desired_accel < -MAX_ACCEL) speed_M1 += MAX_ACCEL; //Change speed of motor by max acceleration else speed_M1 = speed; if(speed_M1 == 0) { timer_period = ZERO_SPEED; dir_M1 = 0; ////sets motor direction } else if (speed_M1 > 0) { timer_period = 10000 / speed_M1; dir_M1 = 1; //sets motor direction } else { timer_period = 10000 / -speed_M1; dir_M1 = 0; ////sets motor direction } // Update Timer period timer_M1.attach_us(&ISR1, timer_period); //This is what sets motor speed } //Set motor 2 speed. Speed [-100, 0, +100] = [Max Reverse, Stop, Max Forward] void setMotor2Speed(int16_t speed) { long timer_period; speed = CAP(speed, MAX_CONTROL_OUTPUT); //Calculate acceleration from the desired speed int16_t desired_accel = speed_M2 - speed; if(desired_accel > MAX_ACCEL) speed_M2 -= MAX_ACCEL; //Change speed of motor by max acceleration else if(desired_accel < -MAX_ACCEL) speed_M2 += MAX_ACCEL; //Change speed of motor by max acceleration else speed_M2 = speed; if(speed_M2 == 0) { timer_period = ZERO_SPEED; dir_M2 = 0; ////sets motor direction } else if (speed_M2 > 0) { timer_period = 10000 / speed_M2; dir_M2 = 1; //sets motor direction } else { timer_period = 10000 / -speed_M2; dir_M2 = 0; ////sets motor direction } // Update Timer period timer_M2.attach_us(&ISR2, timer_period); //This is what sets motor speed }