亚洲日本一区二区三区在线_久久久不卡国产精品一区二区_精品日韩一区二区_国产一区二区在线观看app

BitVM背景知識:欺詐證明與ZK Fraud Proof的實現思路

訪客 9個月前 (02-28) 閱讀數 1387 #區塊鏈
文章標簽 前沿文章

作者:Shew & Noah,仙壤GodRealmX

眾所周知,欺詐證明是一種在區塊鏈領域中被廣泛應用的技術方案,其最早發源于以太坊社區,并被Arbitrum和Optimism等知名以太坊Layer2所采用。2023年比特幣生態興起后,Robin Linus提出了名為BitVM的方案,以欺詐證明為核心思想,在Taproot等比特幣既有技術的基礎上,為比特幣二層或橋提供了新的安全模型。

BitVM曾先后推出過多個理論版本,從最早的以邏輯門電路為基元的BitVM0,到后來以ZK Fraud Proof和Groth16驗證電路為核心的BitVM2,與BitVM相關的技術實現路徑在不斷的演化并趨于成熟,吸引了許多從業人員的關注。大家所聽聞的Bitlayer、Citrea、BOB、Fiamma和Goat?Network等項目均以BitVM為技術根基之一,在此基礎上進行了不同版本的實現。

鑒于市面上系統解釋BitVM的資料比較稀少且晦澀難懂,我們推出了以BitVM知識科普為目的的系列文章。考慮到BitVM與欺詐證明之間根深蒂固的關系,本篇文章將以欺詐證明和ZK Fraud Proof為主要話題,以盡可能易懂的語言為大家展開解讀。

我們將以Optimism的欺詐證明方案為素材,為大家解析其基于MIPS虛擬機和交互式欺詐證明的方案,以及ZK化欺詐證明的主要思路。

(Optimism交互式欺詐證明的機制原理)

OutputRoot和StateRoot

Optimism是知名的Optimistic Rollup項目,其基礎架構由定序器 (主要模塊包含op-node、op-geth、op-batcher和op-proposer) 和以太坊鏈上的智能合約組成。

當定序器處理了一批交易數據后,這些DA數據會被發送到以太坊上。只要你有能力運行Optimism節點客戶端,就可以把定序器上傳的數據下載到本地,之后你可以在本地執行這些交易,計算出Optimism的當前狀態集hash(包括但不限于每個賬戶的當前余額等數據)。

如果定序器把錯誤的狀態集hash上傳到了以太坊上,那么你在本地算出的狀態集hash會與之不同,此時你可以通過欺詐證明系統發起質疑,系統會根據判決結果對定序器采取限制或懲罰亦或不處罰。

提到“狀態集”一詞,EVM系區塊鏈常用到Merkle Tree式的數據結構來記錄狀態集,名為World State Trie。一筆交易被執行后,某些賬戶的狀態會變化,World State Trie便會發生變化,其最終hash也會變更。以太坊將World State Trie 的最終hash稱為StateRoot,用其表現狀態集的變化。

下圖展示了以太坊 stateRoot 的構成,我們可以看到以太坊內不同賬戶的余額,智能合約賬戶關聯的代碼hash等數據都會被匯總到World State Trie中,并依此計算出stateRoot。

Optimism的賬戶體系及其數據結構大致上與以太坊一致,也采用StateRoot字段來體現狀態集的變化。OP定序器會定期把名為OutputRoot的關鍵字段上傳到以太坊,而OutputRoot字段是由StateRoot和其他兩個字段共同計算得出的。

繼續回到最初的問題,當你運行OP的節點客戶端并在本地計算出StateRoot,以及當前的OutputRoot后,假如你發現自己算出的結果和OP定序器上傳的結果不一致,便可發起欺詐證明。那么其具體的機制原理是怎樣的?下面我們將依次介紹MIPS虛擬機狀態驗證與交互式欺詐證明。

MIPS虛擬機與內存Merkle Tree

前面我們提到,假設我發現OP定序器提交的OutputRoot有問題,就可以發起“挑戰”,挑戰流程需要在鏈上完成一系列交互動作,交互完成后,相關智能合約會斷定OP定序器是否上傳了錯誤的OutputRoot。

