DAT:Uniswap V3 路径编码的进一步优化_PUT价格

本文作者:ripwu

源起

前几天群里有讨论UniswapV3中询价的处理,简单翻了下代码,发现与UniswapV2相比,V3变化真的很大~

其中v3-periphery目录下的Path

functionflashArbs(PoolTiercalldatainput)external;

数据编码为

0000000000000000000000000000000000000000000000000000000000000020//input.offset0000000000000000000000000000000000000000000000000000000000000004//input.length00000000000000000000000055542f696a3fecae1c937bd2e777b130587cfd2d//input00000000000000000000000000000000000000000000000000000000000001f40000000000000000000000009d7076ad0f7fdc5f0f249e97721d36a448d24906//input0000000000000000000000000000000000000000000000000000000000000bb80000000000000000000000006ce15889c141c09ecf76a57795e91214a1f97648//input0000000000000000000000000000000000000000000000000000000000002710000000000000000000000000dfc647c079757bac4f7776cc876746119ac451ea//input0000000000000000000000000000000000000000000000000000000000002710

游戏引擎Unity新增支持MetaMask、Aptos等区块链SDK开发工具:金色财经报道,Unity游戏引擎开发商Unity Technologies推出了一套新的去中心化技术工具,供希望为游戏添加去中心化功能的游戏开发者使用。Unity表示,游戏环境中的“去中心化”是指“游戏中的所有权模式,允许玩家创建、赚取或获得游戏内资源,然后他们可以出售或交易这些资源。”从本质上讲,开发人员现在可以将游戏内资产转化为NFT,并将他们的游戏与各种区块链和Web3生态系统集成。

Unity资产页面上的去中心化类别包括13个经过验证的解决方案,适用于允许不同功能的游戏开发人员。开发人员可以使用其中一些SDK轻松地将NFT、代币和链上程序集成到他们基于Unity的游戏中。基于Unity的游戏开发人员可以选择通过SDK在以太坊、Solana、Algorand、Tezos、Aptos和Flow区块链上进行构建。此外,开发人员可以将MetaMask集成到他们的游戏中,这似乎是目前唯一可用的基于钱包的SDK。[2023/3/1 12:35:17]

消耗gas为230*490*16=2360

节省gas为280

UniswapV3优化

拟以170亿美元收购Unity的AppLovin推出NFT市场Vessel:10月4日消息,面向开发者的移动货币化平台 AppLovin 宣布通过其子公司 OpenVessel Technologies, LLC 推出 NFT 市场及钱包一体化平台Vessel,让用户可以轻松访问定制的 NFT 并支持开发者购买、出售和交易他们铸造的 NFT。目前,Vessel 已通过 Apple 和 Google Play 应用商店审核并上线。

此前报道,移动货币化平台 AppLovin 于 8 月宣布拟以约 170 亿美元收购 Unity。AppLovin 去年以 10.5 亿美元从 Twitter 收购移动广告公司 MoPub,并在 2020 年收购移动游戏开发商 Machine Zone。[2022/10/5 18:39:28]

从上面两个例子可以看到,solidity编码的最大问题在于padding,即32字节对齐,导致引入了非常多无效的空字节

上述例子中gas为2360,而空字节消耗了230*4=920,无效数据占比为~40%

为了进一步优化,考虑到pool和fee都为定长类型,可以直接拼接而不做padding,在实际使用时才做解码

UNI跌破33美元关口 日内跌幅为10.67%:火币全球站数据显示,UNI短线下跌,跌破33美元关口,现报32.9997美元,日内跌幅达到10.67%,行情波动较大,请做好风险控制。[2021/5/17 22:10:09]

函数原型为

functionflashArbs(bytescalldatainput)external;

数据编码为

0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000005c55542f696a3fecae1c937bd2e777b130587cfd2d0001f49d7076ad0f7fdc5f0f249e97721d36a448d24906000bb86ce15889c141c09ecf76a57795e91214a1f97648002710dfc647c079757bac4f7776cc876746119ac451ea00271000000000//padding

UNI突破24美元关口 日内涨幅为8.26%:欧易OKEx数据显示,UNI短线上涨,突破24美元关口,现报24.003美元,日内涨幅达到8.26%,行情波动较大,请做好风险控制。[2021/3/1 18:04:38]

