You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
102 lines
1.7 KiB
102 lines
1.7 KiB
#pragma once |
|
|
|
#include <stdint.h> |
|
#include <MPU.hpp> |
|
|
|
namespace ugv { |
|
namespace io { |
|
|
|
struct Vec3f { |
|
float x; |
|
float y; |
|
float z; |
|
|
|
Vec3f(); |
|
Vec3f(float x, float y, float z); |
|
Vec3f(const mpud::float_axes_t& axes); |
|
|
|
Vec3f operator*(float s) const { return {s * x, s * y, s * z}; } |
|
|
|
Vec3f& operator*=(float s) { |
|
x *= s; |
|
y *= s; |
|
z *= s; |
|
return *this; |
|
} |
|
|
|
Vec3f operator+(const Vec3f& a) const { return {x + a.x, y + a.y, z + a.z}; } |
|
|
|
Vec3f& operator+=(const Vec3f& a) { |
|
x += a.x; |
|
y += a.y; |
|
z += a.z; |
|
return *this; |
|
} |
|
|
|
float dot(const Vec3f& v) const { |
|
return x * v.x + y * v.y + z * v.z; |
|
} |
|
}; |
|
|
|
struct Mat3f { |
|
union { |
|
Vec3f rx; |
|
float xx, xy, xz; |
|
}; |
|
union { |
|
Vec3f ry; |
|
float yx, yy, yz; |
|
}; |
|
union { |
|
Vec3f rz; |
|
float zx, zy, zz; |
|
}; |
|
|
|
Mat3f(Vec3f rx_, Vec3f ry_, Vec3f rz_) |
|
: rx(rx_), ry(ry_), rz(rz_) {} |
|
|
|
Mat3f(float xx, float xy, float xz, float yx, float yy, float yz, float zx, |
|
float zy, float zz) |
|
: rx(xx, xy, xz), ry(yx, yy, yz), rz(zx, zy, zz) {} |
|
|
|
Vec3f operator*(const Vec3f& v) const { |
|
return {rx.dot(v), ry.dot(v), rz.dot(v)}; |
|
} |
|
|
|
Mat3f transpose() const { |
|
return {xx, yx, zx, xy, yy, zy, xz, yz, zz}; |
|
} |
|
|
|
Mat3f operator*(const Mat3f& m) const { |
|
Mat3f mt = m.transpose(); |
|
return {mt * rx, mt * ry, mt * rz}; |
|
} |
|
}; |
|
|
|
struct MpuData { |
|
// G's |
|
Vec3f accel; |
|
// degrees/s |
|
Vec3f gyro_rate; |
|
// flux density uT |
|
Vec3f mag; |
|
}; |
|
|
|
class MPU { |
|
public: |
|
explicit MPU(); |
|
~MPU(); |
|
|
|
void Init(); |
|
void Calibrate(); |
|
|
|
void GetData(MpuData& data); |
|
|
|
private: |
|
mpud::mpu_bus_t* mpu_bus_; |
|
mpud::MPU* mpu_; |
|
mpud::raw_axes_t accel_, gyro_, mag_; |
|
}; |
|
|
|
} // namespace io |
|
} // namespace ugv
|
|
|