9#include <gtest/gtest.h>
14template <
typename Builder_,
15 typename AcirConstraint_,
16 size_t num_multiplication_terms,
17 size_t num_linear_terms,
18 bool overlap_mul_and_linear,
30template <
typename Builder_,
31 typename AcirConstraint_,
32 size_t num_multiplication_terms,
33 size_t num_linear_terms,
34 bool overlap_mul_and_linear,
50 if constexpr (overlap_mul_and_linear) {
54 if constexpr (overlap_mul_and_linear && num_multiplication_terms > 1) {
58 if constexpr (overlap_mul_and_linear && num_multiplication_terms > 2) {
73 size_t num_multiplication_gates = num_multiplication_terms;
74 num_gates += num_multiplication_gates;
77 size_t num_witnesses_into_wires = num_linear_terms;
84 size_t num_witnesses_first_wire = num_multiplication_gates != 0 ? 2U : 4U;
85 if (num_witnesses_into_wires <= num_witnesses_first_wire) {
86 return num_multiplication_gates != 0 ? num_multiplication_gates : 1U;
88 num_witnesses_into_wires -= num_witnesses_first_wire;
89 num_gates += num_multiplication_gates != 0 ? 0U : 1U;
92 if (num_witnesses_into_wires + 1 <= num_gates) {
95 num_witnesses_into_wires -= (num_multiplication_gates - 1);
98 size_t num_additional_gates = num_witnesses_into_wires / (Builder::NUM_WIRES - 1);
99 size_t diff = num_witnesses_into_wires - num_additional_gates * (Builder::NUM_WIRES - 1);
100 num_additional_gates += diff == 0 ? 0U : 1U;
102 return num_gates + num_additional_gates;
112 static std::vector<std::string>
get_labels() {
return {
"None",
"InvalidateConstant",
"InvalidateWitness" }; }
118 const std::vector<bb::fr>& witness_values)
122 for (
const auto& mul_term : mul_terms) {
126 result += scalar * lhs_value * rhs_value;
129 for (
const auto& linear_term : linear_terms) {
130 bb::fr scalar = linear_term.first;
131 bb::fr value = witness_values[linear_term.second.first];
132 result += scalar *
value;
147 mul_terms.reserve(num_multiplication_terms);
148 for (
size_t idx = 0; idx < num_multiplication_terms; ++idx) {
159 linear_terms.reserve(num_linear_terms);
160 for (
size_t idx = 0; idx < num_linear_terms; ++idx) {
172 if constexpr (overlap_mul_and_linear) {
173 BB_ASSERT_GTE(num_linear_terms, 1U,
"We need at least 1 linear terms when overlapping is turned on.");
175 num_multiplication_terms, 1U,
"We need at least 1 multiplication terms when overlapping is turned on.");
178 std::get<1>(mul_terms[0]).first = linear_terms[0].second.first;
180 if constexpr (num_multiplication_terms > 1 && num_linear_terms > 1) {
182 std::get<2>(mul_terms[1]).first = linear_terms[1].second.first;
185 if constexpr (num_multiplication_terms > 2 && num_linear_terms > 2) {
187 std::get<1>(mul_terms[2]).first = linear_terms[2].second.first;
188 std::get<2>(mul_terms[2]).first = linear_terms[2].second.first;
194 if constexpr (overlap_linear) {
198 <<
" linear term when overlapping is turned on.");
208 for (
const auto& mul_term : mul_terms) {
213 for (
const auto& linear_term : linear_terms) {
215 std::make_tuple(linear_term.first.to_buffer(),
Acir::Witness(linear_term.second.first)));
226 if (EXPECTED_NUM_GATES > 1) {
247 switch (invalid_witness_target) {
270 return { constraint, witness_values };
274template <
typename ArithmeticConstra
intParams_>
276 :
public ::testing::Test,
277 public TestClass<ArithmeticConstraintsTestingFunctions<typename ArithmeticConstraintParams_::Builder,
278 typename ArithmeticConstraintParams_::AcirConstraint,
279 ArithmeticConstraintParams_::NUM_MULTIPLICATION_TERMS,
280 ArithmeticConstraintParams_::NUM_LINEAR_TERMS,
281 ArithmeticConstraintParams_::OVERLAP_MUL_AND_LINEAR,
282 ArithmeticConstraintParams_::OVERLAP_LINEAR>> {
315 TestFixture::template test_vk_independence<Flavor>();
320 TestFixture::test_tampering();
323template <
typename ArithmeticConstra
intParams_>
325 :
public ::testing::Test,
326 public TestClass<ArithmeticConstraintsTestingFunctions<typename ArithmeticConstraintParams_::Builder,
327 typename ArithmeticConstraintParams_::AcirConstraint,
328 ArithmeticConstraintParams_::NUM_MULTIPLICATION_TERMS,
329 ArithmeticConstraintParams_::NUM_LINEAR_TERMS,
330 ArithmeticConstraintParams_::OVERLAP_MUL_AND_LINEAR,
331 ArithmeticConstraintParams_::OVERLAP_LINEAR>> {
358 TestFixture::template test_vk_independence<Flavor>();
363 TestFixture::test_tampering();
testing::Types< ArithmeticConstraintParams< UltraCircuitBuilder, QuadConstraint, 1, 0, false, false >, ArithmeticConstraintParams< UltraCircuitBuilder, QuadConstraint, 1, 1, false, false >, ArithmeticConstraintParams< UltraCircuitBuilder, QuadConstraint, 1, 2, false, false >, ArithmeticConstraintParams< UltraCircuitBuilder, QuadConstraint, 1, 3, false, true >, ArithmeticConstraintParams< UltraCircuitBuilder, QuadConstraint, 1, 4, true, true >, ArithmeticConstraintParams< UltraCircuitBuilder, QuadConstraint, 0, 4, false, false >, ArithmeticConstraintParams< UltraCircuitBuilder, QuadConstraint, 0, 4, false, true >, ArithmeticConstraintParams< MegaCircuitBuilder, QuadConstraint, 1, 0, false, false >, ArithmeticConstraintParams< MegaCircuitBuilder, QuadConstraint, 1, 1, false, false >, ArithmeticConstraintParams< MegaCircuitBuilder, QuadConstraint, 1, 2, false, false >, ArithmeticConstraintParams< MegaCircuitBuilder, QuadConstraint, 1, 3, false, true >, ArithmeticConstraintParams< MegaCircuitBuilder, QuadConstraint, 1, 4, true, true >, ArithmeticConstraintParams< MegaCircuitBuilder, QuadConstraint, 0, 4, false, false >, ArithmeticConstraintParams< MegaCircuitBuilder, QuadConstraint, 0, 5, false, true > > QuadConstraintConfigs
testing::Types< ArithmeticConstraintParams< UltraCircuitBuilder, BigQuadConstraint, 1, 3, false, false >, ArithmeticConstraintParams< UltraCircuitBuilder, BigQuadConstraint, 0, 5, false, false >, ArithmeticConstraintParams< UltraCircuitBuilder, BigQuadConstraint, 2, 0, false, false >, ArithmeticConstraintParams< UltraCircuitBuilder, BigQuadConstraint, 3, 3, true, false >, ArithmeticConstraintParams< UltraCircuitBuilder, BigQuadConstraint, 1, 4, false, true >, ArithmeticConstraintParams< UltraCircuitBuilder, BigQuadConstraint, 5, 5, true, true >, ArithmeticConstraintParams< UltraCircuitBuilder, BigQuadConstraint, 0, 6, false, true >, ArithmeticConstraintParams< MegaCircuitBuilder, BigQuadConstraint, 1, 3, false, false >, ArithmeticConstraintParams< MegaCircuitBuilder, BigQuadConstraint, 0, 5, false, false >, ArithmeticConstraintParams< MegaCircuitBuilder, BigQuadConstraint, 2, 0, false, false >, ArithmeticConstraintParams< MegaCircuitBuilder, BigQuadConstraint, 3, 3, true, false >, ArithmeticConstraintParams< MegaCircuitBuilder, BigQuadConstraint, 1, 4, false, true >, ArithmeticConstraintParams< MegaCircuitBuilder, BigQuadConstraint, 5, 5, true, true >, ArithmeticConstraintParams< MegaCircuitBuilder, BigQuadConstraint, 0, 6, false, true > > BigQuadConstraintConfigs
#define BB_ASSERT(expression,...)
#define BB_ASSERT_GTE(left, right,...)
#define BB_ASSERT_GT(left, right,...)
#define BB_ASSERT_EQ(actual, expected,...)
static constexpr size_t NUM_LINEAR_TERMS
static constexpr size_t NUM_MULTIPLICATION_TERMS
AcirConstraint_ AcirConstraint
static constexpr bool OVERLAP_MUL_AND_LINEAR
static constexpr bool OVERLAP_LINEAR
static std::vector< std::string > get_labels()
static std::vector< Target > get_all()
static void generate_constraints(AcirConstraint &arithmetic_constraint, WitnessVector &witness_values)
AcirConstraint_ AcirConstraint
static constexpr size_t NUM_OVERLAP_MUL_AND_LINEAR
static constexpr size_t LINEAR_OFFSET
static std::pair< AcirConstraint, WitnessVector > invalidate_witness(AcirConstraint constraint, WitnessVector witness_values, const typename InvalidWitness::Target &invalid_witness_target)
static bb::fr evaluate_expression_result(const std::vector< std::tuple< bb::fr, std::pair< uint32_t, bb::fr >, std::pair< uint32_t, bb::fr > > > &mul_terms, const std::vector< std::pair< bb::fr, std::pair< uint32_t, bb::fr > > > &linear_terms, const std::vector< bb::fr > &witness_values)
static constexpr size_t num_overlap_mul_and_linear()
Compute the number of elements to overlap between multiplication and linear terms.
static constexpr size_t NUM_OVERLAP_LINEAR
static ProgramMetadata generate_metadata()
static size_t expected_num_gates()
static constexpr bool IS_BIG_QUAD
static void SetUpTestSuite()
static void SetUpTestSuite()
std::filesystem::path bb_crs_path()
void init_file_crs_factory(const std::filesystem::path &path)
TYPED_TEST_SUITE(BoomerangRecursiveVerifierTest, Flavors)
TYPED_TEST(ShpleminiTest, CorrectnessOfMultivariateClaimBatching)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
std::vector< uint8_t > to_buffer(T const &value)
std::vector< std::tuple< std::vector< uint8_t >, Acir::Witness > > linear_combinations
std::vector< uint8_t > q_c
std::vector< std::tuple< std::vector< uint8_t >, Acir::Witness, Acir::Witness > > mul_terms
static constexpr field one()
static field random_element(numeric::RNG *engine=nullptr) noexcept
BB_INLINE std::vector< uint8_t > to_buffer() const