本文详细探讨了ZK-EVM的五种类型,每种类型都有其独特的架构、优点和缺点,以及可能的解决方案。
此外文章还列举了一些实际的项目例子,以便读者更好地理解这些类型在实际应用中的表现。无论你是区块链开发者,还是对区块链技术感兴趣的读者,这篇文章都将为你提供深入且简洁的洞见。
让我们探讨一下ZK-EVM的类型,以及它的优缺点。
1.类型1:完全等同于以太坊;
2.类型2:完全等同于EVM;
3.类型2.5:部分等同于EVM;
4.类型3:几乎等同于EVM;
5.类型4:其中的高级语言等同。
Bancor发起将BoringDAO(BORING)列入白名单相关提案投票:去中心化交易协议Bancor已发起将BoringDAO(BORING )列入白名单并共同投资20万枚BNT的提案投票,投票将于8月6日结束。这是BancorDAO上的第二个BoringDAO白名单提案,BoringDAO最近已经完成治理代币迁移。[2021/8/4 1:33:54]
类型1:完全等同于以太坊
架构:完全同于以太坊且不改变以太坊系统的任何部分。
优点
完美兼容性:
能够验证以太坊区块;
帮助使以太坊L1更具可扩展性;
适用于Rollups,因为它们可以重复使用大量基础设施。
缺点
完美兼容性:
以太坊最初不是为ZK功能设计的;
LBANK蓝贝壳于3月26日22:00首发DPR:据官方公告,3月26日22:00,LBANK蓝贝壳首发DPR(Deeper Network),开放USDT交易,3月26日20:00开放充值。LBANK蓝贝壳于3月26日22:00开启DPR交易大赛。本次活动设置了瓜分奖和鼓励奖。前50名可按个人交易量占比瓜分8,000 USDT;未进入前50名的用户若交易量≥15,000 DPR,根据交易量每人可获得 8 USDT鼓励奖,限额100名。详情请点击官方公告。[2021/3/25 19:17:56]
以太坊的许多组件需要大量计算来生成ZK证明;
以太坊区块的证明需要很多小时才能生成。
问题的解决方案:
大规模并行化证明者;
ZK-SNARKASIC.
类型2:完全等同于EVM
LBank“LBK双倍回购”计划已完成第九期回购:据官方消息,LBank“LBK双倍回购”第九期于1月5日16:00开始至18:00结束。本期共100,764,146?LBK参与回购,实际回购 8,788,519?LBK。
“LBK双倍回购”为LBank回馈LBK社区用户所创,每两周一次,对LBK进行双倍价格回购,且每次回购价格不低于上一次回购。更多详情可登录LBank官网进行查看。[2021/1/5 16:30:02]
架构:
数据结构与以太坊有显著区别;
与现有应用程序完全兼容;
对以太坊进行了微小修改,以便更容易开发和更快生成证明。
优点
提供比类型1更快的证明时间;
数据结构不直接被EVM访问;
在以太坊上运行的应用程序:很可能可以在类型2上运行;
LBank将于11月6日16:00上线NEST交易:据悉,LBank将于11月6日16:00上线NEST/USDT交易对,并于11月5日16:00开启充值,11月9日16:00开启提现。
NESTProtocol是基于以太坊网络开发的去中心化价格预言机网络。NEST定义并实现了一种全新的在区块链上生成链上价格的方案。其采用市场博弈理论,通过矿工双向报价的方式将链下市场的价格同步产生于链上,并结合NEST报价挖矿机制,对矿工进行激励,使其成为一套逻辑闭环的分布式报价系统,完美的将链下价格同步在链上生成出来,形成NEST价格预言机。[2020/11/4 11:38:30]
支持现有的EVM调试工具和其他开发基础设施。
缺点
在了解缺点之前,先了解什么是「Keccak」:
以太坊区块链的哈希算法;
用于保护以太坊上的数据;
确保信息被转换为哈希。
类型2与验证历史区块的Merkle证明以验证有关历史交易、收据/状态的应用程序不兼容。这是因为如果哈希算法发生变化,证明将会失效。
我们可以将Keccak看作是一种语言,它使用Merkle证明如果ZK-EVM将Keccak替换为另一种哈希算法,Merkle证明将变得陌生,应用程序将无法读取和验证它们的声明。
对缺点的潜在解决方案:以太坊可以添加未来可扩展的历史访问预编译。
项目
Scroll;
PolygonHermez.
然而,这些项目尚未实现更复杂的预编译,因此,它们可以被认为是不完整的类型2。
类型2.5:部分等同于EVM
架构:
增加难以进行ZK证明的特定EVM操作的Gas成本;
预编译;
Keccak操作码;
调用合约的模式;
访问内存;
存储。
优点
显著提高最坏情况下的证明时间;
比对EVM堆栈进行更深层次的更改更安全。
缺点
开发工具的兼容性降低;
一些应用程序将无法工作。
类型3:几乎等同于EVM
架构:
在ZK-EVM实现中,删除了一些异常难以实现的功能,通常是预编译;
ZK-EVM在处理合约代码、内存或堆栈方面存在轻微差异。
优点
缩短验证时间;
让EVM更容易开发;
目标是对不太兼容的应用程序只需要最少的重写。
缺点
更多的不兼容性;
在类型3中删除的使用预编译的应用程序将需要重新编写。
项目
目前,Scroll和Polygon被认为是类型3,然而,ZK-EVM团队不应满足于成为类型3,类型3是ZK-EVM添加预编译以提高兼容性并转向类型2.5的过渡阶段。
类型4:高级语言等同
架构:
接受用高级语言编写的智能合约代码;
编译为设计为ZK-SNARK友好的语言。
优点
非常快的证明时间;
降低开销;
降低成为证明者的门槛:提高去中心化程度。
缺点
在类型4系统中,合约的地址可能与EVM中的地址不同,因为地址取决于确切的字节码;
这意味着如果类型4的ZK-EVM没有字节码,它们将无法创建地址;
在上述情况下,类型4将与依赖反事实合约的应用不兼容;
许多调试基础设施无法移植,因为它们运行在EVM字节码上。
项目
zkSync
最后,我们可以将上述的几种类型放在一起做一个比较,帮助大家一目了然的理解不同的zkEVM。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。