剖析DeFi交易产品之UniswapV4:Swap

Swap可分为两种场景:单池交易和跨池交易。在PoolManager合约里,要完成交易流程,会涉及到lock()、swap()、settle()、take()四个函数。

Uniswap v3 数学洞察系列翻译 —— 第六部分 共 6 部分

数字资产的价格行为

Uniswap v3 数学洞察系列翻译 —— 第五部分 共 6 部分

展示了对 Uniswap v2 和 v3 的希腊解决方案;在交互式 desmos 文件中提供了使用 Uniswapv3 对亚洲期权、欧式期权和 Bachelier 期权进行对冲的解决方案。展示了使用 desmos 对 LP 对冲积累策略。解释了导致 LVR 的历史和替代推导

Uniswap v3 数学洞察系列翻译 —— 第四部分 共 6 部分

两种简单的对冲 LP 头寸的方法和一种复杂的方法

Uniswap v3 数学洞察系列翻译 —— 第三部分 共 6 部分

第二部分中,我们研究了将我们的价格范围划分为多个流动性提供者(LP)头寸。在这里,我们将使用相同的概念来建模流动性分布,看看我们如何拟合它,然后调整风险。

剖析DeFi交易产品之UniswapV4:添加/移除流动性

前一篇文章我们已经知道了创建新池子的流程,那接下来就要添加流动性了。而其实,在PoolManager合约里,添加和移除流动性都是在同一个函数里统一处理的。当然,要完成添加或移除流动性的全流程,会涉及到多个函数。接下来我们展开一一细说。

剖析DeFi交易产品之UniswapV4:创建池子

创建池子的底层函数是PoolManager合约的initialize函数,其代码实现并不复杂

剖析DeFi交易产品之UniswapV4:合约结构篇

前一篇文章已经对UniswapV4做了简单的概述,了解了其主要特性。从本篇开始,我们要深入合约实现了,先看看其合约结构。

剖析DeFi交易产品之UniswapV4:概述篇

UniswapV4与UniswapV3相比,算法上并没有什么改变,依然还是采用集中流动性模型,但架构上变化很大,包括功能架构,也包括技术架构。

剖析DeFi交易产品之UniswapV3:交易路由合约

SwapRouter合约封装了面向用户的交易接口,但不再像UniswapV2Router一样根据不同交易场景拆分为了那么多函数,UniswapV3的SwapRouter核心就只有4个交易函数

剖析DeFi交易产品之UniswapV3:头寸管理合约

实现用户层面的流动性头寸管理的合约是NonfungiblePositionManager合约,其实现比较复杂,还继承了很多子合约,限于篇幅,我们无法全都一一讲解,就只能挑一些重点的来讲。

剖析DeFi交易产品之UniswapV3:Pool合约

UniswapV3Pool合约则复杂很多了,其引用的库合约就达到了13个,通过using方式使用的也达到了9个

剖析DeFi交易产品之UniswapV3:工厂合约

UniswapV3Factory合约主要用来创建不同代币对的流动性池子合约,其代码实现并不复杂

剖析DeFi交易产品之UniswapV3:概述篇

UniswapV3于2021年5月上线,相比UniswapV2,改动很大,也变得复杂很多。

浅谈 DEX,从过去到未来

本文是由 BuidlerDAO 主办,联合多家 DeFi 项目和投资机构设立的 DeFi 全赛道投研系列课的课程笔记。

  • 0xHowe
  • 发布于 2023-10-23
  • 阅读 ( 591 )
  • ( 22 )

赛道全景投研课 —— DeFi Overview

本文是由 BuidlerDAO 主办,联合多家 DeFi 项目和投资机构设立的 DeFi 全赛道投研系列课的课程笔记与思考。

  • 0xHowe
  • 发布于 2023-10-21
  • 阅读 ( 450 )
  • ( 4 )

在GMX v2中 发起一笔添加流动性交易背后会发生什么(上)

GMX V2版本上线之后短短两个月TVL做到5千万,让我们逐步解析他背后的技术

  • zero
  • 发布于 2023-10-19
  • 阅读 ( 496 )
  • ( 11 )

对比 Uniswap,一种新的去中心化交易所的流动性算法

不同于 Uniswap的一种新的去中心化交易所的流动性算法

以太坊上的借贷应用架构演变: 比较 MakerDAO、Yield、Aave、Compound 和 Euler

以太坊上的借贷应用架构演变: 比较 MakerDAO、Yield、Aave、Compound 和 Euler。你会发现不同的阶段有不同的优先级,一些关键创新也影响着后来的借贷应用

UniV3 Share

UniV3Share