如果要在鏈上用智能合約驗證OutputRoot的正確性,最簡單的方法是在以太坊鏈上實現出OP節點客戶端,采用與OP定序器相同的輸入參數,執行相同的程序,查驗計算結果是否一致。這個方案被稱為Fault Proof Program,其在鏈下很容易實現,但想要在以太坊鏈上運行卻十分困難。因為存在兩個問題:

1.?以太坊上的智能合約無法自動獲得欺詐證明需要的輸入參數;

2.?以太坊每個區塊的Gas Limit有限,不支持復雜度過高的計算任務,我們無法在鏈上完全實現OP節點客戶端

第一個問題等價于讓鏈上智能合約讀取鏈下數據,可以通過類似預言機的方案來解決。OP在以太坊鏈上專門部署了PreimageOracle合約,欺詐證明相關合約可以在PreimageOracle 內讀取所需的數據。

理論上任何人都可以向該合約隨意上傳數據,但OP的欺詐證明系統有辦法鑒別數據是否為其所需,具體過程在此不展開論述,因為對本文的核心話題而言不重要。

對于第二個問題,OP開發團隊用Solidity編寫了一個MIPS虛擬機,實現了OP節點客戶端中的部分功能,足夠欺詐證明系統所用。MIPS是一種常見的CPU指令集架構,而OP定序器的代碼是用Golang/Rust等高級語言編寫的,我們可以將Golang/Rust寫的程序編譯為MIPS程序,然后通過以太坊鏈上的MIPS虛擬機進行處理。

OP的開發團隊使用Golang編寫了欺詐證明所需的最簡化程序,與OP節點中執行交易、生成區塊及OutputRoot的模塊功能基本一致。不過這套精簡化的程序仍無法“完整執行”。

也就是說,每個OP區塊中包含很多筆交易,這批交易處理完后,會得到一個OutputRoot。雖然你知道是哪個區塊高度下的OutputRoot有錯誤,但你如果要把該區塊中包含的交易全都放到鏈上去跑,證明對應的OutputRoot有錯,是不現實的。

此外,每筆交易的執行流程中,又涉及到一連串MIPS操作碼的有序處理,你不可能把這一串操作碼都放到鏈上合約實現的MIPS虛擬機中去跑,因為涉及的計算開銷和Gas消耗量太大。

(MIPS指令集工作原理)

為此,Optimism團隊設計了交互式欺詐證明系統,其目的是對OP的交易處理流程做深度細化。從OutputRoot的整個計算流程中,觀測是處理哪個MIPS操作碼時,OP定序器的MIPS虛擬機出了錯誤。若確定有錯,則可斷定定序器提供的OutputRoot無效。

那么問題就變得明朗了:OP定序器處理交易打包區塊的過程,可以被拆解為對巨量MIPS操作碼的有序處理,每個MIPS操作碼執行后,虛擬機的狀態hash都會變化,這些記錄可以匯總為一棵Merkle樹。

在交互式欺詐證明流程中,要確定OP定序器在執行哪個MIPS操作碼后,虛擬機的狀態hash出了問題,然后在鏈上重現出當時MIPS虛擬機的狀態,執行操作碼,觀測之后的狀態hash是否與定序器提交的結果一致。由于只在鏈上執行一條MIPS操作碼,復雜度不高,可以在以太坊鏈上完成計算流程。但要做到這些,我們需要把MIPS虛擬機的狀態信息如部分內存數據上傳到鏈上。

在代碼實現層面,以太坊鏈上與欺詐證明相關的智能合約,會通過以下名為 Step 的函數完成最后的MIPS操作碼執行流程:

上述函數參數中的 _stateData 和 _proof 代表單條MIPS操作碼執行的依賴數據項,比如MIPS虛擬機的寄存器狀態、內存狀態hash等。其示意圖如下:

我們可以通過 _stateData 和 _proof 輸入這些MIPS虛擬機的環境參數,在鏈上運行單條MIPS指令,獲得權威結果。如果鏈上得出的權威結果與定序器提交的結果不一致,則說明定序器做惡。

