ARK:Layer2扩容关键技术:递归零知识证明剖析

在Layer2扩容赛道上,ZkRollup方案以完美的数据可用性以及与Layer1同等级的安全性,备受青睐;以单个Block为处理单元,用零知识证明算法来保证此区块引起的世界状态变化的有效性,大幅降低了每笔交易的上链成本,同时也增长了系统的吞吐效率。然而,在实际的落地过程中,研究者们发现,简单的ZkRollup方案带来的扩容效果,并不能满足真实的场景需求;这和很多因素有关,电路参数的限制,零知识证明算法的效率等等;研究者们做了很多努力,比如对零知识证明算法进行加速,配备超高配置机器,优化电路规模等,虽带来了一定的性能提升,但仍难以满足需求。

研究者们当然希望,链上一次处理的交易越多越好。朝着这个目标出发,研究者们首先发现了聚合证明技术,该技术已经被ZKSwap推出的ZKSpeed扩容方案采用。在前面的文章中,已经解释了聚合证明的原理和思想,简单来说就是把多个区块的证明聚合成一个证明,使得链上一次就可以完成多个区块的验证,大大的降低了交易的平均成本,其原理如下图所示:

数据:本周5种代币将迎来解锁,总计释放价值超1.67亿美元:5月15日消息,Token.Unlocks数据显示,本周有5个加密项目将进行代币解锁,总计释放价值超1.67亿美元。

BitDAO(BIT)将于5月15日8时解锁187,499,999.36枚代币,价值约9185万美元,占总供应量的1.951%。

ApeCoin(APE)将于5月17日8时解锁15,601,325枚代币,价值约5164万美元,占总供应量的1.56%。

1inch(1INCH)将于5月18日8时解锁21429枚代币,价值约8891美元,占总供应量的0.001%。

Oasis Network(ROSE)将于5月19日0时解锁199,500,000枚代币,价值约1065万美元,占总供应量的1.995%。

ImmutableX(IMX)将于5月20日18时解锁18,075,990.71枚代币,价值约1357万美元,占总供应量的0.904%。[2023/5/15 15:02:57]

?该方案虽然有优势,可实现多个区块的证明的一次验证,但也有其一定的局限性:

BitfinexAlpha:比特币现货交易量自上月达到峰值后大幅下降:4月18日消息,根据BitfinexAlpha最新报告,3月份消费者价格指数(CPI)有所改善,尽管仍居高不下。月通货膨胀率下降主要是由于能源价格大幅下降。剔除食品和能源,核心通胀依然存在。然而,我们认为过去一年已经做了足够的工作,可以暂停加息。虽然我们预计5月3日还会加息25个基点,但在那之后预计会进一步收紧。支持这一观点的事实是,生产者价格指数(PPI),或批发通胀,见证了近三年来的最大跌幅。能源价格和贸易服务的大幅下跌在一定程度上夸大了该指数的跌幅,尽管本月早些时候OPEC+宣布石油减产后,能源价格可能再次飙升,但其他方面应该有足够的下行压力,让美联储可以从经济进一步收紧中喘息一下。[2023/4/18 14:10:20]

1.一次聚合的区块是有上限的,受限于电路参数的限制;

外媒:瑞银收购瑞信后计划裁员20%-30%:4月2日消息,据外媒消息,一位瑞银高级经理透露,瑞银收购瑞士信贷后计划将裁员20%-30%,可能在瑞士削减约11000个工作岗位。其美国投资银行部门的工作也将受到影响,瑞银将与华尔街交易商迈克尔·克莱恩谈判,以终止一项可能使后者控制瑞信大部分投行业务的交易。?[2023/4/2 13:40:44]

2.聚合的区块越多,电路就越大,直到其规模的上限;这种电路生成的证明时间要更长,证明密钥和验证密钥也会占用更大的存储空间;

3.目前可支持的最大聚合粒度是20个区块,也就是凑齐20个区块后,才会开始聚合处理。如果生成证明的效率比较低,这会导致这些区块被确认的时间拉长,尤其是最早生成的那些区块;

前AAX高管:AAX不太可能重新开放:12月1日消息,前AAX通信主管Ben Caselin接受最新采访时表示,AAX现在更有可能被解散,而不是重新开放恢复正常运营,AAX于11月13日关闭了服务,客户余额已无法验证,资产也无法被提取。Ben Caselin透露,两周前AAX的情况似乎还不错,但随着与潜在投资者的谈判进行,获取信息的渠道正在变差,决策变得更加不透明。(CoinDesk)[2022/12/1 21:14:05]

受限于证明计算和CRS生成复杂度的限制,上述的零知识证明算法是不可扩展的。因此,研究者们也在努力寻找一个可扩展的零知识证明算法,即Scalablezk-SNARKs。

