以太坊價格 以太坊價格
Ctrl+D 以太坊價格
ads
首頁 > PEPE幣 > Info

ISC:ZK開發者必讀:從入門到高階的可選工具

Author:

Time:1900/1/1 0:00:00

原文:ADeveloper’sGuidetothezkGalaxy去年夏天,Vitalik寫了一篇博文,概述了不同類型的zkEVM。Vitalik根據性能和兼容性來定義與權衡。

這是一個非常有用的啟發式方法,以區分支持zkEVM的方法。然而,zkEVM是構建零知識應用程序的所有可能方法的一個子集。對于想要利用zk計算的獨特屬性,即簡潔性、零知識和正確性的程序員來說,zkEVM可能不是最好的選擇。通過闡述整個開發工具集,本文希望提供一個指南,幫助開發者在決策過程中選擇合適的zk堆棧。抽象復雜度的力量

在過去的一兩年中,zk工具有了巨大的進步。使得普通軟件的開發人員可以利用zk的強大屬性,而不需要深入了解令人生畏的基礎數學和工程。另一方面,為高級用戶提供的工具激增,使zk專家能夠極其精細地控制zk堆棧。現代軟件是建立在無數的抽象層上的,以最大限度地提高專家的生產力。工程中的抽象有許多優勢,這些優勢在某種程度上是直觀的--網絡開發者不需要深入了解操作系統的工作原理。建立良好的、可重復使用的抽象層的關鍵是封裝一個層的復雜性,然后為堆棧中更高的層提供簡單但有表現力的接口。正確的做法是,這使得具有不同專業領域和知識的開發人員能夠在整個堆棧中建立有用的工具。毫不奇怪,這些原則也適用于zk系統,而且這些抽象層正變得足夠成熟,一個zk新手今天就可以開始使用它們并構建應用程序。

zk堆棧與各層的一些工具/技術實例低級別的zk開發

Arkworks-rs

Arkworks-rs是一個Rust庫的生態系統,它為zkSNARK應用程序的子組件提供高效和安全的實現。Arkworks為開發者提供了必要的接口,以定制zk應用程序的軟件棧,而不必重新實現與其他現有庫的共性。在Arkworks之前,創建一個新的zk應用程序的唯一方法是從頭開始構建一切。與定制的垂直整合工具相比,Arkworks-rs的主要優勢在于其靈活性水平,減少重復工程,以及減少審計工作。Arkworks組件之間合理的接口線允許升級的速度,可以使堆棧在zk技術快速創新的過程中保持相關性,而不會迫使團隊從頭開始重建一切。優點通過模塊化實現靈活性減少重復代碼降低工程成本減少審計/bug的表面積無需重大重構即可升級任何組件易于在快速發展的zk環境中試驗新原語缺點需要深入了解完整的軟件堆棧如果沒有正確理解,太多的控制會導致腳槍精細控制需要堆棧所有級別的專業知識。Arkworks確實提供了一些合理的默認設置。zk領域專用語言(DSL)

ZKTR官方聲明:ZKTR和ZKS之間沒有任何關系:據官方消息,ZKTR令牌的官方機構發布聲明稱,我方從未公布有關于機構投資的信息,經zkTube法律團隊查明,并未有真實存在White Swan Capital(WSC)這家公司,純屬造謠。WSC所稱原因均為虛假消息;

ZKTR和ZKS之間沒有任何關系;zkTube是基于zkrollup技術和零知識證明算法來提供Layer2解決方案,在zkTube Protocol上面可以搭建很多去中心化Dapp,像支付、去中心化交易所等這樣的高頻Dapp更適合在zkTube的底層上搭建。而zks即zkswap是一個去中心化Dex屬于Dapp的一種, 因此跟zkswap不存在代碼抄襲或雷同。

zkTube團隊會進一步采取措施追究造謠者法律責任,在此特別提醒請廣大zkTube社區注意分辨信息。[2021/6/4 23:13:09]

為了創建一個關于某些計算的證明,首先這個計算必須以一個zkSNARK系統可以理解的形式來表達。一些特定領域的語言已經創建了編程語言,允許應用開發者以這種方式表達他們的計算。這些語言包括AztecNoir、Starknet的Cairo、Circom、ZoKrates和Aleo的Leo等等。底層的證明系統和數學細節一般不會暴露給應用開發者。開發者的經驗

