poc区块链详解,PoC原理解

当前位置:首页 > NFT > poc区块链详解,PoC原理解

poc区块链详解,PoC原理解

2022-05-07NFT94
摘要: *本系列文章,是链博核心区块链研究小组输出的高质量区块链研究性文章,旨在研究和分享底层区块链技术的原理解析,新技术趋势,拒绝讨论任何token,行情和投资建议。

上一篇文章中,我们探讨了Stefan Dziembowski[14]从数学角度对PoC的形式化模型和证明的讨论,Burst则是在工程角度实际运行的PoC完备系统。

两者在理念上是完全一致的,但Burst在实现细节上却与该论文提出的模型和交互不完全相同。

本篇文章我们会从Plot文件和出块流程两方面讨论PoC的算法细节,同时末尾结合Stefan Dziembowski的模型讨论Burst是否可以纳入其框架之下。

PoC硬盘利用与Plot文件

Plot文件即每一个参与出块的节点或是矿工需要在硬盘中存储的文件,其内容由大量特定结构的Hash值组成。Plot文件包含以下的几个基本概念:

Shabal256:Shabal256是BurstCoin所使用的Hash算法,相比SHA256等Hash算法,Shabal需要更多的CPU计算时间和计算量。结合上一章节的内容我们可以了解,BurstCoin选用Shabal一方面是因为在出块阶段矿工并不需要进行大量的Hash运算,另一方面也可以通过计算代价来防止可能的恶意矿工在每个出块阶段临时计算需要的Hash值而非存储中的Hash值。

Nonce:Nonce是Plot文件中拥有固定编号的基本单元,由256KB的数据构成,是矿工用来参与PoC过程的基础逻辑单元。

Scoop:每个Nonce文件由4096个Scoop文件构成,同样拥有编号,其编号范围为0-4095。而每个Scoop文件包含2个Hash值,也即一个Nonce文件包含8192个Hash值。

Nonce的生成流程如下:

1.Nonce文件的种子由Account Id(即BurstCoin网络中的用户地址或者用户Id) 与Nonce Id(即nonce编号)组成,经过第一次Hash,生成Hash #8191,即Non中的编号为8191的Hash值。

2.#8190Hash值由之前一个#8191Hash值与Account Id,Nonce Id 生成。

3.#8189Hash值由之前两个#8191Hash,#8190Hash值与Account Id,NonceId 生成,依次类推,每下个Hash值,都有其之前计算的所有Hash值与AccountId,Nonce Id 生成。如果过程中超过了4096个bytes,则取最近生成的4096bytes作为下一次的Hash函数输入参数。

4.最终Hash的生成,由Hash#0-8191与Account Id,蓑衣网小编Nonce Id共同生成,之后对8192个Hash值都分别对其进行异或操作,作为每个Hash最终的值。

5.得到了8192个Hash值后,Scoop文件的结构如下图所示:

至此,我们生成了1个完整的Nonce文件,一个Nonce文件包含8192个Hash值,占用空间256KB。

这同时也是矿工参与挖矿的最低门槛,即只要有大于等于1个Nonce文件即可参与挖矿。

按照目前BurstCoin全网算力估计,3PB大约占全网算力的百分之一,那么需要多少个Nonce?经过简单计算我们得知,大约需要117亿左右个这样的Nonce。

而一般的家用主机以500G为例,仅可以存储200万个Nonce。

故在BurstCoin的世界里,低算力基本也都是以参与矿池的形式参与挖矿的过程。

PoC的共识与出块

上一章节我们介绍了Plot文件与其基本结构,本章节我们将介绍PoC作为区块链共识,其完整的挖矿流程是怎样的,其同时探讨几个共识中的核心问题,最后与Stefan Dziembowski的理论相结合,探讨两套体系的关联和异同。

上图是一个完整的PoC共识出块流程,下面我们将结合图示分别介绍其每一个步骤。

步骤1-2,GenHash的生成:GenHash类似于BitCoin中BlockHash的概念,用于形成前后相继的区块链结构。

BurstCoin中,由于该Hash同时参与共识过程中参数的建立,其将概念拆分为两个:

GenSig由上一个区块中的GenSig与上个区块的出块者做Hash得出,GenHash由GenSig与快高信息做Hash得出。通过这样两次Hash计算,即将当前区块前的所有区块形成了不可修改历史区块的链式结构,同时也得出了PoC共识中的重要参数GenHash。

