Aleph Zero Blog
Fundamentals

Fundamentals: WASM vs. EVM and Why Aleph Zero Leaves the Choice Up To The Developers

Apr 13, 2023

AI Summary

Here's your AI summary of Fundamentals: WASM vs. EVM and Why Aleph Zero Leaves the Choice Up To The Developers on Aleph Zero blog

Top 10 Key Takeaways:

  1. Smart Contracts Overview: Smart contracts are specialized code executed on the blockchain, enabling transactions without intermediaries like brokers or banks.

  2. Virtual Machines: Smart contracts require runtime environments known as virtual machines (VMs) for execution. The two most popular VMs are Ethereum Virtual Machine (EVM) and WebAssembly (WASM).

  3. Solidity: Solidity is the primary language for writing smart contracts on the Ethereum blockchain. It is popular due to its simplicity, inheritance properties, and extensive libraries.

  4. ink!: ink! is a language for writing smart contracts on Aleph Zero's Layer 1, built on Rust and compiled to WASM. It offers type safety, efficient memory management, and native support for upgradeable contracts.

  5. EVM vs. WASM: EVM is designed specifically for smart contracts, making it less reusable but more specialized. WASM, on the other hand, is a more general standard used in web applications, requiring additional complexity for smart contract functionality.

  6. Storage Differences: Solidity uses 256-bit storage entries, which can handle large values but may incur performance penalties. ink! uses 128-bit storage entries, offering better performance but potentially limiting for developers used to Solidity.

  7. Contract Upgrades: Solidity often uses proxy contracts for upgrades, which can be risky. ink! uses a set_code_hash message to swap bytecode, providing a safer upgrade method.

  8. Deployment Costs: EVM requires uploading bytecode for each contract instance, increasing costs. ink! allows uploading bytecode once and creating multiple instances with minimal gas costs.

  9. Aleph Zero's Dual Support: Aleph Zero supports both EVM and WASM, offering developers the choice between deploying on an EVM-compatible Layer 2 or a Substrate-based Layer 1.

  10. Developer Choice: The choice between EVM and WASM on Aleph Zero often depends on the developer's familiarity with Solidity or Rust/ink!. Developers are encouraged to experiment with both chains to determine the best fit for their use case.

AI Summary

With the upcoming launch of the Aleph Zero EVM-compatible chain, let’s explore WASM and EVM: the two most popular runtime environments that facilitate the execution of smart contracts on the blockchain. 

Smart contracts are one of the more exciting developments of recent years, allowing users to create personalized use-cases whose execution is bereft of any kind of institutional intermediary or middleman. These contracts are pieces of specialized code that can be executed by users on demand; for example, two parties can potentially engage in an exchange of real estate through the help of a smart contract.

In this scenario, the smart contract will stipulate all of the requirements for the deal to be concluded. Once the pre-decided conditions occur, the property will change hands. The whole process will be completed and finalized by applying the smart contract without involving any real estate brokers, lawyers, or banks. In order to make smart contracts possible, it is necessary to employ a runtime environment known as virtual machines in which they can be executed. We’ll explore the two most popular ones, the Ethereum Virtual Machine (EVM) and WebAssembly (WASM). 

—————–

Please note that for the sake of simplicity we use the terms EVM and WASM to describe the entire standard for smart contracts, including the byte code they are compiled to, the associated execution environment and the virtual machine.

—————–

The Building Blocks of Smart Contracts

Before we dive into the whole debate on EVM versus WASM, we should briefly explain the building blocks of a smart contract platform. This mechanism is actually very similar to how one would write and execute regular programs on a computer: the difference is that instead of running the programs on a local machine, they are executed by the blockchain!

  1. The high-level smart contract language in which the contract is written, e.g, Solidity, Vyper, ink!;
  2. The compiler translates the code into the actual smart contract. This list of instructions that inhabits the smart contract is called the bytecode and must follow a certain standard to be executable. These rules are pre-established in the virtual machine standard; 

This bytecode is finally uploaded to the blockchain, where it is stored. When a user performs a smart contract call, the corresponding piece of bytecode is loaded into the execution environment (a virtual machine able to execute that particular type of bytecode), where the instructions constituting that call are executed. 

The Languages Behind Smart Contracts 

Solidity is one of the programming languages through which we can code smart contracts.

Solidity

Solidity is one of the programming languages which we can use to write smart contracts. It is the foundation upon which the Ethereum blockchain is built and is the most popular smart contract language currently in use. Some of the pros of Solidity are as follows: 

  • Solidity offers inheritance properties for their contracts, including multiple-level inheritance properties;
  • It is quite easy to learn due to its fairly simple design and similarity to other popular languages;
  • It comes with a wide selection of reusable libraries and frameworks that allow a developer to reuse existing code;
  • It is the default smart contract programming language when working within the Ethereum blockchain, as it was designed solely with the purpose of working with Ethereum. This translates into considerable support from a large community that worked through many of the initial bugs and provided a more user-friendly / dev-friendly environment.
