XEN 合约代码深入解读

这两天XEN特别火,看了看代码,相对比较简单。这篇文章就来结合文档来解读一下合约代码,仅做学习交流用。对于玩法还不熟悉的朋友可以先看看我昨天发的推文。

整个玩法分成两部分,我这里将其区别为:

时间挖矿,也就是在参与时指定时间,时间到期后即可领取对应的XEN,唯一付出的成本就是gas费用和等待的时间stake挖矿,通过质押XEN来挖矿时间挖矿

先来看第一部分,时间挖矿。用户通过调用?claimRank(uint256term)?来参与,term?代表用户想要挖矿的天数,在这个时间到期之后才能领取XEN奖励。

其中全局变量?globalRank?代表的是全局参与的总人数,只增不减。activeMinters?代表正在参与挖矿的人数,当用户参与时间挖矿时增加?1,到期领取奖励后减少?1。userMints?代表用户的挖矿参数。我们看到,这里最短需要参与一天,最多参与的天数是通过?_calculateMaxTerm()?实时计算出来的。

美SEC在FTX破产后半年至少采取了17次与加密相关的执法行动,环比增长183%:6月8日消息,在加密货币交易所 FTX 破产后的六个月内,证券监管机构采取的与加密货币相关的执法行动显着增加。在 FTX 破产前的六个月里,美国证券交易委员会(SEC)采取了大约 6 次执法行动。在 FTX 于 2022 年 11 月 11 日破产后的六个月内,SEC 与加密货币相关的执法行动至少 17 次,比上一时期增加 183%,该分析尚未考虑 SEC 对币安和 Coinbase 提起的两起诉讼。[2023/6/8 21:24:36]

首先如果全部参与人数没有超过5000,那么最多只能挖100天。如果达到了5000,通过对参与人数进行对数运算,计算出对应的最大天数。对应于文档中的:

最大参与时间计算公式

代码中的?fromUInt()?和?log_2()?都来自于?ABDKMath64x64?库。其中?fromUInt()?的代码:

Primitive将推出新产品Portfolio:金色财经报道,DeFi 基础设施和产品开发商Primitive将推出新产品Portfolio,可以低成本创建多边流动性头寸,可用于设计特定策略,类似于多边期权策略。

其中在将资产分配给自动做市商时,LP 会接触到独特的代币组合,随着这些代币的价格随时间变化,代理人(如套利者)将重新平衡资金池以匹配投资组合的目标价值。用户可以使用它创建一个完全算法化的、无需信任的链上策略,该策略通过激励代理人发挥作用。[2023/4/10 13:54:10]

入参x有限制,这个最大值转换为10进制是?9223372036854775807,全部参与人数不可能超过这个数,所有可以安全使用。

在构造的挖矿系数?mintInfo?中,_calculateRewardAmplifier()?和?_calculateEAARate()?也是实时计算的。

可以看到,越早参与,可以获得到的?AMP?就越多,最开始一天是?3000,每过一天会减少?1,最终超过3000天就会恒定为?1。

Surecomp与基于区块链的数字平台WaveBL达成合作:1月28日消息,Surecomp今天宣布与基于区块链的数字平台WaveBL合作,通过在其金融科技中心 ?RIVO中访问电子提单,进一步增强数字贸易融资工作流程。

通过将WaveBL的功能集成到Surecomp的协作贸易融资平台中,金融机构和企业等将能够接收和管理电子提单,以降低成本并节省宝贵的时间。

WaveBL是一个基于区块链的数字平台,可促进以电子方式传输原始纸质文档的传统过程。(PR News Wire)[2023/1/29 11:34:27]

对应于文档中?AMP?的计算方式:

AMP计算公式

EAA计算公式

由于Solidity中没有小数,因此在代码中将其放大了?1000?倍,后面在?getGrossReward?方法中会再缩小?1000?倍。

Aztec Network现允许用户在Aztec上私下将资金借给Euler协议:金色财经报道,基于ZK Rollup的隐私和扩容解决方案Aztec Network宣布借贷协议Euler Finance成为Aztec ERC-4626桥支持的第一个收益协议,Euler使用ERC-4626 wrapper实现协议的借贷,这意味着Euler产生的eToken符合ERC-4626标准,并使Aztec非常容易集成。Aztec Network表示,目前允许用户在Aztec上私下将资金借给Euler协议。[2022/10/9 12:50:25]