步骤3-4. Scoop Number的计算:钱包生成GenHash后,将此值发送给矿工,矿工由此计算本次出块需要的Scoop Number。GenHash Modulo 4096 即是Scoop Number的值。该Scoop Number用来定义本次出块中,全网的所有矿工应当查询自己拥有的所有Nonce中的Scoop的数据。结合上一章节内容我们可以得知,也即其拥有的某个Scoop中两个Hash的值。

步骤5,计算target,deadline:首先,矿工需要遍历磁盘,找到自己拥有的所有nonce中对应于上一步计算出的Scoop Number的两个hash,记为scoopdata,使表达式 target=Hash(scoopdata, GenSig)的值最小。之后利用该最小值targer,计算target/BaseTarget得出deadline。target类似bitcoin中的difficulty_target参数,控制全网挖矿难度,而dealine决定了了该矿工产生的区块在全网中是否成功得到该区块铸造权。

上述每个参数:

deadline:是一个整数类型数值,一个拥有特定deadline的区块,在全网中需要等待对应于该deadline所指定的时间之后,才可以被作为一个合法的区块。举例来说,如果deadline为60,则代表在上一个块出块时间一分钟后,这个块可以被允许添加到主网作为合法区块。由此我们可以得知,计算得出deadline越小的矿工,越有胜算得到当前块的铸造权。而deadline的计算过程是矿工通过遍历自己所有随机生成的Nonce中的值计算得出,也即代表所拥有Nonce个数越多,磁盘占用空间越大,获取数值更低的deadline的概率更大,从而得到铸块权的概率也更大。

BaseTarget:BurstCoin设定的全网平均出块时间为4分钟,全网的存储算力是波动,如何在波动的算力下控制全网平均出块时间?类似与BitCoin,BaseTarget代表挖矿难度,其值越小,说明全网挖矿难度越高。在burstcoin中,最小的target需要除BaseTarget得到最后deadline。所以对BaseTarget的动态调整,可以直接控制全网的区块间的间隔,也即区块时间。

步骤6-9,打包交易,铸造区块,广播区块。此过程与所有区块链系统类似。值得一提的是,BurstCoin的区块负载大小限制为176KB,平均可以承载19k个左右的交易,不难得出其理论tps上限控制在80左右,与Bitcoin和Eth等PoW类型的区块链系统相比,其性能量级也是相类似的。

综上所述,本次我们以BurstCoin为例,详细介绍工程中的PoC共识算法的实现,主要集中在Plot文件内容的生成,与出块的详细交互和计算流程。

在下一篇文章中,我们提取几个PoC共识过程的核心问题,帮助读者更好地理解PoC算法,同时结合Stefan Dziembowski的模型讨论Burst是否可以纳入其框架之下和一些思考的分享,敬请期待。

链博科技区块链系列文章,致力于分享区块链领域的底层技术知识,努力提供原创,有深度的技术内容。

从技术角度探索区块链创新的同时,链博科技也从产业结合角度深入思考,推进区块链落地项目的建设,为企业提供专业、易用、全栈的区块链链改服务。

蓑衣网-以上内容来自网络整理,不能代表本站立场,转载请注明出处。

本文链接:https://www.baoguzi.com/12107.html

poc区块链详解,PoC原理解 | 分享给朋友:

相关文章

什么是数字货币区块链,数字货币区块链如何运营及交易

什么是数字货币区块链,数字货币区块链如何运营及交易

在刚刚过去的这个周末,人们议论最多的经济话题恐怕就是区块链了。这个之前主要在金融圈和IT圈被广泛讨论的概念因为总书记在中央政治局一次集体学习中的讲话迅速在普通民众之间走红。“我们要把区块链作为核心技术...

区块链交易平台有哪些,九个最好的区块链平台

区块链交易平台有哪些,九个最好的区块链平台

为开发区块链智能合约而创建的固定性编程语言已成为密码行业标准。这种语言被用于Etherum的智能合同,这是分散应用程序的最大网络。坚固性使您可以创建图灵完全的智能合约,这意味着不需要第三方。语言是Te...

区块链挖矿app大全,很火的区块链挖矿应用有哪些

区块链挖矿app大全,很火的区块链挖矿应用有哪些

区块链市场已经进行了很多次的洗牌,但是整个市场调整的态势依然没有改变。究其原因,主要是因为区块链技术始终没有完全脱胎于数字货币有关。正是由于区块链没有完全脱胎于数字货币,所以,我们看到很多的区块链项目...

中国NFT用户量(nft中国用户数量)

中国NFT用户量(nft中国用户数量)

