密码学系列 - 零知识证明(ZKP) - NTT与MSM的总结

区别

特性 多项式乘法 (NTT) 椭圆曲线点乘 (MSM)
定义 两个多项式的系数逐项乘积并合并结果。 标量和椭圆曲线点的点乘。
数学背景 代数运算(有限域/环上的多项式)。 椭圆曲线上的群运算。
操作对象 多项式的系数。 椭圆曲线上的点和整数标量。
结果类型 多项式(一个更高次的多项式)。 椭圆曲线上的点。
复杂度 使用 NTT 优化到 O ( n log ⁡ n ) O(n \log n) O(nlogn)。 使用双倍和加法优化到 O ( log ⁡ k ) O(\log k) O(logk)。
主要用途 多项式承诺、FFT 运算、约束检查等。 密钥生成、签名、验证、证明生成。
加速方法 NTT、FFT、并行化等。 Pippenger 算法、分块优化等。

联系

尽管它们在数学定义上不同,但在许多密码学和零知识证明系统中,它们常常相辅相成:

  1. 多项式承诺和 KZG(Kate-Zaverucha-Goldberg)方案:
    • 多项式承诺用于证明一个多项式在某一点的值是正确的。
    • KZG 承诺需要将多项式的系数映射到椭圆曲线上的点,这种映射本质上是 MSM(多标量乘法)的应用。
  2. 生成证明:
    • 零知识证明需要将电路表达为一个多项式约束系统。
    • 约束系统中的多项式运算需要通过多项式乘法(优化为 NTT)来处理,而验证者需要依赖 MSM 来验证多项式承诺和点对验证。
  3. 两者协同加速:
    • 电路约束阶段
      • 多项式运算的优化(例如 NTT 加速)可以减少整个电路的中间步骤。
    • 证明生成与验证阶段
      • 椭圆曲线点乘(MSM)的优化(如 Pippenger 算法)可以加速证明的最终生成和验证。

: 区块链知识系列
: 密码学系列
: 零知识证明系列
: 共识系列
: 公链调研系列
: BTC系列
: 以太坊系列
: EOS系列
: Filecoin系列
: 联盟链系列
: Fabric系列
: 智能合约系列
: Token系列

相关推荐
新时代的弩力4 小时前
哈希,对称加密,非对称加密
密码学
橘子真甜~13 小时前
C/C++ Linux网络编程11 - 数据加密与https协议
linux·服务器·网络·http·https·密码学·加密解密
岁岁的O泡奶2 天前
NSSCTF_crypto_[MTCTF 2021 final]ezRSA
经验分享·python·算法·密码学·crypto
傻小胖6 天前
第2讲:BTC-密码学原理 北大肖臻老师客堂笔记
笔记·web3·密码学
T***u3339 天前
区块链零知识证明
区块链·零知识证明
courniche9 天前
金融数据密码机、服务器密码机、签名验签服务器、时间戳服务器4款相比较
密码学
漏洞文库-Web安全9 天前
CTF密码学之SM4
安全·web安全·网络安全·密码学·ctf
HaiLang_IT9 天前
2026年密码学专业选题全攻略:从数字签名到漏洞挖掘的精选选题指南
密码学
搬砖魁首9 天前
密码学系列 - ECDSA vs. EdDSA:主要区别
密码学·签名·ecdsa·eddsa
C++ 老炮儿的技术栈10 天前
用密码学安全随机数生成256位密钥
c语言·开发语言·c++·windows·安全·密码学·visual studio