主要来源 https://blog.ethereum.org/2016/12/05/zksnarks-in-a-nutshell/ 中“Tradeoff between Input and Witness Size”段落
论文GGPR12中,生成的proof只有7个elements of a group.
Verifier主要需要计算pairing等式的成立(如 W := E(w(s)),W’ := E(α w(s)),则e(W’, E(1)) = e(E(α w(s)), E(1)) = e(g,g)αw(s) = e(gw(s),gα) = e(E(w(s)), E(α)) = e(W, E(α)))以及计算E(vin(s))。
计算E(vin(s))的时效与input size的大小呈线性关系。
在verification时,witness string size和验证QSP都不会有任何影响。
也就是说,因为SNARK在做verify时仅仅是check多项式at a single point而不是计算整个多项式,所以SNARK在verify复杂问题和简单问题都需要相同的时效。
影响SNARK verification时效的因素主要有:
- the level of security(如 the size of the group)
- the maximum size for the inputs
所以,降低input size的大小,转移input的信息至witness,是一种可行的办法:

博客主要参考相关文章及论文,介绍了SNARK验证相关内容。提到生成的proof元素数量,Verifier需计算pairing等式及E(vin(s)),其时效与input size呈线性关系。验证时witness string size和验证QSP无影响,影响SNARK验证时效的因素有安全级别和输入最大尺寸,还提出降低input size、转移信息至witness的办法。
2454

被折叠的 条评论
为什么被折叠?



