加密貨幣交易所 加密貨幣交易所
Ctrl+D 加密貨幣交易所
ads

自動做市商(AMM)算法的數學原理及其未來發展_Curve:SWAP

Author:

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

本文總共分為中篇闡述自動做市商算法、現狀及未來迭代的思考,本文為中篇。下篇請點擊

目錄

7.?Curve的StableSwap和交易公式

8.?CurveV2的動態權重、可定制的價格錨定和平滑的價格過渡

9.?CurveV2在2代幣池中的做市商函數

10.與CPMM和StableSwap相比,CurveV2的價格函數

11.價格重錨過程:Xcp標準、EMA價格預言機、相對價格變化步長s

12.CurveV2的動態交易手續費

13.DEX聚合器:BalancerSOR算法的通用解決方案

14.Pivot算法:解決無常損失問題的一種嘗試

15.單邊流動性解決方案

Curve的StableSwap和交易公式:

Curve將恒定加和做市商(CSMM)和恒定乘積做市商(CPMM)合并在一起,以實現更低的價格滑點。我們可以把這個算法看作是向Uniswap/Balancer模型添加一個固定價格部分,使最終的做市函數錨定于一個價格。

Curve1?V1,被稱為StableSwap,設計了用于穩定幣交易的算法。它將CSMM與權重相乘并加上CPMM:

Curve1?V1

StableSwap—efficientmechanismforStablecoinliquidity

https://curve.fi/files/stableswap-paper.pdf

首先我們考慮一個特殊情況,即流動性池中每種代幣的數量是相同的。很容易證明在平衡點處時這個方程成立。但是,當流動性池失衡時,如果χ是一個常數,則該等式將不再成立。因此,我們需要將χ變量化。CurveV1選擇了一種χ的函數形式,使它在流動性池極端不平衡時變為零,這意味著該方程由CPMM主導。在平衡點下,χ等于A。A是一個常數,通過模擬歷史數據進行優化。代入χ給了我們一個始終成立的方程。

Solana自動做市商協議Raydium將推出NFT發行平臺Dropzone:9月9日,SolanaNews官方發布推文稱,Solana自動做市商協議Raydium將推出NFT發行平臺Dropzone。DropZone將成為Solana熱門NFT項目的啟動平臺,包括籌集資金,無縫分發NFT項目合集,并建立他們的社區等。[2021/9/9 23:13:24]

接下來,讓我們推導出StableSwap如何實際計算交易結果。根據當前池中的代幣數量,我們可以計算出D。例如,如果我們想換出代幣j,我們可以將x?分離開來并求解x?的方程:

該方程可以簡化為二次形式。可悲的是,現在鏈上Vyper語言里沒有可以解二次方程的數學庫。因此,StableSwap使用了牛頓法來求解x?。迭代公式每次迭代都將其精度加倍。因此,可以在設定的gas上限內計算可接受的x?。最后,交換前后x?之間的差值將是購買的代幣j的數量。

牛頓法

它是一種在實數域和復數域上近似求解方程的方法

https://en.wikipedia.org/wiki/Newton%27s_method

FromStableSwapwhitepaper

FromStableSwapwhitepaper

與CPMM相比,StableSwap做市商受壓、以x+y=常數方向壓平。這確保交易價格接近或等于1,在平衡點附近有非常小的滑點。當池中的一個代幣幾乎售罄時,價格開始急劇下降。這很容易理解:函數的曲率/滑點被集中/推到別處,以確保在平衡點附近的低滑點。

自動做市商BurgerSwap發布補償計劃:官方消息,BSC鏈上首個自動做市商BurgerSwap發布補償計劃,在區塊高度7781159(5月27日06:54:46 PM之前,UTC時間),持有遭受攻擊的BURGER LP將有資格獲得補償。

此前消息,BurgerSwap更新閃電貸細節,共被盜走4400枚WBNB、140萬枚USDT等代幣。已修復Bug并重新開放兌換和流動性,隨后公布補償計劃。[2021/5/31 22:58:10]

該模型中的CPMM和動態權重被用于懲罰提前知道消息的大額訂單,防止池中的代幣被完全售罄。

優點:通過添加CSMM和CPMM以及動態權重,Curve的StableSwap實現了非常小的滑點,非常適合穩定幣。

缺點:價格始終錨定在1。如果市場價格與流動性池價格顯著不同,流動性池將被買空。因此,StableSwap僅適用于穩定幣。

CurveV2的動態權重、可定制的價格錨定和平滑的價格過渡:

為了確保更平穩的價格過渡和可定制的價格錨定,Curve11V2將動態權重χ修改為K,如下所示:

