Curve:Curve V2方案解析:通用与定制化AMM之争_SWAP

CurveV2版本的发布极其低调,既没有制作精美的介绍页面,也没有讲解原理的视频,甚至都没有进行像样的宣传。整个的发布活动,便是在项目的官方网站放出了一版介绍V2基本原理的白皮书。该版白皮书虽然只有区区5页,但其中却充满了让普通用户望而生畏的数学公式。所以,在正式介绍CurveV2的意义之前,有必要先用最简单易懂的语言,解析一下Curve是如何在V2版本中,实现对非稳定币交易对的支持的。

白话解读CurveV2基本原理

大家千万不要一开始就被Curve白皮书中的累加“∑”或累乘“Π”等数学符号所吓倒,之所以Curve的公式会变得如此复杂,并不是因为其算法有多么玄妙。而是因为Curve希望在一开始就能够在底层逻辑上,原生的支持多币种交易资金池,因此原本简单易懂的二维恒定乘积公式xy=k,也就需要升维变成

Mercuryo通过Fireblocks集成扩展加密资产:金色财经报道,加密支付解决方案Mercuryo已经整合数字资产托管技术提供商Fireblocks。

由于这一产品整合,从集中式交易所到DeFi钱包现在有机会访问大量的货币。这种整合也将成为Mercuryo的银行即服务(BaaS)产品的一部分,使加密货币原生公司能够将内置的银行账户整合到他们的平台中。Fireblocks还为Mercuryo提供了一种简单的方法,可以根据需要和要求在其产品中增加对新资产的支持。(finextra)[2022/10/29 11:54:38]

这种看似复杂的多维恒定乘积形式。

因此,为了使读者能够更好地理解,我们在此重新将多维模型降低到更易理解的二维状态。那么,在更简单的二维模型里,CurveV2的价格曲线是什么样子呢?

Curver社区发起对CRV/yCRV流动性池提供激励的投票:9月24日消息,Curver社区发起对CRV/yCRV流动性池提供激励的投票,yCRV是Yearn上的Curve中DAI、USDC、TUSD、USDT流动性池LP代币。[2022/9/24 7:18:24]

上图是摘自CurveV2白皮书中的价格曲线。与CurveV1中通过将xy=k与x+y=k两个基本价格曲线按照一定权重比例进行拟合类似,CurveV2的价格曲线也是由其他基本曲线拟合而成。简单来讲,就是曲线在交易价格附近更接近CurveV1的曲线形状,而在远离交易价格的位置,则更加接近xy=k。以此构成了一个在交易价格附近更平滑,但在远离交易价格范围后弧度更大的一条价格曲线。相比V1版本中更接近于一条直线的价格曲线,V2的曲线在远端的弧度更大,以此增加对非稳定币交易对的支持程度。

当然,如果CurveV2仅仅是重新构造了一条固定形状的价格曲线,自然也无法达到其在所有价格点动态聚合流动性的目标。CurveV2最关键的改进,是在当价格偏离原聚合范围时,可以对流动性进行自动再平衡,重新构造一条适用于新价格的曲线。

稳定币交易协议 Curve 发起新提案,将进行多链部署:稳定币交易协议 Curve 发起新提案,将进行多链部署。由于以太坊的使用成本很高,Curve 将支持在其他链上创建 gauge,veCRV 持有者可以为它们投票,并分配 CRV 给 gauge 和特定链的质押者。如果部署失败,DAO 可以选择关闭 CRV 奖励。多链部署后 Curve 可用于所有侧链和 Layer 2,并且将使 veCRV 持有者能够对以太坊侧链和 Layer 2 上的 gauge 进行投票治理。[2021/5/12 21:55:27]

此时需要解决的另一个问题是,系统该如何感知市场价格的变化,并在适当的时候进行再平衡操作呢?大多数同类项目会选择直接接入外部预言机,但引入外部预言机也同时也会为系统引入新的外部风险,一旦预言机失效或被操纵,LP的资金安全便很难得到保证。

CurveV2为了彻底杜绝外部风险,改为依靠内部数据作为参考价格,官方将这种机制称为EMA预言机。读者这里同样不需要去理解EMA是什么,只需要了解这个EMA预言机提供的价格,是根据Curve的历史成交价以及最新的交易信息综合计算出的一种参考价格就可以。这个参考价格有些类似于技术分析中的30天均线,他会根据最新的成交价格进行动态调整,但在调整的同时也会保有一定的滞后性,以免在价格剧烈波动时过度频繁地触发再平衡机制。

Curve今日启动新的CRV代币分红计划:9月20日消息,Curve正在为其治理代币CRV的持有者启动一项新的分红计划。Curve创始人Michael Egorov表示,他们将开始转向基于现金流的协议。为了参与治理,用户需要将其CRV放到有投票权的合同中,将CRV交换为veCRV(被锁定的代币CRV)。从今日开始,这些托管代币将开始收到Curve上所有抵押费用的一半。(Coindesk)[2020/9/20]