到这里,我们可以看到,在用户参与时间挖矿时,已经确定的数据有

用户在全局中的位置参与时长,由用户在参与时指定AMP,越早参与越大EAA,越早参与越大接下来我们来看用户领取奖励时的方法?claimMintReward():

校验限制后,计算可得奖励数量,然后?_mint?给用户,计算奖励数量的主要计算逻辑在?_calculateMintReward()?中:

机构借贷协议Maple Finance推出3000万美元流动资金池:8月11日消息,机构借贷协议 Maple Finance 推出由加密原生投资公司 Maven 11 支持的 3000 万美元流动资金池。机构投资者资助的资金池将为借款人提供流动性,这是加密熊市期间特别有价值的资源。

Maven 11 将向加密货币做市商或为交易平台提供足够资金以稳定交易的大公司提供贷款。借款人包括 Wintermute、Bastion、Flow Traders、Nibbio 和 Folkvang Trading。作为回报,贷方将从做市商那里获得收益。[2022/8/11 12:19:25]

这里我们先忽略?penalty?这一块,其他部分的计算正好对应于文档中的:

时间挖矿奖励数量计算公式

在计算最终奖励数量的时候,自己参与的位置越靠前,后面的人越多,那么

cRG-cRu

就会越大,同样说明越早参与越好。

我们再来看?penalty?这部分,这块其实就是系统限制用户必须在到期后一定时间内领取走,如果没有领取则会随着时间越来越少,最终归零。

对应于文档中的扣除比例:

扣除比例时间关系

文档中显示超过七天就全部不能领取,但是代码中显示最多只会扣除?99%。

到这里,我们就介绍完了时间挖矿的代码部分,接下来我们来看看stake挖矿的部分。

stake挖矿

这里的stake其实比常见的挖矿计算逻辑要简单。常见的挖矿?APY?是根据用户质押数量占比以及参与时间来计算的,属于随挖随走类型的。而这里的stake挖矿的?APY?在参与时就已经固定了,且需要在参与时就指定参与时间,在时间到期后才能领取奖励,如果没有到期就领取,只能取回本金,没有任何的奖励。

用户可以在前面时间挖矿到期时调用?claimMintRewardAndStake?同时领取奖励并进行stake,或者单独调用?stake(uint256amount,uint256term)?进行stake挖矿:

整体的逻辑也比较简单,参与的时候需要指定时间?term。有一个小细节是在?stake?的时候直接?burn?掉了用户的token,而不是通过转账的方法,这样可以少一步授权操作。由于合约本身既包含了挖矿操作,同时也是ERC20,因此可以实现这个逻辑。

接下来我们看看计算APY的方法?_calculateAPY():

基本逻辑也是类似于上面计算?EAA?的方法,一次函数递减,参与的时间越早,相对应的?APY?就越大。初始值为?20,每过?90?天,减少?1。最终在?1620?天后,恒定为?2。对应于文档:

APY时间关系

最终在?stake?到期后,可以调用?withdraw()?取出本金和奖励:

对应于文档中的:

stake奖励计算公式

对于stake挖矿而言,没有领取的限制,奖励数量不会变化。

总结

到这里我们就看完了主要的逻辑代码。这个玩法有意思的地方在于越早参与获得的奖励越多,相当于普通的挖头矿,但是同时也取决于总体的参与人数,如果后面没有人参与,那么也没啥意义。必须是参与的早且后面还有更多人参与的情况下,奖励才会更多。目前时刻总参与人数已经快达到50万了,热度确实很高。

同时,前面的时间挖矿和后面的stake挖矿也存在博弈关系,如果前面选择的时间越长,获得的奖励就越多,但是来到后面的stake挖矿的APY就会降低,需要大家自行抉择。

合约本身代码没啥难度,但是整体机制比较有趣,值得花点时间了解。

责任编辑:MK

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

银河链

币安币SushiSwap 新 CEO 对近期传闻的回应

两天前,推特用户YannickCrypto发推指控SushiSwap新CEOJaredGrey为加密犯并列举了其多项「罪行」,该推特在社区引发了激烈讨论,并一度导致SUSHI代币价格剧烈波动.

[0:15ms0-1:947ms