poc区块链详解,PoC原理解

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

poc区块链详解,PoC原理解

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

相关文章

区块链现在能做吗,区块链技术还能用“现在还早”骗多久

区块链现在能做吗,区块链技术还能用“现在还早”骗多久

当我谈到流行的区块链技术效率太低时、当我提到我们似乎正在向一个如此中心化的 "web3 "冲刺时、当我指出:不知何故,没有人设法为区块链找到一个积极的用途挑战大科技巨头(而无区块链技术不会更好地服务)...

日本NFT(日本nf公司)

日本NFT(日本nf公司)

日本位于哪个时区 补充: 时区 与 UTC 的偏移量 描述 NZDT +13:00 新西兰夏时制 IDLE +12:00 国际日期变更线,东边 NZST +12:00 新西兰标准时间 NZT +12...

区块链技术特点包括哪些,区块链具有哪些特性

区块链技术特点包括哪些,区块链具有哪些特性

编者按:现如今,区块链已经成为全民关注的领域,不少企业也早已深入其中研究该技术的落地情况。但目前仍有很大一部分人对区块链技术的相关概念并不熟悉。近日,维京研究院和甲子智库联合出品了《区块链行业词典》,...

普通人如何利用NFT赚钱(普通人玩nft能赚钱吗)

普通人如何利用NFT赚钱(普通人玩nft能赚钱吗)

一个普通人怎么赚钱又多又快? 许多成功人士就是从普通人成长起来的,所以不要觉得是不可能的事情,但是要走在正确的道路上,我身边就有人经历了失败后,没有放弃,在小红象迎来了新的转机,没有多的要求,普通人...

什么是区块链技术,它是如何保证安全的

什么是区块链技术,它是如何保证安全的

区块链由“ 区块”和“ 链”两个词组成,字面上是一个链条或一系列“ 区块”。这些块或数据集群相互链接。在常规的信息流模型中,确切的来源指示通过集中式服务器进行数据分发。区块链是基于共识的模型。基于节点...

如何获得NFT(如何获得nfc功能)

如何获得NFT(如何获得nfc功能)

raft材料怎么获得 木筏生存方法及玩法技巧攻 1.岛屿水下能够找到的材料:泥土、沙子、铁、铜、碎片、海草(铜在深海,需要氧气瓶和鳍)。 2.湿的钻块-˃放在船上晾干-˃干燥的钻块。 3.熔炉里...

海南元宇宙公司有哪些,海南旅游元宇宙科技公司详解

海南元宇宙公司有哪些,海南旅游元宇宙科技公司详解

要说近期资本市场的主流风口,元宇宙绝对要算一个。即使板块指数经历了周四的大幅杀跌,但元宇宙相关概念股近一个月以来的涨幅仍十分可观。据Datayes!数据,目前市场元宇宙概念股有58只,自10月28日F...

什么是真正的区块链,要解决四大原则问题

什么是真正的区块链,要解决四大原则问题

目前,以区块链、工业互联网、人工智能、5G为代表的信息科技发展迅速,科技与经济的融合给经济与社会带来了巨大变革和进步。面对新的国际形势和国际竞争格局,今年10月,中共中央政治局第十八次集体学习,对区块...

区块链产品有哪些,腾讯云升级发布三大区块链产品详解

区块链产品有哪些,腾讯云升级发布三大区块链产品详解

11月4日,在以“数实融合·绽放新机”为主题的2021腾讯数字生态大会上,腾讯云正式升级发布三大区块链产品,全面拥抱“长安链”。从底层引擎升级到身份标识模式升级,再到整体解决方案升级,腾讯云区块链“云...

元宇宙中国公司发展如何,连投三家元宇宙公司,字节开始比拼了

元宇宙中国公司发展如何,连投三家元宇宙公司,字节开始比拼了

看来,字节跳动在元宇宙上的布局上不准备停下来。近日,众趣(北京)科技有限公司发生工商变更,新增字节跳动关联公司北京量子悦动科技有限公司等多名股东,字节持股6.6667%。同时,公司的注册资本由约162...

区块链钱包如何研发,多币种钱包系统app开发

区块链钱包如何研发,多币种钱包系统app开发

钱包就是保存区块链数字资产的一个软件随着行业的发展,未来市场上出现的钱包产品肯定也会越来越多,软件开发,其使用的技术、策略以及侧重的功能点也可能各不相同。数字资产钱包通常和区块链节点关系紧密,依据钱包...

元宇宙板块分析,三大领域,全产业链细分龙头详解

元宇宙板块分析,三大领域,全产业链细分龙头详解

元宇宙产业链:元宇宙生态主要分为三层:元宇宙生态版图(资料来源:清华大学2020-2021元宇宙发展研究报告)底层技术支持,包括:人工智能、区块链、云计算、边缘计算等等;前段设备平台,包括:VR、AR...

未来概念NFT(未来概念车)

未来概念NFT(未来概念车)

未来的定义? 其实生活就是奋斗和收获,人生是短暂的,人生是应该有合适的目标,人总是要有点精神的,无论做什么总是要有所作为的.生活应该丰富多彩.应该是:不断的求索,不断的追求,不断的奋斗,尽管前进的路...

孙宇晨NFT(孙宇晨nft币有潜力吗)

孙宇晨NFT(孙宇晨nft币有潜力吗)

90后晓晨个人资料? 真实姓名:孙宇晨 性别:男 年龄:17 家住:陕西省泾阳县 腾讯企鹅:346667700 空间地址: 寄语:诚信专业优质的服务是我们始终如一的追求!真实姓名:孙宇晨 性别:男...

nft公司详解,2021年现状回顾及未来展望

nft公司详解,2021年现状回顾及未来展望

区块链行业在最近几年中经历了飞速发展和变化:从 2017 年的萌芽,2018 年的智能合约,到 2020 年的 DeFi,2021 年,NFT 无疑是最热门的话题。NFT 于 2015 年首次亮相,2...