有了内部预言机提供的参考价格,系统便有了进行再平衡的触发依据。当EMA预言机报出的价格偏离原始价格超过一定范围后,协议便会自动对整条曲线的形状进行调整,使得流动性重新聚合于最新的交易价格附近。

CurveV2与UniswapV3的解决方案有哪些不同

早在CurveV2刚刚发布的时候,便有评论认为CurveV2版本将与UniswapV3展开直接竞争。毕竟两者都提出了在全部价格区间聚合流动性的通用解决方案。可是如果仔细分析这两个项目的具体实现方式,又会发现两者间存在着明显的区别。

动态 | 报告:Security Token跨国别大规模交易可能较难实现:据标准共识、了得生态BECO与STO发行平台Polymath共同发布的报告《通证经济下一个时代:Security Token》,由于不同国家监管细节和进度不同,以及存在资金外流等风险,Security Token 跨国别的大规模交易深度可能较难实现,场外交易也会受到周期和监管的限制,Security Token 短期内其整体流动性的水平并不如市场预期。但 Security Token 作为一种新型证券载体/系统在接下来的数字资本市场发展中起着巨大推进作用。[2018/10/29]

区别一:如何决定在何处聚合流动性

在CurveV2中做市,完全不需要LP主动选择流动性的聚合范围。系统将会依据市场价格的变动,自动将LP的流动性集中到交易价格的附近。而UniswapV3则需要LP自己判断市场的价格走势,并自主选择做市的价格区间。

区别二:LP的头寸是否同质

我们知道,由于每个LP的做市金额与范围都不尽相同,Uniswap在V3中使用NFT来表示LP的做市头寸。而在CurveV2中则完全没有这个问题,每一个LP在资金池中的流动性分布是完全相同的,相互之间只有数量差异,因此依然可以使用同质的ERC20代币表示LP的头寸。这大大降低了其他协议与Curve进行组合时候的困难程度。

区别三:如何对资金进行再平衡

我们常常说Uniswap在升级到V3版本后,被动的做市管理方案已经不再有效,LP需要不断主动判断价格走势并调整头寸。而CurveV2将再平衡的策略完全融入了协议层本身,用户不再需要了解再平衡的基本原理,也不需在市场诸多代理方案中进行选择,只需要考虑什么时候存入,何时取出,剩下的全部交给Curve的协议层自动执行。

区别四:交易手续费如何确定

在手续费的问题上,Uniswap其实并没有给出通用的解决方案。系统原生只提供了三个档位的费率供LP们选择,每个档位对应一个独立的资金池,这不但限制了用户的选择范围,还增加了流动性的割裂程度。

相对来说,CurveV2依然采用了自动化解决方案,系统内置的手续费率范围为0.04%-0.4%。当市场价格接近流动性聚合的中点时手续费最低,而在偏离时手续费会逐渐升高。整个过程完全自动完成,不需要LP进行管理和干预。

经多以上对比,我们发现相比CurveV2这种一站式解决方案,UniswapV3似乎显得既复杂又难用。不但做市的几乎所有关键参数都需要用户自主选择,还需要在后续做市过程中不断进行再平衡。那么同样有着行业内顶尖开发团队的两个头部DEX项目,为什么会针对同样的需求,却交出了差别如此之大的解决方案呢?

方法论之争:做应用还是做生态

两种截然不同的解决方案,显然不是受制于开发团队的技术能力,根本原因在于两个团队创始人对行业核心诉求的理解截然不同。

UniswapV3的核心思路,是通过开发一套可以模拟任何形状价格曲线的通用解决方案,从根本上解决不断产生的定制化AMM分叉项目。因此开发团队必须将各种关键参数的决定权留给市场,并通过成立开发者基金不断扶持生态的发展。寄希望于市场能够通过自由竞争,形成几套成熟的主动做市管理方案,以解决不断变化的市场需求。

承认个人与团队的意志无法永远正确,并将选择权充分的开放给市场和社区,自己仅参与底层基础架构的建设,是Uniswap团队的核心理念。

而Curve团队则反其道而行之,他们认为用户的时间和注意力都是有限的,不应再使他们陷于复杂的选择困境之中。开发团队应当直接为用户提供全套的最优解决方案,使用户只需考虑何时存入资金,何时取回资金,其他的过程一律交给协议自动完成。

承认多数用户不具备专业分析能力,作为更专业的行业精英有必要提供一揽子解决方案,尽量解决用户可能遇到的一切障碍,是CurveV2的核心理念。

是直接做一个功能强大的好产品,还是成为一个通用的底层架构并赋能生态发展,这是Curve与Uniswap两个顶级团队开发思路最重要的区别。两种不同的方法论哪一个会最终通过市场的考验,或许只有等待时间来给出答案。

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

大币网

[0:15ms0-7:82ms