binius_core/composition/
product_composition.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// Copyright 2024-2025 Irreducible Inc.

use binius_field::PackedField;
use binius_math::{ArithExpr, CompositionPolyOS};
use binius_utils::bail;

#[derive(Debug, Default, Copy, Clone)]
pub struct ProductComposition<const N: usize>;

impl<const N: usize> ProductComposition<N> {
	pub const fn n_vars(&self) -> usize {
		N
	}

	pub const fn degree(&self) -> usize {
		N
	}
}

impl<P: PackedField, const N: usize> CompositionPolyOS<P> for ProductComposition<N> {
	fn n_vars(&self) -> usize {
		self.n_vars()
	}

	fn degree(&self) -> usize {
		self.degree()
	}

	fn expression(&self) -> ArithExpr<P::Scalar> {
		(0..N).map(ArithExpr::Var).product()
	}

	fn evaluate(&self, query: &[P]) -> Result<P, binius_math::Error> {
		if query.len() != N {
			bail!(binius_math::Error::IncorrectQuerySize { expected: N });
		}
		Ok(query.iter().copied().product())
	}

	fn binary_tower_level(&self) -> usize {
		0
	}
}

pub type BivariateProduct = ProductComposition<2>;
pub type TrivariateProduct = ProductComposition<3>;