Divergence from Ethereum
While Sei features full EVM compatibility, there are some distinctions between Sei’s EVM and Ethereum itself:
Feature | Sei EVM | Ethereum |
---|---|---|
Blocktime | 380 ms | 12 s |
Transaction Throughput | ~ 12,500 TPS | ~ 11 TPS |
Gas per Second | ~ 25 MegaGas/s | ~ 3 MegaGas/s |
Finality | Instant | Various commitment levels (safe, latest, justified, finalized) |
Parallelized Execution | Yes | No |
Ethereum Tooling Compatibility | 100% | 100% |
EVM Version | Cancun (w/o blobs) | Cancun |
Gas Limit | 10 M | 36 M |
Byte Size Limit | 21 MB | No byte-denominated limits |
Execution Environment | EVM and CosmWasm | EVM |
Address Space | Dual ECDSA-derived addresses; sei-native Bech32 (sei…) + EVM-compatible address (0x…) | ECDSA-derived address (0x…) |
State Storage | AVL-tree (global root) | Merkle Patricia Trie (MPT) |
-
Sei uses the Cancun version of EVM, excluding the blob transactions. - Sei’s gas limit is 10 M as opposed to Ethereum’s 36 M. Sei also has a byte size limit of 21MB. - Sei has instant finality. This means the various commitment levels typical for Ethereum (i.e., safe, latest, justified) do not apply on Sei.
-
Sei is a dual-execution environment (EVM and CosmWasm). This means:
- Non-EVM transactions can update EVM-accessible state.
- For example, an account’s SEI balance can be affected by both Cosmos (bank send, wasm execute) transactions as well as EVM send transactions
- Sei assets can not only exist as EVM (i.e., ERC20/721/1155), but also as CW (i.e., CW20, CW721) or as native (Sei, IBC, Tokenfactory).
- User accounts on Sei have two addresses derived from the same public key (sei-native Bech32 and EVM-compatible 0x…)
- Non-EVM transactions can update EVM-accessible state.
Opcode Differences
PREVRANDAO
Since Sei doesn’t rely on the same pseudo-randomness way of determining the next
validator like Proof of Stake (PoS) Ethereum does, it doesn’t really have the
RANDOM
artifact that can be set as PREVRANDO
’s return value. In Sei
PREVRANDAO
is set to return the hash of the current block time. For strong
randomness guarantee needs in contracts logic, it’s advised to use external
verifiable oracles (as is advised on Ethereum itself).
COINBASE
Coinbase address on Sei is always set to (the EVM address of) the global fee collector.
State Root
Since Sei uses AVL-tree instead of Merkle Patricia Trie (MPT) for data storage, Sei doesn’t have per-account state root. The global state root is the AVL-tree root which is also not equivalent to Ethereum’s overall state root (which is a MPT root)
Block Hash
The block hash on Sei is computed based on the block header in Tendermint data format, and is different from Ethereum’s block Hash as a result.
Base Fee & Tips
Sei supports all transaction types. However for a legacy (non EIP1559) type transaction, you must specify a base fee of 1gwei. In addition to this, excess “gas wanted/gas limit” beyond the actual “gas used” may not be refunded in full or in part.
Current EIP1559 parameters can be fetched from the seid
SDK tool:
seid q params subspace evm KeyTargetGasUsedPerBlock
key: KeyTargetGasUsedPerBlock
subspace: evm
value: '"850000"'
root@ip-172-31-4-247:/home/ubuntu# seid q params subspace evm KeyMaxDynamicBaseFeeUpwardAdjustment
key: KeyMaxDynamicBaseFeeUpwardAdjustment
subspace: evm
value: '"0.007500000000000000"'
Non-EVM Transactions
On Sei there exists non-EVM transactions which may update states accessible by EVM transactions. The simplest example would be bank balances, which may be updated by both native Cosmos bank send transactions and EVM send transactions. As a result, if certain offchain applications only parse EVM transactions, they may find certain state changes unattributable to any EVM transaction.
Finality
Sei has instant finality, meaning that commitment levels of “safe”, “latest”, “justified”, and “finalized” on Ethereum are all the same thing on Sei.
Pending State
On Ethereum the block proposer would execute its proposed block first (and update its local state) before broadcasting the proposal to others (the updated state would be marked “pending” until the node is accepted by other nodes).
However, on Sei, the block proposer would broadcast first and only execute the proposal if it’s accepted (i.e. every node would execute the block at roughly the same time), so Sei does not really have a window when “pending state” exists.