-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfpmath.hpp
51 lines (45 loc) · 1.26 KB
/
fpmath.hpp
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
#pragma once
// Fixed-point math library for Cortex chips without an FPU
#include <cstdint>
#include <string>
#include <cassert>
#include <cstdlib>
#define FPD_FACTOR (1U << 20U)
#define FPD_FRAC (FPD_FACTOR >> 1U)
#define FPD_MASK (FPD_FACTOR - 1U)
namespace fp
{
constexpr std::int32_t to(double num)
{
return std::int32_t(double(FPD_FACTOR) * num + 0.5);
}
constexpr std::int32_t to(std::int32_t num)
{
return FPD_FACTOR * num;
}
constexpr double fromD(std::int32_t num)
{
return double(num) / double(FPD_FACTOR);
}
constexpr std::int32_t fromI(std::int32_t num)
{
return (num + FPD_FRAC) / FPD_FACTOR;
}
constexpr std::int64_t mul(std::int32_t a, std::int32_t b)
{
return (std::int64_t(a) * std::int64_t(b) + std::int64_t(FPD_FRAC)) / std::int64_t(FPD_FACTOR);
}
constexpr std::int32_t div(std::int64_t a, std::int32_t b)
{
return std::int32_t( (a * std::int64_t(FPD_FACTOR) + std::int64_t(b >> 1)) / std::int64_t(b));
}
constexpr std::int32_t muldiv(std::int32_t a, std::int32_t b, std::int32_t c)
{
return std::int32_t( (std::int64_t(a) * std::int64_t(b) + std::int64_t(c >> 1)) / std::int64_t(c) );
}
constexpr std::int32_t dec(std::int32_t fpd)
{
return fpd / FPD_FACTOR;
}
char * frac(std::int32_t fpd, std::uint8_t accuracy);
}