科普:CFMM(恒定函数做市商)的演变

在传统金融市场上,每种证券都需要一个买方和卖方市场才能有效地进行交易。如今,股票交易的速度和简便性被视为理所当然,尤其是在新引入的Robinhood投资模式下。在这个新时代,做市商扮演着举足轻重的角色,为市场参与者创造了无缝的交易体验。在过去的一年里,做市商这个角色以名为自动化做市商(AMMs)的算法代理的形式移植到加密生态系统中。

AMMs执行的功能与传统做市商相同,促进两种数字资产之间的交易。然而,在智能合约里不是由大银行或交易公司来做市,而是通过算法做市。与传统的做市商依靠大量资源提供严格的买卖价差不同,AMMs重新定义了提供流动性的方式,并应用数学公式来决定资产交易的价格。

恒定函数做市商(CFMM)是最流行的AMM系列。当交易者希望将代币A换成代币B时,这种AMM会使用恒定函数作为其定价机制。在这种情况下,术语 "恒定函数 "指的是资产储备的乘积必须在发生任意交易时都保持不变。

自2017年以来,针对不同使用案例的优化,一些DEX已经把这个恒定函数进行了修改。下面将介绍一些最流行的DEX,并详细介绍其采用的恒定函数。

Uniswap

Uniswap是第一个让使用恒定函数(来交换两种资产)变得流行的DEX。它使用了一种被称为 "恒定乘积AMM "的AMM变体,它强制要求两种资产储备量的乘积必须始终保持不变。

HyperPay钱包发布5.0版本,支持中心化和去中心化模式自由切换:据官方消息,日前,HyperPay钱包发布了全新5.0版本,支持中心化和去中心化模式自由切换。在该版本中,托管钱包和自管钱包完全独立,托管钱包分为简洁版和专业版。HyperPay托管钱包由获得合规托管牌照的HyperBC进行资金托管,并定期经由慢雾科技、知道创宇、CERTIK等知名安全公司审计,全方位保障用户资产安全;自管钱包新增DeFi理财超市、热门空投、行情资讯等板块,并支持聚合Dex交易、跨链闪兑、合约安全检测、NFT收藏与分享等功能。

HyperPay钱包成立于2017年,迄今,HyperPay钱包用户逾百万,资管规模超10亿美元,转账超3.1亿次,托管钱包支持51+公链,自管钱包支持30+公链,HyperMate硬件钱包支持17+公链。[2022/5/30 3:50:03]

在这个等式中,x和y代表流动性池中两种资产的单位数量。举例说明,假设ETH/DAI池包含100 ETH(x的值)和10,000 DAI(y的值)。在这个例子中,Uniswap将这两个数量相乘,得到k的值为1,000,000。现在的目标是保持k值恒定,而不考虑对流动性池的交易量。做到这一点的唯一方法是,x和y的数量反向变化。换句话说,当x的数量增加时(交易者将ETH加入池中),y的数量必须减少(交易者将DAI从池中取出)。最终,任何给定交易所的报价都是常量乘积公式和池中代币比例的函数。

需要注意的是,x和y之间的关系不是线性的。用10个ETH兑换1000个DAI不等于用20个ETH兑换2000个DAI。相反,这种关系是渐近式的。这意味着随着花费的代币数量增加,收到的代币数量会变小。

韩国社交媒体巨头Kakao旗下公链Klaytn加入BSN:金色财经报道,韩国互联网巨头 Kakao 旗下的公共区块链平台 Klaytn 宣布加入区块链基础设施BSN。目前BSN分为两个实体:BSN China和 BSN International,截至目前,后者已与以太坊、Solana、Tezos和Polkadot实现了整合,随着Klaytn的加入,旗下生态中 25,000 名开发人员将能访问BSN资源。[2022/1/27 9:16:41]

恒定乘积函数的特性对AMMs很有用,因为它确保了当任何一种资产的价格接近无穷大时,总会有流动性。

Balancer

Balancer的AMM一般化了Uniswap的恒定乘积功能,创造了一个被称为 "恒定平均AMM"的变体。这个AMM的核心是价值函数,它强制规定资产池中的资产余额的权重次幂的乘积应始终保持不变。

在这个公式中,t代表池中的资产的种类数,Bt是资产数量,Wt是资产权重。虽然与Uniswap简单易懂的常量乘积函数相比,数学公式看起来要复杂得多,但其实很容易理解。例如,假设用户创建了一个Balancer Pool,其中包含三种资产:100 ETH、100 BTC和100,000 DAI,每种资产的权重为33.3%。Balancer对这些数值进行如下处理:

Bzone已正式推出治理代币BzoneDAO:据Bzone官方报道,晚22点附近ETH区块高度达到12335700,此后每个区块将为BZO产出2个BZO铸造额度,目前已产出370个BZO额度,将于30日下午3点开启交易。

BzoneDAO拥有三大应用场景:生态治理、社区建设以及跨链桥。生态治理:持有BZO可获得Bzone生态合作,并参与平台治理。社区建设:搭建基于Bzone的社区及Dapp应用,BZO为唯一通证。跨链桥:支持多链(陆续支持HECO、BSC、TRC、EOS等)跨链,生态互通。[2021/4/30 21:11:55]

