ModNum
and ModNumC
are highly ergonomic modular arithmetic structs intended
for no_std
use.
ModNum
objects represent a value modulo m. The value and modulo can be of any
primitive integer type. Arithmetic operators include +
, -
(both unary and binary),
*
, /
, pow()
, and ==
. Additional capabilities include computing multiplicative inverses
and solving modular equations.
ModNumC
objects likewise represent a value modulo M
, where M
is a generic constant of the
usize
type. Arithmetic operators include +
, -
(both unary and binary), *
, and ==
.
This library was originally developed to facilitate bidirectional navigation through fixed-size
arrays at arbitrary starting points. This is facilitated by a double-ended iterator that
traverses the entire ring starting at any desired value. The iterator supports both ModNum
and
ModNumC.
Modular numbers represent the remainder of an integer when divided by the modulo. If we also store the quotient in addition to the remainder, we have a count of the number of times a value had to "wrap around" during the calculation.
For example, if we start with 8 (mod 17) and add 42, the result is 16 (mod 17) with
a wraparound of 2. WrapCountNum
and WrapCountNumC
objects store this wraparound value
and make it available.
Furthermore, it is sometimes useful to be able to move back and forth in a range that is offset from zero. To that end, OffsetNum
and OffsetNumC
are provided.
Note that ModNum
, ModNumC
, WrapCountNum
, WrapCountNumC
, OffsetNum
, and OffsetNumC
are not designed to work with
arbitrary-length integers, as they require their integer type to implement the Copy
trait.
OffsetNum
and OffsetNumC
.OffsetNum
and OffsetNumC
.trait_set
crate.ModNumC
, WrapCountNumC
, and OffsetNumC
implement Default
.OffsetNum
and OffsetNumC
introduced.WrapCountNum
and WrapCountNumC
now support .pow()
. extern crate alloc;
, inadvertently added at the top level, to mod tests
.WrapCountNum
and WrapCountNumC
, variants of ModNum
/ModNumC
that track wraparounds.ModNumC
to support .pow()
, .inverse()
, and division. MNum
trait and some internal macros.num
dependency to 0.4
.ModNum
and ModNumC
now implement the Hash
trait.ModNum
and ModNumC
now implement PartialOrd
with reference to generic integers.replace()
method.with()
method.SaturatingAdd
and SaturatingSub
documentation.ModNumC
.ModNumC
, which uses const generics
to enable compile-time checking of compatible modulo. MNum
trait to allow ModNumIterator
to work with both ModNum
and ModNumC
.
Note: To use the .a()
and .m()
methods, be sure to import MNum
(or just use bare_metal_modulo::*;
)num::Saturating
is deprecated.num::Saturating
implementation.num::traits::SaturatingAdd
and num::traits::SaturatingSub
instead.num::Saturating
trait.ModNum
as a right-hand side option for arithmetic operators.Display
for ModNum
objects.