2018-04-30 18:23:39 -04:00
|
|
|
#include "fixed.h"
|
2020-07-19 19:24:48 -04:00
|
|
|
#include "dglfixp.h"
|
|
|
|
#include "dglmath.h"
|
2018-04-30 18:23:39 -04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include "helpers.h"
|
|
|
|
|
|
|
|
void test_fixed(void) {
|
|
|
|
fixed a, b, c;
|
|
|
|
float af, bf, cf, f;
|
2018-04-30 20:52:43 -04:00
|
|
|
float aaf, bbf, ccf;
|
2018-04-30 18:23:39 -04:00
|
|
|
int i;
|
|
|
|
|
|
|
|
a = FTOFIX(PI);
|
|
|
|
f = FIXTOF(a);
|
|
|
|
ASSERT(FFIX_EQU(PI, f));
|
|
|
|
|
2018-04-30 20:52:43 -04:00
|
|
|
a = FTOFIX(-0.38f);
|
2018-04-30 18:23:39 -04:00
|
|
|
f = FIXTOF(a);
|
|
|
|
ASSERT(FFIX_EQU(-0.38f, f));
|
|
|
|
|
|
|
|
a = ITOFIX(17);
|
|
|
|
i = FIXTOI(a);
|
|
|
|
ASSERT(17 == i);
|
|
|
|
|
|
|
|
a = ITOFIX(-17);
|
|
|
|
i = FIXTOI(a);
|
|
|
|
ASSERT(-17 == i);
|
|
|
|
|
|
|
|
a = FTOFIX(1.5f);
|
|
|
|
b = FTOFIX(2.3f);
|
|
|
|
c = a + b;
|
|
|
|
f = FIXTOF(c);
|
|
|
|
ASSERT(FFIX_EQU((1.5f + 2.3f), f));
|
|
|
|
|
|
|
|
a = FTOFIX(0.2f);
|
|
|
|
b = FTOFIX(1.7f);
|
|
|
|
c = a - b;
|
|
|
|
f = FIXTOF(c);
|
|
|
|
ASSERT(FFIX_EQU((0.2f - 1.7f), f));
|
|
|
|
|
|
|
|
a = FTOFIX(16.0f);
|
|
|
|
c = a >> 2;
|
|
|
|
f = FIXTOF(c);
|
|
|
|
ASSERT(FFIX_EQU((16 >> 2), f));
|
|
|
|
|
|
|
|
a = FTOFIX(7.1f);
|
|
|
|
b = ITOFIX(2);
|
|
|
|
c = fix_mul(a, b);
|
|
|
|
f = FIXTOF(c);
|
|
|
|
ASSERT(FFIX_EQU((7.1f * 2), f));
|
|
|
|
|
|
|
|
a = FTOFIX(77.7f);
|
|
|
|
b = ITOFIX(3);
|
|
|
|
c = fix_div(a, b);
|
|
|
|
f = FIXTOF(c);
|
|
|
|
ASSERT(FFIX_EQU((77.7f / 3), f));
|
|
|
|
|
|
|
|
for (i = 0; i <= 360; i += 45) {
|
|
|
|
f = DEG_TO_RAD(i + 1);
|
|
|
|
a = fix_sin(FTOFIX(f));
|
|
|
|
af = sin(f);
|
2018-04-30 20:52:43 -04:00
|
|
|
aaf = FIXTOF(a);
|
2018-04-30 18:23:39 -04:00
|
|
|
b = fix_cos(FTOFIX(f));
|
|
|
|
bf = cos(f);
|
2018-04-30 20:52:43 -04:00
|
|
|
bbf = FIXTOF(b);
|
2018-04-30 18:23:39 -04:00
|
|
|
c = fix_tan(FTOFIX(f));
|
|
|
|
cf = tan(f);
|
2018-04-30 20:52:43 -04:00
|
|
|
ccf = FIXTOF(c);
|
|
|
|
ASSERT(FFIX_EQU(aaf, af));
|
|
|
|
ASSERT(FFIX_EQU(bbf, bf));
|
|
|
|
ASSERT(FFIX_EQU(ccf, cf));
|
2018-04-30 18:23:39 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|