1#include <gmock/gmock.h>
2#include <gtest/gtest.h>
24using ::testing::NiceMock;
25using ::testing::TestWithParam;
27using tracegen::FieldGreaterThanTraceBuilder;
28using tracegen::RangeCheckTraceBuilder;
29using tracegen::TestTraceContainer;
31using simulation::DeduplicatingEventEmitter;
32using simulation::EventEmitter;
33using simulation::FieldGreaterThan;
34using simulation::FieldGreaterThanEvent;
35using simulation::MockRangeCheck;
36using simulation::RangeCheck;
37using simulation::RangeCheckEvent;
38using simulation::U256Decomposition;
46TEST(FieldGreaterThanConstrainingTest, EmptyRow)
63 GtTestParams{ 27, 0,
true },
64 GtTestParams{ TWO_POW_128, 0,
true },
65 GtTestParams{ -1, 0,
true },
67 GtTestParams{ 27, 27,
false },
68 GtTestParams{ TWO_POW_128, TWO_POW_128,
false },
69 GtTestParams{ -1, -1,
false },
71 GtTestParams{ 0, 1,
false },
72 GtTestParams{ 0, TWO_POW_128,
false },
73 GtTestParams{ 0, -1,
false },
75 GtTestParams{ 0, 0,
false },
76 GtTestParams{ 1, 0,
true },
78 GtTestParams{ -1, 1,
true },
79 GtTestParams{ -2, -1,
false },
81 GtTestParams{ TWO_POW_128 - 1, TWO_POW_128,
false },
82 GtTestParams{ TWO_POW_128, TWO_POW_128 - 1,
true }
87 DecTestParams{ 0, { .lo = 0, .hi = 0 } },
88 DecTestParams{ 1, { .lo = 1, .hi = 0 } },
90 DecTestParams{
uint256_t(1) << 128, { .lo = 0, .hi = 1 } },
100class GtBasicTest :
public TestWithParam<GtTestParams> {};
102TEST_P(GtBasicTest, BasicComparison)
104 const auto& param = GetParam();
107 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
108 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
110 EXPECT_EQ(field_gt_simulator.ff_gt(param.a, param.b), param.expected_result);
112 TestTraceContainer
trace({
113 { { C::precomputed_first_row, 1 } },
116 FieldGreaterThanTraceBuilder
builder;
119 check_relation<ff_gt>(trace);
124class DecBasicTest :
public TestWithParam<DecTestParams> {};
126TEST_P(DecBasicTest, BasicDecomposition)
128 const auto& param = GetParam();
131 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
132 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
134 EXPECT_EQ(field_gt_simulator.canon_dec(param.a), param.expected_result);
136 TestTraceContainer
trace({
137 { { C::precomputed_first_row, 1 } },
140 FieldGreaterThanTraceBuilder
builder;
143 check_relation<ff_gt>(trace);
148class GtInteractionTests :
public TestWithParam<GtTestParams> {};
150TEST_P(GtInteractionTests, InteractionsWithRangeCheck)
152 const auto& param = GetParam();
156 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
157 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
159 EXPECT_EQ(field_gt_simulator.ff_gt(param.a, param.b), param.expected_result);
161 TestTraceContainer
trace({
162 { { C::precomputed_first_row, 1 } },
165 FieldGreaterThanTraceBuilder
builder;
175 check_relation<ff_gt>(trace);
178INSTANTIATE_TEST_SUITE_P(FieldGreaterThanConstrainingTest, GtInteractionTests, ::testing::ValuesIn(comparison_tests));
180class DecInteractionTests :
public TestWithParam<DecTestParams> {};
182TEST_P(DecInteractionTests, InteractionsWithRangeCheck)
184 const auto& param = GetParam();
188 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
189 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
191 EXPECT_EQ(field_gt_simulator.canon_dec(param.a), param.expected_result);
193 TestTraceContainer
trace({
194 { { C::precomputed_first_row, 1 } },
197 FieldGreaterThanTraceBuilder
builder;
207 check_relation<ff_gt>(trace);
212 ::testing::ValuesIn(decomposition_tests));
214TEST(FieldGreaterThanConstrainingTest, NegativeManipulatedDecompositions)
217 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
218 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
220 field_gt_simulator.ff_gt(0, 0);
222 TestTraceContainer
trace({
223 { { C::precomputed_first_row, 1 } },
226 FieldGreaterThanTraceBuilder
builder;
228 check_relation<ff_gt>(trace);
230 trace.
set(Column::ff_gt_a_lo, 1, 1);
231 trace.
set(Column::ff_gt_b_hi, 1, 1);
237TEST(FieldGreaterThanConstrainingTest, NegativeManipulatedComparisonsWithP)
240 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
241 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
243 field_gt_simulator.ff_gt(0, 0);
245 TestTraceContainer
trace({
246 { { C::precomputed_first_row, 1 } },
249 FieldGreaterThanTraceBuilder
builder;
251 check_relation<ff_gt>(trace);
258 trace.
set(Column::ff_gt_a_lo, 1, p_lo);
259 trace.
set(Column::ff_gt_a_hi, 1, p_hi);
260 trace.
set(Column::ff_gt_b_lo, 1, p_lo);
261 trace.
set(Column::ff_gt_b_hi, 1, p_hi);
263 trace.
set(Column::ff_gt_p_sub_a_hi, 1, p_lo - 1);
264 trace.
set(Column::ff_gt_p_sub_a_lo, 1, p_hi - 1);
265 trace.
set(Column::ff_gt_p_sub_b_hi, 1, p_lo - 1);
266 trace.
set(Column::ff_gt_p_sub_b_lo, 1, p_hi - 1);
274TEST(FieldGreaterThanConstrainingTest, NegativeLessRangeChecks)
277 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
278 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
280 field_gt_simulator.ff_gt(0, 0);
282 TestTraceContainer
trace({
283 { { C::precomputed_first_row, 1 } },
286 FieldGreaterThanTraceBuilder
builder;
288 check_relation<ff_gt>(trace);
290 trace.
set(Column::ff_gt_cmp_rng_ctr, 1, 3);
291 trace.
set(Column::ff_gt_cmp_rng_ctr, 2, 0);
297TEST(FieldGreaterThanConstrainingTest, NegativeRangeCheckCtrInitInDec)
300 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
301 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
303 field_gt_simulator.canon_dec(0);
305 TestTraceContainer
trace({
306 { { C::precomputed_first_row, 1 } },
309 FieldGreaterThanTraceBuilder
builder;
311 check_relation<ff_gt>(trace);
313 trace.
set(Column::ff_gt_cmp_rng_ctr, 1, 4);
314 trace.
set(Column::ff_gt_cmp_rng_ctr, 2, 2);
320TEST(FieldGreaterThanConstrainingTest, NegativeSelectorConsistency)
323 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
324 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
326 field_gt_simulator.ff_gt(0, 0);
328 TestTraceContainer
trace({
329 { { C::precomputed_first_row, 1 } },
332 FieldGreaterThanTraceBuilder
builder;
334 check_relation<ff_gt>(trace);
342TEST(FieldGreaterThanConstrainingTest, NegativeEraseShift)
345 DeduplicatingEventEmitter<FieldGreaterThanEvent>
event_emitter;
346 FieldGreaterThan field_gt_simulator(range_check,
event_emitter);
348 field_gt_simulator.ff_gt(42, 27);
350 TestTraceContainer
trace({
351 { { C::precomputed_first_row, 1 } },
354 FieldGreaterThanTraceBuilder
builder;
356 check_relation<ff_gt>(trace);
358 trace.
set(Column::ff_gt_a_lo, 2, 0);
359 trace.
set(Column::ff_gt_a_hi, 2, 0);
360 trace.
set(Column::ff_gt_p_sub_a_lo, 2, 0);
361 trace.
set(Column::ff_gt_p_sub_a_hi, 2, 0);
362 trace.
set(Column::ff_gt_b_lo, 2, 0);
363 trace.
set(Column::ff_gt_b_hi, 2, 0);
364 trace.
set(Column::ff_gt_p_sub_b_lo, 2, 0);
365 trace.
set(Column::ff_gt_p_sub_b_hi, 2, 1);
374 "SHIFT_RES_TO_P_SUB_B_LO");
376 "SHIFT_RES_TO_P_SUB_B_HI");
#define EXPECT_THROW_WITH_MESSAGE(code, expectedMessageRegex)
static constexpr size_t SR_P_SUB_B_LO
static constexpr size_t SR_RNG_CTR_GT_INIT
static constexpr size_t SR_SEL_CONSISTENCY
static constexpr size_t SR_RNG_CTR_DECREMENT
static constexpr size_t SR_P_SUB_A_LO
static constexpr size_t SR_B_DECOMPOSITION
static constexpr size_t SR_SHIFT_RES_TO_P_SUB_B_LO
static constexpr size_t SR_SHIFT_P_SUB_B_TO_B_LO
static constexpr size_t SR_P_SUB_B_HI
static constexpr size_t SR_SHIFT_B_TO_P_SUB_A_HI
static constexpr size_t SR_SHIFT_P_SUB_B_TO_B_HI
static constexpr size_t SR_SHIFT_P_SUB_A_TO_A_LO
static constexpr size_t SR_SHIFT_B_TO_P_SUB_A_LO
static constexpr size_t SR_P_SUB_A_HI
static constexpr size_t SR_A_DECOMPOSITION
static constexpr size_t SR_SHIFT_RES_TO_P_SUB_B_HI
static constexpr size_t SR_SHIFT_P_SUB_A_TO_A_HI
static constexpr size_t SR_RNG_CTR_DEC_INIT
void process(const simulation::EventEmitterInterface< simulation::AluEvent >::Container &events, TraceContainer &trace)
Process the ALU events and populate the ALU relevant columns in the trace.
void process(const simulation::EventEmitterInterface< simulation::RangeCheckEvent >::Container &events, TraceContainer &trace)
Processes range check events and populates the trace with decomposed value columns.
uint32_t get_num_rows() const
void set(Column col, uint32_t row, const FF &value)
RangeCheckTraceBuilder range_check_builder
EventEmitter< RangeCheckEvent > range_check_event_emitter
EventEmitter< DataCopyEvent > event_emitter
TEST_P(AvmRecursiveTestsParameterized, TwoLayerAvmRecursion)
A test of the Two Layer AVM recursive verifier.
INSTANTIATE_TEST_SUITE_P(PaddingVariants, AvmRecursiveTestsParameterized, ::testing::Values(false, true), [](const auto &info) { return info.param ? "Padded" :"Unpadded";})
void check_interaction(tracegen::TestTraceContainer &trace)
TEST(AvmFixedVKTests, FixedVKCommitments)
Test that the fixed VK commitments agree with the ones computed from precomputed columns.
U256Decomposition decompose_256(const uint256_t &x)
TestTraceContainer empty_trace()
lookup_settings< lookup_ff_gt_a_lo_range_settings_ > lookup_ff_gt_a_lo_range_settings
lookup_settings< lookup_ff_gt_a_hi_range_settings_ > lookup_ff_gt_a_hi_range_settings
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
unsigned __int128 uint128_t
static constexpr uint256_t modulus