中国的互联网上网用户数居世界第二位,用户已超过9800万,用科学记数法表示9800万这个数据______万 9 800万=9.8×103万. 故答案为9.8×103.额 Steam中国用户数...

区块链的电子商务分析,区块链电商有什么价值

区块链的电子商务分析,区块链电商有什么价值

我们阐述了区块链将防伪溯源技术运用到电商平台的情况。又提到绝大部分电商平台只是将区块链技术应用于商品溯源上。而对于区块链电商的运行模式没有涉及,但一种电商的运行模式会牵扯到消费者、平台中介以及生产厂家...

算法生成NFT原理(NFT头像生成算法是什么)

算法生成NFT原理(NFT头像生成算法是什么)

关于最小生成树的算法问题 呃……最小生成树的算法有两种,从你的问法看,感觉你对算法有点误会了。 权值是边的权值,不是节点的权值哦,所以我们涉及的是边。你说的那个算法是: 初始集合为空集,然后找权...

nft藏品如何交易,腾讯nft藏品怎么卖

nft藏品如何交易,腾讯nft藏品怎么卖

近期,视觉中国(000681.SZ)因数字藏品交易平台“元视觉”股价大涨,领起了二级市场“NFT概念”炒作之风。1月4日晚间,视觉中国发布股价异常公告,称“元视觉”平台目前处于上线起步阶段,公司尚无法...

如何购买NFT头像(如何制作NFT头像)

如何购买NFT头像(如何制作NFT头像)

怎么购买QQ头像? 充值Q币 从QQ商城买 如果你的 QQ已经有了太阳了 那么 你应该采取 将付费头像 右键存入电脑 再添加到自定义头像 就能不用花钱 头像万变 嘿嘿嘿这个也要购买吗?无语中.....

什么是nft铸造,nft铸造流程及平台详解

什么是nft铸造,nft铸造流程及平台详解

2012年,第一个类似 NFT 的通证Colored Coin(染色币)诞生了。2014年,Kevin McCoy创造的货币图形化,标志着NFT首次问世。之后,Spells of Genesis,Cr...

怎么玩NFT(怎么玩抖音赚钱)

怎么玩NFT(怎么玩抖音赚钱)

怎么玩双杠? 双杠最普遍玩法就是曲臂摆动:双手分别撑在两边的横杆上,身体在空中前后摇摆,当双腿往后摆到最高点时,双臂弯曲,使身体俯在杠面之上,接着双腿由后往前摆动,借着惯性,双臂渐渐伸直,等到双腿摆...

元宇宙个人分析,爆火的背后普通人是机会还是韭菜?

元宇宙个人分析,爆火的背后普通人是机会还是韭菜?

 自从脸书宣布改名为Meta,让这个新名称的词源 " 元宇宙 " ( metaverse ) ,一下子成为了整个科技行业最火的新概念,元宇宙的标签也越来越频繁地出现在大家的视野里。但是前几天,“元宇宙...

吴说区块链详解分析,四川矿场水电消纳全年预计50亿度

吴说区块链详解分析,四川矿场水电消纳全年预计50亿度

吴说区块链获悉,四川电力交易中心有限公司表示,目前2020年四川年度电量交易完成,其中,水电消纳产业示范区交易目前成交电量约13.71亿千瓦时。此外,行业人士预计全年总量在50亿度,将创历史新高。四川...

互联网元宇宙分析详解,互联网巨轮如何拥抱新风口

互联网元宇宙分析详解,互联网巨轮如何拥抱新风口

随着微软、苹果、腾讯、华为等国内外企业进军布局相关产业,“元宇宙”这一全新互联网形态浪潮席卷全球,引爆了资本的热情,科技巨头们争做“头号玩家”,这个充满着浪漫想象力和严谨科学色彩的词引发各界热议,《元...

一起NFT官网下载(NFT中国官网app下载)

一起NFT官网下载(NFT中国官网app下载)

电脑开机出现系统缺少文件nft文件 起不来机需要重启按f11才可以开? 缺少的文件下载下来放到指定的目录重启试一试,还是不行重新做个系统吧不行还是重装一下系统吧,这样是最快的方法。 再看看别人怎么...

如何用NFT创作(nft创作工具)

如何用NFT创作(nft创作工具)

如何用Fresh Paint进行绘画创作 1、在Fresh Paint的主界面上,我们可以选择“NEW”来新建画作,或是浏览之前的创作,之前创作是自动以月来整理存放的。这里我们选择“NEW”新建一张...