Add addition limbs carry test

This commit is contained in:
Mamy André-Ratsimbazafy 2020-02-08 19:09:20 +01:00
parent 2c750cbc5b
commit edd728610c
No known key found for this signature in database
GPG Key ID: 7B88AD1FE79492E1

View File

@ -102,3 +102,40 @@ suite "Arithmetic operations - Addition":
let c = a
check:
bool(a == c)
test "Addition limbs carry":
block:
var a = fromHex(BigInt[128], "0x00000000_FFFFFFFF_FFFFFFFF_FFFFFFFE")
let b = fromHex(BigInt[128], "0x00000000_00000000_00000000_00000001")
let carry = a.add(b, ctrue(Word))
let c = fromHex(BigInt[128], "0x00000000_FFFFFFFF_FFFFFFFF_FFFFFFFF")
check:
bool(a == c)
not bool(carry)
block:
var a = fromHex(BigInt[128], "0x00000000_FFFFFFFF_FFFFFFFF_FFFFFFFF")
let b = fromHex(BigInt[128], "0x00000000_00000000_00000000_00000001")
let carry = a.add(b, ctrue(Word))
let c = fromHex(BigInt[128], "0x00000001_00000000_00000000_00000000")
check:
bool(a == c)
not bool(carry)
block:
var a = fromHex(BigInt[128], "0xFFFFFFFF_FFFFFFFF_FFFFFFFF_FFFFFFFF")
let b = fromHex(BigInt[128], "0x00000000_00000000_00000000_00000001")
let carry = a.add(b, ctrue(Word))
# BigInt[128] takes 3 Words as a BigInt Word is 63-bit
var ab: array[3*sizeof(Word), byte]
ab.dumpRawUint(a, littleEndian)
# Given that it uses 3 words, we actually can store 2^128 in BigInt[128]
var c: array[3*sizeof(Word), byte]
c[16] = 1
check:
c == ab
not bool(carry) # carry can only happen within limbs