类似于Uniswap,目标是在保持资产权重不变的情况下,只改变资产余额,从而保持k不变。在3种资产Balancer Pool的情况下,交易可以发生在三个资产中的任意两个之间。用户可以用ETH交换DAI,用ETH交换BTC,或者用DAI交换ETH。通过保持k的值不变,可以在三种资产之间生成一个价值面。

有趣的是,这个曲面与Uniswap的常量乘积函数并没有太大区别。另一种思考方式是将图1中的恒积函数,额外增加一个代表池中第三个代币的轴。通过改变图2的角度,两个函数之间的相似性变得更加明显。

由于Balancer池被设计成有2到8种资产,任意两个代币之间的交易价格报价就比较复杂了。池中的每一对代币都有一个价格,这个价格取决于该特定代币的余额B和权重W。从形式上看,交易执行的价格是按照代币余额与代币权重的比值来计算的。

在上面的公式中,代币A代表被卖出的代币(进入池子) 而代币B是被买入的代币(离开池子)。如果池子的持有者不改变资产储备,很容易看出价格的变化完全基于交易,因为资产权重必须始终保持不变。这种机制与图2所示的恒定面相结合,可以保证买入资产的价格上升,而卖出资产的价格下降。在与Uniswap相同的情况下,套利机会保证了Balancer Pools提供的价格与市场其他部分同步变动。

Curve

Curve是一个交易所流动性池,预期价格稳定的资产之间可以在该池里进行高效交易(如稳定币或封装的比特币(wrapped bitcoin))。Uniswap和Balancer主要是针对波动和价格不稳定的代币的交易。然而,当处理那些想要互相保持稳定的资产之间的交易时,低价格滑点是最重要的。之前迭代的各种AMMs固有曲率就有问题了,因为交易规模越大,滑点就越大。

解决价格滑点问题的一个方法是,使用常数和函数作为AMM的内部交易机制。当使用两种资产进行操作时,恒和(constant sum)做市商强制规定资产数量之和必须保持不变,并遵循以下函数:

如图,一个双资产恒和做市商是一条简单的直线。

虽然这个函数的简单性实现了低滑点,但它缺乏恒定产品做市商的关键属性,即当任何一种资产从池子中流出时,池子总还会有流动性,而另一种资产的数量趋于无穷大。

为了解决这些问题,Curve通过结合恒定总和和恒定乘积函数创造了一种混合AMM:在曲线的平衡点附近创建一条相对平坦的曲线,类似于恒定总和函数,以保持价格相对稳定,同时使两端更加倾斜,类似于恒定乘积函数,因此在曲线的每个点都有流动性。在双资产的情况下(x和y),最终的结果是下面的复杂函数。

除了复杂的数学之外,请注意两个常数函数是如何嵌入方程中的。左边是常数和,右手边是常数积。此外,公式中还包含了一些其他的项来达到预期的目的。在公式中,n代表资产数量(在本例中n=2),A是一个 "放大系数 "参数,它决定了函数与常积函数的相似程度。A的值越低,Curve的函数就越接近Uniswap的函数。

就像之前的CFMMs一样,我们的目标是在x和y之间发生交换时保持k的值不变。绘制该函数会像这样:

来源:Curve白皮书

从图5中可以看出,Curve的函数在中间表现为恒定加和函数,但随着x和y的值的变大,则变为恒定乘积函数。这种形状使曲线中间段的价格保持稳定,同时又能在两端提供流动性。

在过去的几年里,AMMs通过以去中心化的、全球可访问的和非托管的方式汇聚和提供流动性,它已经成为DeFi的重要组成部分。具体而言,Uniswap、Balancer和Curve等CFMMs获得了巨大的增长和应用,交易量超过数十亿美元。

自2017年以来,这些去中心化的交易所已经开发了恒定函数的各种变体,以解决特定的交易所问题。随着该领域继续扩大,涵盖各种资产,为使交易更高效,交易所必须对底层功能进行大量思考。虽然这项技术仍处于早期阶段,但它已经带出了新的研究领域,更多的AMM设计将会出现,最终为所有DeFi用户提供更好的流动性。

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

UNI走向云端:区块链+云技术

2009年1月3日,中本聪挖掘了比特币创世区块,启动了本世纪以来最大的技术淘金热。比特币曾经被认为是一种软件、一种“协议”、一个网络、一个开发团队或者一种叫做加密货币的新东西。而与此同时,云技术证明了抽象机制和应用程序编程接口可以促进可扩展性和产品敏捷性的爆炸性成长,消除了90%的应用程序中普遍存在的所有干扰因素。

币安下载晚间必读5篇 | 灰度负溢价 DCG拉盘

1.MW隐私协议将激活 莱特币会有监管风险吗? 3月17日,莱特币基金会发推称,MimbleWimble 隐私协议代码已完成。该代码已准备好供其他开发人员进行正式审核,审核过程可能会持续数周或数月,最终代码将被合并到莱特币的主要代码库中,以便节点运营商及矿工选择是否支持,最终将由莱特币社区决定 MimbleWimble 协议激活时间。

[0:15ms0-0:531ms