use crate::ir::{Expr, Program};
use crate::ops::primitive;
use crate::ops::{AlgebraicLaw, OpSpec, U32_INPUTS, U32_OUTPUTS};
pub const LAWS: &[AlgebraicLaw] = &[
AlgebraicLaw::Bounded { lo: 0, hi: 32 },
AlgebraicLaw::Complement {
complement_op: "primitive.bitwise.not",
universe: 32,
},
];
#[derive(Debug, Clone, Copy, Default)]
pub struct Popcount;
impl Popcount {
pub const SPEC: OpSpec = OpSpec::composition_inlinable(
"primitive.bitwise.popcount",
U32_INPUTS,
U32_OUTPUTS,
LAWS,
Self::program,
);
#[must_use]
pub fn program() -> Program {
primitive::unary_u32_program(Expr::popcount)
}
}