Debugging some motor issues
This commit is contained in:
parent
76d60a2111
commit
69f1841d8e
@ -111,6 +111,22 @@ static void read_trim_switch()
|
|||||||
}else{ // switch is disengaged
|
}else{ // switch is disengaged
|
||||||
if(trim_flag){
|
if(trim_flag){
|
||||||
trim_flag = false;
|
trim_flag = false;
|
||||||
|
|
||||||
|
if(CH7_wp_index == 0){
|
||||||
|
// this is our first WP, let's save WP 1 as a takeoff
|
||||||
|
// increment index
|
||||||
|
CH7_wp_index = 1;
|
||||||
|
|
||||||
|
// set our location ID to 16, MAV_CMD_NAV_WAYPOINT
|
||||||
|
current_loc.id = MAV_CMD_NAV_TAKEOFF;
|
||||||
|
|
||||||
|
// save command:
|
||||||
|
// we use the current altitude to be the target for takeoff.
|
||||||
|
// only altitude will matter to the AP mission script for takeoff.
|
||||||
|
// If we are above the altitude, we will skip the command.
|
||||||
|
set_cmd_with_index(current_loc, CH7_wp_index);
|
||||||
|
}
|
||||||
|
|
||||||
// increment index
|
// increment index
|
||||||
CH7_wp_index++;
|
CH7_wp_index++;
|
||||||
|
|
||||||
@ -142,6 +158,7 @@ static void auto_trim()
|
|||||||
auto_level_counter--;
|
auto_level_counter--;
|
||||||
trim_accel();
|
trim_accel();
|
||||||
led_mode = AUTO_TRIM_LEDS;
|
led_mode = AUTO_TRIM_LEDS;
|
||||||
|
do_simple = false;
|
||||||
|
|
||||||
if(auto_level_counter == 1){
|
if(auto_level_counter == 1){
|
||||||
//g.rc_1.dead_zone = 0; // 60 = .6 degrees
|
//g.rc_1.dead_zone = 0; // 60 = .6 degrees
|
||||||
@ -150,6 +167,8 @@ static void auto_trim()
|
|||||||
clear_leds();
|
clear_leds();
|
||||||
imu.save();
|
imu.save();
|
||||||
|
|
||||||
|
reset_control_switch();
|
||||||
|
|
||||||
//Serial.println("Done");
|
//Serial.println("Done");
|
||||||
auto_level_counter = 0;
|
auto_level_counter = 0;
|
||||||
|
|
||||||
@ -160,22 +179,45 @@ static void auto_trim()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
How this works:
|
||||||
|
Level Example:
|
||||||
|
A_off: -14.00, -20.59, -30.80
|
||||||
|
|
||||||
|
Right roll Example:
|
||||||
|
A_off: -6.73, 89.05, -46.02
|
||||||
|
|
||||||
|
Left Roll Example:
|
||||||
|
A_off: -18.11, -160.31, -56.42
|
||||||
|
|
||||||
|
Pitch Forward:
|
||||||
|
A_off: -127.00, -22.16, -50.09
|
||||||
|
|
||||||
|
Pitch Back:
|
||||||
|
A_off: 201.95, -24.00, -88.56
|
||||||
|
*/
|
||||||
|
|
||||||
static void trim_accel()
|
static void trim_accel()
|
||||||
{
|
{
|
||||||
g.pi_stabilize_roll.reset_I();
|
g.pi_stabilize_roll.reset_I();
|
||||||
g.pi_stabilize_pitch.reset_I();
|
g.pi_stabilize_pitch.reset_I();
|
||||||
|
|
||||||
if(g.rc_1.control_in > 0){ // Roll RIght
|
float trim_roll = (float)g.rc_1.control_in / 3000;
|
||||||
imu.ay(imu.ay() + 1);
|
float trim_pitch = (float)g.rc_2.control_in / 3000;
|
||||||
}else if (g.rc_1.control_in < 0){
|
|
||||||
imu.ay(imu.ay() - 1);
|
trim_roll = constrain(trim_roll, -1.5, 1.5);
|
||||||
|
trim_pitch = constrain(trim_pitch, -1.5, 1.5);
|
||||||
|
|
||||||
|
if(g.rc_1.control_in > 200){ // Roll RIght
|
||||||
|
imu.ay(imu.ay() + trim_roll);
|
||||||
|
}else if (g.rc_1.control_in < -200){
|
||||||
|
imu.ay(imu.ay() + trim_roll);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(g.rc_2.control_in > 0){ // Pitch Back
|
if(g.rc_2.control_in > 200){ // Pitch Back
|
||||||
imu.ax(imu.ax() + 1);
|
imu.ax(imu.ax() + trim_pitch);
|
||||||
}else if (g.rc_2.control_in < 0){
|
}else if (g.rc_2.control_in < -200){
|
||||||
imu.ax(imu.ax() - 1);
|
imu.ax(imu.ax() + trim_pitch);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -99,6 +99,8 @@ static void output_motors_armed()
|
|||||||
APM_RC.Force_Out0_Out1();
|
APM_RC.Force_Out0_Out1();
|
||||||
APM_RC.Force_Out2_Out3();
|
APM_RC.Force_Out2_Out3();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
//debug_motors();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void output_motors_disarmed()
|
static void output_motors_disarmed()
|
||||||
@ -134,7 +136,7 @@ static void output_motors_disarmed()
|
|||||||
motor_out[CH_3],
|
motor_out[CH_3],
|
||||||
motor_out[CH_4]);
|
motor_out[CH_4]);
|
||||||
}
|
}
|
||||||
*/
|
//*/
|
||||||
|
|
||||||
static void output_motor_test()
|
static void output_motor_test()
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user