aboutsummaryrefslogtreecommitdiff
path: root/apps/multirotor_att_control
diff options
context:
space:
mode:
authorLorenz Meier <lm@inf.ethz.ch>2012-10-03 15:02:47 +0200
committerLorenz Meier <lm@inf.ethz.ch>2012-10-03 15:02:47 +0200
commitbeca2b072e45fc91ba6c315919abd26ee6814863 (patch)
tree2e4e659d9a68b521b132f2b3c3415289af23460c /apps/multirotor_att_control
parent053ce0e2f8c445dae046658ba5741adbd79d6ddb (diff)
downloadpx4-firmware-beca2b072e45fc91ba6c315919abd26ee6814863.tar.gz
px4-firmware-beca2b072e45fc91ba6c315919abd26ee6814863.tar.bz2
px4-firmware-beca2b072e45fc91ba6c315919abd26ee6814863.zip
Moved from raw gyro to estimated angular rate from EKF for rate control
Diffstat (limited to 'apps/multirotor_att_control')
-rw-r--r--apps/multirotor_att_control/multirotor_att_control_main.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/apps/multirotor_att_control/multirotor_att_control_main.c b/apps/multirotor_att_control/multirotor_att_control_main.c
index 8bd9ebc96..72566a43c 100644
--- a/apps/multirotor_att_control/multirotor_att_control_main.c
+++ b/apps/multirotor_att_control/multirotor_att_control_main.c
@@ -91,12 +91,12 @@ static void *rate_control_thread_main(void *arg)
struct actuator_controls_s actuators;
- int gyro_sub = orb_subscribe(ORB_ID(sensor_gyro));
+ int att_sub = orb_subscribe(ORB_ID(vehicle_attitude));
int rates_sp_sub = orb_subscribe(ORB_ID(vehicle_rates_setpoint));
- struct pollfd fds = { .fd = gyro_sub, .events = POLLIN };
+ struct pollfd fds = { .fd = att_sub, .events = POLLIN };
- struct gyro_report gyro_report;
+ struct vehicle_attitude_s vehicle_attitude;
struct vehicle_rates_setpoint_s rates_sp;
memset(&rates_sp, 0, sizeof(rates_sp));
float gyro_lp[3] = {0.0f, 0.0f, 0.0f};
@@ -110,10 +110,11 @@ static void *rate_control_thread_main(void *arg)
/* XXX this is seriously bad - should be an emergency */
} else if (ret == 0) {
/* XXX this means no sensor data - should be critical or emergency */
- //printf("[mc att control] WARNING: Not getting gyro data, no rate control\n");
+ printf("[mc att control] WARNING: Not getting gyro data, no rate control\n");
} else {
- /* get data */
- orb_copy(ORB_ID(sensor_gyro), gyro_sub, &gyro_report);
+ /* get current angular rate */
+ orb_copy(ORB_ID(vehicle_attitude), att_sub, &vehicle_attitude);
+ /* get current rate setpoint */
bool rates_sp_valid = false;
orb_check(rates_sp_sub, &rates_sp_valid);
if (rates_sp_valid) {
@@ -126,9 +127,9 @@ static void *rate_control_thread_main(void *arg)
if (state.flag_control_rates_enabled) {
/* lowpass gyros */
// XXX
- gyro_lp[0] = gyro_report.x;
- gyro_lp[1] = gyro_report.y;
- gyro_lp[2] = gyro_report.z;
+ gyro_lp[0] = vehicle_attitude.rollspeed;
+ gyro_lp[1] = vehicle_attitude.pitchspeed;
+ gyro_lp[2] = vehicle_attitude.yawspeed;
multirotor_control_rates(&rates_sp, gyro_lp, &actuators);
orb_publish(ORB_ID_VEHICLE_ATTITUDE_CONTROLS, actuator_pub, &actuators);