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(avm): kernel output opcodes #6416

Merged
merged 80 commits into from
May 28, 2024
Merged
Changes from 1 commit
Commits
Show all changes
80 commits
Select commit Hold shift + click to select a range
8853132
avm_logderivative
Maddiaa0 Apr 3, 2024
abc3cba
temp: chall line up
Maddiaa0 Apr 4, 2024
8b88dcd
fix: degree too low for lookup relations
Maddiaa0 Apr 5, 2024
c8d9601
chore: rename validate trace proof to check circuit, make another met…
Maddiaa0 Apr 5, 2024
c695905
chore: remove dangling code
Maddiaa0 Apr 5, 2024
40eeb8f
Merge branch 'master' into md/04-03-avm_logderivative
Maddiaa0 Apr 5, 2024
619175b
chore: further cleanup
Maddiaa0 Apr 5, 2024
65c3159
chore: from powdr codegen
Maddiaa0 Apr 8, 2024
61d10f6
temp
Maddiaa0 Apr 11, 2024
7e84550
feat: bb support for public input columns
Maddiaa0 Apr 11, 2024
c054aca
Merge branch 'master' into md/04-11-feat_bb_support_for_public_input_…
Maddiaa0 Apr 11, 2024
f38773f
merge fixy
Maddiaa0 Apr 11, 2024
a4262dc
chore: test structure
Maddiaa0 Apr 11, 2024
cf4bb86
🧹
Maddiaa0 Apr 11, 2024
12a9789
use pilgen
Maddiaa0 Apr 12, 2024
14d15cc
Merge branch 'master' into md/04-11-feat_bb_support_for_public_input_…
Maddiaa0 Apr 12, 2024
b0f8041
feat: example caller and address opcode
Maddiaa0 Apr 12, 2024
d5813a2
feat: generalise builder, move after review
Maddiaa0 Apr 15, 2024
6265c61
Merge branch 'master' into md/04-12-feat_example_caller_and_address_o…
Maddiaa0 Apr 17, 2024
59b221c
fix: add tests for all call context opcodes
Maddiaa0 Apr 18, 2024
b613cf5
Merge branch 'master' into md/04-11-feat_bb_support_for_public_input_…
Maddiaa0 Apr 18, 2024
81a2500
Merge branch 'md/04-11-feat_bb_support_for_public_input_columns' into…
Maddiaa0 Apr 18, 2024
c934c61
chore: update pil comments
Maddiaa0 Apr 18, 2024
a8ceaf8
fix: remove redundant comment
Maddiaa0 Apr 18, 2024
af343db
fix: some negative tests
Maddiaa0 Apr 21, 2024
9388ecc
temp
Maddiaa0 Apr 29, 2024
9e7aad0
Merge branch 'master' into md/04-12-feat_example_caller_and_address_o…
Maddiaa0 May 7, 2024
859a3df
chore: remove l1 gas - no longer exists
Maddiaa0 May 7, 2024
b4a47b3
chore: rearrange where relations live, based on review
Maddiaa0 May 7, 2024
79cf849
Merge branch 'master' into md/04-11-feat_bb_support_for_public_input_…
Maddiaa0 May 7, 2024
faac5b1
chore: update codegen
Maddiaa0 May 7, 2024
7e70e7d
Merge branch 'md/04-11-feat_bb_support_for_public_input_columns' into…
Maddiaa0 May 7, 2024
4bb42b8
feat: add cpp constants gen to calculate kernel offsets
Maddiaa0 May 8, 2024
bccfd67
feat: add global variable opcodes
Maddiaa0 May 8, 2024
2a74110
fix: transaction fee selector test
Maddiaa0 May 8, 2024
1285ccf
fix: update tags to line up with kernel
Maddiaa0 May 8, 2024
60836ca
Merge branch 'master' into md/04-12-feat_example_caller_and_address_o…
Maddiaa0 May 8, 2024
e2bcca8
feat: parallelise check circuit relations
Maddiaa0 May 8, 2024
7bff191
fix: forge fmt after constant gen
Maddiaa0 May 8, 2024
115f17c
fix: no futures for wasm builds
Maddiaa0 May 8, 2024
de663f1
feat: fix segfaults in parallel circuit checking
Maddiaa0 May 9, 2024
c910000
fix: missed log
Maddiaa0 May 9, 2024
fd728c7
fix: incorrect kernel tests
Maddiaa0 May 9, 2024
66f958e
Merge branch 'master' into md/04-11-feat_bb_support_for_public_input_…
Maddiaa0 May 9, 2024
ecdf742
🧹
Maddiaa0 May 9, 2024
3f31357
Merge branch 'md/04-11-feat_bb_support_for_public_input_columns' into…
Maddiaa0 May 9, 2024
d6aeda8
feat: use codegen, vector public inputs - pubs now misaligned
Maddiaa0 May 9, 2024
ea48aca
fix: update codegen
Maddiaa0 May 9, 2024
e1e2cb8
fix: remove legacy codegen files
Maddiaa0 May 10, 2024
3be1242
Merge branch 'master' into md/04-12-feat_example_caller_and_address_o…
Maddiaa0 May 10, 2024
bee84aa
fix: relation tags + removal of function opcode
Maddiaa0 May 10, 2024
449f3da
fmt fix
Maddiaa0 May 10, 2024
a6470d7
kernel_outputs
Maddiaa0 May 10, 2024
94269ae
feat: codegen cols
Maddiaa0 May 10, 2024
3d6633b
feat: first implementation of emit note hash
Maddiaa0 May 14, 2024
25e31bd
feat: add emit nullfier, l2 to l1 msg, unencrypted log
Maddiaa0 May 14, 2024
963dbf6
fix: mixup of emit l2 to l1 msg, l1 to l2 exists
Maddiaa0 May 15, 2024
d465a04
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 15, 2024
c45c666
feat: sload and sstore
Maddiaa0 May 15, 2024
036910e
merge master
Maddiaa0 May 15, 2024
9774d95
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 15, 2024
c1c4f21
fix: alter exists opcodes to all use fields
Maddiaa0 May 16, 2024
c88d5ef
fix: different in and out tags for exists opcodes
Maddiaa0 May 16, 2024
c5847b2
feat: use pil generated public input columns
Maddiaa0 May 16, 2024
70a6e86
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 16, 2024
f8e8349
fix: dirty merge
Maddiaa0 May 16, 2024
289c302
fix: annotate todos
Maddiaa0 May 16, 2024
17640ef
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 16, 2024
7e120ad
fix: incorrect offset in emitNoteHash test
Maddiaa0 May 17, 2024
0dc2c58
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 17, 2024
6b2bfd6
fix: review
Maddiaa0 May 23, 2024
3e85832
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 23, 2024
1922ccb
fix: add more constants to constant gen
Maddiaa0 May 23, 2024
9dca2e2
fix: add call_ptrs
Maddiaa0 May 23, 2024
f9cf428
fmt
Maddiaa0 May 23, 2024
cb1f006
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 27, 2024
1bdb64f
fix: share public inputs construction in executor
Maddiaa0 May 27, 2024
17c216b
fix: typo
Maddiaa0 May 27, 2024
c714d7f
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 27, 2024
b95b838
Merge branch 'master' into md/05-10-kernel_outputs
Maddiaa0 May 28, 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
Prev Previous commit
Next Next commit
chore: from powdr codegen
Maddiaa0 committed Apr 8, 2024

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
commit 65c3159dc14e1f2898d544b17720e5458918af57
Original file line number Diff line number Diff line change
@@ -181,18 +181,18 @@ template <typename FF_> class avm_aluImpl {
{
Avm_DECLARE_VIEWS(9);

auto tmp =
(((avm_alu_op_add + avm_alu_op_sub) *
((((((((((avm_alu_u8_r0 + (avm_alu_u8_r1 * FF(256))) + (avm_alu_u16_r0 * FF(65536))) +
(avm_alu_u16_r1 * FF(4294967296UL))) +
(avm_alu_u16_r2 * FF(281474976710656UL))) +
(avm_alu_u16_r3 * FF(uint256_t{ 0, 1, 0, 0 }))) +
(avm_alu_u16_r4 * FF(uint256_t{ 0, 65536, 0, 0 }))) +
(avm_alu_u16_r5 * FF(uint256_t{ 0, 4294967296, 0, 0 }))) +
(avm_alu_u16_r6 * FF(uint256_t{ 0, 281474976710656, 0, 0 }))) -
avm_alu_ia) +
(avm_alu_ff_tag * avm_alu_ic))) +
((avm_alu_op_add - avm_alu_op_sub) * ((avm_alu_cf * FF(uint256_t{ 0, 0, 1, 0 })) - avm_alu_ib)));
auto tmp = (((avm_alu_op_add + avm_alu_op_sub) *
((((((((((avm_alu_u8_r0 + (avm_alu_u8_r1 * FF(256))) + (avm_alu_u16_r0 * FF(65536))) +
(avm_alu_u16_r1 * FF(4294967296UL))) +
(avm_alu_u16_r2 * FF(281474976710656UL))) +
(avm_alu_u16_r3 * FF(uint256_t{ 0UL, 1UL, 0UL, 0UL }))) +
(avm_alu_u16_r4 * FF(uint256_t{ 0UL, 65536UL, 0UL, 0UL }))) +
(avm_alu_u16_r5 * FF(uint256_t{ 0UL, 4294967296UL, 0UL, 0UL }))) +
(avm_alu_u16_r6 * FF(uint256_t{ 0UL, 281474976710656UL, 0UL, 0UL }))) -
avm_alu_ia) +
(avm_alu_ff_tag * avm_alu_ic))) +
((avm_alu_op_add - avm_alu_op_sub) *
((avm_alu_cf * FF(uint256_t{ 0UL, 0UL, 1UL, 0UL })) - avm_alu_ib)));
tmp *= scaling_factor;
std::get<9>(evals) += tmp;
}
@@ -213,10 +213,10 @@ template <typename FF_> class avm_aluImpl {
((((((((avm_alu_u8_r0 + (avm_alu_u8_r1 * FF(256))) + (avm_alu_u16_r0 * FF(65536))) +
(avm_alu_u16_r1 * FF(4294967296UL))) +
(avm_alu_u16_r2 * FF(281474976710656UL))) +
(avm_alu_u16_r3 * FF(uint256_t{ 0, 1, 0, 0 }))) +
(avm_alu_u16_r4 * FF(uint256_t{ 0, 65536, 0, 0 }))) +
(avm_alu_u16_r5 * FF(uint256_t{ 0, 4294967296, 0, 0 }))) +
(avm_alu_u16_r6 * FF(uint256_t{ 0, 281474976710656, 0, 0 }))))) +
(avm_alu_u16_r3 * FF(uint256_t{ 0UL, 1UL, 0UL, 0UL }))) +
(avm_alu_u16_r4 * FF(uint256_t{ 0UL, 65536UL, 0UL, 0UL }))) +
(avm_alu_u16_r5 * FF(uint256_t{ 0UL, 4294967296UL, 0UL, 0UL }))) +
(avm_alu_u16_r6 * FF(uint256_t{ 0UL, 281474976710656UL, 0UL, 0UL }))))) +
(avm_alu_ff_tag * avm_alu_ia)) -
avm_alu_ic)) +
((avm_alu_ff_tag * (avm_alu_op_add - avm_alu_op_sub)) * avm_alu_ib));
@@ -239,10 +239,10 @@ template <typename FF_> class avm_aluImpl {
(((((((((avm_alu_u8_r0 + (avm_alu_u8_r1 * FF(256))) + (avm_alu_u16_r0 * FF(65536))) +
(avm_alu_u16_r1 * FF(4294967296UL))) +
(avm_alu_u16_r2 * FF(281474976710656UL))) +
(avm_alu_u16_r3 * FF(uint256_t{ 0, 1, 0, 0 }))) +
(avm_alu_u16_r4 * FF(uint256_t{ 0, 65536, 0, 0 }))) +
(avm_alu_u16_r5 * FF(uint256_t{ 0, 4294967296, 0, 0 }))) +
(avm_alu_u16_r6 * FF(uint256_t{ 0, 281474976710656, 0, 0 }))) -
(avm_alu_u16_r3 * FF(uint256_t{ 0UL, 1UL, 0UL, 0UL }))) +
(avm_alu_u16_r4 * FF(uint256_t{ 0UL, 65536UL, 0UL, 0UL }))) +
(avm_alu_u16_r5 * FF(uint256_t{ 0UL, 4294967296UL, 0UL, 0UL }))) +
(avm_alu_u16_r6 * FF(uint256_t{ 0UL, 281474976710656UL, 0UL, 0UL }))) -
(avm_alu_ia * avm_alu_ib)));
tmp *= scaling_factor;
std::get<12>(evals) += tmp;
@@ -272,7 +272,7 @@ template <typename FF_> class avm_aluImpl {
(avm_alu_u16_r3 * FF(281474976710656UL))) +
((((avm_alu_u16_r4 + (avm_alu_u16_r5 * FF(65536))) + (avm_alu_u16_r6 * FF(4294967296UL))) +
(avm_alu_u16_r7 * FF(281474976710656UL))) *
FF(uint256_t{ 0, 1, 0, 0 }))) -
FF(uint256_t{ 0UL, 1UL, 0UL, 0UL }))) -
avm_alu_ia));
tmp *= scaling_factor;
std::get<14>(evals) += tmp;
@@ -288,7 +288,7 @@ template <typename FF_> class avm_aluImpl {
((((avm_alu_u16_r4_shift + (avm_alu_u16_r5_shift * FF(65536))) +
(avm_alu_u16_r6_shift * FF(4294967296UL))) +
(avm_alu_u16_r7_shift * FF(281474976710656UL))) *
FF(uint256_t{ 0, 1, 0, 0 }))) -
FF(uint256_t{ 0UL, 1UL, 0UL, 0UL }))) -
avm_alu_ib));
tmp *= scaling_factor;
std::get<15>(evals) += tmp;
@@ -297,19 +297,19 @@ template <typename FF_> class avm_aluImpl {
{
Avm_DECLARE_VIEWS(16);

auto tmp =
((avm_alu_u128_tag * avm_alu_op_mul) *
((((avm_alu_ia * (((avm_alu_u16_r0_shift + (avm_alu_u16_r1_shift * FF(65536))) +
(avm_alu_u16_r2_shift * FF(4294967296UL))) +
(avm_alu_u16_r3_shift * FF(281474976710656UL)))) +
(((((avm_alu_u16_r0 + (avm_alu_u16_r1 * FF(65536))) + (avm_alu_u16_r2 * FF(4294967296UL))) +
(avm_alu_u16_r3 * FF(281474976710656UL))) *
(((avm_alu_u16_r4_shift + (avm_alu_u16_r5_shift * FF(65536))) +
(avm_alu_u16_r6_shift * FF(4294967296UL))) +
(avm_alu_u16_r7_shift * FF(281474976710656UL)))) *
FF(uint256_t{ 0, 1, 0, 0 }))) -
(((avm_alu_cf * FF(uint256_t{ 0, 1, 0, 0 })) + avm_alu_u64_r0) * FF(uint256_t{ 0, 0, 1, 0 }))) -
avm_alu_ic));
auto tmp = ((avm_alu_u128_tag * avm_alu_op_mul) *
((((avm_alu_ia * (((avm_alu_u16_r0_shift + (avm_alu_u16_r1_shift * FF(65536))) +
(avm_alu_u16_r2_shift * FF(4294967296UL))) +
(avm_alu_u16_r3_shift * FF(281474976710656UL)))) +
(((((avm_alu_u16_r0 + (avm_alu_u16_r1 * FF(65536))) + (avm_alu_u16_r2 * FF(4294967296UL))) +
(avm_alu_u16_r3 * FF(281474976710656UL))) *
(((avm_alu_u16_r4_shift + (avm_alu_u16_r5_shift * FF(65536))) +
(avm_alu_u16_r6_shift * FF(4294967296UL))) +
(avm_alu_u16_r7_shift * FF(281474976710656UL)))) *
FF(uint256_t{ 0UL, 1UL, 0UL, 0UL }))) -
(((avm_alu_cf * FF(uint256_t{ 0UL, 1UL, 0UL, 0UL })) + avm_alu_u64_r0) *
FF(uint256_t{ 0UL, 0UL, 1UL, 0UL }))) -
avm_alu_ic));
tmp *= scaling_factor;
std::get<16>(evals) += tmp;
}
@@ -328,8 +328,8 @@ template <typename FF_> class avm_aluImpl {
auto tmp = (avm_alu_op_not *
((avm_alu_ia + avm_alu_ic) - ((((((avm_alu_u8_tag * FF(256)) + (avm_alu_u16_tag * FF(65536))) +
(avm_alu_u32_tag * FF(4294967296UL))) +
(avm_alu_u64_tag * FF(uint256_t{ 0, 1, 0, 0 }))) +
(avm_alu_u128_tag * FF(uint256_t{ 0, 0, 1, 0 }))) -
(avm_alu_u64_tag * FF(uint256_t{ 0UL, 1UL, 0UL, 0UL }))) +
(avm_alu_u128_tag * FF(uint256_t{ 0UL, 0UL, 1UL, 0UL }))) -
FF(1))));
tmp *= scaling_factor;
std::get<18>(evals) += tmp;
Original file line number Diff line number Diff line change
@@ -344,8 +344,6 @@ class AvmCircuitBuilder {
polys.avm_mem_tag_err[i] = rows[i].avm_mem_tag_err;
polys.avm_mem_val[i] = rows[i].avm_mem_val;
polys.avm_mem_w_in_tag[i] = rows[i].avm_mem_w_in_tag;
polys.perm_main_alu[i] = rows[i].perm_main_alu;

polys.lookup_byte_lengths_counts[i] = rows[i].lookup_byte_lengths_counts;
polys.lookup_byte_operations_counts[i] = rows[i].lookup_byte_operations_counts;
polys.incl_main_tag_err_counts[i] = rows[i].incl_main_tag_err_counts;
48 changes: 11 additions & 37 deletions barretenberg/cpp/src/barretenberg/vm/generated/avm_flavor.hpp
Original file line number Diff line number Diff line change
@@ -64,10 +64,10 @@ class AvmFlavor {
perm_main_mem_ind_a_relation<FF>,
perm_main_mem_ind_b_relation<FF>,
perm_main_mem_ind_c_relation<FF>,
incl_main_tag_err_relation<FF>,
incl_mem_tag_err_relation<FF>,
lookup_byte_lengths_relation<FF>,
lookup_byte_operations_relation<FF>>;
lookup_byte_operations_relation<FF>,
incl_main_tag_err_relation<FF>,
incl_mem_tag_err_relation<FF>>;

using Relations = std::tuple<Avm_vm::avm_alu<FF>,
Avm_vm::avm_binary<FF>,
@@ -81,10 +81,10 @@ class AvmFlavor {
perm_main_mem_ind_a_relation<FF>,
perm_main_mem_ind_b_relation<FF>,
perm_main_mem_ind_c_relation<FF>,
incl_main_tag_err_relation<FF>,
incl_mem_tag_err_relation<FF>,
lookup_byte_lengths_relation<FF>,
lookup_byte_operations_relation<FF>>;
lookup_byte_operations_relation<FF>,
incl_main_tag_err_relation<FF>,
incl_mem_tag_err_relation<FF>>;

static constexpr size_t MAX_PARTIAL_RELATION_LENGTH = compute_max_partial_relation_length<Relations>();

@@ -917,9 +917,6 @@ class AvmFlavor {
avm_mem_val };
};

// The plookup wires that store plookup read data.
std::array<PolynomialHandle, 0> get_table_column_wires() { return {}; };

void compute_logderivative_inverses(const RelationParameters<FF>& relation_parameters)
{
ProverPolynomials prover_polynomials = ProverPolynomials(*this);
@@ -940,35 +937,18 @@ class AvmFlavor {
prover_polynomials, relation_parameters, this->circuit_size);
bb::compute_logderivative_inverse<AvmFlavor, perm_main_mem_ind_c_relation<FF>>(
prover_polynomials, relation_parameters, this->circuit_size);
bb::compute_logderivative_inverse<AvmFlavor, incl_main_tag_err_relation<FF>>(
prover_polynomials, relation_parameters, this->circuit_size);
bb::compute_logderivative_inverse<AvmFlavor, incl_mem_tag_err_relation<FF>>(
prover_polynomials, relation_parameters, this->circuit_size);
bb::compute_logderivative_inverse<AvmFlavor, lookup_byte_lengths_relation<FF>>(
prover_polynomials, relation_parameters, this->circuit_size);
bb::compute_logderivative_inverse<AvmFlavor, lookup_byte_operations_relation<FF>>(
prover_polynomials, relation_parameters, this->circuit_size);
bb::compute_logderivative_inverse<AvmFlavor, incl_main_tag_err_relation<FF>>(
prover_polynomials, relation_parameters, this->circuit_size);
bb::compute_logderivative_inverse<AvmFlavor, incl_mem_tag_err_relation<FF>>(
prover_polynomials, relation_parameters, this->circuit_size);
}
};

class VerificationKey : public VerificationKey_<PrecomputedEntities<Commitment>, VerifierCommitmentKey> {
public:
VerificationKey() = default;
VerificationKey(const size_t circuit_size, const size_t num_public_inputs)
: VerificationKey_(circuit_size, num_public_inputs)
{}

VerificationKey(ProvingKey& proving_key)
{
this->pcs_verification_key = std::make_shared<VerifierCommitmentKey>();
this->circuit_size = proving_key.circuit_size;
this->log_circuit_size = numeric::get_msb(this->circuit_size);

for (auto [polynomial, commitment] : zip_view(proving_key.get_precomputed_polynomials(), this->get_all())) {
commitment = proving_key.commitment_key->commit(polynomial);
}
}
};
using VerificationKey = VerificationKey_<PrecomputedEntities<Commitment>, VerifierCommitmentKey>;

using FoldedPolynomials = AllEntities<std::vector<FF>>;

@@ -991,7 +971,6 @@ class AvmFlavor {
ProverPolynomials& operator=(ProverPolynomials&& o) noexcept = default;
~ProverPolynomials() = default;

// NOTE: copied from goblin ultra
ProverPolynomials(ProvingKey& proving_key)
{
for (auto [prover_poly, key_poly] : zip_view(this->get_unshifted(), proving_key.get_all())) {
@@ -1339,8 +1318,6 @@ class AvmFlavor {
Commitment avm_mem_tag_err;
Commitment avm_mem_val;
Commitment avm_mem_w_in_tag;

// Perm inverses
Commitment perm_main_alu;
Commitment perm_main_bin;
Commitment perm_main_mem_a;
@@ -1349,13 +1326,10 @@ class AvmFlavor {
Commitment perm_main_mem_ind_a;
Commitment perm_main_mem_ind_b;
Commitment perm_main_mem_ind_c;
// Lookup inverses
Commitment lookup_byte_lengths;
Commitment lookup_byte_operations;
Commitment incl_main_tag_err;
Commitment incl_mem_tag_err;

// Lookup counts
Commitment lookup_byte_lengths_counts;
Commitment lookup_byte_operations_counts;
Commitment incl_main_tag_err_counts;
Loading