今日实时汇率
1 美元(USD)=
7.178 人民币(CNY)
反向汇率:1 CNY = 0.1393 USD 更新时间:2025-07-09 03:00:01
ZKSwap V2版本预计将于6月初正式上线,届时新版本将会支持Layer2的自主无限上币,用户可以自主添加自己发行的ERC20 token到ZKSwap的Layer2支付网络和兑换网络,实现免费实时转账任意ERC20代币(包括任何稳定币)以及免费实时兑换任意ERC20代币。
ZKSwap在V1的基础上,V2版本新增了如下功能:
1)"⽆限"上币-⽤户在⽀付⼀定费⽤的情况下,可以⾃主添加任意Token,并可创建交易对;
2)优化电路分支的实现,提升电路效率-⽀持⼀个账户,两个余额的修改;
3)优化提现体验- V1版本中,提现的操作和区块验证操作捆绑在⼀起。由于每笔gas费⽤的限制,导致区块中的提现的个数受限,特别是在聚合验证的情况下,受限更多。V2版本将会优化用户的提现体验。
1. Token管理
ZKSwap V2版本将⽀持三种类型的Token:Fee Token、User Token和LP Token。总共⽀持2^16个Token。
1.1 Fee Token
Fee Token只能由Governor添加,主要为ETH、ZKS、USDT、USDC和BTC等。
1.2 User Token
User Token⽤户可以付费添加。
1.3 LP Token
ZKSwap⽤户创建交易对时,必须⽀付费⽤。LP Token将在⽤户创建交易对时⾃动添加。用户创建的交易对中必须有⼀种Token是Fee Token。User Token能创建的交易对个数受限(由Governor设置)。
1.4 Governor Config
Governor可以设置添加User Token和修改创建交易对⽀付的费⽤。
2.账户管理
ZKSwapV2版本将⽀持2^28个账户。其中账户0为Validator账户。
3. Fee模型
ZKSwap V2版本上的Layer2交易,可以指定Fee Token中的⼀种作为⼿续费。
4. Pub Data of Transactions
ZKSwap V2版本上的所有交易(包括Layer1 / Layer2交易)都需要打包提交Pub Data到Layer1。为了保持最优的电路性能,Chunk⼤⼩为11字节,兑换和转账只需要2个Chunk。
4.1 Noop
ZKSwap V2版本允许存在空交易,来填充Layer2区块。
a. pub data
pub data的总⻓度= 1字节。
4.2 Deposit
用户从ZKSwapLayer1发起充值操作时,系统会将用户Layer1的资产映射到Layer2。
a.接⼝函数
function deposit ERC20 (IERC20 _token, uint104 _amount, address _franklinAddr)
function deposit ETH (address _franklinAddr)
b. pub data
pub data的总⻓度= 1+4+2+16+20 = 43字节。总共4个Chunk。
4.3 Transfer
用户通过ZKSwapLayer2发起的转账交易,可实现任意Token的转账。
a. pub data
pub data的总⻓度= 1+4+2+4+5+1+2 = 19字节。2个Chunk。
4.4 TransferToNew
用户通过ZKSwapLayer2发起转账交易,可实现任意Token的转账。转账对⽅不需要提前创建账户。
a. pub data
pub data的总⻓度= 1+4+2+20+4+5+1+2 = 39字节。4个Chunk。
4.5 Withdraw
用户通过ZKSwapLayer2发起提现操作,可实现任意Token在Layer1的提现。
a. pub data
pub data的总⻓度= 1+4+20+2+16+1+2 = 46字节。5个Chunk。
4.6 FullExit
用户可直接从ZKSwapLayer1发起FullExit请求,提取资产,此操作需要Layer2提供证明。
a. pub data
pub data的总⻓度= 1+4+2+20+16 = 43字节。4个Chunk。
4.7 ChangePubKey
用户通过在ZKSwapLayer2发起提取交易,可实现任意Token在Layer1的提现。
a. pub data
pub data的总⻓度= 1+4+20+20+4 = 49字节。5个Chunk。
4.8 CreatePair
用户通过ZKSwapLayer1发起交易池的创建。创建交易池需要在Layer1创建对应的智能合约(LP代币)。
a.接⼝函数
function createPair (address _tokenA, address _tokenB)
b. pub data
pub data的总⻓度= 1+ 4+2+2+2+20 = 31字节。总共3个Chunk。
4.9 AddLiquidity
用户通过ZKSwapLayer2添加流动性。
a. pub data
pub data的总⻓度= 1+4+4+5+5+5+5+1+2 = 32字节。总共3个Chunk。
4.10 RemoveLiquidity
用户通过ZKSwapLayer2移除流动性。
a. pub data
pub data的总⻓度= 1+4+4+5+5+5+1+2 = 27字节。总共3个Chunk。
4.11 Swap
用户通过ZKSwapLayer2实现两种Token之间的兑换。
a. pub data
pub data的总⻓度= 1+4+4+5+5+1+2 = 22字节。总共2个Chunk。
5. Circuit Optimization
ZKSwapV2版本为了降低AMM相关操作的Chunk个数,需要降低“Branch”的个数。原有设计在状态树上的⼀个Account和⼀个Token的Balance组成⼀个“Branch”。在AMM相关的操作中,如果采⽤Fee Token的⽅式,原有的设计效率⽐较低,需要⽀持1个Account和2个Token的Balance的“Branch”。
1) Account Audit Path (aap)
2)该Account下的2个Balance (balance0 / balance1)在修改前的Audit Pat(bap0/bap1) 3)该Account下的2个Balance (balance0'/balance1')在修改后的Audit Pat(bap0'/bap1')
在修改前电路需要证明:
balance0 + bap0 ==> b_root0
balance1 + bap1 ==> b_root0
account (b_root0) + aap ==> root
在balance修改后电路需要证明:
balance0' + bap0 ==> b_root0'
balance1 +bap1'==> b_root0'
balance1' + bap1' ==> b_root0''
account(b_root0'') + aap ==> root'
6. AMM Circuit Explanation
6.1 CreatePair Circuit
6.2 AddLiquidity Circuit
6.3 RemoveLiquidity Circuit
6.4 Swap Circuit
7.Withdrawal Optimization
ZKSwap V2版本提现操作和区块验证隔离开,区块中的提现个数将不受限制。
在某个区块验证后,通过Check Withdrawals函数创建Pending Withdraws,再通过Complete Withdrawls完成提现。Complete Withdrawls函数需要增强可以优先处理某个Pending Withdraws。区块验证是针对多区块聚合实现的。Check Withdrawals针对每个验证后的区块进⾏处理。创建⼀个Pending Withdraw的gas费⽤在7w左右,按照⼀个交易最⼤的gas费⽤1250w来说的话,⼀个区块⽀持的最⼤的提现个数是178笔。
7.1 checkWithdrawals
7.2 completeWithdrawals
8. Limitation
1. Fee Token:32个;User Token:16352个;Pair:49152
2.兑换中交易对的2个Token,其中一个必须是Fee Token;
3.兑换时收取的费用将是2个Token中的一个Fee Token;
4.所有交易的⾦额最⼤为120 bit,且任何中间计算变量的最⼤值为120 bit。