00001 #ifndef GSGL_MATH_QUATERNION_H 00002 #define GSGL_MATH_QUATERNION_H 00003 00004 // 00005 // $Id: quaternion.hpp 2 2008-03-01 20:58:50Z kulibali $ 00006 // 00007 // Copyright (c) 2008, The Periapsis Project. All rights reserved. 00008 // 00009 // Redistribution and use in source and binary forms, with or without 00010 // modification, are permitted provided that the following conditions are 00011 // met: 00012 // 00013 // * Redistributions of source code must retain the above copyright notice, 00014 // this list of conditions and the following disclaimer. 00015 // 00016 // * Redistributions in binary form must reproduce the above copyright 00017 // notice, this list of conditions and the following disclaimer in the 00018 // documentation and/or other materials provided with the distribution. 00019 // 00020 // * Neither the name of the The Periapsis Project nor the names of its 00021 // contributors may be used to endorse or promote products derived from 00022 // this software without specific prior written permission. 00023 // 00024 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 00025 // IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 00026 // TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 00027 // PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER 00028 // OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00029 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00030 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00031 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00032 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00033 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00034 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00035 // 00036 00037 #include "math/math.hpp" 00038 #include "math/vector.hpp" 00039 00040 namespace gsgl 00041 { 00042 00043 namespace math 00044 { 00045 00046 class transform; 00047 00048 00049 /// Quaternion class. 00050 class MATH_API quaternion 00051 : public math_object 00052 { 00053 public: 00054 double w,x,y,z; 00055 00056 quaternion(const double w = 0, const double x = 0, const double y = 0, const double z = 0); 00057 quaternion(const vector & v, double a); 00058 quaternion(const quaternion &); 00059 00060 explicit quaternion(const gsgl::string &); 00061 explicit quaternion(const transform &); 00062 00063 quaternion & operator= (const quaternion &); 00064 quaternion & operator= (const transform &); 00065 virtual ~quaternion(); 00066 00067 double norm() const; 00068 quaternion conjugate() const; 00069 quaternion inverse() const; 00070 void normalize(); 00071 00072 quaternion operator+ (const quaternion &) const; 00073 quaternion operator* (const quaternion &) const; 00074 quaternion operator* (const double &) const; 00075 00076 double dot(const quaternion &) const; 00077 static quaternion interpolate(const quaternion & start, const quaternion & end, const double & percent); 00078 }; // class quaternion 00079 00080 00081 } // namespace math 00082 00083 } // namespace gsgl 00084 00085 #endif