消耗gas为66*490*16=1704,无效数据占比降至~15%

这也是UniswapV3的优化方式

优化

实际上,我们继续优化,使得有效载荷为100%

函数原型为

functionflashArbs()external;

数据编码为

55542f696a3fecae1c937bd2e777b130587cfd2d0001f49d7076ad0f7fdc5f0f249e97721d36a448d24906000bb86ce15889c141c09ecf76a57795e91214a1f97648002710dfc647c079757bac4f7776cc876746119ac451ea002710

是不是有点奇怪,函数原型中没有参数,那么参数从哪里获取呢?

动态 | Qtum推出企业区块链解决方案Unita:据Crypto Briefing消息,Qtum推出企业区块链解决方案Unita。据称,该全自动数据存储和传输协议可以允许高达10000 TPS的交易吞吐量。[2019/4/19]

实际上,我的方式是抛弃solidity编码,直接使用assembly来解析数据,代码如下

bytesmemoryinput;assembly{letcalldata_len:=calldatasize()letinput_len:=sub(calldata_len,4)input:=mload(0x40)mstore(input,input_len)letinput_data:=add(input,0x20)calldatacopy(input_data,4,input_len)letfree:=add(input_data,input_len)letfree_round:=and(add(free,31),not(31))mstore(0x40,free_round。

这里稍微解释下:

首先通过calldatasize得到调用数据的长度,减去functionselector的4字节,得到的input_len即为参数长度

然后通过0x40获得空闲指针,拷贝参数到memory

最后将参数长度按32字节向上取整,修改空闲指针

题外

不要觉得上面的assembly本身消耗了gas,导致优化效果减少

要知道,即使按UniswapV3传bytes参数的方式,也是需要拷贝数据到memory,过程是一样的

如果考究一些,我们甚至可以跳过solidity编译后的某些opcode

比如上面例子中,我并不检查input_len的长度是否大于0,因为我不需要

而solidity编译后的操作码,势必包括种种边界检查

换句话说,这种方式不仅优化了数据gas,还稍微优化了一些opcode

到此为止?

实际上,上面的优化有个小问题,在于memory中消耗了32字节用于保存input的长度,而这个长度,在整个生命周期中是固定的

我选择将它转移到栈上,只是使用时稍微麻烦一些,不像bytes方便~

,即

uintinput;uintinput_len;assembly{letcalldata_len:=calldatasize()input_len:=sub(calldata_len,4)input:=mload(0x40)calldatacopy(input,4,input_len)letfree:=add(input,input_len)letfree_round:=and(add(free,31),not(31))mstore(0x40,free_round。

实测

我用大概100多条套利路径,对UniswapV3编码方式,以及进一步优化方式,分别跑了自动化测试,平均下来一笔交易可以优化2000gas左右

比预期的优化大了很多,具体原因未查

参考资料

ripwu:https://learnblockchain.cn/people/3911

UniswapV3:https://learnblockchain.cn/article/2302

UniswapV2:https://learnblockchain.cn/article/2611

v3-periphery:https://github.com/Uniswap/v3-periphery/tree/main/contracts/libraries

FormalSpecificationoftheEncoding:https://docs.soliditylang.org/en/v0.8.9/abi-spec.html#mapping-solidity-to-abi-types]

免责声明:作为区块链信息平台,本站所发布文章仅代表作者个人观点,与链闻ChainNews立场无关。文章内的信息、意见等均仅供参考,并非作为或被视为实际投资建议。

本文来源于非小号媒体平台:

登链社区

现已在非小号资讯平台发布105篇作品,

非小号开放平台欢迎币圈作者入驻

入驻指南:

/apply_guide/

本文网址:

/news/10417118.html

免责声明:

1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险

2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场

上一篇:

每周编辑精选WeeklyEditors'Picks

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

区块博客

BNB区块链:十月版新 Dapps 报告:NFT 收藏品_TPS

以下内容属于“新dapps系列”,这是一组报告,旨在向用户提供新dapps的层次视角。本文重点关注与去中心化应用程序相关的内容,如销售活动和价格分析等财务指标、独立持有人比率或鲸鱼集中度指数等分.

[0:15ms0-3:641ms