Uniswap的恒定乘积算法里的K值

本文介绍uniswap里的恒定乘积算法中的K值是怎么设计的。

我们拿uniswap里的一个交易对,ETH/USDT来举例说明K值是怎么设计的。

恒定乘积算法。

uniswap里第一个人添加x个ETH和y个USDT的作为流动性时,决定了K值的初始大小,即K=x*y。

这时,ETH和USDT共同构成了一个流动性池。请记住这个概念,很重要。

第一个添加流动性的人,可以任意添加交易对中的两个币的数量,即可以任意决定K值。

添加完流动性后,ETH的价格就等于=y(USDT的数量)/x(ETH的数量)。如果这个价格和其他交易所之间有价差,那肯定会被人搬砖套利。

Uniswap在以太坊二层扩容方案Optimism上推出alpha版本:官方消息,Uniswap在以太坊二层扩容方案Optimism上推出alpha版本,用户需要将资产桥接至Optimism网络后才可进行交易。目前Optimism上Uniswap合约已部署完成。[2021/7/9 0:39:07]

所谓的恒定乘积算法,指的是在流动性池没有再添加或减少流动性的情况下,只有交易行为发生的情况下,K值是不变的。

即如果用户在ETH/USDT交易对里买入或卖出ETH,都无法改变K值的大小。

而交易行为会修改流动性池里的ETH和USDT的成分。比如用户买了dx个ETH,则流动性池里的ETH的数量就会变成(x-dx),而usdt的数量则变成了K/(x-dx),即用户需要花dy=K/(x-dx)-y个Usdt来买dx个ETH。

0x协议优化与UniswapV3集成的提议ZEIP-88已开启投票:去中心化交易协议0x协议称,其关于「优化与UniswapV3集成以降低相关交易成本」的提议ZEIP-88已开启投票。此次提案中提出了两项更改,一是将UniswapV3Feature合约添加到交易代理(ExchangeProxy),二是在MultiplexFeature上添加了对UniswapV3的支持。[2021/5/26 22:45:38]

交易手续费影响K值。

但因为存在交易手续费,用户使用uniswap交易时,需要交0.3%的手续费。比如用户拿dy个usdt买ETH,uniswap会首先扣除0.3%dy的手续费,先将这0.3%dy的手续费丢在一边,完成交易后,这0.3%dy会被添加到流动性池里,此时K值就变成了x*(y+0.3%dy)。

Uniswap V3 24小时交易量达12.9亿美元:据欧科云链OKLink数据显示,以太坊上Dex24小时交易量约合60.3亿美元。其中交易量排名前三的Dex协议分别是Uniswap V2 14.1亿美元,Uniswap V3 12.9亿美元以及SushiSwap 9.17亿美元。Uniswap V3的交易量占到当前以太坊Dex交易量的21.45%。[2021/5/19 22:18:10]

所以,恒定乘积算法的K值并不恒定,每一笔交易都会影响K值。

添加流动性影响K值。

如果现在资金池里有xETH/yUSDT,K=x*y。现在有人又添加了流动性,增加了dx个ETH和dy个usdt,并且dx/dy=x/y。

如果你使用Uniswap的默认设定,即你添加流动性时,先输入ETH的数量,然后uniswap会默认计算出需要多少usdt,这个默认计算就是保持dx/dy=x/y。

但,添加完流动性后,流动性池里的资金变成了:(x+dx)ETH/(y+dy)USDT。此时,(x+dx)*(y+dy)>x*y。所以添加流动性K值变大了。

同样的减少流动性,会减少K值。

如果你在添加流动性时,不是按dx/dy=x/y的比例去添加,而是直接往合约地址里转了dx>0,dy=0,也是可以的。这同样会改变K值。

这样的事是经常发生的,有些人错误地将ETH转入一个uniswap流动性池合约地址里,就产生了捐赠行为,白白把币送给了所有原来的流动性所有者。

这种非K值比例添加流动性的行为,被uniswap称为捐赠。

但这种捐赠行为,在设计上是可以被其他人套利的。比如有人充值了dx>0,dy=0;此时另外的人可以充值按K值比例的dy,并且执行一个添加流动性的操作,就可以把那dx的捐赠给薅走。这个挺复杂的,细节我也搞不清楚。

任何不是按K值比例添加的流动性,都会产生捐赠。比如dx/dy>x/y,则先添加(dx-ddx)/dy=x/y的流动性,并返回给用户对应数量的LPtoken。然后ddx就变成了捐赠。

还有,在同一个区块里,可能即有交易是添加流动性的,也有交易是买卖,那K值就会更复杂的变化。

感谢Plancker Dao成员李世胜对本文的贡献

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

银河链

Gate.ioWeb3时代 用户将拥有数据自主权

当人们想到Web3时,首先想到的可能是NFT、元宇宙或区块链技术之类的东西,所有这些概念都属于Web3的范畴。除去以上提到的,凭证数据网络也属于这个范畴,它们在Web3的发展中也扮演着不可或缺的作用.

世界币特殊的加密方式 Schnorr签名

非对称密钥 公私密钥对是区块链技术加密手段的重要基石,同时也是加密货币安全性的保证。但公私密钥的配对是不对称的,私钥相当于写着箱子号码的钥匙,而地址就是无数个放在区块链中任何人都可以查看的带有编码的箱子,两者的不对称是指用私钥(带有编.

[0:281ms0-1:565ms