Fixed Math

This library implements analytic/trigonometric functions for fixed point numbers.

Implemented functions:

Optional Features

Examples

There are traits and standalone functions, see examples on how to use them.

Errors

Check the examples to see about how much error this implementation produces.

Usually sqrt has an error of around 1-2 Delta.
(Delta = the distance to the next representable number)

sin_cos may produce bigger errors, around 1-2 decimal places.

Benchmarks

You can check or run the benchmarks in benches.

Here are some conclusions I've got to:

SinCos

2022-09-28

Calculation time for sin_cos varies with the fixed number's byte size.

Notes:

2023-07-30

System info:

-` .o+` -------- `ooo/ OS: Arch Linux x86_64 `+oooo: Host: X570 AORUS ELITE -CF `+oooooo: Kernel: 6.4.7-arch1-1 -+oooooo+: `/:-:++oooo+: `/++++/+++++++: Shell: fish 3.6.1 `/++++++++++++++: Resolution: 3840x2160 `/+++ooooooooooooo/` DE: Hyprland ./ooosssso++osssssso+` .oossssso-````/ossssss+` -osssssso. :ssssssso. Terminal: WezTerm :osssssss/ osssso+++. CPU: AMD Ryzen 7 5800X (16) @ 3.800GHz /ossssssss/ +ssssooo/- GPU: AMD ATI Radeon RX 7900 XT/7900 XTX `/ossssso+/:- -:/+osssso+- Memory: 32014MiB `+sso+:-` `.-/+oso: `++:. `-/+/ .` `/

Performance is different now and without native cpu features:

With native cpu features : RUSTFLAGS="-C target-cpu=native" cargo bench:

Notes:

License

All code in this repository is dual-licensed under either:

at your option.

Contributing

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Attribution

We use code modified from cordic, licensed as BSD-3-Clause: