Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Poseidon2 gates for Ultra arithmetisation #7494

Merged
merged 81 commits into from
Aug 21, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
81 commits
Select commit Hold shift + click to select a range
b1518fe
enabled poseidon gates in ultra
maramihali Jul 16, 2024
49eca12
add missing padding
maramihali Jul 16, 2024
a5ccefa
transcript produces constraints
maramihali Jul 16, 2024
1d86341
move print statement for number of gates post finalisation for client…
maramihali Jul 17, 2024
bb178f0
stuff..
maramihali Jul 18, 2024
269da29
fixing tests, fishing for remaiining bug
maramihali Jul 18, 2024
f1edf5f
fix test + cleanups
maramihali Jul 18, 2024
4b98f77
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Jul 19, 2024
5058fa0
preset cleanup
maramihali Jul 19, 2024
bf37f09
fixing tests
maramihali Jul 19, 2024
b116e00
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Jul 22, 2024
e688422
fix stuff
maramihali Jul 22, 2024
3488ac4
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Jul 22, 2024
83ecd92
remove prints
maramihali Jul 22, 2024
2bef500
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Jul 23, 2024
42bae7d
uncomment line
maramihali Jul 23, 2024
191b587
added permutation that was missing and corrected check_circuit, somet…
maramihali Jul 29, 2024
c7b0005
undo relation length modifications as they don't fix problems
maramihali Jul 29, 2024
376a736
Update Earthfile
ludamad Jul 29, 2024
798cf19
Update Earthfile
ludamad Jul 29, 2024
148b8fc
nothing really
maramihali Jul 29, 2024
e91dfd8
test stuff part 2
maramihali Jul 31, 2024
42f472e
handle point at infinity consistently
maramihali Aug 1, 2024
e21b3e4
let's gooo
maramihali Aug 1, 2024
0a16e60
handle point at infinity consistently
maramihali Aug 1, 2024
7144552
handle biggroup and add test for bn254
maramihali Aug 1, 2024
65e9613
cleanup
maramihali Aug 1, 2024
a659abf
Merge branch 'master' into mm/infinityy
maramihali Aug 1, 2024
43241d1
Merge branch 'mm/infinityy' into mm/poseidon-relation-ultra
maramihali Aug 1, 2024
c03a0c0
Merge remote-tracking branch 'refs/remotes/origin/mm/poseidon-relatio…
maramihali Aug 1, 2024
71ecc37
remove Testing file added by mistake
maramihali Aug 1, 2024
b3edc4b
remove unwanted stuff
maramihali Aug 1, 2024
ed7a9eb
Update ci.yml
ludamad Aug 1, 2024
d01ff27
Update earthly-ci
ludamad Aug 1, 2024
aae0648
Update earthly-ci
ludamad Aug 1, 2024
b6e27b9
resolve review comments
maramihali Aug 1, 2024
03ca5fa
Merge remote-tracking branch 'refs/remotes/origin/mm/infinityy' into …
maramihali Aug 1, 2024
dc486a0
bump circuit size
maramihali Aug 1, 2024
b56cb85
add issue to optimise validate on curve
maramihali Aug 1, 2024
002d88e
Merge branch 'master' into mm/infinityy
maramihali Aug 1, 2024
21cfb25
Update Earthfile
ludamad Aug 1, 2024
05b3061
fix manifest tests
maramihali Aug 2, 2024
465912c
Merge remote-tracking branch 'refs/remotes/origin/mm/poseidon-relatio…
maramihali Aug 2, 2024
11592c9
fix issue in schnorr
maramihali Aug 2, 2024
e74d3f7
Merge remote-tracking branch 'refs/remotes/origin/mm/infinityy' into …
maramihali Aug 2, 2024
c60ac06
add issue to investigate bad schnorr input and enable assert
maramihali Aug 2, 2024
166a8e4
Merge branch 'mm/infinityy' into mm/poseidon-relation-ultra
maramihali Aug 2, 2024
698f3fe
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 2, 2024
0fb6a7a
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 2, 2024
1054f9e
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 12, 2024
ce890b2
Merge branch 'master' into mm/poseidon-relation-ultra
maramihali Aug 12, 2024
8eaf4a4
Merge branch 'master' into mm/poseidon-relation-ultra
maramihali Aug 12, 2024
8b18801
Merge branch 'master' into mm/poseidon-relation-ultra
maramihali Aug 12, 2024
2ad9fd3
try remove the prefetches
maramihali Aug 13, 2024
05ad521
Merge branch 'master' into mm/poseidon-relation-ultra
maramihali Aug 13, 2024
6dd0949
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 13, 2024
524f88b
Attempt to fix memory issues, not clean, seeing if CI is ok now
maramihali Aug 14, 2024
4af936b
Merge remote-tracking branch 'refs/remotes/origin/mm/poseidon-relatio…
maramihali Aug 14, 2024
843368c
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 14, 2024
edefb2e
fix issue that was causing the circuit description to differ and upda…
maramihali Aug 16, 2024
5fe0a4d
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 16, 2024
3630ef2
remove accidentally added lock files and output
maramihali Aug 16, 2024
333cf11
Merge branch 'master' into mm/poseidon-relation-ultra
maramihali Aug 16, 2024
61b4789
make pow fix not affect other prover and verifier than ultra
maramihali Aug 19, 2024
c959fcb
Merge remote-tracking branch 'refs/remotes/origin/mm/poseidon-relatio…
maramihali Aug 19, 2024
b251dc7
fix keccak stuff
maramihali Aug 19, 2024
50041c8
undo MSAN related changes
maramihali Aug 20, 2024
1992e8e
more changes to make the solidity flow pass
maramihali Aug 20, 2024
6406a6f
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 20, 2024
3eb0054
remove parallelisation limitation for cmake test
maramihali Aug 20, 2024
b2872d5
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 20, 2024
75a5abc
cleanup
maramihali Aug 20, 2024
59d79b8
Merge branch 'master' into mm/poseidon-relation-ultra
maramihali Aug 20, 2024
96e9e31
more cleanup
maramihali Aug 20, 2024
b7b0248
Merge remote-tracking branch 'refs/remotes/origin/mm/poseidon-relatio…
maramihali Aug 20, 2024
25f4264
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 20, 2024
a8f5fdb
Merge branch 'master' into mm/poseidon-relation-ultra
maramihali Aug 20, 2024
f6521c6
resolve PR review comments
maramihali Aug 20, 2024
a2544bc
Merge remote-tracking branch 'refs/remotes/origin/mm/poseidon-relatio…
maramihali Aug 20, 2024
d355e00
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 20, 2024
a3a2454
Merge remote-tracking branch 'origin/master' into mm/poseidon-relatio…
maramihali Aug 21, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 8 additions & 4 deletions barretenberg/acir_tests/flows/honk_sol.sh
Original file line number Diff line number Diff line change
@@ -1,14 +1,18 @@
#!/bin/sh
set -eu
set -eux