Curve11?V2

Automaticmarket-makingwithdynamicpeg

https://curve.fi/files/crypto-pools-paper.pdf

K0在0和1之間變化,χ和K作為K0的函數繪制如下:

我們可以從上圖中了解CurveV2如何使價格轉變得平滑。它實際上使動態權重在遠離平衡點時迅速下降。γ值越小,下降越快。使動態權重快速下降到零本質上相當于強制函數表現得更像CPMM,即使流動性池只是有一點不平衡。

DW在twitter12上發布了一條很棒的推文,解釋了相同的概念。

BSC鏈上自動做市商BurgerSwap遭閃電貸攻擊:5月28日消息,PeckShield派盾預警顯示,BSC鏈上自動做市商BurgerSwap疑似遭遇閃電貸攻擊,被盜超過432,874個Burger,約330萬美元,目前攻擊者已通過1inch獲利變現,目前仍有20萬枚Burger。有一名為EdisonOh投資者表示,其在投資了100萬美元并質押了xBURGER池,目前流動性從100萬美元下降到只有1萬美元,損失了97%。[2021/5/28 22:51:18]

DW?在?Twitter12的推文

https://twitter.com/dken_w/status/1422623679150649345

價格過渡問題得到了解決。現在我們討論CurveV2如何實現其他不是1的價格錨定。有一個價格錨定意味著在做市曲線上存在一個平衡點,在平衡點處按價格標度縮放的代幣數量相等:

CurveV2在2代幣池中的做市商函數:

縮放后的代幣數滿足與StableSwap類似的等式。以最簡單的2幣流動性池為例,做市商函數可以用A、γ、p、D、x、y表示。該函數可以簡化為關于x,y的三次函數。

該函數的典型值圖如下所示:

與CPMM和StableSwap相比,CurveV2的價格函數:

也可以繪制代幣x相對于代幣y的價格曲線。在平衡點(1000,1000)附近CurveV2價格函數恒定。與StableSwap相比,CurveV2略微延遲了價格變動,而不是完全延遲。與CPMM相比,隨著交易量的增加,價格開始以較小的滑點做出反應。總而言之,CurveV2在平衡點附近實現了非常小的滑點,并且在其他區域比CPMM實現了更好的滑點。至于其他非1的價格錨定,我們只需更改上面三次/六次方程中的p。因此,錨定價格的問題也解決了。

報告:自動做市商代幣批準調用機制可能存在安全漏洞:據2月25日消息,加密貨幣錢包提供商MyCrypto發布報告指出,自動做市商在交易或代幣互換之前使用的審批機制(代幣批準調用)可能存在安全漏洞。報告稱,該功能允許第三方代表用戶從其賬戶中發送代幣。與此同時,報告還指出,現在有詐騙者正使用該種手法利用惡意郵件詐騙LINK。郵件聲稱代幣將進行升級,并承諾減少Gas費用。[2021/2/25 17:52:40]

我們可以使用類似的在StableSwap中的牛頓法來計算交換結果。首先,我們根據池中當前的代幣數量計算D。其次,如果我們想換出代幣i,我們再次使用牛頓法來求解x?。同樣,x?的差異將是我購買的代幣數量。

為了確保多項式函數的根可以在設定的gas上限內求解,Curve白皮書討論了他們選擇的起始猜測,以及函數中的參數。他們使用一種稱為模糊測試的方法來確定這些最佳值。目前,我們不知道有關此方法的任何詳細信息,并且很想了解更多信息。

價格重錨過程:Xcp標準、EMA價格預言機、相對價格變化步長s:

為了確保小滑點,CurveV2通過改變價格標度不斷重錨做市商函數。然而,價格重錨可能導致流動性提供者承受價值損失。CurveV2引入了一個名為Xcp的變量來緩解這個問題:

如果一次重錨后的損失大于累積的Xcp的一半,則該算法將保持做市商函數不變。有幾個問題我們想在未來回答,因為白皮書只簡要討論了Xcp。查看其源代碼可能會有所幫助。

Xcp值是否與用流動性池中當前代幣數計算出的價值成正比?

存入或取出流動性是否計入Xcp?

如果取出流動性計入Xcp,如果Xcp減少幅度過大會阻止取出流動性嗎?

對于價格重錨,CurveV2使用EMA價格預言機來確定預言機價格。新的預言機價格向量由最近一次交易價格向量和前一個預言機價格向量的線性組合確定。新價格標度向量的變化方向與預言機價格相似,但不完全等于新預言機價格。他們通過引入相對價格變化步長s,將價格標度向量滯后于預言機價格。該方程可以使用歐幾里得幾何輕松導出。EMA價格預言機和價格標度延遲是為了減少近期價格波動的影響并更好地代表長期市場價格。

