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
|
#ifndef V2F_H
#define V2F_H
V2F
v2f(F32 x, F32 y)
{
V2F result = { x, y };
return(result);
}
V2F
v2f_zero()
{
V2F result = { 0.0f, 0.0f };
return(result);
}
V2F
v2f_add(V2F a, V2F b)
{
V2F result = { a.x+b.x, a.y+b.y };
return(result);
}
V2F
v2f_sub(V2F a, V2F b)
{
V2F result = { a.x-b.x, a.y-b.y };
return(result);
}
V2F
v2f_scalef(V2F a, F32 scale)
{
V2F result = { a.x*scale, a.y*scale };
return(result);
}
V2F
v2f_scalev(V2F a, V2F scale)
{
V2F result = { a.x*scale.x, a.y*scale.y };
return(result);
}
F32
v2f_length2(V2F a)
{
F32 result = a.x*a.x+a.y*a.y;
return(result);
}
F32
v2f_length(V2F a)
{
F32 result = f32_sqrt(v2f_length2(a));
return(result);
}
void
v2f_print(V2F a)
{
printf("[%4.4f\n%4.4f]\n\n", a.x, a.y);
}
#endif /* V2F_H */
|