4#include <gtest/gtest.h>
10#ifdef STARKNET_GARAGA_FLAVORS
17 UltraStarknetZKFlavor>;
20 testing::Types<UltraFlavor, UltraZKFlavor, UltraKeccakFlavor, UltraKeccakZKFlavor, UltraRollupFlavor>;
48 const size_t virtual_log_n =
Flavor::USE_PADDING ? CONST_PROOF_SIZE_LOG_N : prover_instance->log_dyadic_size();
50 EXPECT_EQ(ultra_proof.size(), expected_proof_length);
63 TestFixture::set_default_pairing_points_and_ipa_claim_and_proof(circuit_builder);
67 typename TestFixture::Prover prover(prover_instance, verification_key);
68 auto proof = prover.construct_proof();
69 auto& polynomials = prover_instance->polynomials;
72 bool has_non_zero_coefficient =
false;
73 for (
auto& coeff : polynomial.coeffs()) {
74 has_non_zero_coefficient |= !coeff.is_zero();
76 ASSERT_TRUE(has_non_zero_coefficient);
79 for (
auto& poly : polynomials.get_selectors()) {
83 for (
auto& poly : polynomials.get_tables()) {
87 for (
auto& poly : polynomials.get_wires()) {
99 size_t num_gates = 10;
103 TestFixture::set_default_pairing_points_and_ipa_claim_and_proof(
builder);
105 TestFixture::prove_and_verify(
builder,
true);
112 for (
size_t i = 0; i < 16; ++i) {
113 for (
size_t j = 0; j < 16; ++j) {
114 uint64_t left =
static_cast<uint64_t
>(j);
115 uint64_t right =
static_cast<uint64_t
>(i);
116 uint32_t left_idx = circuit_builder.add_variable(
fr(left));
117 uint32_t right_idx = circuit_builder.add_variable(
fr(right));
118 uint32_t result_idx = circuit_builder.add_variable(
fr(left ^ right));
121 circuit_builder.add_variable(
fr(left) +
fr(right) + circuit_builder.get_variable(result_idx));
122 circuit_builder.create_big_add_gate(
123 { left_idx, right_idx, result_idx, add_idx,
fr(1),
fr(1),
fr(1),
fr(-1),
fr(0) });
126 TestFixture::set_default_pairing_points_and_ipa_claim_and_proof(circuit_builder);
128 TestFixture::prove_and_verify(circuit_builder,
true);
142 uint32_t x1 = circuit_builder.add_variable(p1.
x);
143 uint32_t y1 = circuit_builder.add_variable(p1.
y);
144 uint32_t x2 = circuit_builder.add_variable(p2.
x);
145 uint32_t y2 = circuit_builder.add_variable(p2.
y);
146 uint32_t x3 = circuit_builder.add_variable(p3.
x);
147 uint32_t y3 = circuit_builder.add_variable(p3.
y);
149 circuit_builder.create_ecc_add_gate({ x1, y1, x2, y2, x3, y3, 1 });
152 x3 = circuit_builder.add_variable(p3.
x);
153 y3 = circuit_builder.add_variable(p3.
y);
154 circuit_builder.create_ecc_add_gate({ x1, y1, x2, y2, x3, y3, 1 });
157 x3 = circuit_builder.add_variable(p3.
x);
158 y3 = circuit_builder.add_variable(p3.
y);
159 circuit_builder.create_ecc_add_gate({ x1, y1, x2, y2, x3, y3, -1 });
161 TestFixture::set_default_pairing_points_and_ipa_claim_and_proof(circuit_builder);
163 TestFixture::prove_and_verify(circuit_builder,
true);
185 const auto split_into_limbs = [&](
const uint512_t& input) {
186 constexpr size_t NUM_BITS = 68;
188 limbs[0] = input.slice(0, NUM_BITS).lo;
189 limbs[1] = input.slice(NUM_BITS * 1, NUM_BITS * 2).lo;
190 limbs[2] = input.slice(NUM_BITS * 2, NUM_BITS * 3).lo;
191 limbs[3] = input.slice(NUM_BITS * 3, NUM_BITS * 4).lo;
196 std::array<uint32_t, 4> limb_indices;
197 limb_indices[0] = circuit_builder.add_variable(limbs[0]);
198 limb_indices[1] = circuit_builder.add_variable(limbs[1]);
199 limb_indices[2] = circuit_builder.add_variable(limbs[2]);
200 limb_indices[3] = circuit_builder.add_variable(limbs[3]);
204 auto modulus_limbs = split_into_limbs(BINARY_BASIS_MODULUS -
uint512_t(modulus));
206 const auto a_indices = get_limb_witness_indices(split_into_limbs(
uint256_t(
a)));
207 const auto b_indices = get_limb_witness_indices(split_into_limbs(
uint256_t(
b)));
208 const auto q_indices = get_limb_witness_indices(split_into_limbs(
uint256_t(q)));
209 const auto r_indices = get_limb_witness_indices(split_into_limbs(
uint256_t(r)));
212 a_indices, b_indices, q_indices, r_indices, modulus_limbs,
214 const auto [lo_1_idx, hi_1_idx] = circuit_builder.evaluate_non_native_field_multiplication(
inputs);
217 const bool is_low_70_bits =
uint256_t(circuit_builder.get_variable(lo_1_idx)).
get_msb() < 70;
218 const bool is_high_70_bits =
uint256_t(circuit_builder.get_variable(hi_1_idx)).
get_msb() < 70;
219 if (is_low_70_bits && is_high_70_bits) {
221 circuit_builder.range_constrain_two_limbs(lo_1_idx, hi_1_idx, 70, 70);
224 circuit_builder.create_limbed_range_constraint(lo_1_idx, 72);
225 circuit_builder.create_limbed_range_constraint(hi_1_idx, 72);
228 TestFixture::set_default_pairing_points_and_ipa_claim_and_proof(circuit_builder);
230 TestFixture::prove_and_verify(circuit_builder,
true);
237 uint32_t
a = circuit_builder.add_variable(
fr(100));
238 uint32_t
b = circuit_builder.add_variable(
fr(100));
239 uint32_t c = circuit_builder.add_variable(
fr(100));
240 uint32_t d = circuit_builder.add_variable(
fr(100));
242 circuit_builder.assert_equal(
a,
b);
243 circuit_builder.assert_equal(
a, c);
244 circuit_builder.assert_equal(
a, d);
246 circuit_builder.create_small_range_constraint(
a, 1000);
247 circuit_builder.create_small_range_constraint(
b, 1001);
248 circuit_builder.create_small_range_constraint(c, 999);
249 circuit_builder.create_small_range_constraint(d, 1000);
251 circuit_builder.create_big_add_gate(
265 TestFixture::set_default_pairing_points_and_ipa_claim_and_proof(circuit_builder);
267 TestFixture::prove_and_verify(circuit_builder,
true);
278 uint16_t mask = (1 << 8) - 1;
280 uint32_t a_idx = circuit_builder.add_variable(
fr(
a));
281 uint32_t b_idx = circuit_builder.add_variable(
fr(
a));
282 ASSERT_NE(a_idx, b_idx);
283 uint32_t c_idx = circuit_builder.add_variable(
fr(
a));
284 ASSERT_NE(c_idx, b_idx);
285 circuit_builder.create_dyadic_range_constraint(b_idx, 8,
"bad range");
286 circuit_builder.assert_equal(a_idx, b_idx);
287 circuit_builder.create_dyadic_range_constraint(c_idx, 8,
"bad range");
288 circuit_builder.assert_equal(a_idx, c_idx);
290 TestFixture::set_default_pairing_points_and_ipa_claim_and_proof(circuit_builder);
292 TestFixture::prove_and_verify(circuit_builder,
true);
309 using VKAndHash =
typename Flavor::VKAndHash;
315 this->set_default_pairing_points_and_ipa_claim_and_proof(
builder);
322 Prover prover(prover_instance,
vk);
323 auto proof = prover.construct_proof();
330 Verifier verifier(vk_and_hash);
#define EXPECT_THROW_WITH_MESSAGE(code, expectedMessageRegex)
Manages the data that is propagated on the public inputs of an application/function circuit.
The verification key is responsible for storing the commitments to the precomputed (non-witnessk) pol...
ECCVMCircuitBuilder CircuitBuilder
static constexpr size_t PROOF_LENGTH_WITHOUT_PUB_INPUTS
static constexpr bool USE_PADDING
static void add_arithmetic_gates_with_public_inputs(Builder &builder, const size_t num_gates=4)
Add a specified number of arithmetic gates (with public inputs) to the provided circuit.
static void add_arithmetic_gates(Builder &builder, const size_t num_gates=4)
Add a specified number of arithmetic gates to the provided circuit.
Base Native verification key class.
A ProverInstance is normally constructed from a finalized circuit and it contains all the information...
The data that is propagated on the public inputs of a rollup circuit.
UltraRollupFlavor extends UltraFlavor with IPA proof support.
Child class of UltraFlavor that runs with ZK Sumcheck.
static affine_element random_element(numeric::RNG *engine=nullptr) noexcept
Samples a random point on the curve.
element class. Implements ecc group arithmetic using Jacobian coordinates See https://hyperelliptic....
virtual uint16_t get_random_uint16()=0
constexpr uint64_t get_msb() const
Manages the data that is propagated on the public inputs of an application/function circuit.
The data that is propagated on the public inputs of a rollup circuit.
grumpkin::g1::affine_element affine_element
uintx< uint256_t > uint512_t
Entry point for Barretenberg command-line interface.
field< Bn254FqParams > fq
TYPED_TEST_SUITE(ShpleminiTest, TestSettings)
field< Bn254FrParams > fr
UltraCircuitBuilder_< UltraExecutionTraceBlocks > UltraCircuitBuilder
TYPED_TEST(ShpleminiTest, CorrectnessOfMultivariateClaimBatching)
VerifierCommitmentKey< Curve > vk
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
static constexpr uint256_t modulus
static field random_element(numeric::RNG *engine=nullptr) noexcept
An object storing two EC points that represent the inputs to a pairing check.
void ensure_non_zero(auto &polynomial)