-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathtrackertest.c
More file actions
55 lines (45 loc) · 1.61 KB
/
trackertest.c
File metadata and controls
55 lines (45 loc) · 1.61 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include <stdio.h>
#include <time.h>
#include <math.h>
#include "tracker.h"
#include "MadgwickAHRS.h"
#define L3G_SO 70.0
#define GYRO_TO_RADIANS(a) ((float)a*M_PI*L3G_SO/(180.0*1000.0))
int main(void)
{
int ret = 0;
tracker_p tracker = tracker_init();
if (!tracker) {
fprintf(stderr, "Failed to init Tracker.\n");
return 1;
}
tracker_packet_t packet = {{0}};
double avg = 500.0;
struct timespec prev, now;
clock_gettime(CLOCK_REALTIME, &prev);
while (1) {
ret = tracker_read(tracker, &packet, 1000);
clock_gettime(CLOCK_REALTIME, &now);
struct timespec diff;
if ((now.tv_nsec-prev.tv_nsec)<0) {
diff.tv_nsec = 1000000000+now.tv_nsec-prev.tv_nsec;
} else {
diff.tv_nsec = now.tv_nsec-prev.tv_nsec;
}
prev = now;
double ddiff = diff.tv_nsec / 1000000000.0;
double hz = 1.0/ddiff;
avg = 0.99*avg+0.01*hz;
MadgwickAHRSupdate(avg, GYRO_TO_RADIANS(packet.gyro[0]),
GYRO_TO_RADIANS(packet.gyro[1]), GYRO_TO_RADIANS(packet.gyro[2]),
packet.acc[0], packet.acc[1], packet.acc[2],
packet.mag[0], packet.mag[1], packet.mag[2]);
/* printf("tracker_read %d. [%d, %d, %d], [%d, %d, %d], [%d, %d, %d]\n", ret,
packet.gyro[0], packet.gyro[1], packet.gyro[2],
packet.acc[0], packet.acc[1], packet.acc[2],
packet.mag[0], packet.mag[1], packet.mag[2]);*/
printf("%d %f %f [%f, %f, %f, %f]\n", ret, hz, avg, q0, q1, q2, q3);
}
tracker_destroy(tracker);
return 0;
}