簡介
Curve協議,一種基于以太坊平臺的去中心化交易所,主要聚焦于穩定幣、封裝資產等的交易。相對于其他DEX,Curve提供的交易對更集中,擁有極低的滑點和手續費,可以滿足巨額的資產交易需求。極低的滑點和手續費以及crv的生態,都使得Curve在眾多DeFi協議中能占據重要的一席之地。
StableSwap
StableSwap是Curve在白皮書中設計提出的一種穩定幣交易模型,該模型能提供極低的交易滑點和無限的流動性。
做市函數
StableSwap模型的恒定函數做市商曲線如下:
該設計理念基于融合恒定和與恒定積兩種做市模型,兼具了恒定和的低滑點以及恒定積的無限流動性的特點
推導
假設現共有n個穩定幣,則有:
給恒定和部分添上杠桿系數,并加上恒定積部分,則有:
其中系數X引入了偏度的概念,由放大系數和偏度構成,其中偏度用來衡量流動池中各代幣的平衡程度
結合以上兩式化簡即可得出公式(1)
特點
StableSwap模型的曲線兼具恒定和與恒定積的特點,在各穩定幣相對平衡的情況下,公式由恒定和占主導,曲線趨于直線,滑點較低;當在極端情況下,各穩定幣不平衡,則公式由恒定積占主導,曲線與坐標軸無交點,不會出現流動性枯竭的情況
Basepool
basepool為Curve推出的基礎兌換池,最常見的有3pool,由三種穩定幣DAI、USDC、USDT組成
basepool合約實現了基本的StableSwap交易模型
參數計算
StableSwap模型的做市曲線公式(1)中,有兩個重要的參數A與D,其中參數A為放大系數,由官方調整設置每個池子的放大系數;而參數D則為池中代幣總量,是動態變化的。在basepool合約中,參數D的計算由_get_D函數實現:
@pure
@internal
def_get_D(_xp:uint256,_amp:uint256)->uint256:
"""
Dinvariantcalculationinnon-overflowingintegeroperations
iteratively
A*sum(x_i)*n**nD=A*D*n**nD**(n1)/(n**n*prod(x_i))
多個DeFi項目發布8.11預告推文,明日或將有Linea相關重要消息發布:8月10日消息,多個DeFi項目在社交媒體上同時發布“11.08.23”配圖推文,圖片中存在較為明顯的Linea Logo元素,或為預告明日將有Linea相關重要消息發布。[2023/8/10 16:18:41]
Convergingsolution:
D=(A*n**n*sum(x_i)-D**(n1)/(n**nprod(x_i)))/(A*n**n-1)
"""
S:uint256=0
Dprev:uint256=0
for_xin_xp:
S=_x
ifS==0:
return0
D:uint256=S
Ann:uint256=_amp*N_COINS
for_iinrange(255):
D_P:uint256=D
for_xin_xp:
D_P=D_P*D/(_x*N_COINS)#Ifdivisionby0,thiswillbeborked:onlywithdrawalwillwork.Andthatisgood
Dprev=D
D=(Ann*S/A_PRECISIOND_P*N_COINS)*D/((Ann-A_PRECISION)*D/A_PRECISION(N_COINS1)*D_P)
#Equalitywiththeprecisionof1
ifD>Dprev:
ifD-Dprev<=1:
returnD
else:
ifDprev-D<=1:
returnD
#convergencetypicallyoccursin4roundsorless,thisshouldbeunreachable!
#ifitdoeshappenthepoolisborkedandLPscanwithdrawvia`remove_liquidity`
raise
_get_D函數的算法將做市函數公式(1)以D為變量,通過牛頓迭代法計算出合適的D值,算法可謂精妙簡潔
同樣的算法還用于_get_y函數計算y值
歐盟計劃在6月28日討論有關數字歐元的立法提案:6月21日消息,歐盟計劃在6月28日討論有關數字歐元的立法提案,此前這一備受爭議的議題曾被從行政議程中移除,Mairead McGuinness委員在布魯塞爾的一次活動中表示,我們期待在下周提出這兩項提案,即數字歐元計劃和有關現金法律地位的平行法律。前者將涵蓋隱私、分配和離線交易等議題。歐洲央行計劃在今年晚些時候做出決策,決定是否推進這一項目。[2023/6/21 21:50:37]
@view
@internal
def_get_y(i:int128,j:int128,x:uint256,_xp:uint256)->uint256:
"""
Calculatexifonemakesx=x
Donebysolvingquadraticequationiteratively.
x_1**2x_1*(sum'-(A*n**n-1)*D/(A*n**n))=D**(n1)/(n**(2*n)*prod'*A)
x_1**2b*x_1=c
x_1=(x_1**2c)/(2*x_1b)
"""
#xintheinputisconvertedtothesameprice/precision
asserti!=j#dev:samecoin
assertj>=0#dev:jbelowzero
assertj<N_COINS#dev:jaboveN_COINS
#shouldbeunreachable,butgoodforsafety
asserti>=0
asserti<N_COINS
A:uint256=self._A()
D:uint256=self._get_D(_xp,A)
Ann:uint256=A*N_COINS
c:uint256=D
S:uint256=0
_x:uint256=0
y_prev:uint256=0
for_iinrange(N_COINS):
if_i==i:
_x=x
elif_i!=j:
_x=_xp
Folius Ventures創始人:對于X-to-earn游戲來說需要大量的實驗來弄清代幣的經濟性:金色財經聯合Coinlive現場報道,“Token 2049”峰會活動在新加坡舉辦,在題為 \"洞察整個亞洲加密貨幣格局 \"的圓桌討論中,Folius Ventures創始人Jason Kam當被問及對 \"x-to-earn \"游戲的看法時,Jason Kam表示,他們學到了一些東西,因為他是STEPN的早期投資者,STEPN最終的問題是現金流從何而來。現金流必須與出去的東西相匹配。他認為現在這個行業還為時過早。對于X-to-earn游戲來說,更謹慎和受限制的方法是必要的。需要進行大量的實驗來弄清代幣的經濟性。[2022/9/29 6:02:03]
else:
continue
S=_x
c=c*D/(_x*N_COINS)
c=c*D*A_PRECISION/(Ann*N_COINS)
b:uint256=SD*A_PRECISION/Ann#-D
y:uint256=D
for_iinrange(255):
y_prev=y
y=(y*yc)/(2*yb-D)
#Equalitywiththeprecisionof1
ify>y_prev:
ify-y_prev<=1:
returny
else:
ify_prev-y<=1:
returny
raise
流動性
Curve池的流動性添加不同于Uniswap必須添加交易對的兩種資產,basepool可以僅添加池中某一種資產
@external
@nonreentrant('lock')
defadd_liquidity(_amounts:uint256,_min_mint_amount:uint256)->uint256:
"""
@noticeDepositcoinsintothepool
@param_amountsListofamountsofcoinstodeposit
@param_min_mint_amountMinimumamountofLPtokenstomintfromthedeposit
ApeCoin特別委員會成員Maaria Bajwa發起100萬美元的“漏洞賞金計劃”提案:金色財經報道,鑒于Apecoin DAO質押系統計劃于本月晚些時候上線,ApeCoin 特別委員會成員Maaria Bajwa已經發起提案,旨在創建一個“漏洞賞金計劃”來保護智能合約并將為該計劃分配價值100萬美元的APE。Maaria Bajwa表示,即將到來的質押計劃是對APE金庫資源的重大分配,將需要 APE 持有者的智能合約交互,漏洞賞金計劃增加了一層額外的安全性,并降低了 APE 持有者和 DAO 的風險,不過由于這個漏洞賞金計劃的創建,預計將使ApeCoin DAO的質押延遲2-4周,如果在此期間沒有發現漏洞則將啟動質押系統上線,據此前消息,Horizen Labs已宣布ApeCoin質押系統的“上線”日期是10月31日。[2022/10/17 17:28:13]
@returnAmountofLPtokensreceivedbydepositing
"""
assertnotself.is_killed#dev:iskilled
amp:uint256=self._A()
old_balances:uint256=self.balances
#Initialinvariant
D0:uint256=self._get_D_mem(old_balances,amp)#hunya#初始狀態D0
lp_token:address=self.lp_token
token_supply:uint256=CurveToken(lp_token).totalSupply()
new_balances:uint256=old_balances
foriinrange(N_COINS):
iftoken_supply==0:
assert_amounts>0#dev:initialdepositrequiresallcoins
#balancesstoreamountsofc-tokens
new_balances=_amounts
#Invariantafterchange
D1:uint256=self._get_D_mem(new_balances,amp)#hunya#添加流動性后理論D1
assertD1>D0
#Weneedtorecalculatetheinvariantaccountingforfees
XRP律師:SEC官員Bill Hinman曾收取900萬美元利潤分成:9月2日消息,代表超過7.2萬XRP持有者對SEC提起訴訟的律師John Deaton發文稱,SEC高級官員Bill Hinman在擔任“企業財務主管”期間,曾從企業以太坊聯盟 (EEA) 的合作伙伴Simpson Thacher律師事務所那里獲得了超過900萬美元的利潤分成,其中2017年獲得780萬美元,2018年又獲得180萬美元,此外還有一筆不菲的退休金,總計1500萬美元。
這些資金,可能影響Bill Hinman在SEC任職期間的相關決定,違反了SEC道德顧問辦公室的相關規定。Bill Hinman回應稱自己并不清楚具體金額明細,以為全部都是退休金,也不存在利益輸送。[2022/9/2 13:05:27]
#tocalculatefairuser'sshare
D2:uint256=D1
fees:uint256=empty(uint256)
mint_amount:uint256=0
iftoken_supply>0:#hunya#非首次添加流動性進行手續費扣出
#Onlyaccountforfeesifwearenotthefirsttodeposit
fee:uint256=self.fee*N_COINS/(4*(N_COINS-1))
admin_fee:uint256=self.admin_fee
foriinrange(N_COINS):
ideal_balance:uint256=D1*old_balances/D0
difference:uint256=0
new_balance:uint256=new_balances
ifideal_balance>new_balance:
difference=ideal_balance-new_balance
else:
difference=new_balance-ideal_balance
fees=fee*difference/FEE_DENOMINATOR
self.balances=new_balance-(fees*admin_fee/FEE_DENOMINATOR)
new_balances-=fees
D2=self._get_D_mem(new_balances,amp)#hunya#扣除手續費后的D2
mint_amount=token_supply*(D2-D0)/D0#hunya#LP鑄幣量
else:
self.balances=new_balances
mint_amount=D1#Takethedustiftherewasany
assertmint_amount>=_min_mint_amount,"Slippagescrewedyou"
#Takecoinsfromthesender
foriinrange(N_COINS):
if_amounts>0:
#"safeTransferFrom"whichworksforERC20swhichreturnboolornot
_response:Bytes=raw_call(
self.coins,
concat(
method_id("transferFrom(address,address,uint256)"),
convert(msg.sender,bytes32),
convert(self,bytes32),
convert(_amounts,bytes32),
),
max_outsize=32,
)
iflen(_response)>0:
assertconvert(_response,bool)#dev:failedtransfer
#end"safeTransferFrom"
#Mintpooltokens
CurveToken(lp_token).mint(msg.sender,mint_amount)
logAddLiquidity(msg.sender,_amounts,fees,D1,token_supplymint_amount)
returnmint_amount
Metapool
metapool為basepool基礎上擴展衍生的新池,用作將新型的穩定幣向basepool的LP代幣錨定。basepool池的流動性提供者可以將basepool的LP代幣再次在metapool中添加流動性,進一步賺取額外的交易手續費收益。
metapool合約中,間接耦合了新型穩定幣和基礎池的穩定幣,在提供了不同穩定幣之間的兌換功能的同時,一定程度上分隔了新型穩定幣的風險。
穩定幣兌換
metapool合約中的exchange_underlying函數實現了穩定幣之間的相互兌換功能
@external
@nonreentrant('lock')
defexchange_underlying(i:int128,j:int128,_dx:uint256,_min_dy:uint256)->uint256:
....
#Usebase_iorbase_jiftheyare>=0
base_i:int128=i-MAX_COIN
base_j:int128=j-MAX_COIN
meta_i:int128=MAX_COIN
meta_j:int128=MAX_COIN
ifbase_i<0:
meta_i=i
ifbase_j<0:
meta_j=j
dy:uint256=0
...
ifbase_i<0orbase_j<0:#hunya#兌換中包含meta池代幣
old_balances:uint256=self.balances
xp:uint256=self._xp_mem(rates,old_balances)
x:uint256=0
ifbase_i<0:#hunya#輸入代幣為meta池代幣
x=xpdx_w_fee*rates/PRECISION
else:#hunya#輸入代幣為base池代幣
#iisfromBasePool
#Atfirst,gettheamountofpooltokens
base_inputs:uint256=empty(uint256)
base_inputs=dx_w_fee
coin_i:address=self.coins
#Depositandmeasuredelta
x=ERC20(coin_i).balanceOf(self)
Curve(base_pool).add_liquidity(base_inputs,0)#hunya#base池添加流動性
#Needtoconvertpooltokento"virtual"unitsusingrates
#dxisalsodifferentnow
dx_w_fee=ERC20(coin_i).balanceOf(self)-x
x=dx_w_fee*rates/PRECISION
#Addingnumberofpooltokens
x=xp
...
#Withdrawfromthebasepoolifneeded
ifbase_j>=0:#hunya#輸出代幣為base池代幣
out_amount:uint256=ERC20(output_coin).balanceOf(self)
Curve(base_pool).remove_liquidity_one_coin(dy,base_j,0)#hunya#base池移除流動性
dy=ERC20(output_coin).balanceOf(self)-out_amount
assertdy>=_min_dy,"Toofewcoinsinresult"
else:#hunya#純base池代幣兌換,直接調用base池exchange函數
#Ifbotharefromthebasepool
dy=ERC20(output_coin).balanceOf(self)
Curve(base_pool).exchange(base_i,base_j,dx_w_fee,_min_dy)
dy=ERC20(output_coin).balanceOf(self)-dy
...
logTokenExchangeUnderlying(msg.sender,i,_dx,j,dy)
returndy
若兌換情況涉及basepool代幣和metapool池代幣,則會通過basepool的LP添加或移除流動性來做中間流程;若只是basepool代幣的兌換,則直接調用basepool的exchange函數進行兌換。
總結
總的來看,無論是白皮書的理論設計還是代碼的算法實現都是十分優秀的,理論設計巧妙夯實,代碼算法高效簡潔。這些優秀的實現都使得Curve在穩定對價資產交易領域中有著明顯的競爭優勢。
Tags:INTUINCOINOINFintruX NetworkHIPENGUINScoinwatch手表價格圖片smallcoin
Gate.iowilllaunchaSharkFin2.0productwithanannualizedyieldof2%~25%.
1900/1/1 0:00:00尊敬的WEEX用戶您好!早春活動百萬交易員征集令 活動四:天天空投 活動方式: 活動期間每天抽出10位有完成合約交易的用戶隨機送8、18、38、68、88USDT,周一至周五不限幣種.
1900/1/1 0:00:00Gate.io槓槓ETF是一種自帶槓桿屬性和具有自動調倉機制的交易產品。ETF產品每日跟進盈利虧損調整槓桿率回到目標槓桿桿倍數,盈利會開倉,虧損會減倉,用戶在交易槓桿產品的時候不需要支付保證金,
1900/1/1 0:00:00自從Facebook更名為Meta后,關于元宇宙的討論愈發激烈,這一詞匯也越來越多的出現在我們的視野里。這是一個非常有趣的話題.
1900/1/1 0:00:00原文作者:arcane 原文翻譯:Blockunicorn對于某些人來說,Web3是元宇宙。對其他人來說,它是令人困惑和抽象的,糾纏在復雜的密碼系統中,這對新手來說似乎是壓倒性的.
1900/1/1 0:00:00關於Gate.ioStartup免費空投計劃爲回饋平臺用戶,Gate.io上線“免費空投計劃”,在Startup區不定期進行區塊鏈項目的免費空投計劃.
1900/1/1 0:00:00