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 p−1可被2的大幂整除。
即传统STARKs,其所使用的域内要有一个smooth order的cyclic group。
原因在于STARKs协议中有2大核心:
- FFT:使用FFT算法来高效插值点,并编写包含相邻行的约束。
- FRI
这就排除了许多尺寸较小的域,尽管这些域非常适合高效计算。如,Mersenne素数域M31,其 p = 2 31 − 1 p=2^{31}-1 p=231−1,而 p − 1 = 2 ( 2 30 − 1 ) p-1=2(2^{30}-1) p−1=2(230−1)甚至不能被 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
相关文章:
Stwo:基于Circle STARK和M31的下一代STARK证明系统
1. 引言 StarkWare团队和Polygon Labs团队,历时数月,构造了基于Mersenne素数域M31的Circle STARK协议,通过使用M31 over a circle,可基于任意有限域构造高效STARKs,具体见2024年2月19日论文《Circle STARKs》。 基于…...
笔记本以太网集线器Hub充电可能导致网络异常(貌似是我把服务器网关写错了)
文章目录 笔记本以太网集线器(Hub)充电导致网络异常概述原理分析电源与信号干扰设备热度设备兼容性问题 解决方案升级固件提高设备散热效率选择兼容性好的设备 总结 今天用笔记本以太网直连服务器,一开始能连通,结果以太网hub插上…...
npm ERR! code ETIMEDOUT
在新建vue项目的时候报错 npm ERR! code ETIMEDOUT npm ERR! syscall connect npm ERR! errno ETIMEDOUT npm ERR! network request to https://registry.npmjs.org/vue%2fcli failed, reason: connect ETIMEDOUT 104.16.2.35:443 npm ERR! network This is a problem relate…...
动态规划(算法竞赛、蓝桥杯)--分组背包DP
1、B站视频链接:E16 背包DP 分组背包_哔哩哔哩_bilibili #include <bits/stdc.h> using namespace std; const int N110; int v[N][N],w[N][N],s[N]; // v[i,j]:第i组第j个物品的体积 s[i]:第i组物品的个数 int f[N][N]; // f[i,j]:前i组物品,能放…...
太阳能供电井盖-物联网智能井盖监测系统-旭华智能
在这个日新月异的科技时代,城市的每一个角落都在悄然发生变化。而在这场城市升级的浪潮中,智能井盖以其前瞻性的科技应用和卓越的安全性能,正悄然崭露头角,变身马路上的智能“眼睛”,守护城市安全。 传统的井盖监测系统…...
贪心 Leetcode 455 分发饼干
分发饼干 Leetcode 455 学习记录自代码随想录 假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。 对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸࿱…...
策略开发:EMA如何计算
EMA的计算原理 EMA 是MA(平滑移动平均线)的另一种形式。全名“加权指数移动平均线”。 2/13就是12日移动平均线的平滑因子,他的意思是指:给予新价格 2/13的权重,给予过去的EMA 11/13的权重。 在计算的时候第一天的M…...
学习Android的第二十天
目录 Android Toast 吐司 常量 常用方法 例子 Android Notification 状态栏通知 Notification 的基本布局 扩展布局 Notification ( 状态栏通知 ) 相关的方法 例子: 参考文档 Android AlertDialog 弹出框 Android Dialog 继承图谱 AlertDialog 几种常…...
Linux技巧|centos7|重新认识和学习egrep和grep命令
前言: 相信提高文本检索工具,大家脑海里肯定有很多工具会自动跳出来,比如,grep,egrep,sed,cat,more,less,cut,awk,vim,vi…...
css实现背景渐变叠加
线性渐变效果图: .box{width: 100vw;height: 100vh;background:linear-gradient(to bottom,transparent,#fff 30%),linear-gradient(to right,pink,skyblue);}径像渐变效果图: .box{width: 100vw;height: 100vh;background:linear-gradient(to bottom,transparent,#…...
Unity(第二十四部)UI
在游戏开发中,用户界面(UI)是至关重要的一部分。它负责与玩家进行交互,提供信息,并增强游戏的整体体验。Unity 提供了强大的工具和功能来创建和管理 UI。 ui的底层就是画布,创建画布的时候会同时创建一个事…...
VSCode通过SSH连接Docker环境进行开发
文章目录 VSCode 插件Docker 镜像构建镜像部署环境 VSCode 连接本地Docker容器VSCode SSH连接Docker容器VSCode 打开容器内目录文件 VSCode 插件 Remote - SSH Docker 镜像 https://hub.docker.com/_/golang # Golang 镜像 docker pull golang:1.22构建镜像 Dockerfile F…...
【QT】QTableView或QTableWidget 搭配QLineEdit实现数据的搜索显示
在 Qt 中,QTableView 和 QTableWidget 都可以用来实现数据的搜索和显示,但它们的适用场景和实现方式有所不同: QTableView 适用场景:QTableView 适用于更复杂的场景,尤其是当需要处理大量数据或需要高度定制化的表格时…...
Apache Flink连载(三十五):Flink基于Kubernetes部署(5)-Kubernetes 集群搭建-1
🏡 个人主页:IT贫道-CSDN博客 🚩 私聊博主:私聊博主加WX好友,获取更多资料哦~ 🔔 博主个人B栈地址:豹哥教你学编程的个人空间-豹哥教你学编程个人主页-哔哩哔哩视频 目录 编辑...
快速幂(c++题解)
题目描述 我们通常把a的b次方记作a^b,为了方便,我们经常直接使用C内置函数pow(a,b)来完成这个工作,但a的b次方就是把a垒乘b次,时间复杂度为O(b),当b值很大时,将会耗去大量时间,所以请同学们不能…...
C#单向链表实现:Append,Move,Delete,InsertAscending, InsertUnAscending,Clear
目录 一、链表定义 二、链表设计 1.先定义一个结点类(Node) 2.再定义链表类(LinkedList)并依次设计其方法 3.再实现删除方法 4.再实现Insert 的方法 5.再增加InsertAscending升序插入 6.再增加 InsertUnAscending 的方法…...
python基础-基本数据类型深入-2.1
目录 元组 什么是元组(tuple) 元组练习-1 元组的基本操作 元组常用内建函数 列表和元组的区别与总结 元组练习-2 元组练习-3 元组 什么是元组(tuple) 与列表(list)一样,元组࿰…...
Android LiveData Cannot add the same observer with different lifecycles
https://www.yxhuang.com/2022/05/29/livedata-add-some-observer-error/ 这篇文章已经解释的很好了。 其实在去年我写的文章, https://blog.csdn.net/jzlhll123/article/details/126593235 中提到了, 其实不论是java或者kotlin,不引用外部的…...
MongoDB聚合运算符:$cmp
文章目录 语法用法举例 $cmp聚合运算符返回连个值的比较结果。 语法 { $cmp: [ <expression1>, <expression2> ] }表达式可以是任何类型,使用标准的BSON比较顺序对不同类型的值进行比较。 用法 $cmp对两个值进行比较,返回: …...
【C++基础知识详细记录】
一、基础知识 C基础知识点的汇总涵盖了许多方面,包括但不限于以下内容: 1. 常量定义 使用#define宏定义常量: #define PI 3.14159265358979323846 // 宏定义一个浮点型常量PI使用const关键字定义常量: const int MAX_SIZE 100;…...
ESP32S3 固件工程化部署指南:从多文件烧录到一体化镜像生成
1. 为什么需要工程化部署ESP32S3固件 第一次接触ESP32S3开发板时,我和很多新手一样踩过这样的坑:编译完代码直接烧录生成的.bin文件,结果设备死活不工作。后来才发现,原来ESP32S3需要同时烧录bootloader、分区表和主程序三个文件才…...
从应用层到内核:一次DRM IOCTL调用如何驱动你的显示器?——以drmModeSetCrtc为例
从应用层到内核:一次DRM IOCTL调用如何驱动你的显示器?——以drmModeSetCrtc为例 当你在Linux桌面环境中拖动窗口或播放视频时,显示器上的像素点如何被精确控制?这一切的魔法始于用户空间的一个简单函数调用——drmModeSetCrtc。…...
如何永久保存微信聊天记录?WeChatMsg完整指南让记忆永不丢失
如何永久保存微信聊天记录?WeChatMsg完整指南让记忆永不丢失 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we…...
Flutter结合高德API实现智能周边搜索与动态展示
1. 环境准备与基础配置 在开始Flutter与高德地图API的集成前,我们需要先搭建好开发环境。我推荐使用Flutter 2.5版本,这个版本对地图插件的兼容性更好。安装完Flutter SDK后,记得在pubspec.yaml中添加以下关键依赖: dependencie…...
lil_tea c++ style guide巢
一、中间件是啥?咱用“餐厅”打个比方 想象一下,你的FastAPI应用是个高级餐厅。 ?? 顾客(客户端请求)来到门口。- 迎宾(CORS中间件):先看你是不是从允许的街区(域名)来…...
50系显卡专属:PyTorch 2.8镜像快速部署与常见问题解决全攻略
50系显卡专属:PyTorch 2.8镜像快速部署与常见问题解决全攻略 1. PyTorch 2.8镜像概述 PyTorch-CUDA-v2.8镜像是一个专为深度学习开发者设计的预配置环境,特别适配NVIDIA 50系显卡(RTX 5090/5080/5070)和CUDA 12.8。这个镜像解决…...
CHORD-X系统作业批改场景应用:基于视觉的编程作业自动检查
CHORD-X系统作业批改场景应用:基于视觉的编程作业自动检查 每次期末或者大作业提交后,老师们最头疼的是什么?是面对几十上百份学生提交的程序运行结果截图,一张张点开,一行行核对输出是否正确。这个过程枯燥、耗时&am…...
GLM-4.1V-9B-Base实操手册:基于Prometheus+Grafana的GPU服务监控看板
GLM-4.1V-9B-Base实操手册:基于PrometheusGrafana的GPU服务监控看板 1. 模型与平台介绍 GLM-4.1V-9B-Base是智谱开源的视觉多模态理解模型,专注于图像内容识别、场景描述、目标问答和中文视觉理解任务。该模型已经完成Web化封装,可以直接用…...
Gemini 3 Pro的国内体验路径:从AI Studio到聚合平台的日常使用观察
Google DeepMind在Gemini 3 Pro上投入的技术资源,从那份长达数十页的技术报告中可见一斑。原生多模态架构意味着图像、音频、视频不再需要额外的预处理步骤,模型能在同一个推理过程中直接理解不同模态的信息。我在AI Studio里试过上传一段技术会议的录像…...
2026最新鸿蒙开发面试题合集(含详细解析,适配ArkTS V2/HarmonyOS NEXT)
说明:本合集聚焦2026年鸿蒙开发核心考点,结合HarmonyOS NEXT(API 10)、ArkTS V2最新特性,覆盖基础入门、进阶核心、实战场景、架构设计四大模块,每题均附详细解析(标注高频考点)&…...
