-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathquaternion.h
executable file
·114 lines (85 loc) · 4.96 KB
/
quaternion.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/****************************************************************************
quaternion.h - A quaternion class
GLUI User Interface Toolkit (LGPL)
Copyright (c) 1998 Paul Rademacher
---------------------------------------------------------------------
WWW: http://sourceforge.net/projects/glui/
Forums: http://sourceforge.net/forum/?group_id=92496
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*****************************************************************************/
#ifndef GLUI_QUATERNION_H
#define GLUI_QUATERNION_H
#include "algebra3.h"
#include <cstdio>
/* this line defines a new type: pointer to a function which returns a */
/* float and takes as argument a float */
typedef float (*V_FCT_PTR)(float);
/****************************************************************
* Quaternion *
****************************************************************/
class quat
{
/*protected: */
public:
vec3 v; /* vector component */
float s; /* scalar component */
/*public: */
/* Constructors */
quat();
quat(float x, float y, float z, float w);
quat(const vec3 &v, float s);
quat(float s, const vec3 &v);
quat(const float *d); /* copy from four-element float array */
quat(const double *f); /* copy from four-element double array */
quat(const quat &q); /* copy from other quat */
/* Assignment operators */
quat &operator = (const quat &v); /* assignment of a quat */
quat &operator += (const quat &v); /* incrementation by a quat */
quat &operator -= (const quat &v); /* decrementation by a quat */
quat &operator *= (float d); /* multiplication by a constant */
quat &operator /= (float d); /* division by a constant */
/* special functions */
float length() const; /* length of a quat */
float length2() const; /* squared length of a quat */
quat &normalize(); /* normalize a quat */
quat &apply(V_FCT_PTR fct); /* apply a func. to each component */
vec3 xform(const vec3 &v ); /* q*v*q-1 */
mat4 to_mat4() const;
void set_angle(float f); /* set rot angle (degrees) */
void scale_angle(float f); /* scale rot angle (degrees) */
float get_angle() const; /* set rot angle (degrees) */
vec3 get_axis() const; /* get axis */
void print( FILE *file, const char *name ) const; /* print to a file */
float &operator [] (int i); /* indexing */
const float &operator [] (int i) const; /* indexing */
void set(float x, float y, float z); /* set quat */
void set(const vec3 &v, float s); /* set quat */
/* friends */
friend quat operator - (const quat &v); /* -q1 */
friend quat operator + (const quat &a, const quat &b); /* q1 + q2 */
friend quat operator - (const quat &a, const quat &b); /* q1 - q2 */
friend quat operator * (const quat &a, float d); /* q1 * 3.0 */
friend quat operator * (float d, const quat &a); /* 3.0 * q1 */
friend quat operator * (const quat &a, const quat &b); /* q1 * q2 */
friend quat operator / (const quat &a, float d); /* q1 / 3.0 */
friend int operator == (const quat &a, const quat &b); /* q1 == q2 ? */
friend int operator != (const quat &a, const quat &b); /* q1 != q2 ? */
friend void swap(quat &a, quat &b); /* swap q1 &q2 */
/*friend quat min(const quat &a, const quat &b); -- min(q1, q2) */
/*friend quat max(const quat &a, const quat &b); -- max(q1, q2) */
friend quat prod(const quat &a, const quat &b); /* term by term mult*/
};
/* Utility functions */
quat quat_identity(); /* Returns quaternion identity element */
quat quat_slerp(const quat &from, const quat &to, float t);
#endif