/** * @file Euler.hpp * * Euler angle tait-bryan body 3-2-1 * * @author James Goppert */ #pragma once #include "math.hpp" namespace matrix { template class Dcm; template class Quaternion; template class Euler : public Vector { public: virtual ~Euler() {}; Euler() : Vector() { } Euler(const Vector & other) : Vector(other) { } Euler(const Matrix & other) : Vector(other) { } Euler(Type phi_, Type theta_, Type psi_) : Vector() { phi() = phi_; theta() = theta_; psi() = psi_; } Euler(const Dcm & dcm) : Vector() { Type psi_val = Type(atan(dcm(1, 0)/ dcm(0, 0))); Type theta_val = Type(asin(-dcm(2,0))); Type phi_val = Type(atan(dcm(2, 1)/ dcm(2, 2))); // protection against NaN if dcm(0,0) or dcm(2,2) == 0 psi() = 0; theta() = 0; phi() = 0; if (psi() >= -M_PI_2 && psi() <= M_PI_2) { psi() = psi_val; } if (theta() >= -M_PI_2 && theta() <= M_PI_2) { theta() = theta_val; } if (phi() >= -M_PI_2 && phi() <= M_PI_2) { phi() = phi_val; } } Euler(const Quaternion & q) : Vector() { *this = Euler(Dcm(q)); } inline Type phi() const { return (*this)(0); } inline Type theta() const { return (*this)(1); } inline Type psi() const { return (*this)(2); } inline Type & phi() { return (*this)(0); } inline Type & theta() { return (*this)(1); } inline Type & psi() { return (*this)(2); } }; typedef Euler Eulerf; }; // namespace matrix /* vim: set et fenc=utf-8 ff=unix sts=0 sw=4 ts=4 : */