日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 物聯(lián)網(wǎng) > 區(qū)塊鏈
[導讀] 以太坊2.0是一種新的分片PoS協(xié)議,在其早期階段(稱為階段0)與現(xiàn)有的PoW鏈(稱為Eth1鏈)并行共存。雖然Eth1鏈由礦工提供支持,但新的PoS鏈(稱為Beacon鏈)將由驗證者驅(qū)動。

以太坊2.0是一種新的分片PoS協(xié)議,在其早期階段(稱為階段0)與現(xiàn)有的PoW鏈(稱為Eth1鏈)并行共存。雖然Eth1鏈由礦工提供支持,但新的PoS鏈(稱為Beacon鏈)將由驗證者驅(qū)動。

在Beacon鏈中,驗證者的作用是創(chuàng)建(稱為propose)和驗證(稱為attest)新區(qū)塊。Beacon鏈的共識協(xié)議建立在重要小工具之上,Casper FFG用于最終區(qū)塊化,LMD GHOST用于分叉選擇規(guī)則,RANDAO用于生成隨機數(shù)。只要大多數(shù)驗證者在創(chuàng)建和驗證新區(qū)塊時誠實遵循協(xié)議,那么就可以保證鏈其所需的安全性和活躍性。

驗證者集群是動態(tài)變化的,這意味著新的驗證者可以選擇加入和舊驗證者可以隨時選擇退出。要成為(新)驗證者,需要通過將交易(通過Eth1網(wǎng)絡)發(fā)送到指定的智能合約(稱為存款合同)來存入一定數(shù)量的以太幣作為“stake”。存款合約記錄存款歷史,由Beacon鏈檢索以維護動態(tài)驗證者集群。(不過此存款流程將在稍后階段發(fā)生變化。)

存款智能合約

用Vyper編寫的存款智能合約采用Merkle樹數(shù)據(jù)結構來存儲存款歷史,其中每當接收到新存款時Merkle樹將被動態(tài)更新(即從左到右依次遞增葉子節(jié)點)。合約中使用的Merkle樹預計非常大。實際上,在當前版本的合約中實現(xiàn)了高度為32的Merkle樹,其可以存儲多達2^32個存款數(shù)量。由于Merkle樹的數(shù)據(jù)量是非常大,所以每次收到新的存款時都需要重建整棵Merkle樹是非常不切實際的。

為了減少時間和空間要求,從而節(jié)省gas成本,合約采用了增量Merkle樹算法。增量算法具有O(h)時間和空間復雜度來重建Merkle樹(更精確地,計算高度為h的Merkle樹的根),而樸素算法將需要O(2^h)時間或空間復雜度。具體來說,該算法維護兩個長度為h的數(shù)組,并且更新Merkle樹的每次重建都需要僅計算從新葉(即新存款)到根的鏈,其中鏈的計算僅需要兩個數(shù)組,從而實現(xiàn)Merkle樹高的線性時間和空間復雜度。

然而,有效的增量算法導致存款合約的實施非常不透明,并且使得確保其正確性變得非常重要??紤]到存款合約的重要性,需要進行形式驗證,而這也是最終保證合同正確性的唯一已知方式。

增量Merkle樹算法的形式化驗證

我們在運行驗證時開始對存款合約進行正式驗證,今天我們很高興地宣布我們實現(xiàn)了第一個里程碑,即增量Merkle樹算法的形式驗證。

具體來說,我們首先嚴格形式化了增量Merkle樹算法。然后,我們提取了存款合約中使用的算法的偽代碼實現(xiàn),并正式證明了偽代碼實現(xiàn)的正確性。這意味著存款合約在源代碼級別是正確的,也就是說,如果Vyper編譯器或EVM字節(jié)碼級功能正確性沒有引入編譯時錯誤,它將以增量方式正確計算Merkle樹根。 (實際上,我們的下一個任務是確保字節(jié)碼級別的正確性。)

意外發(fā)現(xiàn)

在我們的形式化和正確性證明工作的過程中,我們發(fā)現(xiàn)存款合同的一個微妙的Bug,但已在最新版本中修復以及一些重構建議,可以提高代碼可讀性和降低gas成本。

讓我們詳細闡述一下這個微妙的Bug。在我們被要求驗證的合約版本中,當Merkle樹的所有葉節(jié)點都充滿了存儲數(shù)據(jù)時,就會觸發(fā)這個bug,在這種情況下,合約(特別是get-deposit-root函數(shù))錯誤地計算樹的根哈希,返回零根哈希(即空Merkle樹的根哈希),而不考慮葉子節(jié)點的內(nèi)容。例如,假設我們有一個高度為2的Merkle樹,它有四個葉節(jié)點,并且每個葉節(jié)點都填充了某些存款數(shù)據(jù),分別為D1,D2,D3和D4。雖然樹的正確根哈希是hash(hash(D1,D2),hash(D3,D4)),但get_deposit_root函數(shù)返回hash(hash(0,0),hash(0,0)),這是不正確的。

由于代碼的邏輯復雜,在不重寫代碼的情況下正確修復此Bug并非易事,因此我們提出了一種解決方法,只是強制永遠不要填充最后一個葉節(jié)點,即只接受存放最多2^h-1個,其中h是樹的高度。但是,我們注意到,在當前設置中觸發(fā)此Bug行為是不可行的,因為最小沉積量為1以太,并且以太網(wǎng)的總供應量小于130M,遠小于2^32,因此填充32高度樹的所有葉子是不可行的。

因此,現(xiàn)在我們確信增量Merkle樹算法及其存款合約的實現(xiàn)在源代碼級別是正確的,接下來,我們將繼續(xù)正式驗證其編譯的EVM字節(jié)碼的行為是否如預期的那樣。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅(qū)動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅(qū)動性能的關鍵。

關鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質(zhì)量和效率直接關系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅(qū)動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關鍵字: LED 驅(qū)動電源 開關電源

LED驅(qū)動電源是把電源供應轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅(qū)動電源
關閉