当前位置: 首页 > news >正文

Stwo:基于Circle STARK和M31的下一代STARK证明系统

1. 引言

StarkWare团队和Polygon Labs团队,历时数月,构造了基于Mersenne素数域M31的Circle STARK协议,通过使用M31 over a circle,可基于任意有限域构造高效STARKs,具体见2024年2月19日论文《Circle STARKs》。

基于Circle STARK协议,StarkWare团队开发了超快的证明系统:Stwo,大幅改进了现有Stone prover(见Stone Prover:StarkWare的STARK Prover)。

Stwo开源代码见:

  • https://github.com/starkware-libs/stwo(Rust)

BabyBear域背景知识见:

  • RISC Zero的Babybear域 及其 扩域
  • 技术探秘:在RISC Zero中验证FHE——RISC Zero应用的DevOps(2)

Mersenne素数域M31背景知识见:

  • Plonky3 Mersenne素数域的Reed-Solomon codes设计
  • 基于circle group的Reed-Solomon codes

传统STARKs协议,其组成步骤要求代数结构:

  • 需要一个素数域 p p p,其 p − 1 p-1 p1可被2的大幂整除。

即传统STARKs,其所使用的域内要有一个smooth order的cyclic group。
原因在于STARKs协议中有2大核心:

  • FFT:使用FFT算法来高效插值点,并编写包含相邻行的约束。
  • FRI

这就排除了许多尺寸较小的域,尽管这些域非常适合高效计算。如,Mersenne素数域M31,其 p = 2 31 − 1 p=2^{31}-1 p=2311,而 p − 1 = 2 ( 2 30 − 1 ) p-1=2(2^{30}-1) p1=2(2301)甚至不能被 4 4 4整除。从而陷入僵局:

  • 传统STARKs协议无法与M31结合使用

数年前,曾希望让STARKs协议适用于2种主流加密曲线:secp256k1 和 secp256r1。但这2条曲线也不满足上面的要求。为此,还研究出了Elliptic Curve Fast Fourier Transform (ECFFT) Part I: Fast Polynomial Algorithms over all Finite Fields论文,其使用椭圆曲线为FFT和FRI提供了替代的结构源,在该论文中,详细介绍了将STARKs用于任意域的机制——使用某椭圆曲线的cyclic group。

为能让M31与STARKs结合使用,StarkWare团队和Polygon Labs团队合作,最终有了Circle STARKs:

  • 一种紧凑、优雅的协议,避免了ECFFT论文的重型机制。
  • 简而言之:当 p + 1 p+1 p+1可被2的大幂整除时(如M31),基于该素数域的circle curve( x 2 + y 2 = 1 x^2+y^2=1 x2+y2=1)提供了适于FFT和FRI所需的结构。

在这里插入图片描述

2. Stwo:基于Circle STARK和M31的下一代STARK证明系统

Stwo:

  • 利用 Circle STARK 和各种其他优化来带来前所未有的证明性能。

Stone(为St-one)为一代,而Stwo(S-two)为二代。已基于Stone系统构建的应用链和Starknet,都不受影响,高级Cairo将与Stwo完全兼容。当时机到来时,Stwo 已准备好推出,Starknet 生态系统(即用户和开发人员)将受益于 Stwo 的下一级别的扩展,而无需执行任何操作!Stwo 将与编写合约的高级Cairo代码兼容,也与Sierra兼容。当前基于Stone的Starknet prover(s),未来将使用Stwo。用户/构建者/dapp 也将在延迟和费用方面受益。

3. 性能对比

在《Circle STARKs》论文中,对基于M31的Circle STARKs,和,基于Babybear域的传统STARK(使用的Babybear代码为https://github.com/Plonky3/Plonky3/commit/86d13ddf269427c4788cdd41f413308a6050f9f3)做了性能对比,要快约1.4倍:
在这里插入图片描述

参考资料

[1] StarkWare 2024年3月博客 Stwo Prover: the next-gen of STARK scaling is here
[2] 2024年2月21日 Circle STARKs

http://www.lryc.cn/news/309245.html

相关文章:

  • 笔记本以太网集线器Hub充电可能导致网络异常(貌似是我把服务器网关写错了)
  • npm ERR! code ETIMEDOUT
  • 动态规划(算法竞赛、蓝桥杯)--分组背包DP
  • 太阳能供电井盖-物联网智能井盖监测系统-旭华智能
  • 贪心 Leetcode 455 分发饼干
  • 策略开发:EMA如何计算
  • 学习Android的第二十天
  • Linux技巧|centos7|重新认识和学习egrep和grep命令
  • css实现背景渐变叠加
  • Unity(第二十四部)UI
  • VSCode通过SSH连接Docker环境进行开发
  • 【QT】QTableView或QTableWidget 搭配QLineEdit实现数据的搜索显示
  • Apache Flink连载(三十五):Flink基于Kubernetes部署(5)-Kubernetes 集群搭建-1
  • 快速幂(c++题解)
  • C#单向链表实现:Append,Move,Delete,InsertAscending, InsertUnAscending,Clear
  • python基础-基本数据类型深入-2.1
  • Android LiveData Cannot add the same observer with different lifecycles
  • MongoDB聚合运算符:$cmp
  • 【C++基础知识详细记录】
  • Socket网络编程(五)——TCP数据发送与接收并行
  • 2024最新-ubuntu22.04安装最新版QT6.6~6.8教程
  • STM32------分析GPIO寄存器
  • 数学实验-Matlab使用(1)
  • kafka文件存储机制和消费者
  • 《汇编语言》- 读书笔记 - 第15章-外中断
  • 【Vue3】CSS 新特性
  • 四信水电站泄洪预警方案,精准提升防汛应急水平
  • k8s中容器的调度与创建:CRI,cgroup
  • Unity安装与简单设置
  • 数据库的介绍、分类、作用和特点