aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmath/v2math.h
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llmath/v2math.h')
-rw-r--r--linden/indra/llmath/v2math.h326
1 files changed, 326 insertions, 0 deletions
diff --git a/linden/indra/llmath/v2math.h b/linden/indra/llmath/v2math.h
new file mode 100644
index 0000000..1832403
--- /dev/null
+++ b/linden/indra/llmath/v2math.h
@@ -0,0 +1,326 @@
1/**
2 * @file v2math.h
3 * @brief LLVector2 class header file.
4 *
5 * Copyright (c) 2000-2007, Linden Research, Inc.
6 *
7 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement
10 * ("Other License"), formally executed by you and Linden Lab. Terms of
11 * the GPL can be found in doc/GPL-license.txt in this distribution, or
12 * online at http://secondlife.com/developers/opensource/gplv2
13 *
14 * There are special exceptions to the terms and conditions of the GPL as
15 * it is applied to this Source Code. View the full text of the exception
16 * in the file doc/FLOSS-exception.txt in this software distribution, or
17 * online at http://secondlife.com/developers/opensource/flossexception
18 *
19 * By copying, modifying or distributing this software, you acknowledge
20 * that you have read and understood your obligations described above,
21 * and agree to abide by those obligations.
22 *
23 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
24 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
25 * COMPLETENESS OR PERFORMANCE.
26 */
27
28#ifndef LL_V2MATH_H
29#define LL_V2MATH_H
30
31#include <math.h>
32
33#include "llmath.h"
34
35class LLVector4;
36class LLMatrix3;
37class LLQuaternion;
38
39// Llvector2 = |x y z w|
40
41static const U32 LENGTHOFVECTOR2 = 2;
42
43class LLVector2
44{
45 public:
46 F32 mV[LENGTHOFVECTOR2];
47
48 static LLVector2 zero;
49
50 LLVector2(); // Initializes LLVector2 to (0, 0)
51 LLVector2(F32 x, F32 y); // Initializes LLVector2 to (x. y)
52 LLVector2(const F32 *vec); // Initializes LLVector2 to (vec[0]. vec[1])
53
54 // Clears LLVector2 to (0, 0). DEPRECATED - prefer zeroVec.
55 void clearVec();
56
57 // Zero LLVector2 to (0, 0)
58 void zeroVec();
59
60 void setVec(F32 x, F32 y); // Sets LLVector2 to (x, y)
61 void setVec(const LLVector2 &vec); // Sets LLVector2 to vec
62 void setVec(const F32 *vec); // Sets LLVector2 to vec
63
64 F32 magVec() const; // Returns magnitude of LLVector2
65 F32 magVecSquared() const; // Returns magnitude squared of LLVector2
66 F32 normVec(); // Normalizes and returns the magnitude of LLVector2
67
68 BOOL abs(); // sets all values to absolute value of original value (first octant), returns TRUE if changed
69
70 const LLVector2& scaleVec(const LLVector2& vec); // scales per component by vec
71
72 BOOL isNull(); // Returns TRUE if vector has a _very_small_ length
73 BOOL isExactlyZero() const { return !mV[VX] && !mV[VY]; }
74
75 F32 operator[](int idx) const { return mV[idx]; }
76 F32 &operator[](int idx) { return mV[idx]; }
77
78 friend bool operator<(const LLVector2 &a, const LLVector2 &b); // For sorting. x is "more significant" than y
79 friend LLVector2 operator+(const LLVector2 &a, const LLVector2 &b); // Return vector a + b
80 friend LLVector2 operator-(const LLVector2 &a, const LLVector2 &b); // Return vector a minus b
81 friend F32 operator*(const LLVector2 &a, const LLVector2 &b); // Return a dot b
82 friend LLVector2 operator%(const LLVector2 &a, const LLVector2 &b); // Return a cross b
83 friend LLVector2 operator/(const LLVector2 &a, F32 k); // Return a divided by scaler k
84 friend LLVector2 operator*(const LLVector2 &a, F32 k); // Return a times scaler k
85 friend LLVector2 operator*(F32 k, const LLVector2 &a); // Return a times scaler k
86 friend bool operator==(const LLVector2 &a, const LLVector2 &b); // Return a == b
87 friend bool operator!=(const LLVector2 &a, const LLVector2 &b); // Return a != b
88
89 friend const LLVector2& operator+=(LLVector2 &a, const LLVector2 &b); // Return vector a + b
90 friend const LLVector2& operator-=(LLVector2 &a, const LLVector2 &b); // Return vector a minus b
91 friend const LLVector2& operator%=(LLVector2 &a, const LLVector2 &b); // Return a cross b
92 friend const LLVector2& operator*=(LLVector2 &a, F32 k); // Return a times scaler k
93 friend const LLVector2& operator/=(LLVector2 &a, F32 k); // Return a divided by scaler k
94
95 friend LLVector2 operator-(const LLVector2 &a); // Return vector -a
96
97 friend std::ostream& operator<<(std::ostream& s, const LLVector2 &a); // Stream a
98};
99
100
101// Non-member functions
102
103F32 angle_between(const LLVector2 &a, const LLVector2 &b); // Returns angle (radians) between a and b
104BOOL are_parallel(const LLVector2 &a, const LLVector2 &b, F32 epsilon=F_APPROXIMATELY_ZERO); // Returns TRUE if a and b are very close to parallel
105F32 dist_vec(const LLVector2 &a, const LLVector2 &b); // Returns distance between a and b
106F32 dist_vec_squared(const LLVector2 &a, const LLVector2 &b);// Returns distance sqaured between a and b
107F32 dist_vec_squared2D(const LLVector2 &a, const LLVector2 &b);// Returns distance sqaured between a and b ignoring Z component
108LLVector2 lerp(const LLVector2 &a, const LLVector2 &b, F32 u); // Returns a vector that is a linear interpolation between a and b
109
110// Constructors
111
112inline LLVector2::LLVector2(void)
113{
114 mV[VX] = 0.f;
115 mV[VY] = 0.f;
116}
117
118inline LLVector2::LLVector2(F32 x, F32 y)
119{
120 mV[VX] = x;
121 mV[VY] = y;
122}
123
124inline LLVector2::LLVector2(const F32 *vec)
125{
126 mV[VX] = vec[VX];
127 mV[VY] = vec[VY];
128}
129
130
131// Clear and Assignment Functions
132
133inline void LLVector2::clearVec(void)
134{
135 mV[VX] = 0.f;
136 mV[VY] = 0.f;
137}
138
139inline void LLVector2::zeroVec(void)
140{
141 mV[VX] = 0.f;
142 mV[VY] = 0.f;
143}
144
145inline void LLVector2::setVec(F32 x, F32 y)
146{
147 mV[VX] = x;
148 mV[VY] = y;
149}
150
151inline void LLVector2::setVec(const LLVector2 &vec)
152{
153 mV[VX] = vec.mV[VX];
154 mV[VY] = vec.mV[VY];
155}
156
157inline void LLVector2::setVec(const F32 *vec)
158{
159 mV[VX] = vec[VX];
160 mV[VY] = vec[VY];
161}
162
163// LLVector2 Magnitude and Normalization Functions
164
165inline F32 LLVector2::magVec(void) const
166{
167 return fsqrtf(mV[0]*mV[0] + mV[1]*mV[1]);
168}
169
170inline F32 LLVector2::magVecSquared(void) const
171{
172 return mV[0]*mV[0] + mV[1]*mV[1];
173}
174
175inline F32 LLVector2::normVec(void)
176{
177 F32 mag = fsqrtf(mV[0]*mV[0] + mV[1]*mV[1]);
178 F32 oomag;
179
180 if (mag > FP_MAG_THRESHOLD)
181 {
182 oomag = 1.f/mag;
183 mV[0] *= oomag;
184 mV[1] *= oomag;
185 }
186 else
187 {
188 mV[0] = 0.f;
189 mV[1] = 0.f;
190 mag = 0;
191 }
192 return (mag);
193}
194
195inline const LLVector2& LLVector2::scaleVec(const LLVector2& vec)
196{
197 mV[VX] *= vec.mV[VX];
198 mV[VY] *= vec.mV[VY];
199
200 return *this;
201}
202
203inline BOOL LLVector2::isNull()
204{
205 if ( F_APPROXIMATELY_ZERO > mV[VX]*mV[VX] + mV[VY]*mV[VY] )
206 {
207 return TRUE;
208 }
209 return FALSE;
210}
211
212
213// LLVector2 Operators
214
215// For sorting. By convention, x is "more significant" than y.
216inline bool operator<(const LLVector2 &a, const LLVector2 &b)
217{
218 if( a.mV[VX] == b.mV[VX] )
219 {
220 return a.mV[VY] < b.mV[VY];
221 }
222 else
223 {
224 return a.mV[VX] < b.mV[VX];
225 }
226}
227
228
229inline LLVector2 operator+(const LLVector2 &a, const LLVector2 &b)
230{
231 LLVector2 c(a);
232 return c += b;
233}
234
235inline LLVector2 operator-(const LLVector2 &a, const LLVector2 &b)
236{
237 LLVector2 c(a);
238 return c -= b;
239}
240
241inline F32 operator*(const LLVector2 &a, const LLVector2 &b)
242{
243 return (a.mV[0]*b.mV[0] + a.mV[1]*b.mV[1]);
244}
245
246inline LLVector2 operator%(const LLVector2 &a, const LLVector2 &b)
247{
248 return LLVector2(a.mV[0]*b.mV[1] - b.mV[0]*a.mV[1], a.mV[1]*b.mV[0] - b.mV[1]*a.mV[0]);
249}
250
251inline LLVector2 operator/(const LLVector2 &a, F32 k)
252{
253 F32 t = 1.f / k;
254 return LLVector2( a.mV[0] * t, a.mV[1] * t );
255}
256
257inline LLVector2 operator*(const LLVector2 &a, F32 k)
258{
259 return LLVector2( a.mV[0] * k, a.mV[1] * k );
260}
261
262inline LLVector2 operator*(F32 k, const LLVector2 &a)
263{
264 return LLVector2( a.mV[0] * k, a.mV[1] * k );
265}
266
267inline bool operator==(const LLVector2 &a, const LLVector2 &b)
268{
269 return ( (a.mV[0] == b.mV[0])
270 &&(a.mV[1] == b.mV[1]));
271}
272
273inline bool operator!=(const LLVector2 &a, const LLVector2 &b)
274{
275 return ( (a.mV[0] != b.mV[0])
276 ||(a.mV[1] != b.mV[1]));
277}
278
279inline const LLVector2& operator+=(LLVector2 &a, const LLVector2 &b)
280{
281 a.mV[0] += b.mV[0];
282 a.mV[1] += b.mV[1];
283 return a;
284}
285
286inline const LLVector2& operator-=(LLVector2 &a, const LLVector2 &b)
287{
288 a.mV[0] -= b.mV[0];
289 a.mV[1] -= b.mV[1];
290 return a;
291}
292
293inline const LLVector2& operator%=(LLVector2 &a, const LLVector2 &b)
294{
295 LLVector2 ret(a.mV[0]*b.mV[1] - b.mV[0]*a.mV[1], a.mV[1]*b.mV[0] - b.mV[1]*a.mV[0]);
296 a = ret;
297 return a;
298}
299
300inline const LLVector2& operator*=(LLVector2 &a, F32 k)
301{
302 a.mV[0] *= k;
303 a.mV[1] *= k;
304 return a;
305}
306
307inline const LLVector2& operator/=(LLVector2 &a, F32 k)
308{
309 F32 t = 1.f / k;
310 a.mV[0] *= t;
311 a.mV[1] *= t;
312 return a;
313}
314
315inline LLVector2 operator-(const LLVector2 &a)
316{
317 return LLVector2( -a.mV[0], -a.mV[1] );
318}
319
320inline std::ostream& operator<<(std::ostream& s, const LLVector2 &a)
321{
322 s << "{ " << a.mV[VX] << ", " << a.mV[VY] << " }";
323 return s;
324}
325
326#endif