The Aleph Zero smart contract pallet takes advantage of ink!, a Rust-embedded domain-specific language (eDSL) that compiles to WASM.

ink!

Smart contracts on the Aleph Zero L1 are written in ink!, an embedded domain-specific language (eDSL) built on top of Rust, and compiled to WASM. This language was developed particularly for writing smart contracts for the FRAME Contracts pallet developed by Parity Technologies. 

The main advantage of ink! is that it leverages the power of Rust, which is a great modern language for systems and general-purpose programming, striking what seems to be the right balance between expressive power, type and memory safety and developer ergonomics.

Here are some of the advantages of ink!: 

  • Its type system is very safe, eliminating a lot of the errors during the development of the contract;
  • Memory management in Rust and ink! prevents errors without introducing any performance overhead;
  • ink! and pallet_contracts introduce a way of natively creating upgradeable contracts by using a two step contract deployment process: uploading the code to the chain and instantiating;
  • Existing tools for Rust work for ink!;
  • Existing libraries may be used if they can be compiled with no_std feature – this is one of the bigger advantages of ink!;

WASM and EVM: similarities and differences

At this point it’s important to note that when talking about WASM, we actually mean a few things: ink! as a high-level language for writing smart contracts, WASM as a language/format for describing instructions for the virtual machine, the interpreter of this language embedded inside Substrate’s pallet_contracts and set of rules that dictate how the smart contracts interact with the rest of the chain. Similarly, by EVM we mean Solidity as the high-level smart contracts language, the EVM bytecode, the actual virtual machine executing the bytecode and its connection to the chain.

The philosophies behind EVM and WASM are different:

  • EVM was created from the ground-up as a solution targeted specifically for smart contracts. On that account, it contains many primitives specific to this domain but for the same reason it’s less reusable;
  • WASM leverages an existing, ubiquitous standard found in many web applications: this means a lot of solutions were already optimized for WASM but smart contract-specific functionality had to be added in, which does tend to increase the complexity of the whole solution.

At the same time, the key principles of smart contract development are the same on both platforms and almost all of the ideas have one-to-one mapping (albeit with different flavors). On both platforms the developers will create a contract that has some storage, a constructor, and a set of methods for reading and modifying the storage. The calls that modify the storage will cost a bit of the chain’s currency (a concept called ‘gas’) and an error in a transaction will cause it to be reverted.

Naturally, there are also notable differences between WASM and EVM. Below we present a list of those we find the most important:

  • In Solidity the storage entries are all 256 bits. This means that the variables are large enough to fit almost every conceivable value but this comes with a performance penalty. Also, the overflow is of course still possible and has been exploited in the past. In ink! the largest number type available without using additional libraries is 128 bits: it has performance benefits and is more than enough in most cases but developers coming from Solidity might find it limiting.
  • In Solidity a popular method for creating upgradeable contracts is to rely on proxy contracts: it is a powerful method but also introduces some risks. In ink! the default method for contract upgrades is to leverage the set_code_hash message, effectively swapping the bytecode of the contract for an upgraded version.
  • On EVM, each instantiation of the contract uploads the bytecode to the chain, which can result in increased costs when one has to deploy multiple instances of the same contract (e.g. different fungible tokens in a game). To alleviate that, a multi-token standard was created (ERC-1155). In ink! the two-step deployment process allows you to upload the bytecode once and create multiple instances for very little gas.

For an in-depth comparison of how the concepts from Solidity map to ink!, we recommend reading this article

How does Aleph Zero support both WASM and EVM? And how do I choose?

With the creation of the Aleph Zero fully EVM-compatible Layer 2 blockchain, the developers can now choose whether they want to deploy in the EVM-land or in the Substrate world. There are now two chains running as part of Aleph Zero: the EVM-based Layer 2 and the Substrate-based Layer 1. The Layer 2 chain supports all of the languages and tooling available on the EVM, so Solidity developers will feel right at home. At the same time, the Layer 1 chain allows you to deploy smart contracts written in ink! and leverage all of its safety features. 

For the majority of the developers the choice will most probably come down to familiarity with either one of the technologies: developers with experience in Solidity usually prefer to stick to the familiar territory and deploy on the L2 chain. Developers with previous experience in Rust or ink! may want to explore the features of Substrate on the L1 chain. At the same time, we encourage you to do your own research and choose the platform that is best suited for your use case. A good idea might be to get TZERO from the faucets and experiment on two chains until you can make an informed decision. In any case, we’ll be happy to see your project deploy on one or both of the chains!

Be a part of the Aleph Zero community for updates on the latest developments in the ecosystem. You can also stake AZERO today.

Keep learning about the Fundamentals of Aleph Zero:

Related articles