#unsigned-integer #big-integer #uint #math #int #bignum #no-std

no-std i256

Optimized implementations of 256-bit signed and unsigned integers

6 releases

new 0.2.2 Jan 16, 2025
0.2.1 Jan 5, 2025
0.1.2 Dec 30, 2024

#165 in Data structures

Download history 75/week @ 2024-12-18 255/week @ 2024-12-25 312/week @ 2025-01-01 13/week @ 2025-01-08

655 downloads per month

MIT/Apache

620KB
11K SLoC

i256

Optimized implementations of 256-bit signed and unsigned integers.

This contains a fixed-width, performant implementation for 256-bit signed and unsigned integers. This has significantly faster performance for basic math operations than comparable fixed-width integer types, since it can use optimizations from 128-bit integers on 64-bit architectures.

Design

This contains variable-time, optimized algorithms for smaller big integers, primarily, 256-bit integers. It supports a no_std environment, requiring no allocation with all integers stored on the stack.

Features

This crate is optimized for small variants of big integers, but a few additional types can be enabled via the following features:

  • i384: Add the 384-bit I384 and U384 types.
  • i512: Add the 512-bit I512 and U512 types.
  • i1024: Add the 1024-bit I1024 and U1024 types.
  • stdint: Support operations with fixed-width integer types. The ULimb, UWide, and other scalars defined may vary in size for optimal performance on the target architecture (64-bit multiplies, for example, are more expensive on 32-bit architectures): enabling this API adds in overloads for u32, u64, and u128, guaranteeing API stability across all platforms.

If you need larger integers, crypto-bigint has high-performance addition, subtraction, and multiplication. With integers with a large number of bits, it uses Karatsuba multiplication, which is significantly asymptotically faster.

Use Case

i256 is for a very specific purpose: relatively high-performance, fixed-sized 256-bit integers. This is dependent on support for native 64-bit integer multiplies on the architecture, and highly benefits from 64-bit to 128-bit widening multiplies (supported on x86_64). For example, on x86_64, we can get 256-bit multiplications in at worst 10 multiplies and 15 adds, and significantly faster in most cases. However, using 256-bit x 64-bit multiplication, we can get a worst case scenario in 5 mul, 3 add, and 6 sub instructions.

This will, for obvious reasons, not support significantly larger type sizes. It is optimized only for a smaller number of bits.

  • bnum: Arbitrary-precision, fixed-width, big integer support.
  • crypto-bigint: Constant-time, arbitrary-precision, fixed-width, big integer support suitable for cryptographically secure applications.
  • num-bigint, malachite, or rug: Dynamic-width big integers with high-performance calculations with very large integers.

Specifically, i256 has optimizations that would be considered anti-features for these libraries: better performance for smaller values (variable-time calculations) and operations with native, scalar values. This is particularly useful when doing incremental operations with native integers, with performance improvements greater than 2 fold in many cases,

Versioning and Version Support

Rustc Compatibility

i256 currently supports 1.59+, including stable, beta, and nightly. This aims to support at least the Rust included in the latest stable Debian release. Please report any errors compiling a supported i256 version on a compatible Rustc version.

Versioning

i256 uses semantic versioning. Removing support for Rustc versions newer than the latest stable Debian or Ubuntu version is considered an incompatible API change, requiring a major (minor pre-1.0) version change.

Changelog

All changes are documented in CHANGELOG.

License

i256 is dual licensed under the Apache 2.0 license as well as the MIT license.

Almost all of the accessory methods in ints, such as the checked_*, unchecked_*, strict_*, and others, including their documentation, are taken directly from the Rust implementation, specifically, uint_macros and int_macros. The core algorithms under math for numeric operations, both their wrapping and overflowing forms, are not.

Contributing

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in i256 by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions. Contributing to the repository means abiding by the code of conduct.

Dependencies