Exploring Zero Knowledge: zkSync and the zkEVM

CoinVoiceApr 22, 2023
Exploring Zero Knowledge: zkSync and the zkEVM

This is part one of a multi-part series diving deeper into the blockchain applications of zero knowledge proofs. There’s been a lot of hype in this space recently, but not a lot of meaningful technical discussion, so this series of articles will explore the applications under the hood. Let’s get started!

zkSync

zkSync, developed by Matter Labs, was created in 2018 by Alex Gluchowski. zkSync’s end goal is to create a fully trustless L2 with L1 guarantees, such as reorg protection and fund security. In addition to simply being secure, it is also developing tooling to provide support for zero-knowledge based smart contracts.

source: zksync.iosource: zksync.io

zkSync 1.0 initially launched in June 2020 and is fully operational. Currently, it operates using PLONK as the prover. With zkSync 1.1, recursive proofs, subscriptions, fee payments in separate tokens (example: send USDC, pay tx fee in USDC), and ERC-20 minting/burning capabilities were added. With recursive proofs enabled, the current throughput of zkSync is 3,000 TPS.

PLONK

PLONK stands for “Permutations over Lagrange-bases for Oecumenical Noninteractive arguments of Knowledge”. Initially created by Ariel Gabizon, Zac Williamson and Oana Ciobotaru, it provides some improvements to previous proof protocols (Marlin and SONIC, for example), while still retaining some downsides.

PLONK benefits and improvements:

  • Moves from an application-specific trusted setup to a universal and updateable trusted setup
  • Relies on standardized cryptography
  • Smaller proof sizes (~0.5-1kB vs 0.2 kB)

While not perfect, PLONK is much better than previous implementations. source: vitalik.caWhile not perfect, PLONK is much better than previous implementations. source: vitalik.ca

zkSync v1’s PLONK implemetation relies on the Ignition trusted setup ceremony, organized by Aztec. With trusted setup ceremonies, it is secure if just a single party deletes their entropy (input) provided to generate the setup. With Ignition, 176 participants (including Vitalik himself) from over 30 countries participated, significantly lowering the trust requirements.

Beyond PLONK, zkSync is working on RedShift, which aims to remove the need for a trusted setup ceremony with something that is still in active research and development: transparent SNARKs. Transparent SNARKs would help make PLONK completely trustless by default.

zkSync 2.0

zkSync 2.0's zkEVM allows developers to seamlessly transfer L1 dApps to L2; While not an exact copy of the EVM, zkEVM brings scalability to L1. Let’s explore how it works under the hood!

zkSync Infrastructure

zkSync operates several pieces of infrastructure on top of Ethereum. All infrastructure is currently live and operational, including the zkEVM. However, the zkEVM is still being worked on, and will be made public at a later time.

Full Node

Executes zkEVM bytecode using the virtual machine

Filters incorrect transactions

Executes mempool transactions

Builds blocks

Prover

Generates ZK proofs from block witnesses

provides an interface for parallel proof generation

Scalable (can increase # of provers depending on demand)

Interactor

The link between L1 Ethereum and L2 zkSync

Calculates transaction fees

Fees depend on token prices, proof generation, and L1 gas costs

Paranoid Monitor

Monitors infrastructure and notifies Matter Labs if incidents occur

zkEVM

source: Matter Labssource: Matter Labs

Yul is an intermediate representation that compiles Solidity into bytecode. It is then passed off into the LLVM, a modular and reusable compiler. By introducing the LLVM, it opens the door for future zkSync smart contract development written in native Rust or Javascript. While Zinc (based on Rust) will be used in the future, Zinc’s development is currently deprioritized in order to complete the zkEVM implementation of Solidity v8 and Vyper v3.

Programmability

While the Scalability Trilemma focuses on the big 3 issues: scalability, decentralization, and security, there is a fourth piece of the puzzle. A chain that solves the scalability trilemma but is incredibly esoteric and difficult to program for is not viable for mass adoption. zkSync solves for this by making the zkEVM easy to transfer existing L1 protocols to, while also opening the door towards native Rust and Javascript smart contract development.

source: Matter Labssource: Matter Labs

Conclusion

2022 is the year of Layer 2. With so many protocols coming out of research and into the implementation stage, Ethereum will be ready for mass adoption while remaining trustless, secure, and decentralized. In a decade from now, the infrastructure being built today will be the backbone of the next generation of protocols.

Source:Mirror
CoinVoiceInto The New Paradigm
Author

This article is for informational purposes only. It is not offered or intended to be used as investment or other advice.

Lastest information

see all