zkApp的開發者必須熟練地用特定領域的語言編寫程序。其中一些語言看起來很像我們熟悉的編程語言,而其他語言可能相當難學。讓我們來分析一下其中的幾個。Cairo-StarkwareDSL對于在Starknet上構建應用程序是必要的。編譯成Cairo特有的匯編語言,可由CairozkVM解釋。ZoKrates-ZoKrates是一個滿足SNARK常見需求的工具包,包括一種編寫電路的高級語言。ZoKrates在曲線、證明方案和后端方面也有一些靈活性,允許開發者通過簡單的CLI參數進行熱交換。Circom—Circom是一種用于構建電路的專用語言。目前,它是生產電路的實際語言。該語言不是特別符合人體工程學,使開發者敏銳地意識到正在編寫電路。Leo——Leo被開發為Aleo區塊鏈的語言。Leo有一些類似Rust的語法,專門用于區塊鏈內部的狀態轉換。Noir–受Rust啟發的語法。圍繞IR而不是語言本身構建,這意味著它可以有一個任意的前端。

ZKSwap與DeFiBox達成戰略合作:據官方消息,ZKSwap已成為“OpenBox聯盟”伙伴,該聯盟由DeFiBox發起成立,由DeFi錢包、交易所、挖礦平臺等DeFi生態伙伴共同組成。ZKSwap是一套基于自動化做市商的代幣Swap協議,通過ZK-Rollup技術在Layer-2實現了Uniswap的全套功能,可提供無限可擴展性和隱私性。同時,ZKSwap已與DeFiBox達成戰略合作,未來將支持DeFiBox接入其二層生態,雙方將合作推進DEX生態發展,共同推進DEX產品的創新合作。[2021/5/21 22:28:10]

適用于誰

任何想要在其應用程序中利用zk的獨特屬性的應用程序開發人員。其中一些語言已經過數十億美元的實戰測試,如在ZCash和Starknet等鏈的流動。雖然我們將討論的一些項目還沒有完全準備好用于生產,但使用其中一種語言編寫電路是目前最好的策略,除非需要像Arkworks這樣的工具包提供的更精細的控制。優點用戶不需要了解底層的zk細節有一定的生產經驗,今天就可以使用可在鏈上驗證生態系統不可知缺點用戶需要學習一個新的DSL圍繞這些語言的工具和支持都是孤立的對底層證明堆棧幾乎沒有控制權。zkEVMs

zkEVM的主要目標是采取Ethereum狀態轉換,并使用簡潔的零知識正確性證明來證明其有效性。正如Vitalik的帖子中提到的,有許多方法可以做到這一點,并有微妙的差異和相應的權衡。所有這些方法之間的主要技術區別在于,在語言棧中,計算究竟在哪里被轉換為可以在證明系統中使用的形式。在一些zkEVM中,這發生在高級語言中,而其他方法則試圖將EVM一直證明到操作碼級別。這些方法之間的權衡在Vitalik的帖子里有深刻的論述,但我將用一句話來概括它。在堆棧中發生的轉換/算術化越低,性能損失就越大。

歐易OKEx Layer 2板塊將于今日17時上線ZKS及LPT:4月2日,歐易OKEx官方公告宣布在Layer2板塊上線ZKSwap (ZKS)、Livepeer (LPT),現已開放充值,ZKS /USDT和LPT /USDT市場將于今日17:00開放交易,并于4月6日18:00開放提現。

據悉,為慶祝ZKS、LPT重磅上線,歐易OKEx開展充值交易活動回饋社區用戶,在4月2日-4月9日活動期間,用戶參與ZKS、LPT任意幣種的充值或交易,符合活動要求不僅能瓜分10萬USDT獎池,還有機會抽取特斯拉和20部iPhone12。

公開資料顯示,ZKSwap是一套全新的基于zkRollup技術的兌換協議,可以做到零Gas費用的實時兌,并且具備無限的拓展性;Livepeer是一個開放式的視頻直播基礎結構聯網。[2021/4/2 19:40:24]

高操作成本

為虛擬機創建證明的主要挑戰是,電路的大小與每條執行指令的所有可能指令的大小成比例地增長。這是因為電路不知道在每個程序中會執行哪些指令,所以它需要支持所有的指令。