Uniswap將在2021年改善自動做市并探索擴容解決方案:12月31日,Uniswap在其《2020年度回顧》中發布2021年路線圖。具體內容包括:1.改善自動做市:團隊繼續研發AMM技術,在v3上取得長足進展。2.探索擴容解決方案以降低延遲交易、加快結算速度和降低交易成本。3.加強治理:Uniswap核心團隊成員計劃在2021年以個人身份更直接地參與治理,包括公開支持或反對提案。此外,核心團隊可以將投票權委托給他人或自己,治理工作將繼續由社區主導。[2021/1/1 16:12:02]

關于相對價格變化步長s,根據我們“刷新Curve官網”的經驗,部分流動性池的s變化頻率至少為十分鐘的量級以上。CurveV2如何更新s是一個有趣的問題,超出了我們當前知識的范圍。查看其源代碼也會有所幫助。

下面顯示了一個演示一次價格重錨過程的圖:

假設我們在x=1000開始我們的交易,并在x=1400結束我們的交易。最初,價格錨定于1。交易后,價格移動到0.6。為簡化起見,僅出于演示目的,我們將新的價格標度設置為與現貨價格相等,并求解六次方程以獲得D。現在做市商函數錨定于0.6,如上所示。

價格重錨本質上相當于找到一個新的做市商函數,該函數穿過當前代幣數量位置,在(x0,y0)處有一個平衡點,使得y0/x0為等于(x0,y0)處導數的絕對值。一個有趣的課題是獲取真實的Curve流動性池參數,做一個更好的價格重錨過程的演示。

CurveV2的動態交易手續費:

由于上面討論的CurveV2的做市商特性,將交易費用設為2級交易費用與動態權重的線性組合是合理的,衡量我們離平衡點有多遠。CurveV2選擇的fmid和fout值分別為0.04%和0.4%。下圖展示了2代幣池中的費用如何變化:

優點:做市商函數可以錨定于任何價格,適合所有代幣,而不僅僅是穩定幣。價格過渡比StableSwap更平滑。CurveV2還根據其內部的價格預言機不斷更新價格標度,以更好地代表市場價格,確保在平衡點附近交易。動態費用確保在此基礎上提供甚至更好的價格。

缺點:由于求解三次方程和六次方程,Gas費用可能會更高。僅根據其內部價格預言機進行價格重錨可能存在風險。我們想知道在通過Xcp標準時,是否存在價格標度與市場價格明顯不同的情況。如果是這種情況,與其他預言機交叉檢查價格可能會有所幫助。

Curve的StableSwap和動態錨定V2是為了使交易滑點盡可能小。StableSwap始終錨定于1,而V2使錨定價格跟隨市場價格。

下面將討論AMM算法的一些最新進展和可能的改進。

DEX聚合器:BalancerSOR算法的通用解決方案:

DEX聚合器是聚合現有AMM協議以實現更好交易結果的協議。如上所述,Balancer的SOR算法也適用于DEX聚合器,以確保數學上最優的交換策略。

Balancer的SOR算法的一般解決方案,沒有任何價格函數近似,可以表示如下:

因為價格函數可以是任何形式,具體取決于生成它們的AMM算法。這意味著滿足總代幣數量守恒和相等最終價格等條件的方程可能沒有解析解。

因此,我們引入了一種在機器學習等領域常用的技術,稱為梯度下降。我們將損失函數定義為不同價格函數值的方差。在選擇一個起始猜測后,我們可以迭代(通過損失函數相對于該變量的偏導數改變每個交換量,乘以學習率l)以獲得最佳結果,在一定的誤差接受范圍內。

由于作為最終等價函數的總交易量是單調的,因此該方法應該能夠找到全局最小值。同樣,上面的計算假設沒有簡單的解決方案。

Pivot算法:解決無常損失問題的一種嘗試:

Pivot算法試圖通過使做市商函數經過一個固定點(x0,y0)來對其進行樞軸旋轉。

(x0,y0)處的價格將始終是設計的當前市場價格Pt。這在概念上確保套利總是將流動性池帶回到點(x0,y0)。由于此功能,無常損失將為零。然而,實際上,該算法沒有足夠的參數來擬合當前儲備和。這意味著我們必須等待流動性池回到(x0,y0),然后更改做市商函數。

從上圖中我們可以看出,交易后的點不在新的做市商函數上。如果當前市場價格低于當前儲備的現貨價格,則流動性池也可能沒有任何動力回到(x0,y0)。

