5#include <gtest/gtest.h>
26 template <
typename T,
typename CreateFn>
32 for (
size_t i = 0; i < num_elements; ++i) {
34 auto native_value = create_native();
35 auto native_fields = NativeCodec::serialize_to_fields(native_value);
39 for (
const auto& f : native_fields) {
44 [[maybe_unused]]
auto deserialized = Codec::template deserialize_from_fields<T>(witness_fields);
47 check_circuit_and_gate_count(
builder, expected_gates);
51 template <
typename T>
void check_conversion(T in,
bool valid_circuit =
true,
bool point_at_infinity =
false)
53 size_t len = Codec::template calc_num_fields<T>();
55 EXPECT_EQ(
len, frs.size());
56 auto out = Codec::template deserialize_from_fields<T>(frs);
59 EXPECT_EQ(in.get_value() == out.get_value(), expected);
61 auto ctx = in.get_context();
68 size_t len = Codec::template calc_num_fields<T>();
69 auto frs = Codec::template serialize_to_fields<T>(x);
70 EXPECT_EQ(
len, frs.size());
71 auto y = Codec::template deserialize_from_fields<T>(frs);
72 EXPECT_EQ(x.size(), y.size());
73 for (
auto [val1, val2] :
zip_view(x, y)) {
74 EXPECT_EQ(val1.get_value(), val2.get_value());
79using BuilderTypes = testing::Types<UltraCircuitBuilder, MegaCircuitBuilder>;
91 std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"));
93 this->check_conversion(field_element);
97 this->check_conversion(field_element);
99 field_element_val =
bb::fr(1);
101 this->check_conversion(field_element);
114 std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"));
130 this->check_conversion(group_element);
137 this->check_conversion(group_element);
142 const size_t num_points = 50;
145 for (
size_t i = 0; i < num_points; i++) {
149 this->check_conversion(group_element);
160 this->check_conversion(group_element,
true,
true);
173 this->check_conversion(group_element);
190 this->check_conversion(group_element);
194 const size_t num_points = 50;
197 for (
size_t i = 0; i < num_points; i++) {
201 this->check_conversion(group_element);
211 this->check_conversion(group_element,
false);
219 this->check_conversion(group_element);
234 Codec::template deserialize_from_fields<bn254_element<Builder>>(zeros);
236 EXPECT_TRUE(point_at_infinity.is_point_at_infinity().get_value());
243 Codec::template deserialize_from_fields<grumpkin_element<Builder>>(zeros);
262 this->check_conversion_iterable(array_of_frs_4);
271 this->check_conversion_iterable(array_of_frs_7);
286 static_cast<bb::fq>(std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"))),
289 static_cast<bb::fq>(std::string(
"2bf1eaf87f7d27e8dc4056e9af975985bccc89077a21891d6c7b6ccce0631f95"))),
292 static_cast<bb::fq>(std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"))),
295 static_cast<bb::fq>(std::string(
"018555a8eb50cf07f64b019ebaf3af3c925c93e631f3ecd455db07bbb52bbdd3"))),
297 this->check_conversion_iterable(array_of_fqs_4);
312 this->check_conversion_iterable(univariate);
327 static_cast<bb::fq>(std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"))),
330 static_cast<bb::fq>(std::string(
"2bf1eaf87f7d27e8dc4056e9af975985bccc89077a21891d6c7b6ccce0631f95"))),
333 static_cast<bb::fq>(std::string(
"018555a8eb50cf07f64b019ebaf3af3c925c93e631f3ecd455db07bbb52bbdd3"))),
336 static_cast<bb::fq>(std::string(
"2bf1eaf87f7d27e8dc4056e9af975985bccc89077a21891d6c7b6ccce0631f95"))) }
338 this->check_conversion_iterable(univariate);
352 this->
template check_deserialization_gate_count<fr<TypeParam>>([] {
return bb::fr::random_element(); }, 0);
361 this->
template check_deserialization_gate_count<fq<TypeParam>>([] {
return bb::fq::random_element(); }, 3483);
370 this->
template check_deserialization_gate_count<fq<TypeParam>>([] {
return bb::fq::random_element(); }, 3608, 10);
383 this->
template check_deserialization_gate_count<bn254_element<Builder>>(
384 [] {
return curve::BN254::AffineElement::random_element(); }, expected);
395 this->
template check_deserialization_gate_count<bn254_element<Builder>>(
396 [] {
return curve::BN254::AffineElement::random_element(); }, expected, 10);
405 this->
template check_deserialization_gate_count<grumpkin_element<TypeParam>>(
406 [] {
return curve::Grumpkin::AffineElement::random_element(); }, 10);
415 constexpr size_t SIZE = 8;
416 this->
template check_deserialization_gate_count<std::array<fr<TypeParam>, SIZE>>(
419 for (
size_t i = 0; i < SIZE; ++i) {
433 constexpr size_t LENGTH = 8;
434 this->
template check_deserialization_gate_count<Univariate<fr<TypeParam>, LENGTH>>(
437 for (
size_t i = 0; i < LENGTH; ++i) {
467 [[maybe_unused]]
auto bigfield_val = Codec::template deserialize_from_fields<fq<Builder>>(circuit_fields);
#define EXPECT_THROW_OR_ABORT(statement, matcher)
#define BB_DISABLE_ASSERTS()
static bool check(const Builder &circuit)
Check the witness satisifies the circuit.
A univariate polynomial represented by its values on {0, 1,..., domain_end - 1}.
typename Group::affine_element AffineElement
typename Group::affine_element AffineElement
static std::vector< fr > serialize_to_fields(const T &val)
Core stdlib Transcript serialization method.
cycle_group represents a group Element of the proving system's embedded curve, i.e....
bool_t is_point_at_infinity() const
void check_conversion_iterable(T x)
void check_conversion(T in, bool valid_circuit=true, bool point_at_infinity=false)
void check_deserialization_gate_count(CreateFn create_native, uint32_t expected_gates, size_t num_elements=1)
Helper to test gate counts for deserialization.
static field_t from_witness(Builder *ctx, const bb::fr &input)
testing::Types< UltraCircuitBuilder, MegaCircuitBuilder > BuilderTypes
element< Builder, fq< Builder >, fr< Builder >, curve::BN254::Group > bn254_element
void check_circuit_and_gate_count(Builder &builder, uint32_t expected_gates_without_base)
Utility function for gate count checking and circuit verification.
std::conditional_t< IsGoblinBigGroup< C, Fq, Fr, G >, element_goblin::goblin_element< C, goblin_field< C >, Fr, G >, element_default::element< C, Fq, Fr, G > > element
element wraps either element_default::element or element_goblin::goblin_element depending on parametr...
TYPED_TEST_SUITE(ShpleminiTest, TestSettings)
field< Bn254FrParams > fr
TYPED_TEST(ShpleminiTest, CorrectnessOfMultivariateClaimBatching)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
static field random_element(numeric::RNG *engine=nullptr) noexcept
static constexpr uint256_t modulus_minus_two