Stack-based arbitrary-precision integers - Fast and portable with natural syntax for resource-restricted devices.
Go to file
Mamy Ratsimbazafy 4c055e42a7
Add uint256 fuzz test vs TTMath (#34) + Fix multiplication carry bug #36
* Add uint256 fuzz test vs TTMath

* fix the compilation of property_based_uint256

* Fix multiplication carry bug #35

* Change comment in test
2018-05-04 00:11:07 +02:00
benchmarks Rename the library to Stint (#26) 2018-04-25 12:52:00 +02:00
src Add uint256 fuzz test vs TTMath (#34) + Fix multiplication carry bug #36 2018-05-04 00:11:07 +02:00
tests Add uint256 fuzz test vs TTMath (#34) + Fix multiplication carry bug #36 2018-05-04 00:11:07 +02:00
.appveyor.yml Update Quicktest & Continuous Integration configuration to latest. 2018-05-03 11:07:33 +02:00
.gitignore fix the compilation of property_based_uint256 2018-05-03 21:10:55 +03:00
.travis.yml Fix Travis script 2018-05-03 11:35:07 +02:00
LICENSE-APACHEv2 Relicense under dual Apache/MIT 2018-03-02 11:48:08 +01:00
LICENSE-MIT Relicense under dual Apache/MIT 2018-03-02 11:48:08 +01:00
README.md Prefix repo with nim 2018-04-25 14:08:31 +02:00
stint.nimble Add uint256 fuzz test vs TTMath (#34) + Fix multiplication carry bug #36 2018-05-04 00:11:07 +02:00

README.md

Stint (Stack-based multiprecision integers)

Build Status (Travis) License: Apache License: MIT Stability: experimental

A fast and portable stack-based multi-precision integer library in pure Nim

Main focus:

  • Portability
    • 32 and 64 bit arch
    • ARM for usage on mobile phones
    • Additionally RISC-V and MIPS for open hardware and low power IoT devices.
  • Speed, library is carefully tuned to produce the best assembly given the current compilers. However, the library itself does not resort to assembly for portability.
  • No heap/dynamic allocation
  • Ethereum applications
    • Uint256/Int256 for Ethereum Virtual Machine usage.
    • Uint2048 for Ethereum Bloom filters
  • Ease of use:
    • Use traditional +, -, +=, etc operators like on native types
    • Representation of numbers in memory is the exact same as native types and endianness aware.
      • In practice that means that interfacing with binary blobs representing numbers from cryptographic libraries can be done with a cast if it represents a Uint256, Uint512, Uint1024, Uint2048.
    • converting to and from Hex
    • converting to and from decimal strings

License

Licensed under either of

at your option.