Marlin中的Polynomial commitment scheme

Posted mutourend

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Marlin中的Polynomial commitment scheme相关的知识,希望对你有一定的参考价值。

1. 引言

前序博客有:

相关代码实现有:

2. arkworks实现中marlin/marlin_pcsonic_pc对比

[arkworks实现]https://github.com/arkworks-rs/poly-commit()中marlin/marlin_pcsonic_pc,二者都是基于KZG10的变种。主要不同在于:

  • 1)High level:
    二者处理degree bounds的方式不同:
    • marlin/marlin_pc:使用shift powers only in g1,需要2个commitments来enforce degree bounds。
    • sonic_pc:使用shift powers in G1 and G2,仅需一个commitment来enforce degree bounds。
  • 2)Setup阶段:
    • marlin/marlin_pc:shift powers in Marlin are in G1, and are shared with the “non-shift” powers。
    • sonic_pc:需要额外计算some G2 elements for shift powers: ( 1 / β ) i H (1/\\beta)^i H (1/β)iH。这将导致更长的verifying key,因为shift powers in sonic_pc are in G2。
  • 3)Commit阶段:
    • 当没有degree bound时,二者完全一样。
    • 当有degree bound时,marlin/marlin_pc要更昂贵一点,因为其需要其需要额外的commitment来commit to the shifted polynomial。
  • 4)Open阶段:
    • 当没有degree bound时,二者完全一样。
    • 当有degree bound时,marlin/marlin_pc要更昂贵一点,因为其需要更多的scalar field computations。
  • 5)Check阶段:
    • marlin/marlin_pc:由于Marlin仅建档调整了shifted polynomial的commitment,因此开销很小。marlin/marlin_pc中会check a pairing equation with two pairing operations。
    • sonic_pc:要更昂贵,因其需要check check a pairing equation with three pairing operations。当没有degree bound时,可reduce为a pairing equation with two pairing operations。

以上是关于Marlin中的Polynomial commitment scheme的主要内容,如果未能解决你的问题,请参考以下文章

多项式承诺Polynomial commitment方案汇总

Halo2 学习笔记——背景资料之Polynomial commitment

RedShift: Transparent SNARKs from List Polynomial Commitments学习笔记

Marlin-2.0.9.1 串口接收——环形Buffer

Marlin固件是啥?Marlin固件有哪几种版本?Marlin固件在3D打印机中起啥作用?Marlin固件控制啥?

marlin停止打印不关闭加热