Abstract’s gas fees depend on the fluctuating gas prices on Ethereum. As mentioned in the transaction lifecycle section, Abstract posts state diffs (as well as compressed contract bytecode) to Ethereum in the form of blobs.

In addition to the cost of posting blobs, there are costs associated with generating ZK proofs for batches and committing & verifying these proofs on Ethereum.

To fairly distribute these costs among L2 transactions, gas fees on Abstract are charged proportionally to how close a transaction brought a batch to being sealed (i.e. full).

Components

Fees on Abstract therefore consist of both off-chain and onchain components:

  1. Offchain Fee:
    • Fixed cost (approximately $0.001 per transaction).
    • Covers L2 state storage and zero-knowledge proof generation.
    • Independent of transaction complexity.
  2. Onchain Fee:

Differences from Ethereum

AspectEthereumAbstract
Fee CompositionEntirely onchain, consisting of base fee and priority fee.Split between offchain (fixed) and onchain (variable) components.
Pricing ModelDynamic, congestion-based model for base fee.Fixed offchain component with a variable onchain part influenced by Ethereum gas prices.
Data EfficiencyPublishes full transaction data.Publishes only state deltas, significantly reducing onchain data and costs.
Resource AllocationEach transaction independently consumes gas.Transactions share batch overhead, potentially leading to cost optimizations.
Opcode PricingEach opcode has a specific gas cost.Most opcodes have similar gas costs, simplifying estimation.
Refund HandlingLimited refund capabilities.Smarter refund system for unused resources and overpayments.

Gas Refunds

You may notice that a portion of gas fees are refunded for transactions on Abstract. This is because accounts don’t have access to the block.baseFee context variable; and have no way to know the exact fee to pay for a transaction.

Instead, the following steps occur to refund accounts for any excess funds spent on a transaction:

1

Block overhead fee deduction

Upfront, the block’s processing overhead cost is deducted.

2

Gas price calculation

The gas price for the transaction is then calculated according to the EIP-1559 rules.

3

Gas price calculation

The maximum amount of gas (gas limit) for the transaction is deducted from the account by having the account typically send tx.maxFeePerErg * tx.ergsLimit. The transaction is then executed (see transaction flow).

4

Gas refund

Since the account may have overpaid for the transaction (as they are sending the maximum fee possible), the bootloader refunds the account any excess funds that were not spent on the transaction.

Transaction Gas Fields

When creating a transaction on Abstract, you can set the gas_per_pubdata_limit value to configure the maximum gas price that can be charged per byte of pubdata (data posted to Ethereum in the form of blobs). The default value for this parameter is 50000.

Calculate Gas Fees

  1. Base Fee Determination: When a batch opens, Abstract calculates the FAIR_GAS_PER_PUBDATA_BYTE (EPf):
EPf = ⌈(Ef) / (L1_P * L1_PUB)⌉
  • Ef is the “fair” gas price in ETH
  • L1_P is the price for L1 gas in ETH
  • L1_PUB is the number of L1 gas needed for a single pubdata byte
  1. Overhead Calculation: For each transaction, Abstract calculates several types of overhead:

The total overhead is the maximum of these:

  • Slot overhead (SO)
  • Memory overhead (MO)
  • Execution overhead (EAO)
  • O(tx) = max(SO, MO(tx), EAO(tx))
  1. Gas Limit Estimation: When estimating a transaction, the server returns:
tx.gasLimit = tx.actualGasLimit + overhead_gas(tx)
  1. Actual Fee Calculation: The actual fee a user pays is:
ActualFee = gasSpent * gasPrice
  1. Fair Fee Calculation: Abstract calculates a “fair fee”:
FairFee = Ef * tx.computationalGas + EPf * pubdataUsed
  1. Refund Calculation: If the actual fee exceeds the fair fee, a refund is issued:
Refund = (ActualFee - FairFee) / Base