我們一般稱 _stateData 的哈希為 statehash,可以粗略理解為整個MIPS虛擬機狀態的hash。在_stateData的幾個字段內, memRoot是最為精妙的設計。眾所周知,一段程序在執行過程中會占用大量內存,CPU會與部分內存地址中的數據產生讀寫交互。所以當我們在鏈上通過VM.Step函數執行某條MIPS操作碼時,需要提供MIPS虛擬機部分內存地址中的數據。

OP采用了32位架構的MIPS虛擬機,其內存共包含2的27次方個地址,可以組織成一棵28層的二叉Merkle Tree,底層葉子有2的27次方個,每個葉子記錄虛擬機的一個內存地址中的數據。所有葉子中的數據匯總后,算出的hash便是memRoot。下圖顯示了記錄MIPS虛擬機內存數據的Merkle樹的結構:

我們需要提供一部分內存地址中的內容,這部分內容通過step 函數中的_proof 字段來上傳到以太坊鏈上。這里還要上傳基于內存Merkle樹的默克爾證明,證明你/定序器提供的數據的確存在于內存Merkle樹中,而非憑空編造的。

交互式欺詐證明

在上文中,我們已經解決了第二個問題,完成了MIPS操作碼的鏈上執行與虛擬機狀態驗證,但挑戰者與定序器該如何定位到那條有爭議的MIPS操作碼指令?

相信很多人在網上多多少少閱讀過交互式欺詐證明的簡單解釋,對于其二分法的思路有所聽聞。OP團隊開發了一套被稱為 Fault Dispute Game(FDG) 的協議,在FDG中,包含兩個角色:挑戰者和防御者。

假如我們發現定序器提交到鏈上的OutputRoot有問題,那么我們就可以作為FDG中的挑戰者,而定序器會作為防御者。為了便于定位到前文提及的需要鏈上處理的MIPS操作碼,FDG協議要求參與者都要在本地構建一顆Merkle樹,稱為GameTree,其具體結構如下:

我們可以看到GameTree其實比較復雜,有層級嵌套的關系,由第一層級的樹及第二層級的子樹構成,也就是說,第一層級的樹的底層葉子本身包含了一棵樹。

前面我們介紹過,定序器生成的每個區塊都包含一個OutputRoot,而GameTree第一層級樹的葉子節點,就是不同區塊的OutputRoot。挑戰者和防御者需要在OutputRoot構成的Merkle樹中交互,確定哪個區塊的OutputRoot有爭議。

在確定爭議區塊后,我們就會下潛到GameTree的第二層級。第二層級的樹也是一顆Merkle樹,底層葉子就是上文介紹的MIPS虛擬機的狀態hash。在欺詐證明場景下,爭議雙方在本地構造的GameTree的部分葉子節點會不一致,處理了某個操作碼之后的虛擬機狀態hash會表現出不同。

之后雙方在鏈上進行多次交互,最終定位到有爭議的地方,確定需要在鏈上跑的單條MIPS操作碼。

至此,我們就完成了交互式欺詐證明的全部流程??偨Y來說,交互式欺詐證明包含兩個核心機制:

1.FDG先定位到需要上鏈執行的MIPS操作碼及此時的VM狀態信息;

2.在以太坊鏈上實現的MIPS虛擬機里執行該操作碼,獲得最終結果。

ZK化欺詐證明

我們可以看到上述傳統欺詐證明的交互極為復雜,需要在FDG流程里進行多輪交互,然后將單條指令在鏈上重放。但這種方案存在幾個難點:

1. 多輪交互需要在以太坊鏈上觸發,差不多需要幾十次交互,會產生大量 gas 成本;

2. 交互式欺詐證明的過程較長,一旦交互啟動,Rollup就無法正常執行交易;

3. 鏈上實現特定VM來重放指令是較為復雜的,開發難度極高

為了解決這些問題,Optimism官方提出了ZK Fraud Proof的概念。核心在于當挑戰者進行挑戰時,指定其認為需要在鏈上重放的一筆交易,Rollup定序器給出被挑戰交易的ZK證明,由以太坊上的智能合約進行驗證,如驗證通過,則可認為該交易的處理流程沒錯誤,Rollup節點沒做惡。

