forked from ydm/mit-vecmath
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Matrix3f.h
86 lines (63 loc) · 2.62 KB
/
Matrix3f.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
#ifndef MATRIX3F_H
#define MATRIX3F_H
#include <cstdio>
class Matrix2f;
class Quat4f;
class Vector3f;
// 3x3 Matrix, stored in column major order (OpenGL style)
class Matrix3f
{
public:
// Fill a 3x3 matrix with "fill", default to 0.
Matrix3f( float fill = 0.f );
Matrix3f( float m00, float m01, float m02,
float m10, float m11, float m12,
float m20, float m21, float m22 );
// setColumns = true ==> sets the columns of the matrix to be [v0 v1 v2]
// otherwise, sets the rows
Matrix3f( const Vector3f& v0, const Vector3f& v1, const Vector3f& v2, bool setColumns = true );
Matrix3f( const Matrix3f& rm ); // copy constructor
Matrix3f& operator = ( const Matrix3f& rm ); // assignment operator
// no destructor necessary
const float& operator () ( int i, int j ) const;
float& operator () ( int i, int j );
Vector3f getRow( int i ) const;
void setRow( int i, const Vector3f& v );
Vector3f getCol( int j ) const;
void setCol( int j, const Vector3f& v );
// gets the 2x2 submatrix of this matrix to m
// starting with upper left corner at (i0, j0)
Matrix2f getSubmatrix2x2( int i0, int j0 ) const;
// sets a 2x2 submatrix of this matrix to m
// starting with upper left corner at (i0, j0)
void setSubmatrix2x2( int i0, int j0, const Matrix2f& m );
float determinant() const;
Matrix3f inverse( bool* pbIsSingular = NULL, float epsilon = 0.f ) const; // TODO: invert in place as well
void transpose();
Matrix3f transposed() const;
// ---- Utility ----
const float *getElements() const;
void print() const;
static float determinant3x3( float m00, float m01, float m02,
float m10, float m11, float m12,
float m20, float m21, float m22 );
static Matrix3f ones();
static Matrix3f identity();
static Matrix3f rotateX( float radians );
static Matrix3f rotateY( float radians );
static Matrix3f rotateZ( float radians );
static Matrix3f scaling( float sx, float sy, float sz );
static Matrix3f uniformScaling( float s );
static Matrix3f rotation( const Vector3f& rDirection, float radians );
// Returns the rotation matrix represented by a unit quaternion
// if q is not normalized, it it normalized first
static Matrix3f rotation( const Quat4f& rq );
private:
float m_elements[ 9 ];
};
// Matrix-Vector multiplication
// 3x3 * 3x1 ==> 3x1
Vector3f operator * ( const Matrix3f& m, const Vector3f& v );
// Matrix-Matrix multiplication
Matrix3f operator * ( const Matrix3f& x, const Matrix3f& y );
#endif // MATRIX3F_H