在通用電路中,每條執行的指令的成本與所有支持的指令之和成正比。這在實踐中意味著,你要為最昂貴的指令支付,即使你只是在執行最簡單的指令。這導致了通用性和性能之間的直接權衡--當你為通用性增加更多的指令時,你要為你證明的每一條指令付出代價!這就是通用電路的根本問題。但隨著IVC等技術的新發展,這種限制可以通過將計算分成更小的塊來改善,每個塊都有專門的、更小的子電路。今天的zkEVM實現使用不同的策略來減輕這個問題的影響......例如,zkSync去掉了更昂貴的操作

zkEVM的理想客戶是那些需要比L1以太坊上的交易便宜幾個數量級的智能合約應用。這些開發人員不一定有專業知識或帶寬來從頭開始編寫zk應用程序。因此,更喜歡用熟悉的更高級的語言來寫應用程序,如Solidity。眾多開發團隊

ZKSwap提出治理代幣gZKS 需鎖倉360天獲得:據官方消息,以太坊Layer2交易協議ZKSwap宣布將于今日18:00開始,進行鎖倉挖礦活動,共有30天、60天、180天和360天四種鎖倉周期,分別對應1倍、2倍、4倍和8倍的獎勵系數,共計發放1525萬個ZKS獎勵。另外,參與360天的鎖倉挖礦除了可以獲得8倍獎勵系數外,還將獲得ZKSwap投票治理權和治理代幣gZKS,可參與ZKSwap的平臺治理。[2021/2/25 17:51:46]

擴展Ethereum是目前zk技術最需要的應用。zkEVM是一個以太坊擴展解決方案,可以無摩擦地緩解限制L1dApp開發者的擁堵問題。開發者體驗

zkEVM的目標是支持一個盡可能接近當前以太坊開發的開發者體驗。完全支持Solidity意味著團隊不必建立和維護多個代碼庫。這在某種程度上是不切實際的,因為zkEVM需要交換一些兼容性,以便能夠在合理的時間內生成合理規模的證明。zkSync與Scroll

zkSync和Scroll之間的主要區別在于它們在堆棧中的何處/何時執行算術運算——也就是說,它們從普通EVM構造轉換為SNARK友好表示的位置。對于zkSync,當他們將YUL字節碼轉換為他們自己的自定義zk指令集時,就會發生這種情況。對于Scroll來說,這發生在最后,當實際的執行跟蹤用實際的EVM操作碼生成時。因此,對于zkSync,在生成zk字節碼之前,一切都與與EVM交互相同。對于Scroll,在執行實際的字節碼之前,一切都是一樣的。這是一個微妙的差異,它以性能換取支持。例如,zkSync不會像開箱即用的調試器那樣支持EVM字節碼工具,因為它是完全不同的字節碼。雖然Scroll很難從指令集中獲得良好的性能,但這并不是為zk設計的。這兩種策略各有利弊,最終有很多外生因素會影響它們的相對成功。zkLLVM電路編譯器

正如詳細討論的那樣,開發zk應用程序有無數不同的選擇,所有這些都有自己獨特的權衡。此圖表將幫助總結此決策矩陣,以便根據您的zk專業知識水平和性能需求,選擇最適合該工作的工具。這不是一個完整的列表,會隨著zk的發展更新。zkLLVM被設計為現有LLVM基礎設施的擴展,LLVM基礎設施是一個行業標準工具鏈,支持許多高級語言,如Rust、C、C++等。怎么運行

BM:EOS也可部署zksync rollup:9月16日,EOS創始人BM(DanielLarimer)轉發V神“已利用zkSync新資助13個項目”的推特并表示,這很好,但是嘗試將其與像Bancor這樣的DeFi交換器一起使用,并觀察狀態沖突將吞吐量降低到每個塊一個事務,客戶端必須不斷重新生成證明并簽署新的TRX。有人問EOS是否支持zksyncrollup,BM回應稱,EOS也可部署zksyncrollup。[2020/9/17]

想要證明某些計算的用戶只需用C++實現該計算即可。zkLLVM采用其修改后的clang編譯器支持的高級源代碼,并生成電路的一些中間表示。此時,電路已準備好進行驗證,但用戶可能希望根據一些動態輸入來驗證電路。為了處理動態輸入,zkLLVM有一個稱為分配器的附加組件,它生成一個分配表,其中包含所有輸入和見證,這些輸入和見證已完全預處理并準備好與電路一起進行證明。這兩個組件是生成證明所必需的。理論上,用戶可以自己生成證明,但由于這是一項有點專業化的計算任務,可能需要花錢請擁有硬件的其他人做這件事。對于這種交易對手發現機制,=nil;Foundation還建立了一個“證明市場”,證明者競相為支付給他們的用戶證明計算。這種自由市場動態將導致證明者優化最有價值的證明任務。權衡利弊