我們想知道是否存在這樣的函數通過(x,y)和(x0,y0)以及在(x0,y0)處的可調導數來適應市場價格。如果我們假設函數是凸的,那么市場價格不能小于這兩個點之間的線性段斜率。因此,如果做市商函數必須是凸函數,則此問題可能沒有完整的解決方案。

單邊流動性解決方案:

流動性提供者在存入流動性時可能不方便存入所有類型的資產。我想知道是否存在與Bancor采取的彈性供應方法不同的其他機制。直覺上,有兩種解決方案:1.首先使用相同的協議交換部分代幣2.無論如何存入單邊流動性,讓套利將價格帶回市場價格。

例如,我們希望將流動性存入一個等值的2代幣池中。

我們只有代幣x。不難計算我們需要交換多少,以便交換后每種代幣的價值相等。也很容易證明β總是在0和1之間,這意味著一個合理的結果。但是,交易后的價格可能與存入流動性時的價格不同。因此,我想知道協議是否真的將交換和流動性存入作為一項原子操作。進行交易時也存在價格滑點。到目前為止,Balancer和Curve等協議如何處理單邊流動性存入仍然是我們的一個問題。如果滑點很小,則進行上述操作是合理的。

BalancerandCurve白皮書中描述的第二種方法是是直接存入單邊流動性。這可能會大大改變價格。由此產生的套利也可能使無常損失變得重大。我們個人在Balancer白皮書和文檔中沒有看到任何懲罰措施。另一方面,Curve在存入單邊流動性時引入了一種稱為不平衡費的東西,其范圍從0%到0.02%。在現實中,由于套利和無常損失,在第二種方法下存入單邊流動性并沒有真正的動機。

了解更多與單邊流動性相關的其他創新將會很有趣。

由于本論文過長,?AMM算法的一些最新進展和可能的改進及后續內容將于下篇公布。

原文鏈接:https://link.medium.com/ynEydZUihjb???

作者:LeoLiu,GuangwuXie

翻譯:VanessaCao

校對:LeoLiu,GuangwuXie

排版:JaneHu

感謝:FangyuanZhao,ShowenPeng,DW,LianxuanLi,DaveWhite,DanRobinson,VanessaCao,JaneHu

Tags:CurveCURSWAPSTASCURVEProCurrencyLSWAP價格SAFESTAR

POL幣最新價格
是技術創新還是披著羊皮的狼?NFT市場火爆背后的安全隱憂_NFT:TOKE

2021年對于幣圈來講注定是一個值得被載入史冊的一年,后疫情時代各國政府為應對經濟衰退而出臺的一系列宏觀調控政策使得數字經濟突飛猛進,在貨幣寬松政策下大量的資金涌入幣圈.

1900/1/1 0:00:00
金色前哨|CyptoPunk兩小時密集成交1200萬美元_PUN:BabyPunks

金色財經報道,9月16日消息,據larvalabs數據顯示,Cryptopunks?NFT頭像在近兩小時左右的時間內密集成交34枚,總交易額為3445.11ETH.

1900/1/1 0:00:00
陳道富:我國央行數字貨幣的核心價值是適應數字時代開啟技術探索_數字貨幣:boom幣是什么幣

9月23日,由新華網主辦的“2021第六屆金融科技論壇”在北京舉行。本次論壇由中國人民大學金融科技研究所、對外經貿大學中國保險創新研究院、金融科技50人論壇作為學術支持單位.

1900/1/1 0:00:00
元宇宙投資的中美差異_元宇宙:區塊鏈

投資者應密切關注互聯網監管趨勢,在元宇宙建設初期繼續持有多元化投資的大型科技企業,且不要忽略在網絡安全、隱私計算等領域提前部署。未來尚未到來,但投資無心等待.

1900/1/1 0:00:00
Continue Capital 匹馬:新公鏈:列王的紛爭_CON:Cake Monster

也許一切都應該從Coinbase二季報說起。如果留意Coinbase上項目成交量,就會從5月份發現一個微妙的變化:ETH日成交量跟BTC幾乎持平甚至偶爾反超,當二季報公布之后,ETH成交量有史以.

1900/1/1 0:00:00
金色觀察 | 通過這幾十個問答 真實了解薩爾瓦多當地人對BTC的看法_BTC:Tuxcoin

2021年6月9日,薩爾瓦多國會投票批準總統提交的比特幣作為法定貨幣的提案,薩爾瓦多成為全球首個承認比特幣為合法貨幣的國家。2021年9月7日是比特幣正式成為薩爾瓦多法定貨幣的第一天.

1900/1/1 0:00:00
ads