Scalablezk-SNARKs可拓展的zk-SNARKs

KuCoin推出NFT ETF产品,以USDT计价:7月29日消息,加密货币交易所KuCoin以交易所交易基金(ETF)的形式向散户投资者提供顶级不可替代代币(NFT)的部分所有权,该ETF产品以USDT计价,并提供五个蓝筹NFT集合的部分所有权,例如Bored Ape Yacht Club(BAYC)。该产品通过与Fracton Protocol合作提供,该服务致力于将有价值的NFT分解为可替代的基于以太坊的ERC-20代币。

KuCoin的NFT基金中包含的每个ERC-20代币代表BAYC集合所有权的百万分之一,例如,用hiBAYC代币表示。KuCoin的“NFT ETF交易区”将首先列出5个NFT ETF,涵盖hiBAYC、hiPUNKS、hiSAND33、hiKODA和hiENS4作为基础资产。[2022/7/30 2:46:56]

在论文《ScalableZeroKnowledgeviaCyclesofEllipticCurves》中,EliBen-Sasson等给出了Scalablezk-SNARKs的定义:

1.Keygenerationischeap:即,Key生成的时间和计算复杂度没有关系;

2.Proofgenerationiscarriedoutincrementally:即,证明生成过程既包含了当前执行步骤的正确性又包含了在此之前所有计算的正确性,这种zk-SNARKs是incrementallycomputable;

为了方便大家理解,用一张图来表示上述思想:

上图表示意思是:证明着证明一个递归计算过程,即:初始状态为S0,经过t次函数F迭代计算后的结果为St。

第一个计算方式,Monolithicoption:证明方P把t次计算过程全部写成电路,然后一次性证明,正如我们前面所列举的一样,存在相同的局限性,很高的时间复杂度和空间复杂度;

第二个计算方式,Recursiveoption:递归计算,其过程如下:

1.首先对于初始状态S0=>S1,证明方P对于S1?=F(S0)计算过程生成一个证明π1;

2.对于S1=>S2的转换,由图中可以得知,证明方P证明了两部分:{S2?=F(S1),V(S1,π1)=1},前半部分保证了当前计算的有效性,后半部分保证了上一步计算过程的有效性;由于在zk-SNARKs里,证明生成的时间比原始计算要快一些,因此,对于验证过程进行证明是合理的;

由此可以看出,?Recursiveoption满足Scalablezk-SNARKs了基本要求:

1.Key的生成和循环次数没有关系,取决于单次F的复杂度,如果是generalzk-SNARKs,只取决于安全参数;

2.证明满足incrementallycomputable,每个证明都包含了在此之前所有计算的有效性;

3.证明的大小固定,和迭递归次数t没有关系;

由上可知,Scalablezk-SNARKs采用了Recursive思想,即当前的Prove过程包含上一步的验证过程电路,具体如下图所示:

可以看到,P2证明电路里,包含了上一步P1的验证过程电路。需要注意的是,P1对应的V在域Fq上,P2的证明过程在Fr上,如何在Fr上表示V的算术电路,是一个值得探讨的过程;由于Cv可以看作是P的一个子电路,因此,q需要满足?q=#E(Fr)或者?q整除?#E(Fr),即q整除rk?-1,因此:

尝试1.理想的情况下,如果?r=q,那么在Fr上,能完美表示Fq上的V的算术电路,但是根据上述原理,r!=q恒成立;

尝试2.对于q!=r,因为需要在Fr上去模拟Fq上的计算,会导致计算复杂度的提高log(r)倍;

尝试3.采用椭圆曲线循环,可以完美实现Recursive过程;

具体的,选取两个大素数,r和q。满足r=#E(Fq)和q=#E(Fr),即,当前群的域等于另外一个群的阶,反之亦然。因此,域Fq上的证明方P可以完美的在Fq上实现Fr上的验证电路,域Fr上的证明方P也可以在Fr上实现Fq上的验证电路;因此不会出现尝试2里面的缺陷。

下面表格列举常用的cycleofellipticcurves

写在最后

通过采用递归证明组合密码技术(RecursiveProofComposition),zk-SNARKS变成了Scalablezk-SNARKs,实现了更高效、简洁的零知识证明算法,并能真实的落地应用。即将发布主网的Mina就采用了这种技术实现了简洁的区块链,即固定大小的链,保持在22KB左右;同时,其他的技术团队包括MatterLabs、starkWare等也在计划采用Scalablezk-SNARKs技术来实现Layer2更高的扩容。ZKSwap团队在Layer2赛道上持续发力,在Scalablezk-SNARKs上亦有所突破,相信不久就会应用于新的版本上。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

地球链

[0:0ms0-0:756ms