上圖中的Challenger為挑戰者,而Defender是OP定序器。在正常情況下,OP定序器根據接收到的交易生成區塊,并將不同區塊的狀態承諾提交到以太坊上,可以將其簡單視為區塊的哈希值。Challenger可以根據區塊哈希進行挑戰。Defender接受挑戰后,會生成一個ZK證明以證明區塊的生成結果沒有錯誤。上圖中的 Bonsai 實際上是一種 ZK Proof 生成工具。

相比于交互式欺詐證明,ZK Fraud Proof 的最大優點是將多輪交互修改為了一輪的ZK證明生成和鏈上驗證,節省了大量時間和gas成本。而相比于ZK Rollup,基于ZK Fraud Proof的OP Rollup不需要每次出塊都生成證明,只在被挑戰時臨時生成一個ZK證明,這也降低了Rollup節點的計算成本。

ZK化欺詐證明的思路也被BitVM2所采用。采用BitVM2的項目方如Bitlayer和Goat Network及ZKM、Fiama等,通過比特幣腳本來實現ZK Proof驗證程序,并對需要上鏈的程序尺寸進行了極大程度的精簡化。限于篇幅,本文不展開贅述,大家可等待我們之后關于BitVM2的文章來深入理解其實現路徑,敬請期待!

熱門
亚洲日本一区二区三区在线_久久久不卡国产精品一区二区_精品日韩一区二区_国产一区二区在线观看app
  • <strike id="ykeqq"><input id="ykeqq"></input></strike>
  • <strike id="ykeqq"><menu id="ykeqq"></menu></strike>
    <strike id="ykeqq"></strike>
    <fieldset id="ykeqq"></fieldset>
    <del id="ykeqq"><dfn id="ykeqq"></dfn></del>
    欧美激情第9页| 欧美国产视频一区二区| 久久九九久精品国产免费直播| 嫩模写真一区二区三区三州| 欧美视频网址| 精品91在线| 久久久久网址| 国产精品女人网站| 亚洲在线黄色| 欧美国产高潮xxxx1819| 国内欧美视频一区二区| 久久久亚洲精品一区二区三区| 国产精品r级在线| 亚洲在线一区| 欧美日韩国产bt| 亚洲视频播放| 欧美日韩成人免费| 在线亚洲自拍| 欧美人与性动交a欧美精品| 一区二区三区在线免费观看 | 母乳一区在线观看| 国产一区二区三区高清| 久久久久久97三级| 国产日韩欧美一二三区| 久久网站热最新地址| 国产日韩欧美制服另类| 久久九九有精品国产23| 国产免费成人av| 久久久久久国产精品mv| 国产日韩欧美不卡在线| 久久久久综合网| 国产一区二区三区在线观看免费| 久久香蕉国产线看观看av| 国产亚洲二区| 欧美电影打屁股sp| 在线亚洲一区二区| 欧美日韩中文字幕在线| 性欧美18~19sex高清播放| 国产精品国产| 久久久久九九九| 极品尤物一区二区三区| 欧美激情精品久久久久久久变态 | 欧美日韩视频在线一区二区| 欧美成人久久| 国产午夜精品全部视频在线播放 | 欧美肥婆在线| 国产视频亚洲精品| 久久久久国产一区二区三区四区| 国产精品主播| 欧美.www| 午夜久久久久| 国产乱码精品1区2区3区| 久久这里只有| 中文有码久久| 欧美性色综合| 久久久www成人免费精品| 国产一区二区无遮挡| 欧美大片在线看免费观看| 亚洲一区二区三区免费在线观看| 欧美色欧美亚洲另类七区| 欧美一区=区| 国产一二精品视频| 欧美理论电影在线观看| 欧美亚洲在线| 激情91久久| 欧美亚洲第一区| 免费成人高清在线视频| 午夜精品免费| 国产一区二区三区观看| 欧美日韩免费一区| 久久一区二区三区国产精品| 亚洲一区二区精品在线观看| 国产精品午夜电影| 欧美国产日韩亚洲一区| 欧美一区在线看| 狠狠爱www人成狠狠爱综合网| 欧美日韩综合精品| 久久视频一区二区| 亚洲在线视频| 韩日成人在线| 国产精品一区三区| 欧美日韩国产成人精品| 久久久久久亚洲精品中文字幕| **欧美日韩vr在线| 国产欧美亚洲视频| 欧美日韩一区三区四区| 久久久久久久久久久久久女国产乱| 国产精品成人aaaaa网站 | 欧美日韩色一区| 蜜桃伊人久久| 久久国内精品自在自线400部| 精品999在线播放| 国产精品久久久久久久久久直播 | 国产麻豆视频精品| 国产人成精品一区二区三| 午夜激情综合网| 国产一区二区视频在线观看| 欧美日韩亚洲一区三区 | 亚洲一区二区三区中文字幕在线| 国产网站欧美日韩免费精品在线观看| 欧美日韩国产综合一区二区| 蜜桃av一区二区三区| 亚洲欧美视频一区二区三区| 在线成人h网| 国产真实精品久久二三区| 国产精品视频精品| 欧美日韩在线播放| 欧美精品电影| 欧美77777| 久色婷婷小香蕉久久| 久久精品女人| 久久国产精品99精品国产| 午夜精品成人在线视频| 亚洲一区二区三区高清不卡| 激情欧美日韩| 激情校园亚洲| 国产一区在线免费观看| 国产精品每日更新在线播放网址| 欧美日韩国产电影| 欧美巨乳波霸| 欧美日韩色婷婷| 欧美日韩一区二区三区在线看 | 欧美中文字幕视频在线观看| 亚洲欧美国产一区二区三区| 亚洲欧美激情诱惑| 亚洲女人天堂成人av在线| 亚洲图片自拍偷拍| 亚洲欧美日本国产专区一区| 亚洲一区二区三区高清| 亚洲男人av电影| 亚洲欧美日本国产专区一区| 亚洲欧美日韩国产一区二区| 亚洲欧美日韩中文视频| 亚洲欧美日韩天堂一区二区| 午夜精品视频| 久久精品一区二区| 久久久欧美一区二区| 久久人人97超碰国产公开结果| 久久精品视频亚洲| 久久久人成影片一区二区三区观看 | 欧美精品一区二区蜜臀亚洲| 欧美区一区二| 欧美视频国产精品| 国产精品五区| 国产日韩欧美亚洲一区| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲视频成人| 欧美一区深夜视频| 久久色中文字幕| 欧美国产日韩二区| 欧美日韩天天操| 国产精品美腿一区在线看 | 国产精品午夜在线观看| 国产一区二区久久久| 在线观看亚洲精品| 亚洲欧美成人一区二区在线电影| 性色av一区二区三区在线观看 | 欧美伊人久久久久久久久影院| 久久久av毛片精品| 欧美黄色精品| 国产精品毛片在线看| 国产在线一区二区三区四区| 亚洲一区三区视频在线观看 | 欧美一区二区日韩一区二区| 久久青草久久| 欧美日韩国产精品自在自线| 国产精品狼人久久影院观看方式| 国产亚洲激情在线| 亚洲一区影音先锋| 久久久综合香蕉尹人综合网| 欧美精品在欧美一区二区少妇| 国产精品美女久久久久aⅴ国产馆| 国产视频精品网| 亚洲主播在线| 久久伊伊香蕉| 国产精品qvod| 精品1区2区| 久久狠狠一本精品综合网| 欧美激情国产日韩精品一区18| 国产精品日韩欧美一区二区| 尤物yw午夜国产精品视频| 老司机午夜精品| 国内精品久久久久影院色| 国产区精品在线观看| 亚洲一区国产一区| 久久男女视频| 国产精品高清网站| 亚洲视频网站在线观看| 久久久久国产精品厨房| 欧美视频一区二区三区四区| 国产亚洲一级高清| 欧美一区二区三区四区在线观看 | 久久女同精品一区二区| 欧美色欧美亚洲高清在线视频| 国内精品免费午夜毛片| 久久精品成人一区二区三区| 欧美日韩在线视频一区二区| 黄色日韩精品| 久久婷婷激情| 国产精品视频自拍|