Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

Changeset 3971 in orxonox.OLD for orxonox/trunk/src/lib/math


Ignore:
Timestamp:
Apr 26, 2005, 1:23:57 AM (20 years ago)
Author:
bensch
Message:

orxonox/trunk: return value of quat-slerp was wrong

Location:
orxonox/trunk/src/lib/math
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • orxonox/trunk/src/lib/math/vector.cc

    r3970 r3971  
    441441   \returns the Result of the smooth move
    442442*/
    443 Quaternion Quaternion::quatSlerp(const Quaternion& from, const Quaternion& to, float t)
     443Quaternion quatSlerp(const Quaternion& from, const Quaternion& to, float t)
    444444{
    445445  float tol[4];
    446446  double omega, cosom, sinom, scale0, scale1;
    447   DELTA = 0.2;
     447  //  float DELTA = 0.2;
    448448
    449449  cosom = from.v.x * to.v.x + from.v.y * to.v.y + from.v.z * to.v.z + from.w * to.w;
     
    488488    res.w = scale0 * from.w + scale1 * tol[3];
    489489  */
    490   return Quaternion(scale0 * from.w + scale1 * tol[3],
    491                     Vector(scale0 * from.v.x + scale1 * tol[0],
     490  return Quaternion(Vector(scale0 * from.v.x + scale1 * tol[0],
    492491                           scale0 * from.v.y + scale1 * tol[1],
    493                            scale0 * from.v.z + scale1 * tol[2]));
     492                           scale0 * from.v.z + scale1 * tol[2]),
     493                    scale0 * from.w + scale1 * tol[3]);
    494494}
    495495
  • orxonox/trunk/src/lib/math/vector.h

    r3966 r3971  
    7676 
    7777  inline Quaternion () { w = 1; v = Vector(0,0,0); }
    78   inline Quaternion (const Vector& b, float a) { w = a; v = b; }
     78  inline Quaternion (const Vector& v, float f) { this->w = f; this->v = v; }
    7979  Quaternion (float m[4][4]);
    8080  inline Quaternion (float angle, const Vector& axis) { w = cos(angle/2); v = axis * sin(angle/2); }
     
    9999  float norm () const;
    100100  void matrix (float m[4][4]) const;
    101   Quaternion quatSlerp(const Quaternion& from, const Quaternion& to, float t);
    102101 
    103102  void debug();
    104  private:
    105   float DELTA;      //!< resolution of calculation
     103};
    106104
    107 };
     105Quaternion quatSlerp(const Quaternion& from, const Quaternion& to, float t);
     106
     107
    108108
    109109//! 3D rotation (OBSOLETE)
Note: See TracChangeset for help on using the changeset viewer.