aboutsummaryrefslogtreecommitdiff
path: root/src/systemcmds/tests/test_mixer.cpp
diff options
context:
space:
mode:
authorLorenz Meier <lm@inf.ethz.ch>2013-12-31 14:45:38 +0100
committerLorenz Meier <lm@inf.ethz.ch>2013-12-31 14:45:38 +0100
commit7f14f1f7deb945b7f0ba14c2f49758e9a79d12a3 (patch)
tree85224dcdd724e6a59129cbdbe67a246b432172e2 /src/systemcmds/tests/test_mixer.cpp
parentc367959d28134fb6c937af83a3e2dcc25b411eee (diff)
downloadpx4-firmware-7f14f1f7deb945b7f0ba14c2f49758e9a79d12a3.tar.gz
px4-firmware-7f14f1f7deb945b7f0ba14c2f49758e9a79d12a3.tar.bz2
px4-firmware-7f14f1f7deb945b7f0ba14c2f49758e9a79d12a3.zip
Add conversions and mixer tests. Work in progress
Diffstat (limited to 'src/systemcmds/tests/test_mixer.cpp')
-rw-r--r--src/systemcmds/tests/test_mixer.cpp52
1 files changed, 51 insertions, 1 deletions
diff --git a/src/systemcmds/tests/test_mixer.cpp b/src/systemcmds/tests/test_mixer.cpp
index 4da86042d..d330da39f 100644
--- a/src/systemcmds/tests/test_mixer.cpp
+++ b/src/systemcmds/tests/test_mixer.cpp
@@ -51,6 +51,7 @@
#include <systemlib/err.h>
#include <systemlib/mixer/mixer.h>
+#include <systemlib/pwm_limit/pwm_limit.h>
#include "tests.h"
@@ -59,6 +60,18 @@ static int mixer_callback(uintptr_t handle,
uint8_t control_index,
float &control);
+const unsigned output_max = 8;
+static float actuator_controls[output_max];
+static bool should_arm = false;
+uint16_t r_page_servo_disarmed[output_max];
+uint16_t r_page_servo_control_min[output_max];
+uint16_t r_page_servo_control_max[output_max];
+uint16_t r_page_servos[output_max];
+/*
+ * PWM limit structure
+ */
+pwm_limit_t pwm_limit;
+
int test_mixer(int argc, char *argv[])
{
warnx("testing mixer");
@@ -164,6 +177,40 @@ int test_mixer(int argc, char *argv[])
if (mixer_group.count() != 8)
return 1;
+ /* execute the mixer */
+
+ float outputs_unlimited[output_max];
+ float outputs[output_max];
+ unsigned mixed;
+ const int jmax = 50;
+
+ pwm_limit_init(&pwm_limit);
+ pwm_limit.state = PWM_LIMIT_STATE_ON;
+ should_arm = true;
+
+ for (int j = -jmax; j <= jmax; j++) {
+
+ for (int i = 0; i < output_max; i++) {
+ actuator_controls[i] = j/100.0f + 0.1f * i;
+ r_page_servo_disarmed[i] = 900;
+ r_page_servo_control_min[i] = 1000;
+ r_page_servo_control_max[i] = 2000;
+ }
+
+ /* mix */
+ mixed = mixer_group.mix(&outputs_unlimited[0], output_max);
+
+ memcpy(outputs, outputs_unlimited, sizeof(outputs));
+
+ pwm_limit_calc(should_arm, mixed, r_page_servo_disarmed, r_page_servo_control_min, r_page_servo_control_max, outputs, r_page_servos, &pwm_limit);
+
+ warnx("mixed %d outputs (max %d), values:", mixed, output_max);
+ for (int i = 0; i < mixed; i++)
+ {
+ printf("\t %d: %8.4f limited: %8.4f, servo: %d\n", i, outputs_unlimited[i], outputs[i], (int)r_page_servos[i]);
+ }
+ }
+
/* load multirotor at once test */
mixer_group.reset();
@@ -193,7 +240,10 @@ mixer_callback(uintptr_t handle,
if (control_group != 0)
return -1;
- control = 0.0f;
+ if (control_index > (sizeof(actuator_controls) / sizeof(actuator_controls[0])))
+ return -1;
+
+ control = actuator_controls[control_index];
return 0;
}