VFLAG=${VERBOSE:+-v}
BFLAG="-b ./target/program.json"
FLAGS="-c $CRS_PATH $VFLAG"

export PROOF="$(pwd)/proof"
export PROOF_AS_FIELDS="$(pwd)/proof_fields.json"

# Create a proof, write the solidity contract, write the proof as fields in order to extract the public inputs
$BIN prove_keccak_ultra_honk -o proof
$BIN write_vk_ultra_honk -o vk
$BIN prove_keccak_ultra_honk -o proof $FLAGS $BFLAG
$BIN write_vk_ultra_keccak_honk -o vk $FLAGS $BFLAG
$BIN proof_as_fields_honk -k vk -c $CRS_PATH -p $PROOF
$BIN contract_ultra_honk -k vk -c $CRS_PATH -b ./target/program.json -o Verifier.sol
$BIN contract_ultra_honk -k vk -c $CRS_PATH -o Verifier.sol

# Export the paths to the environment variables for the js test runner
export VERIFIER_PATH="$(pwd)/Verifier.sol"
Expand Down
7 changes: 5 additions & 2 deletions barretenberg/cpp/src/barretenberg/bb/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,7 @@ bool proveAndVerifyHonkAcirFormat(acir_format::AcirFormat constraint_system, aci

// Verify Honk proof
auto verification_key = std::make_shared<VerificationKey>(prover.instance->proving_key);

Verifier verifier{ verification_key };

return verifier.verify_proof(proof);
Expand Down Expand Up @@ -589,7 +590,6 @@ void prove_tube(const std::string& output_path)

builder->add_recursive_proof(current_aggregation_object);

info("num gates in tube circuit: ", builder->get_num_gates());
using Prover = UltraProver_<UltraFlavor>;
using Verifier = UltraVerifier_<UltraFlavor>;
Prover tube_prover{ *builder };
Expand Down Expand Up @@ -819,7 +819,7 @@ void contract(const std::string& output_path, const std::string& vk_path)
*/
void contract_honk(const std::string& output_path, const std::string& vk_path)
{
using VerificationKey = UltraFlavor::VerificationKey;
using VerificationKey = UltraKeccakFlavor::VerificationKey;
using VerifierCommitmentKey = bb::VerifierCommitmentKey<curve::BN254>;

auto g2_data = get_bn254_g2_data(CRS_PATH);
Expand Down Expand Up @@ -1457,6 +1457,9 @@ int main(int argc, char* argv[])
} else if (command == "write_vk_ultra_honk") {
std::string output_path = get_option(args, "-o", "./target/vk");
write_vk_honk<UltraFlavor>(bytecode_path, output_path);
} else if (command == "write_vk_ultra_keccak_honk") {
std::string output_path = get_option(args, "-o", "./target/vk");
write_vk_honk<UltraKeccakFlavor>(bytecode_path, output_path);
} else if (command == "prove_mega_honk") {
std::string output_path = get_option(args, "-o", "./proofs/proof");
prove_honk<MegaFlavor>(bytecode_path, witness_path, output_path);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,8 @@ template <typename Builder> void generate_basic_arithmetic_circuit(Builder& buil
stdlib::field_t a(stdlib::witness_t(&builder, fr::random_element()));
stdlib::field_t b(stdlib::witness_t(&builder, fr::random_element()));
stdlib::field_t c(&builder);
size_t passes = (1UL << log2_num_gates) / 4 - 4;
// Ensure the circuit is filled but finalisation doesn't make the circuit size go to the next power of two
size_t passes = (1UL << log2_num_gates) / 4 - 8;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I will add a comment, the function fills a circuit up ot the desired numbers of gates for the benchmark, ensuring finalisation and the add gates to ensure non zero polys method wont cause it to go to the next power of 2 (or at least that was my deduction). Because we enabled poseidon add gates to ensure non zero polys will add more gates so i need to lower a bit the number of passes

if (static_cast<int>(passes) <= 0) {
throw_or_abort("too few gates");
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -105,15 +105,16 @@ bool UltraCircuitChecker::check_block(Builder& builder,
if (!result) {
return report_fail("Failed Lookup check relation at row idx = ", idx);
}
result = result && check_relation<PoseidonInternal>(values, params);
if (!result) {
return report_fail("Failed PoseidonInternal relation at row idx = ", idx);
}
result = result && check_relation<PoseidonExternal>(values, params);
if (!result) {
return report_fail("Failed PoseidonExternal relation at row idx = ", idx);
}

if constexpr (IsMegaBuilder<Builder>) {
result = result && check_relation<PoseidonInternal>(values, params);
if (!result) {
return report_fail("Failed PoseidonInternal relation at row idx = ", idx);
}
result = result && check_relation<PoseidonExternal>(values, params);
if (!result) {
return report_fail("Failed PoseidonExternal relation at row idx = ", idx);
}
result = result && check_databus_read(values, builder);
if (!result) {
return report_fail("Failed databus read at row idx = ", idx);
Expand Down Expand Up @@ -289,10 +290,10 @@ void UltraCircuitChecker::populate_values(
values.q_elliptic = block.q_elliptic()[idx];
values.q_aux = block.q_aux()[idx];
values.q_lookup = block.q_lookup_type()[idx];
values.q_poseidon2_internal = block.q_poseidon2_internal()[idx];
values.q_poseidon2_external = block.q_poseidon2_external()[idx];
if constexpr (IsMegaBuilder<Builder>) {
values.q_busread = block.q_busread()[idx];
values.q_poseidon2_internal = block.q_poseidon2_internal()[idx];
values.q_poseidon2_external = block.q_poseidon2_external()[idx];
}
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1 +1 @@
barretenberg_module(commitment_schemes_recursion commitment_schemes stdlib_primitives)
barretenberg_module(commitment_schemes_recursion commitment_schemes stdlib_poseidon2)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why do we need stdlib poseidon and not primitives for commitment schemes?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the module doesnt link without poseidon now that it's enabled and stdlib_poseidon2 already includes stdlib_primitives

Original file line number Diff line number Diff line change
Expand Up @@ -270,7 +270,7 @@ struct Transcript {
Fr beta;
Fr gamma;
Fr[NUMBER_OF_ALPHAS] alphas;
Fr[LOG_N] gateChallenges;
Fr[CONST_PROOF_SIZE_LOG_N] gateChallenges;
Fr[CONST_PROOF_SIZE_LOG_N] sumCheckUChallenges;
Fr rho;
// Zero morph
Expand All @@ -297,7 +297,7 @@ library TranscriptLib

t.gateChallenges = generateGateChallenges(t.alphas[NUMBER_OF_ALPHAS - 1]);

t.sumCheckUChallenges = generateSumcheckChallenges(proof, t.gateChallenges[LOG_N - 1]);
t.sumCheckUChallenges = generateSumcheckChallenges(proof, t.gateChallenges[CONST_PROOF_SIZE_LOG_N - 1]);
t.rho = generateRhoChallenge(proof, t.sumCheckUChallenges[CONST_PROOF_SIZE_LOG_N - 1]);

t.zmY = generateZMYChallenge(t.rho, proof);
Expand Down Expand Up @@ -385,9 +385,9 @@ library TranscriptLib
}
}

function generateGateChallenges(Fr previousChallenge) internal view returns(Fr[LOG_N] memory gateChallenges)
function generateGateChallenges(Fr previousChallenge) internal view returns(Fr[CONST_PROOF_SIZE_LOG_N] memory gateChallenges)
{
for (uint256 i = 0; i < LOG_N; i++) {
for (uint256 i = 0; i < CONST_PROOF_SIZE_LOG_N; i++) {
previousChallenge = FrLib.fromBytes32(keccak256(abi.encodePacked(Fr.unwrap(previousChallenge))));
gateChallenges[i] = previousChallenge;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,6 @@ template <class Fq, class Fr, class T> constexpr void affine_element<Fq, Fr, T>:
x.data[1] = Fq::modulus.data[1];
x.data[2] = Fq::modulus.data[2];
x.data[3] = Fq::modulus.data[3];

} else {
(*this).x = Fq::zero();
(*this).y = Fq::zero();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -701,7 +701,7 @@ TEST_F(join_split_tests, test_0_input_notes_and_detect_circuit_change)
// The below part detects any changes in the join-split circuit
constexpr size_t DYADIC_CIRCUIT_SIZE = 1 << 16;

constexpr uint256_t CIRCUIT_HASH("0x470358e4d91c4c5296ef788b1165b2c439cd498f49c3f99386b002753ca3d0ee");
constexpr uint256_t CIRCUIT_HASH("0x9170317e02f4131b84f6b4efdd3ac23e5f392d815df37750c8f05a94c64797b2");
maramihali marked this conversation as resolved.
Show resolved Hide resolved

const uint256_t circuit_hash = circuit.hash_circuit();
// circuit is finalized now
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,18 @@ typename ExecutionTrace_<Flavor>::TraceData ExecutionTrace_<Flavor>::construct_t

uint32_t offset = Flavor::has_zero_row ? 1 : 0; // Offset at which to place each block in the trace polynomials
// For each block in the trace, populate wire polys, copy cycles and selector polys
for (auto& block : builder.blocks.get()) {

// TODO(https://github.com/AztecProtocol/barretenberg/issues/1078): remove when Keccak flavor works with Poseidon
// gate
auto get_blocks = [&]() {
if constexpr (!HasKeccak<Flavor>) {
return builder.blocks.get();
} else {
return builder.blocks.get_for_ultra_keccak();
}
};

for (auto& block : get_blocks()) {
auto block_size = static_cast<uint32_t>(block.size());

// Update wire polynomials and copy cycles
Expand All @@ -76,10 +87,12 @@ typename ExecutionTrace_<Flavor>::TraceData ExecutionTrace_<Flavor>::construct_t

// Insert the selector values for this block into the selector polynomials at the correct offset
// TODO(https://github.com/AztecProtocol/barretenberg/issues/398): implicit arithmetization/flavor consistency
for (auto [selector_poly, selector] : zip_view(trace_data.selectors, block.selectors)) {
for (size_t selector_idx = 0; selector_idx < NUM_USED_SELECTORS; selector_idx++) {
auto selector_poly = trace_data.selectors[selector_idx];
auto selector = block.selectors[selector_idx];
for (size_t row_idx = 0; row_idx < block_size; ++row_idx) {
size_t trace_row_idx = row_idx + offset;
selector_poly[trace_row_idx] = selector[row_idx];
trace_data.selectors[selector_idx][trace_row_idx] = selector[row_idx];
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,16 +9,21 @@ template <class Flavor> class ExecutionTrace_ {
using Builder = typename Flavor::CircuitBuilder;
using Polynomial = typename Flavor::Polynomial;
using FF = typename Flavor::FF;
using TrackBlocks = typename Builder::Arithmetization::TraceBlocks;
using TraceBlocks = typename Builder::Arithmetization::TraceBlocks;
using Wires = std::array<SlabVector<uint32_t>, Builder::NUM_WIRES>;
using ProvingKey = typename Flavor::ProvingKey;

public:
static constexpr size_t NUM_WIRES = Builder::NUM_WIRES;

// TODO(https://github.com/AztecProtocol/barretenberg/issues/1078): Since Keccak doesn't have knowledge of Poseidon2
// gate yet, we ignore the two related selectors
static constexpr size_t NUM_USED_SELECTORS =
!HasKeccak<Flavor> ? Builder::Arithmetization::NUM_SELECTORS : Builder::Arithmetization::NUM_SELECTORS - 2;

struct TraceData {
std::array<Polynomial, NUM_WIRES> wires;
std::array<Polynomial, Builder::Arithmetization::NUM_SELECTORS> selectors;
std::array<Polynomial, NUM_USED_SELECTORS> selectors;
// A vector of sets (vectors) of addresses into the wire polynomials whose values are copy constrained
std::vector<CyclicPermutation> copy_cycles;
uint32_t ram_rom_offset = 0; // offset of the RAM/ROM block in the execution trace
Expand Down Expand Up @@ -55,7 +60,7 @@ template <class Flavor> class ExecutionTrace_ {
}
{
ZoneScopedN("selector initialization");
for (size_t idx = 0; idx < Builder::Arithmetization::NUM_SELECTORS; ++idx) {
for (size_t idx = 0; idx < NUM_USED_SELECTORS; ++idx) {
selectors[idx] = Polynomial(proving_key.circuit_size);
std::string selector_tag = builder.selector_names[idx] + "_lagrange";
proving_key.polynomial_store.put(selector_tag, selectors[idx].share());
Expand Down
3 changes: 3 additions & 0 deletions barretenberg/cpp/src/barretenberg/flavor/flavor.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -411,6 +411,9 @@ concept IsHonkFlavor = IsAnyOf<T, UltraFlavor, UltraKeccakFlavor, UltraFlavorWit
template <typename T>
concept IsUltraFlavor = IsAnyOf<T, UltraFlavor, UltraKeccakFlavor, UltraFlavorWithZK, MegaFlavor>;

template <typename T>
concept HasKeccak = IsAnyOf<T, UltraKeccakFlavor>;

template <typename T>
concept IsGoblinFlavor = IsAnyOf<T, MegaFlavor,
MegaRecursiveFlavor_<UltraCircuitBuilder>,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,10 +78,4 @@ template <typename FF, size_t NUM_WIRES, size_t NUM_SELECTORS> class ExecutionTr
void set_fixed_size(uint32_t size_in) { fixed_size = size_in; }
};

class TranslatorArith {
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This could just be moved to Translator, randomly stumbled across it

public:
static constexpr size_t NUM_WIRES = 81;
static constexpr size_t NUM_SELECTORS = 0;
};

} // namespace bb
Original file line number Diff line number Diff line change
Expand Up @@ -156,25 +156,15 @@ template <typename FF_> class MegaArith {
* conventional Ultra arithmetization
*
*/
void pad_additional()
{
q_busread().emplace_back(0);
q_poseidon2_external().emplace_back(0);
q_poseidon2_internal().emplace_back(0);
};
void pad_additional() { q_busread().emplace_back(0); };

/**
* @brief Resizes all selectors which are not part of the conventional Ultra arithmetization
* @details Facilitates reuse of Ultra gate construction functions in arithmetizations which extend the
* conventional Ultra arithmetization
* @param new_size
*/
void resize_additional(size_t new_size)
{
q_busread().resize(new_size);
q_poseidon2_external().resize(new_size);
q_poseidon2_internal().resize(new_size);
};
void resize_additional(size_t new_size) { q_busread().resize(new_size); };
};

struct TraceBlocks : public MegaTraceBlocks<MegaTraceBlock> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,16 @@ template <typename FF_> class UltraArith {
T elliptic;
T aux;
T lookup;
T poseidon_external;
T poseidon_internal;

auto get() { return RefArray{ pub_inputs, arithmetic, delta_range, elliptic, aux, lookup }; }
auto get()
{
return RefArray{ pub_inputs, arithmetic, delta_range, elliptic,
aux, lookup, poseidon_external, poseidon_internal };
}

auto get_for_ultra_keccak() { return RefArray{ pub_inputs, arithmetic, delta_range, elliptic, aux, lookup }; }

bool operator==(const UltraTraceBlocks& other) const = default;
};
Expand All @@ -38,12 +46,14 @@ template <typename FF_> class UltraArith {
this->elliptic = FIXED_SIZE;
this->aux = FIXED_SIZE;
this->lookup = FIXED_SIZE;
this->poseidon_external = FIXED_SIZE;
this->poseidon_internal = FIXED_SIZE;
}
};

public:
static constexpr size_t NUM_WIRES = 4;
static constexpr size_t NUM_SELECTORS = 11;
static constexpr size_t NUM_SELECTORS = 13;
using FF = FF_;

class UltraTraceBlock : public ExecutionTraceBlock<FF, NUM_WIRES, NUM_SELECTORS> {
Expand Down Expand Up @@ -75,6 +85,8 @@ template <typename FF_> class UltraArith {
auto& q_elliptic() { return this->selectors[8]; };
auto& q_aux() { return this->selectors[9]; };
auto& q_lookup_type() { return this->selectors[10]; };
auto& q_poseidon2_external() { return this->selectors[11]; };
auto& q_poseidon2_internal() { return this->selectors[12]; };
};

struct TraceBlocks : public UltraTraceBlocks<UltraTraceBlock> {
Expand Down Expand Up @@ -107,6 +119,12 @@ template <typename FF_> class UltraArith {
}

auto get()
{
return RefArray{ this->pub_inputs, this->arithmetic, this->delta_range, this->elliptic,
this->aux, this->lookup, this->poseidon_external, this->poseidon_internal };
}

auto get_for_ultra_keccak()
{
return RefArray{ this->pub_inputs, this->arithmetic, this->delta_range,
this->elliptic, this->aux, this->lookup };
Expand All @@ -121,6 +139,8 @@ template <typename FF_> class UltraArith {
info("elliptic :\t", this->elliptic.size());
info("auxiliary :\t", this->aux.size());
info("lookups :\t", this->lookup.size());
info("poseidon ext :\t", this->poseidon_external.size());
info("poseidon int :\t", this->poseidon_internal.size());
}

size_t get_total_structured_size()
Expand Down Expand Up @@ -152,9 +172,19 @@ template <typename FF_> class UltraArith {
};

// Note: These are needed for Plonk only (for poly storage in a std::map). Must be in same order as above struct.
inline static const std::vector<std::string> selector_names = { "q_m", "q_c", "q_1", "q_2",
"q_3", "q_4", "q_arith", "q_sort",
"q_elliptic", "q_aux", "table_type" };
inline static const std::vector<std::string> selector_names = { "q_m",
"q_c",
"q_1",
"q_2",
"q_3",
"q_4",
"q_arith",
"q_sort",
"q_elliptic",
"q_aux",
"table_type",
"q_poseidon2_external",
"q_poseidon2_internal" };
};

} // namespace bb
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ void compute_pow_poly(benchmark::State& state)
int64_t num_betas = state.range(0);
std::vector<bb::fr> cur_betas(betas.begin(), betas.begin() + num_betas);
PowPolynomial pow{ cur_betas };
pow.compute_values();
pow.compute_values(static_cast<size_t>(num_betas));
}
}

Expand Down
Loading
Loading