mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-27 11:08:29 -04:00
AP_Math: examples: test custom rotations
This commit is contained in:
parent
15326a8d90
commit
97602aadf5
@ -4,6 +4,9 @@
|
||||
|
||||
#include <AP_HAL/AP_HAL.h>
|
||||
#include <AP_Math/AP_Math.h>
|
||||
#include <AP_CustomRotations/AP_CustomRotations.h>
|
||||
|
||||
AP_CustomRotations cust_rot;
|
||||
|
||||
void setup();
|
||||
void loop();
|
||||
@ -165,9 +168,9 @@ static void test_euler(enum Rotation rotation, float roll, float pitch, float ya
|
||||
float q_roll, q_pitch, q_yaw, qe_roll, qe_pitch, qe_yaw;
|
||||
q.to_euler(q_roll, q_pitch, q_yaw);
|
||||
qe.to_euler(qe_roll, qe_pitch, qe_yaw);
|
||||
const float roll_diff = fabsf(wrap_PI(q_roll - qe_roll));
|
||||
const float pitch_diff = fabsf(wrap_PI(q_pitch - qe_pitch));
|
||||
const float yaw_diff = fabsf(wrap_PI(q_yaw - qe_yaw));
|
||||
float roll_diff = fabsf(wrap_PI(q_roll - qe_roll));
|
||||
float pitch_diff = fabsf(wrap_PI(q_pitch - qe_pitch));
|
||||
float yaw_diff = fabsf(wrap_PI(q_yaw - qe_yaw));
|
||||
if ((roll_diff > q_accuracy) || (pitch_diff > q_accuracy) || (yaw_diff > q_accuracy)) {
|
||||
hal.console->printf("quaternion test %u failed : yaw:%f/%f roll:%f/%f pitch:%f/%f\n",
|
||||
(unsigned)rotation,
|
||||
@ -175,6 +178,36 @@ static void test_euler(enum Rotation rotation, float roll, float pitch, float ya
|
||||
(double)q_roll,(double)qe_roll,
|
||||
(double)q_pitch,(double)qe_pitch);
|
||||
}
|
||||
|
||||
// test custom rotations
|
||||
AP::custom_rotations().set(ROTATION_CUSTOM_1, roll, pitch, yaw);
|
||||
v1 = v;
|
||||
v1.rotate(ROTATION_CUSTOM_1);
|
||||
|
||||
diff = (v2 - v1);
|
||||
if (diff.length() > accuracy) {
|
||||
hal.console->printf("euler test %u failed : yaw:%d roll:%d pitch:%d\n",
|
||||
(unsigned)rotation,
|
||||
(int)yaw,
|
||||
(int)roll,
|
||||
(int)pitch);
|
||||
hal.console->printf("custom rotated: ");
|
||||
print_vector(v1);
|
||||
hal.console->printf("correct rotated: ");
|
||||
print_vector(v2);
|
||||
hal.console->printf("\n");
|
||||
}
|
||||
|
||||
Quaternion qc;
|
||||
qc.from_rotation(ROTATION_CUSTOM_1);
|
||||
float qc_roll, qc_pitch, qc_yaw;
|
||||
qc.to_euler(qc_roll, qc_pitch, qc_yaw);
|
||||
roll_diff = fabsf(wrap_PI(qc_roll - qe_roll));
|
||||
pitch_diff = fabsf(wrap_PI(qc_pitch - qe_pitch));
|
||||
yaw_diff = fabsf(wrap_PI(qc_yaw - qe_yaw));
|
||||
if ((roll_diff > q_accuracy) || (pitch_diff > q_accuracy) || (yaw_diff > q_accuracy)) {
|
||||
hal.console->printf("custom quaternion test %u failed\n", (unsigned)rotation);
|
||||
}
|
||||
}
|
||||
|
||||
static void test_rotate_inverse(void)
|
||||
|
Loading…
Reference in New Issue
Block a user