use super::{__m128i, __m256i};
use super::{_b16_eq, _b16_from_b32, _b16_value, _b32_eq, _b32_value};
use crate::utils::B1Dbl;
#[derive(Debug, Copy, Clone)]
pub(crate) struct MMB16Dbl {
pub v1: __m128i,
pub v2: __m128i,
}
impl MMB16Dbl {
#[inline(always)]
pub fn new(b1: u8, b2: u8) -> Self {
Self {
v1: unsafe { _b16_value(b1) },
v2: unsafe { _b16_value(b2) },
}
}
}
impl PartialEq for MMB16Dbl {
fn eq(&self, other: &Self) -> bool {
let a = unsafe { _b16_eq(self.v1, other.v1) };
let b = unsafe { _b16_eq(self.v2, other.v2) };
a && b
}
}
impl From<B1Dbl> for MMB16Dbl {
fn from(cc: B1Dbl) -> Self {
Self::new(cc.v1, cc.v2)
}
}
#[derive(Debug, Copy, Clone)]
pub(crate) struct MMB32Dbl {
pub v1: __m256i,
pub v2: __m256i,
}
impl MMB32Dbl {
#[inline(always)]
pub fn new(b1: u8, b2: u8) -> Self {
Self {
v1: unsafe { _b32_value(b1) },
v2: unsafe { _b32_value(b2) },
}
}
}
impl PartialEq for MMB32Dbl {
fn eq(&self, other: &Self) -> bool {
let a = unsafe { _b32_eq(self.v1, other.v1) };
let b = unsafe { _b32_eq(self.v2, other.v2) };
a && b
}
}
impl From<B1Dbl> for MMB32Dbl {
fn from(cc: B1Dbl) -> Self {
Self::new(cc.v1, cc.v2)
}
}
impl From<MMB32Dbl> for MMB16Dbl {
fn from(cc: MMB32Dbl) -> Self {
Self {
v1: unsafe { _b16_from_b32(cc.v1) },
v2: unsafe { _b16_from_b32(cc.v2) },
}
}
}
#[cfg(test)]
mod mini {
#![allow(clippy::clone_on_copy)]
use super::super::super::cpuid;
use super::*;
#[test]
fn t_b32() {
if !cpuid::has_avx2() {
return;
}
let a = MMB32Dbl::new(b'A', b'B');
let b = a.clone();
let c = a;
assert_eq!(a, b);
assert_eq!(a, c);
assert_eq!(
format!("{a:?}"),
"MMB32Dbl { v1: __m256i(4702111234474983745, 4702111234474983745, 4702111234474983745, 4702111234474983745), v2: __m256i(4774451407313060418, 4774451407313060418, 4774451407313060418, 4774451407313060418) }"
);
}
#[test]
fn t_b16() {
let a = MMB16Dbl::new(b'A', b'B');
let b = a.clone();
let c = a;
assert_eq!(a, b);
assert_eq!(a, c);
assert_eq!(
format!("{a:?}"),
"MMB16Dbl { v1: __m128i(4702111234474983745, 4702111234474983745), v2: __m128i(4774451407313060418, 4774451407313060418) }"
);
}
#[test]
fn t_into() {
if !cpuid::has_avx2() {
return;
}
let a_b32 = MMB32Dbl::new(b'A', b'B');
let a_b16: MMB16Dbl = a_b32.into();
assert_eq!(a_b32, MMB32Dbl::new(b'A', b'B'));
assert_eq!(a_b16, MMB16Dbl::new(b'A', b'B'));
}
}