binius_field/arch/portable/
packed_64.rsuse cfg_if::cfg_if;
use super::{
packed::{impl_broadcast, impl_ops_for_zero_height, PackedPrimitiveType},
packed_arithmetic::{alphas, impl_tower_constants},
};
use crate::{
arch::{PackedStrategy, PairwiseRecursiveStrategy, PairwiseStrategy},
arithmetic_traits::{
impl_invert_with, impl_mul_alpha_with, impl_mul_with, impl_square_with,
impl_transformation_with_strategy,
},
BinaryField16b, BinaryField1b, BinaryField2b, BinaryField32b, BinaryField4b, BinaryField64b,
BinaryField8b,
};
pub type PackedBinaryField64x1b = PackedPrimitiveType<u64, BinaryField1b>;
pub type PackedBinaryField32x2b = PackedPrimitiveType<u64, BinaryField2b>;
pub type PackedBinaryField16x4b = PackedPrimitiveType<u64, BinaryField4b>;
pub type PackedBinaryField8x8b = PackedPrimitiveType<u64, BinaryField8b>;
pub type PackedBinaryField4x16b = PackedPrimitiveType<u64, BinaryField16b>;
pub type PackedBinaryField2x32b = PackedPrimitiveType<u64, BinaryField32b>;
pub type PackedBinaryField1x64b = PackedPrimitiveType<u64, BinaryField64b>;
impl_broadcast!(u64, BinaryField1b);
impl_broadcast!(u64, BinaryField2b);
impl_broadcast!(u64, BinaryField4b);
impl_broadcast!(u64, BinaryField8b);
impl_broadcast!(u64, BinaryField16b);
impl_broadcast!(u64, BinaryField32b);
impl_broadcast!(u64, BinaryField64b);
impl_ops_for_zero_height!(PackedBinaryField64x1b);
impl_tower_constants!(BinaryField1b, u64, { alphas!(u64, 0) });
impl_tower_constants!(BinaryField2b, u64, { alphas!(u64, 1) });
impl_tower_constants!(BinaryField4b, u64, { alphas!(u64, 2) });
impl_tower_constants!(BinaryField8b, u64, { alphas!(u64, 3) });
impl_tower_constants!(BinaryField16b, u64, { alphas!(u64, 4) });
impl_tower_constants!(BinaryField32b, u64, { alphas!(u64, 5) });
impl_mul_with!(PackedBinaryField32x2b @ PackedStrategy);
impl_mul_with!(PackedBinaryField16x4b @ PackedStrategy);
cfg_if! {
if #[cfg(all(target_arch = "x86_64", target_feature = "sse2", target_feature = "gfni"))] {
impl_mul_with!(PackedBinaryField8x8b => crate::PackedBinaryField16x8b);
impl_mul_with!(PackedBinaryField4x16b => crate::PackedBinaryField8x16b);
impl_mul_with!(PackedBinaryField2x32b => crate::PackedBinaryField4x32b);
impl_mul_with!(PackedBinaryField1x64b => crate::PackedBinaryField2x64b);
} else {
impl_mul_with!(PackedBinaryField8x8b @ crate::arch::PairwiseTableStrategy);
impl_mul_with!(PackedBinaryField4x16b @ PairwiseRecursiveStrategy);
impl_mul_with!(PackedBinaryField2x32b @ PairwiseRecursiveStrategy);
impl_mul_with!(PackedBinaryField1x64b @ PairwiseRecursiveStrategy);
}
}
impl_square_with!(PackedBinaryField32x2b @ PackedStrategy);
impl_square_with!(PackedBinaryField16x4b @ PackedStrategy);
cfg_if! {
if #[cfg(all(target_arch = "x86_64", target_feature = "sse2", target_feature = "gfni"))] {
impl_square_with!(PackedBinaryField8x8b => crate::PackedBinaryField16x8b);
impl_square_with!(PackedBinaryField4x16b => crate::PackedBinaryField8x16b);
impl_square_with!(PackedBinaryField2x32b => crate::PackedBinaryField4x32b);
impl_square_with!(PackedBinaryField1x64b => crate::PackedBinaryField2x64b);
} else {
impl_square_with!(PackedBinaryField8x8b @ crate::arch::PairwiseTableStrategy);
impl_square_with!(PackedBinaryField4x16b @ PairwiseStrategy);
impl_square_with!(PackedBinaryField2x32b @ PairwiseRecursiveStrategy);
impl_square_with!(PackedBinaryField1x64b @ crate::arch::HybridRecursiveStrategy);
}
}
impl_invert_with!(PackedBinaryField32x2b @ PackedStrategy);
impl_invert_with!(PackedBinaryField16x4b @ PackedStrategy);
cfg_if! {
if #[cfg(all(target_arch = "x86_64", target_feature = "sse2", target_feature = "gfni"))] {
impl_invert_with!(PackedBinaryField8x8b => crate::PackedBinaryField16x8b);
impl_invert_with!(PackedBinaryField4x16b => crate::PackedBinaryField8x16b);
impl_invert_with!(PackedBinaryField2x32b => crate::PackedBinaryField4x32b);
impl_invert_with!(PackedBinaryField1x64b => crate::PackedBinaryField2x64b);
} else {
impl_invert_with!(PackedBinaryField8x8b @ crate::arch::PairwiseTableStrategy);
impl_invert_with!(PackedBinaryField4x16b @ PairwiseStrategy);
impl_invert_with!(PackedBinaryField2x32b @ PairwiseStrategy);
impl_invert_with!(PackedBinaryField1x64b @ PairwiseRecursiveStrategy);
}
}
impl_mul_alpha_with!(PackedBinaryField32x2b @ PackedStrategy);
impl_mul_alpha_with!(PackedBinaryField16x4b @ PackedStrategy);
impl_mul_alpha_with!(PackedBinaryField8x8b @ PackedStrategy);
impl_mul_alpha_with!(PackedBinaryField4x16b @ PackedStrategy);
impl_mul_alpha_with!(PackedBinaryField2x32b @ PackedStrategy);
impl_mul_alpha_with!(PackedBinaryField1x64b @ PairwiseRecursiveStrategy);
impl_transformation_with_strategy!(PackedBinaryField64x1b, PackedStrategy);
impl_transformation_with_strategy!(PackedBinaryField32x2b, PackedStrategy);
impl_transformation_with_strategy!(PackedBinaryField16x4b, PackedStrategy);
impl_transformation_with_strategy!(PackedBinaryField8x8b, PackedStrategy);
impl_transformation_with_strategy!(PackedBinaryField4x16b, PackedStrategy);
impl_transformation_with_strategy!(PackedBinaryField2x32b, PackedStrategy);
impl_transformation_with_strategy!(PackedBinaryField1x64b, PairwiseStrategy);