Skip to content

Add base fee that covers nullifier, account and output note hashes #1685

@PhilippGackstatter

Description

@PhilippGackstatter

The initial fee implementation contains only the verification_base_fee, but we need additional ones to cover the cost of inserting nullifiers and accounts into their respective tree and notes in the block note tree and potentially data storage. I'll ignore data storage in this issue since we have discussed it the least.

There are at least two approaches we've previously discussed:

  • Two separate tree_base_fee and output_note_base_fee.
  • A single hash_base_fee that covers any kind of hashing operation.

As explained here and here nullifiers + accounts and output notes are independent resources and so they shouldn't be covered by the same base fee. This suggests separate base fees.

The argument for having a single fee is that, essentially, the expensive part of inserting nullifiers, account updates or notes into the block note tree are hash operations. And so a single base fee would be sufficient, at least, conceptually. Moreover, an important resource we care about is the number of cycles a transaction adds to the batch and block kernels and input/output notes contribute to this metric (see also #1217 (reply in thread)), and so these would already be partially captured by the cycle-based verification_base_fee.

I'm honestly not sure what the better approach is, so I would default to implementing the simpler option first and if we find it is insufficient, split the hash_base_fee into two later.

Broken out of #1673.

Metadata

Metadata

Assignees

No one assigned

    Labels

    feesRelated to fees.kernelsRelated to transaction, batch, or block kernels

    Projects

    No projects

    Milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions