零知识证明_2

loopring,路印,一直专注在高性能的去中心化交易协议。路印协议的目标是想实现以太坊上基于订单撮合的去中心化的交易协议。从2017年,路印从“环路撮合”的最初设计,经过了10,20以及30的三个大的版本的协议升级。1020,相对来说,受限以太坊本身性能的限制,交易流程复杂,体验和中心化交易所相比,有较大的差距。路印协议30,是一种大胆的设计和尝试,通过零知识证明技术(zkp),兼顾去中心化和交易性能。众所周知,pi币的出现值得很多人的关注,激起了整个市场的波澜。
本文对比路印协议2030,分析zksnark零知识证明技术如何在路印30协议中运用。
1 路印协议1020
路印协议在20版本之前,虽然有一些细致的功能和改进,但是,从框架上来说,没有本质的改变:
链下主要由relay维护订单(order management)和完成订单的撮合(settlement engine)。完成撮合的订单,需要在链上记录(由链上的智能合约实现)。简单的说,20协议之前,采用的是“链下撮合,链上记录“的方式。在这种方式下,所有的交易状态记录在链上,链上的智能合约需要实现很多逻辑:
· 检查订单的签名信息
· 检查订单的填充率以及是否取消
· 检查订单的时间
· 计算费率
· 在上述检查和计算完成后,完成token之间的转账
往往一个撮合中包括多个订单,完成这样的一笔撮合大概需要20w~30w的gas费用。也就是说,在以太坊区块最大gas 800w,出块速度是15秒的前提下,路印20协议的撮合性能大概是:每秒大约2笔撮合。
2 路印协议30
采用零知识证明(zkp)技术,路印协议30所有的撮合逻辑都在链下完成。每一笔撮合(settlement)都会生成证明并提交到链上,证明链下的撮合正确无误。路印协议30的设计文档发布在github上:
githubcomloopringprotocolsblobmasterpackagesloopring_v3designmd
路印协议30的框架如下:
21 链上链下同步
路印协议采用和以太一致的“账户”模型,所有的账户的“状态”(余额)都记录在链下。
所有和状态相关的操作,都是在链下更改,提交proof到链上记录。因为存在链上链下的状态同步,账户的任何操作有三个状态:
1 committed (操作已经提交)2 verified (该操作已经提供了相应的proof)3 finalized(之前的所有的操作都已经提交正确的proof)
以用户deposit“充值”的操作为例:
用户转账到路印协议的智能合约,转账在链上确认(链上完成充值)。该操作的状态就是“committed”。链下的relay,监测到“committed”的状态后,更改链下的状态,生成proof,并将证明提交到链上,此时该“充值”操作的状态为“verified” - 链下也已经完成充值。如果之前的所有操作都是verified,那该操作的状态就是finalized(也就是这个状态是确定的,不会被篡改的)。
22 链下状态和操作
为了支持dex的业务场景,并结合zkp的技术要求,路印30将链下的状态用三层的四叉merkle树来表示:
第一层是n层的四叉树,维护dex的所有账户信息(也就是能支持400w左右的用户)。
第二层是m层的四叉树,支持一个账户下的所有token信息。一个token一个叶子节点。
第三层是k层的四叉树,一个账户下某个token的order信息。
所有的操作,都会更改这三层merkle,完成状态的变化。路印30协议支持如下的一些操作:
1 on-chain deposits (在线充值)
2 on-chain withdrawals(在线提币)
3 off-chain settlements (链下撮合)
4 off-chain withdrawals (链下提币)
5 off-chain order cancellation(链下取消订单)
6 off-chain transfers (链下转账)
大部分操作都比较容易理解,需要说明的是2和4。因为每个操作都需要经历三个状态,需要链上链下的同步,所以, 用户既可以从链上,也可以从链下发起提币操作。
23 zkp证明
路印30,采用的是zksnark的groth16算法提供零知识证明。针对每种操作,relay都会提供对应的zkp证明电路。以链下撮合为例,相应的电路证明的逻辑如下:
假设account x链下转账给account y。zkp证明电路,包括:
1 tradehistory中order ox的变化导致traderhistory的树根的变化
2 tradehistory中order oy的变化导致traderhistory的树根的变化
3 balance bx变化导致balance的树根的变化
4 balance by变化导致balance的树根的变化
5 两个账户的balance的变化一致
6 account x和account y账户的变化导致的account树根的变化
注意,不同的操作会有不同的电路对应。简单的说,链下的状态的变化,都会对应不同的电路,并且,电路生成的证明会提交到链上。链下的状态变化,“固化”成规则,并通过zkp的电路表示。这种思路,和以太坊的zk rollup的思路一致。
在链上,虽然智能合约不再需要验证和记录撮合信息,但是,需要提供order信息以及各种操作的证明。order信息可以通过calldata存储在链上。在链上验证groth16的proof,还是比较昂贵的。一个proof的验证,目前需要50w左右的gas费用。在君士坦丁堡升级后,可以降到原来14左右。
为了进一步节省链上的gas费用,路印30设计了“batching”的操作处理(批量处理),也就是多个同类操作,一起生成一个proof。多个同类操作,被打包在一起,称为“block”(和区块链中的block不是一个含义)。
3 性能对比
在足够多的交易的情况下,路印30的tps在目前的以太坊上达到了350。在君士坦丁堡升级后,tps能达到1400。每笔交易平均下来的费用大约在1美分。
总结:
loopring,路印,一直专注在高性能的去中心化交易协议。从2017年,路印从“环路撮合”的最初设计,经过了10,20以及30的三个大的版本的协议升级。路印协议30,通过零知识证明技术(zkp),兼顾去中心化和交易性能。在链下维护account模型的账户状态,每个操作都通过zkp,生成证明并存储到链上,保证链下的状态可靠安全。在足够多交易的情况下,目前路印30协议的tps可以达到350。每笔交易平均下来的费用大约在1美分。