mirror of
https://github.com/logos-storage/nim-poseidon2.git
synced 2026-01-07 16:13:10 +00:00
Convert all types of integers to field element
This commit is contained in:
parent
f76d8dd654
commit
ddff11d4f0
@ -38,7 +38,8 @@ iterator elements*(bytes: openArray[byte], _: type F): F =
|
|||||||
yield finalElement
|
yield finalElement
|
||||||
|
|
||||||
# Remark: since `fromInt()` does not work at compile time, this doesn't either
|
# Remark: since `fromInt()` does not work at compile time, this doesn't either
|
||||||
func toF*(a: int) : F =
|
func toF*(a: SomeInteger | SomeUnsignedInt) : F =
|
||||||
var y : F
|
when a is SomeInteger:
|
||||||
y.fromInt(a)
|
fromInt(result, a)
|
||||||
return y
|
else:
|
||||||
|
fromUInt(result, a)
|
||||||
|
|||||||
@ -1,6 +1,7 @@
|
|||||||
import std/unittest
|
import std/unittest
|
||||||
import std/sequtils
|
import std/sequtils
|
||||||
import constantine/math/io/io_bigints
|
import constantine/math/io/io_bigints
|
||||||
|
import constantine/math/io/io_fields
|
||||||
import constantine/math/arithmetic
|
import constantine/math/arithmetic
|
||||||
import poseidon2/types
|
import poseidon2/types
|
||||||
import poseidon2/io
|
import poseidon2/io
|
||||||
@ -54,3 +55,29 @@ suite "conversion to/from bytes":
|
|||||||
var expected: array[32, byte]
|
var expected: array[32, byte]
|
||||||
marshal(expected, element.toBig(), littleEndian)
|
marshal(expected, element.toBig(), littleEndian)
|
||||||
check element.toBytes() == expected
|
check element.toBytes() == expected
|
||||||
|
|
||||||
|
suite "conversion from integers":
|
||||||
|
|
||||||
|
test "converts unsigned integers to a field element":
|
||||||
|
|
||||||
|
proc checkConversion[I](integer: I) =
|
||||||
|
var expected: F
|
||||||
|
fromUint(expected, integer)
|
||||||
|
check bool(integer.toF == expected)
|
||||||
|
|
||||||
|
checkConversion(0x11'u8)
|
||||||
|
checkConversion(0x1122'u16)
|
||||||
|
checkConversion(0x11223344'u32)
|
||||||
|
checkConversion(0x1122334455667788'u64)
|
||||||
|
|
||||||
|
test "converts signed integers to a field element":
|
||||||
|
|
||||||
|
proc checkConversion[I](integer: I) =
|
||||||
|
var expected: F
|
||||||
|
fromInt(expected, integer)
|
||||||
|
check bool(integer.toF == expected)
|
||||||
|
|
||||||
|
checkConversion(0x11'i8)
|
||||||
|
checkConversion(0x1122'i16)
|
||||||
|
checkConversion(0x11223344'i32)
|
||||||
|
checkConversion(0x1122334455667788'i64)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user