由于每個要證明的計算任務都是獨一無二的,并且會生成不同的電路,因此證明者需要能夠處理的電路數量是無限的。這種強制的通用性使得單個電路的優化變得困難。證明市場的引入允許對市場認為有價值的電路進行專業化。如果沒有這個市場,由于這種自然的冷啟動問題,說服驗證者優化該電路將是一項挑戰。另一個權衡是經典的抽象與控制。愿意采用這種易于使用的界面的用戶正在放棄對底層加密原語的控制。對于許多用戶來說,這是一個非常有效的權衡,因為讓密碼學專家為您做出這些決定通常更好。優點用戶可以用熟悉的高級語言編寫代碼所有的zk內部結構都被抽象出來,不受用戶影響不依賴增加額外開銷的特定"虛擬機"電路。缺點每個程序都有一個不同的電路。難以優化。(證明市場部分解決了這個問題)交換/升級內部zk庫并非易事zkVM

zkVM描述了所有zk虛擬機的超集,而zkEVM是一種特定類型的zkVM,由于其在當今的流行,值得作為一個單獨的主題進行討論。除了定制的加密VM之外,還有一些其他項目正在致力于構建基于ISA的更通用的zkVM。系統可以證明不同的指令集架構(ISA),例如新VM中的RISC-V或WASM,而不是證明EVM。致力于這些通用zkVM的兩個項目是RISCZero和zkWASM。讓我們在這里深入了解一下RISCZero,以證明這種策略是如何工作的,以及它的一些優勢/劣勢。RiscZero

RiscZero證明生成的高級架構RISCZero能夠證明任何在RISC-V架構上執行的計算。RISC-V是一個開源的指令集架構標準,已經越來越受歡迎。RISC的理念是以最小的復雜性建立一個極其簡單的指令集。這意味著堆棧中較高層次的開發者在使用這種架構實現指令時最終會承擔更大的負荷,同時使硬件實現更加簡單。這種理念也適用于一般的計算,ARM芯片一直在利用RISC風格的指令集,并開始主導移動芯片的市場。事實證明,更簡單的指令集也具有更大的能量和芯片面積效率。

這個類比對于生成zk證明的效率來說相當適用。正如前面所討論的,在證明zk的執行軌跡時,你要為軌跡中每一項的所有指令的成本之和買單,所以更簡單、更少的總指令是更好的。如何工作

