Managed to figure it out, also thanks to boost for their exp function data:image/s3,"s3://crabby-images/5029f/5029f85783330ba7db46d1ab5f283738c5b97a00" alt=":) smile.png"
// Raise a quaternion to a real power
template <typename S>
inline quaternion<S> pow(const quaternion<S> &q, const S ex)
{
return exp(ex * log(q) );
}
// Raise a unit quaternion to a real power
template <typename S>
inline quaternion<S> unit_pow(const quaternion<S> &q, const S ex)
{
static const S C = S(1) - std::numeric_limits<S>::epsilon();
// Check for the case of an identity quaternion.
// This will protect against divide by zero
if ( std::abs(real(q)) > C )
return q;
S a = acos( real(q) );
S u = a*ex;
return quaternion<S>(std::cos(u),
imag(q) * (std::sin(u) / std::sin(a)));
}
// logarithm of a quaternion.
// when q is unit this gives { 0 + acos(r) * v/|v| }
template <typename S>
inline quaternion<S> log ( const quaternion<S> &q )
{
S N = std::sqrt(norm(q));
return quaternion<S>( std::log(N),
std::acos(real(q) / N) * normalize(imag(q)) );
}
// exponential of a quaternion
template <typename S>
inline quaternion<S> exp( const quaternion<S> &q )
{
S z = length(imag(q));
S w = std::sin(z) / z;
return std::exp(real(q)) *
quaternion<S>(std::cos(z), w * imag(q));
}