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);
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);
58 EXPECT_EQ(in.get_value(), out.get_value());
60 auto ctx = in.get_context();
67 size_t len = Codec::template calc_num_fields<T>();
68 auto frs = Codec::template serialize_to_fields<T>(x);
69 EXPECT_EQ(
len, frs.size());
70 auto y = Codec::template deserialize_from_fields<T>(frs);
71 EXPECT_EQ(x.size(), y.size());
72 for (
auto [val1, val2] :
zip_view(x, y)) {
73 EXPECT_EQ(val1.get_value(), val2.get_value());
78using BuilderTypes = testing::Types<UltraCircuitBuilder, MegaCircuitBuilder>;
90 std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"));
92 this->check_conversion(field_element);
96 this->check_conversion(field_element);
98 field_element_val =
bb::fr(1);
100 this->check_conversion(field_element);
113 std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"));
129 this->check_conversion(group_element);
136 this->check_conversion(group_element);
141 const size_t num_points = 50;
144 for (
size_t i = 0; i < num_points; i++) {
148 this->check_conversion(group_element);
156 this->check_conversion(group_element);
169 this->check_conversion(group_element);
186 this->check_conversion(group_element);
190 const size_t num_points = 50;
193 for (
size_t i = 0; i < num_points; i++) {
197 this->check_conversion(group_element);
207 this->check_conversion(group_element,
false);
217 this->check_conversion(group_element);
232 Codec::template deserialize_from_fields<bn254_element<Builder>>(zeros);
234 EXPECT_TRUE(point_at_infinity.get_value().is_point_at_infinity());
241 Codec::template deserialize_from_fields<grumpkin_element<Builder>>(zeros);
260 this->check_conversion_iterable(array_of_frs_4);
269 this->check_conversion_iterable(array_of_frs_7);
284 static_cast<bb::fq>(std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"))),
287 static_cast<bb::fq>(std::string(
"2bf1eaf87f7d27e8dc4056e9af975985bccc89077a21891d6c7b6ccce0631f95"))),
290 static_cast<bb::fq>(std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"))),
293 static_cast<bb::fq>(std::string(
"018555a8eb50cf07f64b019ebaf3af3c925c93e631f3ecd455db07bbb52bbdd3"))),
295 this->check_conversion_iterable(array_of_fqs_4);
310 this->check_conversion_iterable(univariate);
325 static_cast<bb::fq>(std::string(
"9a807b615c4d3e2fa0b1c2d3e4f56789fedcba9876543210abcdef0123456789"))),
328 static_cast<bb::fq>(std::string(
"2bf1eaf87f7d27e8dc4056e9af975985bccc89077a21891d6c7b6ccce0631f95"))),
331 static_cast<bb::fq>(std::string(
"018555a8eb50cf07f64b019ebaf3af3c925c93e631f3ecd455db07bbb52bbdd3"))),
334 static_cast<bb::fq>(std::string(
"2bf1eaf87f7d27e8dc4056e9af975985bccc89077a21891d6c7b6ccce0631f95"))) }
336 this->check_conversion_iterable(univariate);
350 this->
template check_deserialization_gate_count<fr<TypeParam>>([] {
return bb::fr::random_element(); }, 0);
359 this->
template check_deserialization_gate_count<fq<TypeParam>>([] {
return bb::fq::random_element(); }, 3515);
368 this->
template check_deserialization_gate_count<fq<TypeParam>>([] {
return bb::fq::random_element(); }, 3914, 10);
381 this->
template check_deserialization_gate_count<bn254_element<Builder>>(
382 [] {
return curve::BN254::AffineElement::random_element(); }, expected);
393 this->
template check_deserialization_gate_count<bn254_element<Builder>>(
394 [] {
return curve::BN254::AffineElement::random_element(); }, expected, 10);
403 this->
template check_deserialization_gate_count<grumpkin_element<TypeParam>>(
404 [] {
return curve::Grumpkin::AffineElement::random_element(); }, 10);
413 constexpr size_t SIZE = 8;
414 this->
template check_deserialization_gate_count<std::array<fr<TypeParam>, SIZE>>(
417 for (
size_t i = 0; i < SIZE; ++i) {
431 constexpr size_t LENGTH = 8;
432 this->
template check_deserialization_gate_count<Univariate<fr<TypeParam>, LENGTH>>(
435 for (
size_t i = 0; i < LENGTH; ++i) {
460 std::vector<bb::fr> native_fields = { low_limb, high_limb };
461 EXPECT_THROW(FrCodec::deserialize_from_fields<bb::fq>(native_fields), std::runtime_error);
473 [[maybe_unused]]
auto bigfield_val = Codec::template deserialize_from_fields<fq<Builder>>(circuit_fields);
497 constexpr uint64_t NUM_LIMB_BITS = 68;
502 const uint256_t x_hi = modulus >> (NUM_LIMB_BITS * 2);
507 EXPECT_THROW(FrCodec::deserialize_from_fields<curve::BN254::AffineElement>(native_fields), std::runtime_error);
518 [[maybe_unused]]
auto point = Codec::template deserialize_from_fields<bn254_element>(circuit_fields);
537 constexpr uint64_t NUM_LIMB_BITS = 68;
538 constexpr uint64_t LOW_BITS = NUM_LIMB_BITS * 2;
542 return {
value & LOW_MASK,
value >> LOW_BITS };
548 const auto [low_limb, high_limb] = split_to_limbs(
value);
551 std::vector<bb::fr> native_fields = {
bb::fr(low_limb),
bb::fr(high_limb) };
552 auto native_result = FrCodec::deserialize_from_fields<bb::fq>(native_fields);
559 [[maybe_unused]]
auto circuit_result = Codec::template deserialize_from_fields<fq_ct>(circuit_fields);
566 const auto [low_limb, high_limb] = split_to_limbs(
value);
569 std::vector<bb::fr> native_fields = {
bb::fr(low_limb),
bb::fr(high_limb) };
570 EXPECT_THROW(FrCodec::deserialize_from_fields<bb::fq>(native_fields), std::runtime_error);
579 [[maybe_unused]]
auto circuit_result = Codec::template deserialize_from_fields<fq_ct>(circuit_fields);
587 const auto [low_limb, high_limb] = split_to_limbs(
value);
594 std::vector<bb::fr> native_fields = {
bb::fr(low_limb),
bb::fr(high_limb) };
595 EXPECT_THROW(FrCodec::deserialize_from_fields<bb::fq>(native_fields), std::runtime_error);
604 [[maybe_unused]]
auto circuit_result = Codec::template deserialize_from_fields<fq_ct>(circuit_fields);
#define EXPECT_THROW_WITH_MESSAGE(code, expectedMessageRegex)
#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
constexpr bool is_point_at_infinity() const noexcept
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....
AffineElement get_value() const
void check_conversion_iterable(T x)
void check_conversion(T in, bool valid_circuit=true)
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(CommitmentKeyTest, Curves)
field< Bn254FrParams > fr
TYPED_TEST(CommitmentKeyTest, CommitToZeroPoly)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
StdlibCodec for in-circuit (recursive) verification transcript handling.
static constexpr uint256_t modulus
static field random_element(numeric::RNG *engine=nullptr) noexcept
static constexpr uint256_t modulus_minus_two