poc区块链详解,PoC原理解

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

poc区块链详解,PoC原理解

2022-05-07NFT72
摘要: *本系列文章,是链博核心区块链研究小组输出的高质量区块链研究性文章,旨在研究和分享底层区块链技术的原理解析,新技术趋势,拒绝讨论任何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原理解 | 分享给朋友:

相关文章

什么是nft,nft币圈详解

什么是nft,nft币圈详解

币圈,早已风声鹤唳。随着国内监管逐步收紧,当下在百度、微博等平台搜索火币、币安等关键词,均提示没有找到相关内容或搜索结果未予显示,这意味着炒币越来越不受待见。传统虚拟货币焉了,NFT却收获了更多的关注...

海外区块链推广如何发展,区块链项目海外运营及推广的操作分析

海外区块链推广如何发展,区块链项目海外运营及推广的操作分析

不少区块链项目面向186的客户2687来源于2983全球各地,这也无异于沿着当下经济全球化与信息全球化的时代浪潮。今天我们便来观摩一下区块链项目通常是如何在海外开始起航的呢?首先,这和项目本身的定位有...

区块链功能有哪些,区块链的3大实际作用解析

区块链功能有哪些,区块链的3大实际作用解析

谈到区块链,就会谈到去中心化和比特币。区块链作为一种新兴的复合型技术,本质上是一个去中心化分布式账本,目前最成功的应用就是以比特币为代表的数字货币。那区块链有哪些功能呢?大致有金融和技术两种功能。自诞...

区块链技术到底是什么 ,技术应用分析

区块链技术到底是什么 ,技术应用分析

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

nft今日价格多少,今日市场行情价格分析

nft今日价格多少,今日市场行情价格分析

据华尔街日报报道,知情人士透露,电子游戏零售商GameStop正在成立一个部门,专门为非同质化代币(NFT)开发一个市场,并建立加密货币合作关系。受此消息影响,这家电子游戏零售商股价在周四盘后交易中大...

到底什么是区块链技术,区块链技术的重要性分析

到底什么是区块链技术,区块链技术的重要性分析

什么是区块链?举个例子来说:区块链就好比是一个特殊的谷歌电子表格,它被世界上每台计算机共享,并连接到因特网上。每次发生事务时,它都会被记录到这张电子表格的一行中。任何拥有移动设备或计算机的人都可以通过...

什么是NFT铸造(主流NFT是基于什么来铸造的)

什么是NFT铸造(主流NFT是基于什么来铸造的)

什么是砂型铸造?砂型铸造的工艺流程图具体是什么样的? 一、砂型铸造定义及简介 砂型铸造是指用型砂紧实成铸型并用重力浇注的铸造方法。钢、铁和大多数有色合金铸件都可用砂型铸造方法获得。由于砂型铸造所用...

最值钱的NFT(最值钱的r卡值多少钱)

最值钱的NFT(最值钱的r卡值多少钱)

世界上最值钱的10种货币排行榜。 世界上最值钱的货币是赛堡尔加,即Seborgan Luigno(SPL),约合人民币38.141元 其次是科威特第纳尔(KWD),约合人民币22.53元 再次是...

区块链NFT元宇宙(区块链Nft,opensea平台)

区块链NFT元宇宙(区块链Nft,opensea平台)

什么是NFT? NET(Non-Fungible Token,非同质化数字权益证明),在区块链技术支持下可作为数字艺术品、活动门票等数字商品的链上权利凭证。 每个NFT都映射着特定区块链上的唯一序...

值几千万的NFT图(值几千万的NFT图)

值几千万的NFT图(值几千万的NFT图)

五千万蒙图值多少人民币? 按2020-03-14银行汇率:10000 蒙古图格里克 = 25.4117 人民币 50000000 蒙古图格里克 = 127058.2933 人民币 支持一下感觉挺...

区块链技术是什么意思,区块链技术的9个问题

区块链技术是什么意思,区块链技术的9个问题

什么是区块链?区块链能做什么?区块链怎么赚钱?相信面对这个新鲜的名词,很多网友都表示摸不到头脑。那么到底怎么才能更好的理解区块链并且让这项新技术为我们所有呢?笔者从网上搜罗来九个十分常见的问题,希望当...

vr元宇宙关系分析,VR遇上元宇宙,韭菜不够割了

vr元宇宙关系分析,VR遇上元宇宙,韭菜不够割了

如何让股价短时间迅速上扬?和“元宇宙”沾上点边儿。尽管遭监管屡屡关切——据36氪统计,自元宇宙概念发酵以来,包括天下秀、中青宝、盛天网络等在内至少有10家公司收到监管函或关注函,但这场喧嚣的“数字大跃...

nft发行量多少,发行价及信息分析

nft发行量多少,发行价及信息分析

NFT资产今年非常受欢迎,迄今为止,100 个收藏品的 NFT 销售额已超过 200 亿美元。虽然许多单个 NFT 以数百万美元的价格售出,但许多 NFT 项目和收藏的成交量达到了数亿甚至数十亿。根据...

区块链大学排名,区块链大学生好就业吗

区块链大学排名,区块链大学生好就业吗

CoinDesk本周宣布的CoinDesk顶级区块链大学,使用五个关键指标来检查一所大学的区块链教育基础设施:校园区块链产品、学术影响、就业和行业成果、成本和学术声誉。在某些情况下,声誉最好的大学——...

区块链钱包分析,怎么用及如何排名

区块链钱包分析,怎么用及如何排名

区块链钱包与我们传统的钱包不同。它们并不以任何物理形式将加密货币存储在钱包中。区块链钱包通过内置软件连接到区块链,允许您将交易提交到整个区块链的运转中去。何为钱包?钱包的本质是一个工具,即存储、转账和...