從開發者的角度來看,使用RISCZero來處理zk證明,很像使用AWSLambda函數來處理后端服務器架構。開發人員通過簡單地編寫代碼與RISCZero或AWSLambda互動,服務處理所有后端復雜性。對于RISCZero,開發者編寫Rust或C++。然后,系統接受編譯過程中產生的ELF文件,并將其作為虛擬機電路的輸入代碼。開發者只需調用證明,返回一個收據對象,任何人都可以從任何地方調用`驗證'。從開發者的角度來看,沒有必要了解zk是如何工作的,底層系統處理所有這些復雜的問題。為了支持這樣一個通用接口,需要大量的開銷。需要對證明生成技術進行重大改進,以實現對現有庫的廣泛支持預建的可重復使用電路

對于一些對區塊鏈應用或其他地方特別有用的基本和可重復使用的電路,團隊可能已經為你構建和優化了這些電路。你只需為你的特定用例提供輸入即可。例如,Merkle包容證明是加密貨幣應用中普遍需要的東西。作為一個應用程序的開發者,你總是可以重新使用這些經過實戰檢驗的合約,只是在上面修改一些層,以創建一個獨特的應用程序。例如,TornadoCash的電路可以重新用于私人空投應用程序或私人投票應用程序。Manta和Semaphore正在構建一個完整的工具包,包括像這樣的通用電路小工具,可以在Solidity合約中使用,而無需了解或不了解底層的zkmoon數學。正如詳細討論的那樣,開發zk應用程序有無數不同的選擇,所有這些都有自己獨特的權衡。此圖表將幫助總結此決策矩陣,以便根據您的zk專業知識水平和性能需求,選擇最適合該工作的工具。這不是一個完整的列表,會隨著zk的發展更新。zkGalaxy應用開發者指南

1.低級Snark庫

適用場景需要對整個證明堆棧進行精細控制避免重建公共組件嘗試證明方案、曲線和其他低級原語的不同組合不適用場景尋找高級證明接口的新手可選用工具Arkworks-rs2.zkDSLs

適用場景想使用一些久經考驗的語言需要最小的電路尺寸,愿意放棄抽象不適用場景需要對證明的后端進行精細控制可選用工具CircomAztecNoirCairoZoKratesLeo3.zk編譯器

適用場景不愿意承擔通用電路的開銷想用熟悉的語言編寫電路需要高度定制的電路不適用場景想要控制底層加密原語需要一個已經高度優化的電路可選用工具nilzkLLVM4.zkEVM

適用場景有一個已經在EVM上運行的dApp需要為用戶提供更便宜的交易希望將部署到新鏈的工作量降到最低只關心zk的簡潔性不適用場景需要完美的EVM等效性需要zk的隱私屬性有一個非區塊鏈用例可選用工具zksync2.0PolygonzkEVMScrollStarknet5.zkVM

適用場景想用高級語言編寫代碼需要證明該執行的正確性需要向驗證者隱藏該執行的一些輸入信息幾乎沒有zk方面的專業知識不適用場景在延遲極低的環境中。有一個巨大的程序。可選用工具RISCZerozkWASM6.預建的可重復使用的電路

適用場景有一個依賴常見的zk構建模塊的智能合約應用,比如Merkle包容。對zk底層的東西幾乎沒有專業知識不適用場景有高度專業化的需求用例不被預建電路所支持可選用工具MantaNetworkSemaphore結論

zk處于多項技術的前沿,構建它需要對數學、密碼學、計算機科學和硬件工程有深刻的理解。然而,隨著每天都有越來越多的抽象層可用,應用程序開發人員無需博士學位即可利用zk的強大功能。隨著時間的推移,通過對堆棧的所有級別進行優化,證明時間的限制會逐漸解除,我們可能會看到針對普通開發人員的更簡單的工具。致謝

本文編譯工作獲得DAOrayaki社區的支持與反饋。原文:ADeveloper’sGuidetothezkGalaxy

Tags:ZKSARKSWAPISCzksync幣圖標Fimi Market Inc.SWAPS價格DISC

PEPE幣
FLASH:一文梳理MEV領域的關鍵進展,有哪些新趨勢與新玩法?

四個月前,我曾發表「MEV保護的四個象限」一文,討論破解MEV困境的不同方法。然而,幾個月以來,MEV領域發生諸多變化.

1900/1/1 0:00:00
CAKE:一覽PancakeSwap V3更新:引入做市商、降低交易費用、激勵交易量

雖是BNB鏈上的龍頭,PancakeSwap在DEX的對比中卻經常被忽視,實際上它的流動性僅次于Curve和Uniswap,截至3月9日,TVL為25億美元.

1900/1/1 0:00:00
GENS:美SEC主席再發聲:權益證明代幣屬于證券,“建議”尋求合規

本周三,幾乎在加密行業引起公憤的美SEC主席GaryGensler在一次公開會議上再次向著加密貨幣“開炮”。他向記者表示,根據美國法律,使用質押協議的代幣應被視為證券.

1900/1/1 0:00:00
SIGN:SignalPlus美聯儲特別報道

各位朋友,歡迎來到SignalPlus每日晨報。SignalPlus晨報每天為各位更新宏觀市場信息,并分享我們對宏觀趨勢的觀察和看法.

1900/1/1 0:00:00
加密貨幣:一覽全球300家加密VC投資概況:過去12個月誰最活躍?

繼Coinstack備受歡迎的2022年加密貨幣風險投資公司名單發布之后,上周制作了以下報告,對全球頂尖300家加密貨幣風險投資基金進行排名.

1900/1/1 0:00:00
SILV:一夜縮水600億美元,淺析加密市場下跌的潛在原因

今晨,加密市場迎來一波快速調整,比特幣、以太坊一小時內雙雙跌超5%,全網爆倉近1.6億美元。是什么導致加密市場的這波下跌,消息面與基本面上有何動靜,BlockBeats嘗試找到潛在因素如下.

1900/1/1 0:00:00
ads