-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathft_matrix.c
120 lines (109 loc) · 2.21 KB
/
ft_matrix.c
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
115
116
117
118
119
120
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_matrix.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: aaubin <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2013/12/18 22:21:01 by aaubin #+# #+# */
/* Updated: 2013/12/18 22:21:06 by aaubin ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_fdf.h"
t_mat4 ft_create_4d_matrix(void)
{
t_mat4 m = {
{
{1.0, 0.0, 0.0, 0.0},
{0.0, 1.0, 0.0, 0.0},
{0.0, 0.0, 1.0, 0.0},
{0.0, 0.0, 0.0, 1.0}
}
};
t_mat4 a = {
{
{1, 3, 2, 6},
{2, 1, 2, 0},
{5, 0, 1, 3},
{1, 2, 3, 2}
}
};
t_mat4 b = {
{
{2, 3, 2, 0},
{4, 1, 2, 3},
{3, 0, 1, 3},
{1, 3, 0, 2}
}
};
t_mat4 c;
c = ft_multiply_matrix (a, b);
ft_print_matrix (a);
ft_print_matrix (b);
ft_print_matrix (c);
return (m);
}
t_mat4 ft_get_translation_matrix(float x, float y, float z)
{
t_mat4 m;
m = ft_create_4d_matrix ();
m.v[0][3] = x;
m.v[1][3] = y;
m.v[2][3] = z;
return (m);
}
t_mat4 ft_multiply_matrix(t_mat4 ma, t_mat4 mb)
{
t_mat4 mc;
int i;
int j;
int z;
/* aaah ! une boucle for !
mc = ft_create_4d_matrix ();*/
for (i = 0; i < 4; i++)
{
for (j = 0; j < 4; j++)
{
mc.v[i][j] = 0;
for (z = 0; z < 4; z++)
{
mc.v[i][j] += ma.v[i][z] * mb.v[z][j];
}
}
}
return (mc);
}
void ft_copy_matrix(t_mat4 *dest, t_mat4 src)
{
int c;
int cc;
c = 0;
while (c < 4)
{
cc = 0;
while (cc < 4)
{
dest->v[c][cc] = src.v[c][cc];
cc++;
}
c++;
}
}
void ft_print_matrix(t_mat4 mat)
{
int c;
int cc;
c = 0;
while (c < 4)
{
cc = 0;
while (cc < 4)
{
printf(" %5.2f ", mat.v[c][cc]);
cc++;
}
printf("\n");
c++;
}
printf("\n");
}