AP_Motors: example sketch can test helicopter

This commit is contained in:
Randy Mackay 2016-02-03 09:51:26 +09:00
parent 47873c1d34
commit 93597d152f

View File

@ -40,7 +40,11 @@ void motor_order_test();
void stability_test(); void stability_test();
void update_motors(); void update_motors();
#define HELI_TEST 1 // set to 1 to test helicopters
#define NUM_OUTPUTS 4 // set to 6 for hexacopter, 8 for octacopter and heli
RC_Channel rc1(0), rc2(1), rc3(2), rc4(3); RC_Channel rc1(0), rc2(1), rc3(2), rc4(3);
RC_Channel rc7(6), rsc(8), h1(0), h2(1), h3(2), h4(3);
// uncomment the row below depending upon what frame you are using // uncomment the row below depending upon what frame you are using
//AP_MotorsTri motors(400); //AP_MotorsTri motors(400);
@ -49,8 +53,7 @@ AP_MotorsQuad motors(400);
//AP_MotorsY6 motors(400); //AP_MotorsY6 motors(400);
//AP_MotorsOcta motors(400); //AP_MotorsOcta motors(400);
//AP_MotorsOctaQuad motors(400); //AP_MotorsOctaQuad motors(400);
//AP_MotorsHeli motors(rc1, rc2, rc3, rc4, 400); //AP_MotorsHeli_Single motors(rc7, rsc, h1, h2, h3, h4, 400);
// setup // setup
void setup() void setup()
@ -61,8 +64,10 @@ void setup()
motors.set_update_rate(490); motors.set_update_rate(490);
motors.set_frame_orientation(AP_MOTORS_X_FRAME); motors.set_frame_orientation(AP_MOTORS_X_FRAME);
motors.Init(); motors.Init();
#if HELI_TEST == 0
motors.set_throttle_range(130,1000,2000); motors.set_throttle_range(130,1000,2000);
motors.set_hover_throttle(500); motors.set_hover_throttle(500);
#endif
motors.enable(); motors.enable();
motors.output_min(); motors.output_min();
@ -136,6 +141,7 @@ void stability_test()
// arm motors // arm motors
motors.armed(true); motors.armed(true);
motors.set_interlock(true);
//hal.console->printf("Roll,Pitch,Yaw,Thr,Mot1,Mot2,Mot3,Mot4,AvgOut\n"); // quad //hal.console->printf("Roll,Pitch,Yaw,Thr,Mot1,Mot2,Mot3,Mot4,AvgOut\n"); // quad
//hal.console->printf("Roll,Pitch,Yaw,Thr,Mot1,Mot2,Mot3,Mot4,Mot5,Mot6,AvgOut\n"); // hexa //hal.console->printf("Roll,Pitch,Yaw,Thr,Mot1,Mot2,Mot3,Mot4,Mot5,Mot6,AvgOut\n"); // hexa
@ -155,13 +161,19 @@ void stability_test()
motors.set_yaw(yaw_in); motors.set_yaw(yaw_in);
motors.set_throttle(throttle_in); motors.set_throttle(throttle_in);
motors.set_desired_spool_state(AP_MotorsMulticopter::DESIRED_THROTTLE_UNLIMITED); motors.set_desired_spool_state(AP_MotorsMulticopter::DESIRED_THROTTLE_UNLIMITED);
#if HELI_TEST == 0
motors.set_throttle_mix_mid(); motors.set_throttle_mix_mid();
#endif
update_motors(); update_motors();
avg_out = ((hal.rcout->read(0) + hal.rcout->read(1) + hal.rcout->read(2) + hal.rcout->read(3))/4); avg_out = ((hal.rcout->read(0) + hal.rcout->read(1) + hal.rcout->read(2) + hal.rcout->read(3))/4);
// display input and output // display input and output
//hal.console->printf("%d,%d,%d,%3.1f,%d,%d,%d,%d,%d,%d,%d,%d,%d\n", // octa #if NUM_OUTPUTS <= 4
//hal.console->printf("%d,%d,%d,%3.1f,%d,%d,%d,%d,%d,%d,%d\n", // hexa
hal.console->printf("%d,%d,%d,%3.1f,%d,%d,%d,%d,%d\n", // quad hal.console->printf("%d,%d,%d,%3.1f,%d,%d,%d,%d,%d\n", // quad
#elif NUM_OUTPUTS <= 6
hal.console->printf("%d,%d,%d,%3.1f,%d,%d,%d,%d,%d,%d,%d\n", // hexa
#else
hal.console->printf("%d,%d,%d,%3.1f,%d,%d,%d,%d,%d,%d,%d,%d,%d\n", // octa
#endif
(int)roll_in, (int)roll_in,
(int)pitch_in, (int)pitch_in,
(int)yaw_in, (int)yaw_in,
@ -170,10 +182,14 @@ void stability_test()
(int)hal.rcout->read(1), (int)hal.rcout->read(1),
(int)hal.rcout->read(2), (int)hal.rcout->read(2),
(int)hal.rcout->read(3), (int)hal.rcout->read(3),
//(int)hal.rcout->read(4), #if NUM_OUTPUTS >= 6
//(int)hal.rcout->read(5), (int)hal.rcout->read(4),
//(int)hal.rcout->read(6), (int)hal.rcout->read(5),
//(int)hal.rcout->read(7), #endif
#if NUM_OUTPUTS >= 8
(int)hal.rcout->read(6),
(int)hal.rcout->read(7),
#endif
(int)avg_out); (int)avg_out);
} }
} }