链资讯 链资讯
Ctrl+D收藏链资讯
首页 > DYDX > 正文

科普:什么是稀疏默克尔树多值证明

作者:

时间:

译者注:以太坊网络是一台富状态(stateful)的世界计算机,其状态包括状态余额、交易流水号(nonce)、合约代码及合约存储内容等。在技术上,这些状态数据是靠一种叫做 “默克尔树” 的结构来组织的,因此,以太坊世界状态及其访问、更新,便可表达为一棵默克尔树及其访问、更新。同样地,所有跟默克尔树相关的数据证明及验证操作,都可以在以太坊协议的语境下被理解为状态的证明及验证操作。实际上,默克尔树是我们理解、利用、改进以太坊协议不可或缺的一环。本文介绍了一种可以证明多个值存在于同一棵默克尔树上的方法,因此也可以说,这就是在介绍如何证明多个以太坊状态隶属于同一时刻的世界状态的方法。

稀疏默克尔树多值证明(Sparse Merkle multiproofs)是对默克尔树截顶(Merkle pollard)的一种替代方案,可在为证明一棵默克尔树上存在多个值时提供空间上较为节约的证明。什么是默克尔证明、默克尔树截顶,我已在前一篇··文章中解释过了;推荐您先阅读并理解这些概念再来阅读本文。接下来,文本将用下图的默克尔树来解释多值证明:

-图 1:一棵默克尔树-

稀疏多值证明最早由 Vitalik Buterin 提出。

多值证明

多值证明(multiproof)就是把一棵默克尔树中的一组证明打包在一起,从而节省存储空间。例如,下面是上图所示默克尔树的 3 条默克尔证明:

日本政府向地方当局颁发NFT证书:金色财经报道,根据CoinPost的一份报告称,所谓的“数字证书”被授予“2022年夏季Digi Takoshien”竞赛的地方政府当局获胜者,以嘉奖其在该竞赛中使用数字技术振兴当地社区的努力。

NFT奖励由日本内阁官房长官松野博和领导的政府机构内阁秘书处发放。岸田首相也出席了颁奖典礼,这是该机构第一次使用NFT。

岸田首相今年曾多次谈到NFT,并表示元宇宙和NFT相关的创新可以促进日本Web3的发展。[2022/9/8 13:15:15]

-图 2、3、4:分别对应 Banana、Peach 和Kumquat 的默克尔证明-

从上图可以看出,3 个证明总共包含 9 个中间分支的哈希值(即由绿色标出的部分):每条证明有 3 个哈希值。将这 3 个证明组合成如下图所示的结构,即成多值证明:

-图 5:对应 Banana、Peach 和Kumquat 的默克尔多值证明-

相比于单条证明时总共需要的 9 个中间分支哈希值,默克尔多值证明只需要 7 个哈希值,这就节省了存储空间。

稀疏的多值证明

虽然默克尔树的多值证明确实节省了一些存储空间,但其中一些数据可以用其他方式得到,所以移除这些数据可以进一步节省存储空间。(译者注:可通过其他方式得到的数据,就不需要存储在证明中,只要在需要时能够得到即可)

以上图的默克尔树多值证明为例,许多中间分支的哈希值都可以被计算出来。比如验证者将已知的值 Banana 和 Peach 通过哈希函数计算后,可以得到哈希值 bc4F…8d3f 和 59a0…421d。对于与根节点相连的两个节点的哈希值 c0b7…da30 和 6ff9…8e3d,可以通过其孩子节点(与两个节点直接相连的,并处于上方的节点)的哈希值计算出来。因为孩子节点的哈希值要么是证明中包含的,要么可以通过再上一层的哈希值计算出来。下图中黄色的节点标记了这 4 个可由计算得到的哈希值:

-图 6:默克尔树多值证明中可以被移除的哈希值(见黄色标记)-

移除这些哈希值后,可以得到 默克尔树中稀疏的多值证明,如下图所示:

-图 7:稀疏的默克尔树多值证明-

稀疏的默克尔树多值证明将需要包含的哈希值数量从 9 个减少到了 3 个。证明效果相同时,稀疏的多值证明也比默克尔截顶更有效,因为后者需要 6 个哈希值。

验证者得到稀疏的多值证明后,为了验证那些值是默克尔树的一部分,需要执行以下的步骤(在默克尔树中,依照从左到右,从上到下的顺序):

(译者注:“将某个值哈希”指:将值作为哈希函数的输入,得到随机的一串输出)

将 Banana 哈希得到 bc4f…8d3f

将Peach 哈希得到 59a0…421d

将 Kumquat 哈希得到 2aab…6f791

将bc4f…8d3f 和 59a0…421d哈希得到 9c15…5dec

