算术化电路中如何使用定制gates?

1. 引言

现有ZKP证明系统中,除关注proof size和verification time之外,Prover Time是一个重要瓶颈。
算术化电路中如何使用定制gates?_第1张图片
当侧重Prover Time时,可考虑STARK方案。并借助recursive STARK+SNARK,来获得small proof。

Prover Time:

  • 直接取决于计算size。

针对同一计算,不同的算术化策略,会影响证明时的计算size,进而影响Prover Time。如证明 y = x − 1 m o d    p y=x^{-1}\mod p y=x1modp

  • 方案1:
    • 根据费马小定理有 x − 1 = x p − 2 m o d    p x^{-1}=x^{p-2}\mod p x1=xp2modp
    • 然后采用double and add来计算 x p − 2 x^{p-2} xp2
    • 检查 y = x p − 2 y=x^{p-2} y=xp2是否成立
    • 开销为 log ⁡ ( p ) \log(p) log(p)个约束
      算术化电路中如何使用定制gates?_第2张图片
  • 方案2:
    • 转为证明 1 = x × y m o d    p 1=x\times y \mod p 1=x×ymodp
    • 对应1个约束。

本文重点关注Plonkish算术化系统中的:

  • addition and multiplication约束
  • copy约束
  • selector多项式
  • custom约束
  • lookup约束

如需证明 0 ≤ c 3 < 4 0\leq c_3<4 0c3<4

  • 1)若电路中仅有multiplication约束,则不可能实现该证明。
  • 2)若电路中有addition and multiplication约束,则可做二进制分解,表示为:【缺少足够的结构,无法约束 c 3 = a 1 + 2 a 2 c_3=a_1+2a_2 c3=a1+2a2
    算术化电路中如何使用定制gates?_第3张图片
    算术化电路中如何使用定制gates?_第4张图片
  • 3)若电路中有addition and multiplication约束,以及,copy约束,则:【是否存在过度约束的问题?】
    算术化电路中如何使用定制gates?_第5张图片
    算术化电路中如何使用定制gates?_第6张图片
    算术化电路中如何使用定制gates?_第7张图片
    算术化电路中如何使用定制gates?_第8张图片
    算术化电路中如何使用定制gates?_第9张图片
    算术化电路中如何使用定制gates?_第10张图片
    算术化电路中如何使用定制gates?_第11张图片
  • 4)若电路中有addition and multiplication约束,以及,copy约束,以及,selector多项式,则:【其中selector多项式用于选择何时使用哪种gate。】
    算术化电路中如何使用定制gates?_第12张图片

为乘法约束增加零知识属性的策略为:
算术化电路中如何使用定制gates?_第13张图片

2. copy constraints

算术化电路中如何使用定制gates?_第14张图片
算术化电路中如何使用定制gates?_第15张图片
算术化电路中如何使用定制gates?_第16张图片
算术化电路中如何使用定制gates?_第17张图片

即Copy Constraints enforcement分为3大步:

  • 1)按顺序连接所有public和private inputs
  • 2)展示permuted inputs之间的等价性
  • 3)使用Neff Permutation argument来证明。详细见:
    https://github.com/asn-d6/curdleproofs(Rust)

3. selector多项式

selector多项式用于对约束进行开关。
算术化电路中如何使用定制gates?_第18张图片
算术化电路中如何使用定制gates?_第19张图片
算术化电路中如何使用定制gates?_第20张图片

4. custom约束

如MinRoot Verifiable Delay Function,其需求背景在于:

  • 好的随机数真的很难获得
  • 以太坊需要好的随机数来达成共识

所谓MinRoot Verifiable Delay Function,是指,每一轮都计算:
( x i + 1 , y i + 1 ) = ( ( x i + y i ) 1 3 , x i + i ) (x_{i+1},y_{i+1})=((x_i+y_i)^{\frac{1}{3}},x_i+i) (xi+1,yi+1)=((xi+yi)31,xi+i)

在约束电路中,转为计算:

  • x i + 1 3 = x i + y i x_{i+1}^3=x_i+y_i xi+13=xi+yi,从而需要做大量三次方运算,而不是开三次方运算。

不过在custom约束(定制约束)中,需权衡:

  • 每增加一列,可让定制约束更具表达性,但会增加额外的proof元素开销。
  • 每增加一个乘法运算,可让定制约束更具表达性,但会增加额外的proof元素开销。
  • 每种类型的custom约束会增加额外的proof元素开销。
  • 实际就是在proof size/verifier time 与 prover time之间做权衡取舍。
    算术化电路中如何使用定制gates?_第21张图片

参考资料

[1] 以太坊基金会Mary Maller 2023年2月在第13届 BIU Winter School on Cryptography上的分享视频 How Custom Gates Are Used During Arithmetization - Mary Maller

你可能感兴趣的:(零知识证明,零知识证明)