What is the significance of parallelizing the EVM? Or is it the endgame under the EVM hegemony?
Author: ZHIXIONG PAN
TL;DR
-
Several top VCs are betting on the concept of Parallel EVM: Paradigm, Jump, Dragonfly, etc.
-
The representative projects include Monad, as well as Sei, MegaETH, Polygon, Neon EVM, BSC, etc. Some are L1, some are L2. There is currently no complete public information on the specific differences between the teams.
-
Although the literal meaning of Parallel EVM only represents "parallelization," it is actually a specialized optimization of the performance of various components of EVM. Therefore, its efforts are likely to represent the performance limit under the EVM standard.
-
Challenges: In addition to the need to refactor the entire technology stack, there is also the issue of how to predict in advance whether parallel transactions will conflict, and the efficiency of re-execution in case of conflicts.
-
Challenge: How to build differentiation in the open-source ecosystem, and how to find a balance between decentralization and performance.
After consensus algorithms, DA (data layer), and zero-knowledge proof technology have been widely researched and iterated, the next hardcore technology to be focused on is Parallel EVM. The capital market has already invested hundreds of millions of dollars in this narrative and has given birth to several unicorn-level startups.
The community began to pay attention to Parallel EVM (EVM parallelization) when Georgios Konstantopoulos (CTO of Paradigm) and Haseeb Qureshi of Dragonfly coincidentally mentioned this same keyword at the end of 2023 when looking ahead to the trends of 2024. However, there are not many details discussed about this topic, and many people do not consider it a new concept. Both EVM and parallel computing are relatively mature concepts, so why is combining these two terms considered an important trend?
But this is still a very niche topic, to the extent that if you look through the annual summaries and trend forecasts of many research institutions, Parallel EVM is not mentioned. So this is still a new concept that has not formed a large-scale consensus. Moreover, similar to concepts like consensus algorithms and DA, this is purely technically related, so the audience paying attention is even smaller.
The most direct advantage of Parallel EVM is enabling existing decentralized applications to achieve Internet-level performance. It can even be said that Parallel EVM is the only new technology that can both utilize (a large number of mature) existing smart contracts and achieve high-performance, parallel public chain throughput.
Paradigm has been looking forward to entering the game for a long time, Jump is heavily invested
According to "Fortune," Paradigm is planning to lead the latest round of funding for Monad, raising $200 million at a valuation of $3 billion. Although this is the first team with a Parallel EVM concept that Paradigm plans to invest in, they have actually been paying attention to this technology for many years. Georgios Konstantopoulos (CTO of Paradigm) mentioned this term back in 2021.
The origin of the word Monad is also interesting. In the philosopher Leibniz's philosophical system, Monad is the basic element that makes up the universe. They are indivisible entities that are not affected by physical influences, and each Monad reflects the entire universe, translated into Chinese as "单子."
In computer science, Monad is a design pattern in functional programming languages that helps programmers deal with the complexity of the real world with almost mathematical purity, making the code more modular, easy to understand, and maintain.
Another interesting fact is that Monad and Nomad are anagrams of each other, where nomad refers to a wanderer, and digital nomad refers to a digital wanderer.
In addition to Monad, Georgios also mentioned Sei and Polygon when discussing this topic. However, another important reason he is so optimistic about Parallel EVM is that they have developed an Ethereum client called Reth. It is positioned as a high-performance Ethereum execution layer client implemented in Rust. Reth is developing at a fast pace and has just entered the Beta stage. Perhaps they will consider implementing Parallel EVM directly on Reth, but considering the amount of engineering work, it may be a better choice to promote Parallel EVM through investing in other teams. According to Monad's documentation, they mainly use C++ and Rust in their engineering.
When Reth was first launched, it was accused by members of the Erigon team of plagiarizing their open-source code Akula, which also led to a lack of funding for the Akula project. Georgios responded that Reth is not a fork of any other client, and the code is not derived from any other client, but it is indeed influenced and inspired by Geth, Erigon, and Akula. (https://thedefiant.io/paradigm-accused-copying-code)
Another core participant is Jump Trading and Jump Capital, with the founder of Monad coming from Jump Trading, having extensive experience in high-frequency trading; Sei's investors include Jump Capital, and Jump has been deeply involved in the Solana ecosystem, including infrastructure and projects.
Early investors in Monad, Dragonfly, have also been paying attention to related tracks, having invested in NEAR, which focuses on sharding technology, as well as Aptos, Avalanche, Nervos, and other public chains.
Upgrading consensus algorithms is not enough, it's finally the turn of the execution layer
In the past few public chain battles, the execution layer has always been overlooked, with almost exclusive focus on innovative consensus algorithms, whether it's Solana, Avalanche, or EOS, etc. Although they have many innovations in the execution layer, the community mostly remembers the consensus algorithms they use, and the entire community also tends to think that the performance of these high-performance public chains comes from the innovative consensus algorithms.
However, if you want to have a high-performance public chain, both the consensus algorithm and the execution layer need to be complementary, which also aligns with the principle of the weakest link in a chain. For those public chains based on EVM and only improving the consensus algorithm, increasing performance requires stronger nodes. For example, referring to BSC limiting the block Gas processing to a level of 2000 TPS, the machine configuration required is several times that of an Ethereum full node. Polygon theoretically can achieve 1000 TPS, but usually only reaches tens to hundreds.
BSC archive nodes require at least 16-core CPUs and 128GB of memory, while Ethereum nodes only require at least 4-core CPUs and 16GB of memory.
The BSC team has long been aware of these issues, so they are also collaborating with NodeReal to develop Parallel EVM technology. Only in this way can the number of transactions processed per block be further increased, allowing more transactions to be executed in parallel and increasing the upper limit of TPS.
Parallel: Upgrading from a single-core to a multi-core CPU
In most blockchain systems, transactions are executed strictly in order, similar to a single-core CPU, where the next calculation can only be performed after the current one is completed. Although this method is slow, its advantage lies in its simplicity and low system complexity.
However, if future blockchain systems need to accommodate Internet-level user scales, a single-core CPU will definitely not be sufficient. Therefore, upgrading to a multi-core CPU parallelized virtual machine can process multiple transactions simultaneously, increasing throughput. However, there are many challenges in engineering implementation, such as what to do if two transactions being processed simultaneously write data to the same smart contract? This requires designing a new
Mechanisms to resolve this contradiction. For the parallel execution of other completely unrelated smart contracts, the throughput can be increased according to the number of parallel processing threads.Furthermore, Parallel EVM not only enhances parallel capabilities but also optimizes the efficiency of single-thread execution. Monad CEO Keone Hon stated, "...(EVM's) real bottleneck lies in frequent reads and writes of states...". He also mentioned that parallel execution is just part of the roadmap, and Monad's greater mission is to optimize EVM to be as efficient as possible.
Therefore, although Parallel EVM literally represents "parallelization," it is also a specialized optimization of the performance of various components of EVM. Therefore, its efforts likely represent the performance limit under the EVM standard.
EVM is not equal to Solidity
Writing smart contracts is a necessary skill for most blockchain developers. Engineers can write corresponding logic implementations based on business requirements using Solidity or other high-level languages for smart contracts. However, EVM cannot directly understand the logic of Solidity; it needs some "translation" to be translated (compiled) into a low-level language that machines can understand (opcode / bytecode) before it can be executed by the virtual machine. Solidity developers do not need to understand this translation process because mature tools have already implemented it.
Since it is a "translation," there will be some overhead involved. For engineers with experience in low-level code, they can directly write program logic using opcodes in Solidity, achieving the highest efficiency, which means saving gas for user transactions. For example, Opensea's Seaport protocol extensively uses inline assembly in smart contracts to minimize gas expenditure for users.
Therefore, if Parallel EVM can be eventually implemented, it will not only bring parallel capabilities but also optimize the performance of the entire EVM stack. Ordinary application developers will not need to expend significant efforts to optimize just to save a bit of gas because the underlying virtual machine is already powerful enough to bridge these differences.
Differences in EVM Performance, "Standard" Does Not Equal "Engineering Practice"
"Virtual machine" can also be referred to as the "execution layer," which is the engine where smart contracts are compiled into opcodes and ultimately computed and processed. The "bytecode" defined by the Ethereum Virtual Machine (EVM) has become an industry standard, and whether based on Ethereum's layer 2 networks or other independent public chains, they prefer to directly and fully compatible with the EVM standard. Developers can write a smart contract once and deploy it to multiple networks, which is highly cost-effective.
As long as it fully complies with the "bytecode" standard compatible with EVM, it can be called EVM, but the implementation methods can vary greatly. For example, the Ethereum client Geth implemented the EVM standard using the Go language. However, the Ethereum Foundation's execution layer research team Ipsilon maintains an EVM independent implementation developed in C++, which other Ethereum clients can directly call as the EVM execution.
For example, many industrially produced products have corresponding international standards. For instance, a product must meet a specific value of bacterial count before it can be sold, which is the "standard." However, each factory can choose from dozens of different sterilization methods to meet this requirement, and some factories may find a more cost-effective way to meet this requirement, which is the "practice."
Since there is an implementation like evmone, other implementations can also be done. Therefore, in this example of EVM, the EVM standard defines some basic operation methods "bytecode" (such as supporting basic arithmetic operations like addition, subtraction, multiplication), where each bytecode has a specific input, resulting in a specific output. While meeting this standard, the implementation (practice) methods can vary significantly, offering a lot of customization space and engineering optimization possibilities.
Similarities and Differences of Parallel EVM
In the Parallel EVM track, apart from the most popular Monad, there are also Sei, MegaETH, Polygon, Neon EVM, BSC, and Paradigm's Reth client also aims to implement parallelization.
In terms of positioning, Monad, Sei, Polygon, BSC are all Layer 1 blockchains, while MegaETH may be Layer 2, and Neon EVM is based on the Solana network. In addition, Reth is an open-source client, and MegaETH will also continue development based on some of Reth's engineering.
Of course, there is competition among these teams, and not all technical details and engineering files have been fully disclosed. More comparisons will have to wait for them to gradually open up in the future. Perhaps this is like an arms race, similar to BTC Layer 2, Restaking, Ethereum Layer 2, despite the subtle technical differences (and being open-source), the key is how to build the uniqueness of the ecosystem.
Technical Challenges of Parallel EVM
For sequentially executed transactions, the bottleneck lies in the CPU and the process of reading and writing states. However, the advantage of this method is that it is simple enough, error-free, and all transactions can be executed step by step. For a virtual machine that executes in parallel, there may be state conflicts, so additional checks need to be added before or after execution.
A simple example is, if the virtual machine supports four threads for parallel execution, and each thread can process a transaction simultaneously, if all four transactions are related to the same transaction pool on Uniswap, then parallel computation cannot be done because each transaction will affect the transaction price of this pool. However, if these four threads are processing four completely unrelated tasks simultaneously, then there is no issue.
This involves the design and engineering implementation of different teams, but it is essential to ensure that after parallel execution, there needs to be a module to detect conflicts and re-execute if conflicts are encountered. Of course, if potential conflicting transactions can be predicted and screened in advance, it can also increase the overall parallel efficiency of the virtual machine.
In addition to the engineering implementation differences of Parallel EVM, each team generally redesigns and enhances the read/write performance of the state database and designs a consensus algorithm, such as Monad's MonadDb and MonadBFT.
Challenges
For Parallel EVM, there are two potential challenges: whether the long-term engineering value will be captured by Ethereum and centralization of nodes.
Since various teams are still in the development and testing stages of Parallel EVM technology, none have chosen to open-source all engineering details yet, which is one of the current moats. However, once they enter the testnet and mainnet, these engineering files will be made public and may be absorbed by Ethereum or other public chains. Therefore, at that time, it will be necessary to accelerate ecosystem development and build more moats at the ecosystem level.
However, this issue is not so severe. On the one hand, for crypto developers, there are now more open-source licenses to choose from (such as Uniswap's type of license that allows code to be made public but prohibits forking into commercial projects), and on the other hand, Monad's positioning is already different from Ethereum. Even if Ethereum can achieve single-slot finality (SSF) in the future, the finality of transactions is at least 12 seconds, which is not sufficient for higher-frequency use cases.
Another challenge common to all high-performance public chains is how to deploy more nodes to meet the basic requirements of permissionless and trustless for users: decentralization. Perhaps some metrics can be quantified, such as "TPS divided by the hardware requirements of nodes," so that variable control can be achieved to compare which public chain/client has a higher TPS under specific hardware requirements. After all, the lower the hardware requirements of nodes, the more nodes can be deployed.
Next, we will continue to track the progress of various projects related to Parallel EVM and delve into their technologies and differences in detail.
Disclaimer: The content of this article solely reflects the author's opinion and does not represent the platform in any capacity. This article is not intended to serve as a reference for making investment decisions.
You may also like
AAVE breaks above $340
BTC falls below $104,000
Radius Completes $7 Million Seed Round Led by Pantera Capital