将 2aab…6f79 和 45cf…14d9哈希得到 a6e4…87df

将d596…66ef 和 9c15…5dec 哈希得到 c0b7…da30

将e336…ed14 和 a6e4…87df 哈希得到 6ff9…8e3d

将c0b7…da30 和 6ff9…8e3d 哈希得到 d576…ffd9

至此可以把最终得到的哈希值与默克尔树的根哈希值做比较,如果二者一致,则认定所有的值都在该默克尔树中。

下图对比了默克尔树中值和证明的数量变化时,默克尔树截顶和默克尔树中稀疏的多值证明在存储默克尔证明时可以节约的空间存储量:

值得注意的是,多值证明的节省量是近似值,因为能节省多少取决于被证明的值在默克尔树中的位置以及可以被移除的中间分支哈希值个数。

对比稀疏多值证明与默克尔截顶

从上表中可以看出,稀疏的多值证明比默克尔树截顶节省更多的存储空间,那么为什么还要使用默克尔树截顶呢?因为稀疏的多值证明相对于默克尔树截顶,拥有一些不同的特性,主要有以下几点:

在多值证明方法中,所有值的证明都是一起生成、一起得到验证的;而在截顶方法中,各个值的证明是分别生成、分别验证的(译者注:生成及验证时,对截顶来说,具体是哪个值,只需要这个值和相关的证明即可,对于多值证明,则需要把要验证的多个值,以及多个值对应的证明都拿出来)

稀疏的多值证明在生成及验证证明时,需要更多的内存和 CPU 周期

稀疏的多值证明很难并行地生成和验证

稀疏的多值证明的大小是可变的,而默克尔树截顶在给定默克尔树和总证明数时,其证明大小是固定的

一些情况下,因为用于传输信息的编码系统不同,可能会导致稀疏的多值证明比默克尔树截顶需要更多的空间;因此建议使用之前做一下测试

总的来说,还要看单个应用的需求来决定哪个更合适。但是这两种方法都比单独的默克尔证明节省更多的存储空间,因此当需要对同一棵默克尔树提供多个证明时,可以考虑使用这两种方法。

实现样例

https://github.com/wealdtech/go-merkletree/ 提供了稀疏的默克尔树多值证明的 Go 语言实现 。

标签:比特币PEANANNANA比特币害死了多少人了pepeai币的价值yearn.financeNANA币

DYDX热门资讯
数字货币钱包里面放的竟然不是币 那是什么?

想要快速入门区块链,除了要对比特币和区块链的概念做个大概了解,其次就是动手操作一番,但在操作过程中难以避免会遇到钱包、地址、公钥、私钥等等“拦路虎”,不得不一个一个的打跑。 前几天给大家介绍了除了比特币之外的一些别的币,在业内把这些币统称为“加密资产”或“加密货币”。

金色百科丨比特币可以无限次进行减半吗?

2020年是比特币第三次减半,在关心币价行情的同时,不知道大家有没有想过,比特币最终可以减产多少次,可以无限次减产下去吗? 先来说结论吧,按照目前比特币网络规则,在减产33次之后,将不能再减产。那么,为什么是33次? 我们知道,比特币的货币政策写在软件规则里,货币供应总量2100万个,平均十分钟一个区块,每210000个区块奖励减半。

金色百科 | 如何购买比特币?买完放在哪里比较安全?

了解什么是比特币后,相信你已经急不可待的想买比特币了,那怎么购买呢?买完放在哪里呢? 首先,你需要在交易所开户,现在国内比较安全的大交易所有两个,火币交易所和OKex交易所,点击官网注册,实名认证后就可以购买比特币了。 我们可以看到购买比特币有两种方式,法币交易和币币交易。

金色百科 | 什么是EOS?

EOS英文全称Enterprise Operation System,熟称柚子,是Block.one的产品,一个允许开发者在其协议顶端创建区块链应用的新平台。EOS是基于http://EOS.IO软件项目之上发布的代币。从2017年6月27日开始,总共将发行10亿代币。

金色百科 | 什么是期权?

1  期权(Options),也称选择权,是指买方支付给卖方费用后,拥有在将来某一时间按照期权合约规定的价格,买入或卖出一定数量资产(期货、指数或金融工具等)的权利。期权卖方收取费用后,负有相应卖出或买入的义务。

新手指南|为什么要选择一个高流动性的交易所?

流动性是每个人在交易或投资加密货币时都需要了解的最重要概念。并且多年来,流动性一直是加密货币交易所的重点。但是,这到底意味着什么?为什么高流动性如此重要? 什么是流动性? 资产流动性 流动性是指在不影响其价格总体稳定性的前提下,可以快速购买或出售特定资产的程度。 用最简单的话来说,流动性是指资产转换为现金的能力。