summaryrefslogtreecommitdiffstats
path: root/nebu/include/base/nebu_vector.h
blob: 3c16c71bb2080a8a904796c9d2372661e1b62338 (plain)
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
#ifndef NEBU_VECTOR_H
#define NEBU_VECTOR_H

typedef struct { float v[2]; } vec2;
typedef struct { float v[3]; } vec3;
typedef struct { float v[4]; } vec4;

typedef struct { vec2 vStart, vDirection; } segment2;

vec4* vec4Add(vec4 *pOut, const vec4 *pV1, const vec4 *pV2);
vec4* vec4Sub(vec4 *pOut, const vec4 *pV1, const vec4 *pV2);

vec3* vec3Add(vec3 *pOut, const vec3 *pV1, const vec3 *pV2);
vec3* vec3Sub(vec3 *pOut, const vec3 *pV1, const vec3 *pV2);
vec3* vec3Cross(vec3 *pOut, const vec3 *pV1, const vec3 *pV2);

float vec4Dot(const vec4 *pV1, const vec4 *pV2);

float vec3Dot(const vec3 *pV1, const vec3 *pV2);

float vec3Length(const vec3 *pV);
float vec3LengthSqr(const vec3 *pV);
vec3* vec3Normalize(vec3 *pOut, const vec3 *pV);

vec3* vec3fromVec4(vec3 *pOut, const vec4 *pV);
vec4* vec4fromVec3(vec4 *pOut, const vec3 *pV);

vec3* vec3Copy(vec3 *pOut, const vec3 *pV);
vec3* vec3Scale(vec3 *pOut, const vec3 *pV, float f);
void vec4Print(const vec4 *pV);
void vec3Print(const vec3 *pV);
vec3* vec3Zero(vec3 *pV);
vec3* vec3TriNormalDirection(vec3* pOut, const vec3* pV1, const vec3* pV2, const vec3 *pV3);

vec2* vec2Copy(vec2 *pOut, const vec2 *pV);

unsigned int uintFromVec3(vec3 *pV);
// vec4* vec4Transform(vec4* pOut, const vec4* pV, const matrix16 *pM);

vec2* segment2_Intersect(vec2 *pOut, float *t1, float *t2,
												 const segment2 *s1, const segment2 *s2);

vec2* vec2_Orthogonal(vec2 *pOut, const vec2 *pV);

vec2* vec2Add(vec2 *pOut, const vec2 *pV1, const vec2 *pV2);
vec2* vec2Sub(vec2 *pOut, const vec2 *pV1, const vec2 *pV2);
vec2* vec2Scale(vec2 *pOut, const vec2 *pV, float fScale);
vec2* vec2Normalize(vec2 *pOut, const vec2 *pV);
float vec2Dot(const vec2 *pV1, const vec2 *pV2);

float vec2Length(const vec2 *pV);
float segment2_Length(const segment2 *s);
#endif