binius_field/arch/portable/byte_sliced/
mod.rsmod invert;
mod multiply;
mod packed_byte_sliced;
mod square;
pub use packed_byte_sliced::*;
#[cfg(test)]
pub mod tests {
macro_rules! define_byte_sliced_test {
($module_name:ident, $name:ident, $scalar_type:ty) => {
mod $module_name{
use proptest::prelude::*;
use crate::{$scalar_type, underlier::WithUnderlier, packed::PackedField, arch::byte_sliced::$name};
fn scalar_array_strategy() -> impl Strategy<Value = [$scalar_type; 32]> {
any::<[<$scalar_type as WithUnderlier>::Underlier; 32]>().prop_map(|arr| arr.map(<$scalar_type>::from_underlier))
}
proptest! {
#[test]
fn check_add(scalar_elems_a in scalar_array_strategy(), scalar_elems_b in scalar_array_strategy()) {
let bytesliced_a = <$name>::from_scalars(scalar_elems_a);
let bytesliced_b = <$name>::from_scalars(scalar_elems_b);
let bytesliced_result = bytesliced_a + bytesliced_b;
for i in 0..32 {
assert_eq!(scalar_elems_a[i] + scalar_elems_b[i], bytesliced_result.get(i));
}
}
#[test]
fn check_add_assign(scalar_elems_a in scalar_array_strategy(), scalar_elems_b in scalar_array_strategy()) {
let mut bytesliced_a = <$name>::from_scalars(scalar_elems_a);
let bytesliced_b = <$name>::from_scalars(scalar_elems_b);
bytesliced_a += bytesliced_b;
for i in 0..32 {
assert_eq!(scalar_elems_a[i] + scalar_elems_b[i], bytesliced_a.get(i));
}
}
#[test]
fn check_sub(scalar_elems_a in scalar_array_strategy(), scalar_elems_b in scalar_array_strategy()) {
let bytesliced_a = <$name>::from_scalars(scalar_elems_a);
let bytesliced_b = <$name>::from_scalars(scalar_elems_b);
let bytesliced_result = bytesliced_a - bytesliced_b;
for i in 0..32 {
assert_eq!(scalar_elems_a[i] - scalar_elems_b[i], bytesliced_result.get(i));
}
}
#[test]
fn check_sub_assign(scalar_elems_a in scalar_array_strategy(), scalar_elems_b in scalar_array_strategy()) {
let mut bytesliced_a = <$name>::from_scalars(scalar_elems_a);
let bytesliced_b = <$name>::from_scalars(scalar_elems_b);
bytesliced_a -= bytesliced_b;
for i in 0..32 {
assert_eq!(scalar_elems_a[i] - scalar_elems_b[i], bytesliced_a.get(i));
}
}
#[test]
fn check_mul(scalar_elems_a in scalar_array_strategy(), scalar_elems_b in scalar_array_strategy()) {
let bytesliced_a = <$name>::from_scalars(scalar_elems_a);
let bytesliced_b = <$name>::from_scalars(scalar_elems_b);
let bytesliced_result = bytesliced_a * bytesliced_b;
for i in 0..32 {
assert_eq!(scalar_elems_a[i] * scalar_elems_b[i], bytesliced_result.get(i));
}
}
#[test]
fn check_mul_assign(scalar_elems_a in scalar_array_strategy(), scalar_elems_b in scalar_array_strategy()) {
let mut bytesliced_a = <$name>::from_scalars(scalar_elems_a);
let bytesliced_b = <$name>::from_scalars(scalar_elems_b);
bytesliced_a *= bytesliced_b;
for i in 0..32 {
assert_eq!(scalar_elems_a[i] * scalar_elems_b[i], bytesliced_a.get(i));
}
}
#[test]
fn check_inv(scalar_elems in scalar_array_strategy()) {
let bytesliced = <$name>::from_scalars(scalar_elems);
let bytesliced_result = bytesliced.invert_or_zero();
for (i, scalar_elem) in scalar_elems.iter().enumerate() {
assert_eq!(scalar_elem.invert_or_zero(), bytesliced_result.get(i));
}
}
#[test]
fn check_square(scalar_elems in scalar_array_strategy()) {
let bytesliced = <$name>::from_scalars(scalar_elems);
let bytesliced_result = bytesliced.square();
for (i, scalar_elem) in scalar_elems.iter().enumerate() {
assert_eq!(scalar_elem.square(), bytesliced_result.get(i));
}
}
}
}
};
}
define_byte_sliced_test!(tests_32x128, ByteSlicedAES32x128b, AESTowerField128b);
define_byte_sliced_test!(tests_32x64, ByteSlicedAES32x64b, AESTowerField64b);
define_byte_sliced_test!(tests_32x32, ByteSlicedAES32x32b, AESTowerField32b);
define_byte_sliced_test!(tests_32x16, ByteSlicedAES32x16b, AESTowerField16b);
define_byte_sliced_test!(tests_32x8, ByteSlicedAES32x8b, AESTowerField8b);
}