RISC Zero ZKP协议中的商多项式

1. 引言

前序博客见:

  • Reed-Solomon Codes及其与RISC Zero zkVM的关系

RISC Zero zkVM主要针对可验证计算,其具有隐私和可扩展属性:
在这里插入图片描述

Reed-Solomon Codes及其与RISC Zero zkVM的关系博客中指出:RISC Zero中的Reed-Solomon Codes处理流程为:

  • 1)Step 1 生成trace columns:在RISC Zero zkVM中执行某二进制文件,并记录其execution trace。
  • 2)Step 2 将trace columns转换为trace blocks:采用Reed-Solomon Encoding对execution trace中的每列进行编码。
  • 3)Step 3 对trace blocks之上的constraints进行evaluate,然后计算quotients:对trace blocks做STARK数学运算。
  • 4)Step 4 应用FRI Protocol:让Verifier信服该结果是a valid Reed-Solomon codeword。
    在这里插入图片描述

本文重点关注Step 3中的quotient商多项式:

  • 商多项式用于哪?
    • 用于整个ZKP协议中。
  • 为何需要商多项式?
    • 为强化多项式承诺的约束。(To enforce constraints on polynomial commitments.)

本文内容基本结构为:

  • 回顾多项式承诺方案
  • 回顾多项式代数运算:即用于强化约束(Enforcing Constraints)。
  • STARKs、KZG&DEEP上下文中的商多项式

2. 多项式承诺方案回顾

2.1 何为承诺方案?

所谓承诺方案,是指:

  • 一种 确保某人在应答后无法修改答案 的方式。

所有的承诺方案:

  • 都具有binding属性
  • 不一定都具有hiding属性。某些承诺方案也还可能具有hiding属性。

承诺方案中包括:

  • commit函数:对data数据进行承诺。
  • reveal函数:公开该承诺值的片段信息。
  • check函数:检查所公开的片段信息是否与原始承诺值匹配。

RISC Zero的承诺方案是基于Merkle trees的:

  • commit函数:用于构建a Merkle tree。
  • reveal函数:用于show该Merkle tree的某叶子节点。
  • check函数:检查相应的Merkle branch。

2.2 何为多项式承诺方案?

当所承诺的data数据源自某多项式的evaluation时,则将相应的承诺方案,称为多项式承诺方案。

在基于Merkle的多项式承诺方案中,该Merkle tree中的每个叶子节点,都对应某“evaluation domain”内的一个点。

3. 回顾多项式代数运算:即用于强化约束(Enforcing Constraints)

3.1 多项式代数运算

多项式具有如下分解属性:

  • f ( x ) f(x) f(x)为某多项式,且有 f ( 3 ) = 0 f(3)=0 f(3)=0,则 f ( x ) x − 3 \frac{f(x)}{x-3} x3f(x)也是一个多项式。
  • f ( x ) f(x) f(x)为某多项式,但有 f ( 3 ) ≠ 0 f(3)\neq 0 f(3)=0,则 f ( x ) x − 3 \frac{f(x)}{x-3} x3f(x)为一个“rational function”。
  • f ( x ) f(x) f(x)为某多项式,且有 f ( 3 ) = 5 f(3)=5 f(3)=5,则 f ( x ) − f ( 3 ) x − 3 = f ( x ) − 5 x − 3 \frac{f(x)-f(3)}{x-3}=\frac{f(x)-5}{x-3} x3f(x)f(3)=x3f(x)5也是一个多项式。
  • f ( x ) f(x) f(x)为某多项式,但有 f ( 3 ) ≠ 5 f(3)\neq 5 f(3)=5,则 f ( x ) − f ( 3 ) x − 3 = f ( x ) − 5 x − 3 \frac{f(x)-f(3)}{x-3}=\frac{f(x)-5}{x-3} x3f(x)f(3)=x3f(x)5为一个“rational function”。

如:

  • f ( x ) = x 3 − 5 x − 12 = ( x − 3 ) ( x 2 + 3 x + 4 ) f(x)=x^3-5x-12=(x-3)(x^2+3x+4) f(x)=x35x12=(x3)(x2+3x+4)为多项式,且 f ( 3 ) = 0 f(3)=0 f(3)=0,则 f ( x ) x − 3 = ( x 2 + 3 x + 4 \frac{f(x)}{x-3}=(x^2+3x+4 x3f(x)=(x2+3x+4也是多项式。
  • f ( x ) = x 3 − 5 x − 7 f(x)=x^3-5x-7 f(x)=x35x7为多项式, f ( x ) − 5 = x 3 − 5 x − 12 = ( x − 3 ) ( x 2 + 3 x + 4 ) f(x)-5=x^3-5x-12=(x-3)(x^2+3x+4) f(x)5=x35x12=(x3)(x2+3x+4)为多项式:
    • 且有 f ( 3 ) = 5 f(3)=5 f(3)=5,则 f ( x ) − f ( 3 ) x − 3 = f ( x ) − 5 x − 3 \frac{f(x)-f(3)}{x-3}=\frac{f(x)-5}{x-3} x3f(x)f(3)=x3f(x)5也是一个多项式。
    • 但有 f ( 3 ) ≠ 5 f(3)\neq 5 f(3)=5,则 f ( x ) − f ( 3 ) x − 3 = f ( x ) − 5 x − 3 \frac{f(x)-f(3)}{x-3}=\frac{f(x)-5}{x-3} x3f(x)f(3)=x3f(x)5为一个“rational function”。

3.2 利用多项式代数运算来强化约束

已知某多项式 f f f,如何来强化如下约束呢?

  • f ( 1 ) = 0 f(1) = 0 f(1)=0
  • f ( 2 ) = 0 f(2) = 0 f(2)=0
  • f ( 3 ) = 0 f(3) = 0 f(3)=0
  • f ( 4 ) = 0 f(4) = 0 f(4)=0

答案就是:当且仅当 f ( x ) ( x − 1 ) ( x − 2 ) ( x − 3 ) ( x − 4 ) \frac{f(x)}{(x-1)(x-2)(x-3)(x-4)} (x1)(x2)(x3)(x4)f(x)为一个多项式时,以上约束成立。

同理,已知某多项式 f f f,如何来强化如下约束呢?(其中 w w w为root of unity,便于后续用FFT加速)

  • f ( w 0 ) = 0 f(w^0) = 0 f(w0)=0
  • f ( w 1 ) = 0 f(w^1) = 0 f(w1)=0
  • f ( w 2 ) = 0 f(w^2) = 0 f(w2)=0
  • f ( w 3 ) = 0 f(w^3) = 0 f(w3)=0

答案就是:当且仅当 f ( x ) ( x − w 0 ) ( x − w 1 ) ( x − w 2 ) ( x − w 3 ) \frac{f(x)}{(x-w^0)(x-w^1)(x-w^2)(x-w^3)} (xw0)(xw1)(xw2)(xw3)f(x)为一个多项式时,以上约束成立。

4. STARKs、KZG&DEEP上下文中的商多项式

4.1 STARKs上下文中的商多项式

STARKs上下文中,Prover的处理流程为:

  • 1)Prover对execution trace f f f进行承诺
  • 2)Prover断言在所有相关点的约束evaluation值均为0:
    • C ( f ( w 0 ) ) = 0 C(f(w^0))=0 C(f(w0))=0
    • C ( f ( w 1 ) ) = 0 C(f(w^1))=0 C(f(w1))=0
    • ⋯ \cdots
    • C ( f ( w n − 1 ) ) = 0 C(f(w^{n-1}))=0 C(f(wn1))=0
  • 3)Prover通过展示 C ( f ( x ) ) ( x − w 0 ) ( x − w 1 ) ( x − w 2 ) ⋯ ( x − w n − 1 ) \frac{C(f(x))}{(x-w^0)(x-w^1)(x-w^2)\cdots (x-w^{n-1})} (xw0)(xw1)(xw2)(xwn1)C(f(x))为一个多项式,来证明以上断言的正确。

4.2 DEEP上下文中的商多项式

DEEP为Degree Extension for Elimination of Pretenders的简称。

DEEP上下文中,Prover的处理流程为:

  • 1)Prover对多项式 f f f进行承诺,并断言 f ( 5 ) = 2 f(5)=2 f(5)=2
  • 2)Prover有2个选项:
    • 2.1)选项1:公开 f ( 5 ) f(5) f(5),并提供相应的opening proof。
    • 2.2)选项2:公开 f ( 5 ) f(5) f(5),并提供一个DEEP Quotient:
      • 2.2.1)Prover对第二个多项式 q ( x ) = f ( x ) − 2 x − 5 q(x)=\frac{f(x)-2}{x-5} q(x)=x5f(x)2进行承诺。【其核心思想为:若 f ( 5 ) ≠ 2 f(5)\neq 2 f(5)=2,则 q q q将不会是一个多项式。】
      • 2.2.2)Prover对“ q q q为多项式”提供FRI proof。(注意,不对“ f f f为多项式”提供FRI proof。)

引入DEEP商多项式:

  • 好处在于:可在Merkle tree之外工作。
  • 劣势在于:需额外引入一轮交互开销。

4.3 RISC Zero中的商多项式

RISC Zero ZKP协议中有2个关键的商多项式:

  • 1)针对validity witness的商多项式:在使用随机值将各个约束组合之后,将组合后的结果除以相应的vanishing多项式,获得的即是 针对validity witness的商多项式。
    在这里插入图片描述
  • 2)针对DEEP的商多项式:为证明execution trace承诺值的“openings”是真实有效的,同时为证明其validity witness是有效的,RISC使用DEEP协议,并需计算针对DEEP的商多项式:
    在这里插入图片描述

4.4 KZG上下文中的商多项式

KZG多项式承诺方案基本流程为:
在这里插入图片描述

参考资料

[1] 2023年3月视频 Quotients in ZK Protocols (RISC Zero Study Club)【slide见Quotients in ZK Protocols: A Peek Inside STARKs】

RISC Zero系列博客

  • RISC0:Towards a Unified Compilation Framework for Zero Knowledge
  • Risc Zero ZKVM:zk-STARKs + RISC-V
  • 2023年 ZK Hack以及ZK Summit 亮点记
  • RISC Zero zkVM 白皮书
  • Risc0:使用Continunations来证明任意EVM交易
  • Zeth:首个Type 0 zkEVM
  • RISC Zero项目简介
  • RISC Zero zkVM性能指标
  • Continuations:扩展RISC Zero zkVM支持(无限)大计算
  • A summary on the FRI low degree test前2页导读
  • Reed-Solomon Codes及其与RISC Zero zkVM的关系
  • RISC Zero zkVM架构
  • RISC-V与RISC Zero zkVM的关系
  • 有限域的Fast Multiplication和Modular Reduction算法实现
  • RISC Zero的Bonsai证明服务

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/122135.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

django+drf+vue 简单系统搭建 (2) - drf 应用

按照本系统设置目的,是为了建立一些工具用来处理简单的文件。 1. 准备djangorestframework 关于drf的说明请参见:Django REST Framework教程 | 大江狗的博客 本系列直接使用drf的序列化等其他功能。 安装 conda install djangorestframework conda i…

Spire.Office for .NET 8.10.2 同步更新-Crk

Spire.Office for .NET是 E-iceblue 提供的企业级 Office .NET API 的组合。它包括Spire.Doc、Spire.XLS、Spire.Spreadsheet、Spire.Presentation、Spire.PDF、Spire.DataExport、Spire.OfficeViewer、Spire.PDFViewer、Spire.DocViewer、Spire.Barcode和Spire.Email。Spire.O…

OceanBase 如何通过日志观测冻结转储流程?

本文旨在通过日志解析 OceanBase 的冻结转储流程,以其冻结检查线程为切入点,以租户(1002)的线程名为例。 作者:陈慧明,爱可生测试工程师,主要参与 DMP 和 DBLE 自动化测试项目。 爱可生开源社区…

在MacBook上实现免费的PDF文件编辑

之前我想对PDF文件进行简单处理(比如删页面、添空白页、调整页面顺序),要么是开wps会员【花钱贵】,下载(盗版)Adobe Acrobat【macOS不好下载】,要么用福昕阅览器登陆学生账号(学校买…

MySQL的存储过程

存储过程:是一组为了完成特定功能的sql语句的集合,类似于函数 写好一个存储过程之后,我们可以像函数一样随时可以调用sql的集合 复杂的,需要很多sql语句联合执行完成的任务 存储过程在执行上比sql语句执行速度快,效率…

错误未找到concrt140.dll最详细的解决方法与修复教程

作为一名长期活跃电脑计算机上的用户,我非常理解找不到concrt140.dll导致无法继续执行代码的困扰。这个问题可能会影响到许多软件的工作进度,甚至影响到项目的完成。在这里,我将分享我对于这个问题的理解和修复方法,希望能对大家有…

劳务派遣公司如何通过网盘与境外用户共享文件数据

中外企业合作、跨国公司已成为趋势,相应的文件数据共享问题应运而生。数据作为现代全球经济的命脉,如果文件数据无法高效流转,就会成为了企业发展的桎梏。 而传统常用的文件协作方式一般是邮件沟通,不过在日常使用过程中&#xf…

jenkins原理篇——成员权限管理

大家好,我是蓝胖子,前面几节我讲述了jenkins的语法以及我是如何使用jenkins对测试和正式环境进行发布的。但正式环境使用jenkins还有一点很重要,那就是权限管理。正式环境的权限往往不能对所有人开放,以及要做到每次发布都是谁在操…

什么是数据可视化,为什么数据可视化很重要?

数据可视化是数据的图形表示,可以帮助人们更轻松地理解和解释复杂的信息。它涉及创建数据的视觉表示,例如图表、图形、地图和其他视觉元素,以传达数据中的见解、模式和趋势。数据可视化是将原始数据转化为可操作知识的关键工具。 以下是数据…

【数据结构】树与二叉树(三):二叉树的定义、特点、性质及相关证明

文章目录 5.1 树的基本概念5.1.1 树的定义5.1.2 森林的定义5.1.3 树的术语5.1.4 树的表示 5.2 二叉树5.2.1 二叉树1. 定义2. 特点3. 性质引理5.1:二叉树中层数为i的结点至多有 2 i 2^i 2i个,其中 i ≥ 0 i \geq 0 i≥0。引理5.2:高度为k的二叉…

【机芯智能】智能公元(语音模块)

语音模块配置 进入语音模块智能公元官网,配置词条和识别后的串口输出指令. 记录下相关指令以及上图的识别词条,方便SDK烧写后的调试 SDK烧写 4. SDK 先和电脑调试助手配合,验证数据

web框架与Django

web应用程序 什么是web Web应用程序是一种可以通过Web访问的应用程序,程序的最大好处是用户很容易访问应用程序,用户只需要有浏览器即可,不需要再安装其他软件 应用程序有两种模式C/S、B/S。C/S是客户端/服务器端程序,也就是说这…

竞赛选题 深度学习疫情社交安全距离检测算法 - python opencv cnn

文章目录 0 前言1 课题背景2 实现效果3 相关技术3.1 YOLOV43.2 基于 DeepSort 算法的行人跟踪 4 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 **基于深度学习疫情社交安全距离检测算法 ** 该项目较为新颖,适合作为竞赛…

11月11日|欢迎参加Sui Meetup泰国活动!

现在是Sui基金会与泰国Sui社区见面的时候啦,我们诚邀每个人参加今年最大的Sui Meetup泰国活动,主题是“Summer Paradise(夏日天堂)”。在活动中,您将会见到来自Sui基金会、ContributionDAO、KX、Inspex、Cryptomind、A…

企业单位SSL证书

对于企业网站来说,建立一个安全可信的在线环境至关重要。在该过程中,选择适合的SSL证书起着关键作用。SSL证书不仅可以加密敏感数据传输,还可以展示您的企业身份和信誉。本文将为您介绍几款适合企业网站使用的SSL证书,助您确保网站…

Spring Boot 统一处理功能

目录 1.用户登陆权限验证 1.1 每个方法验证 1.2 Spring AOP 用户统一登陆验证 1.3 拦截器 1.3.1 自定义拦截器 1.3.2 将自定义拦截器配置到系统设置中,并且设置拦截规则 1.3.3 排除所有的静态资源 1.4 登录拦截器(练习) 1.5 拦截器原…

MGEF 记录添加(物料主数据有一个存储区域的选项英文显示Haz. material number(危险物料号))

物料主数据有一个存储区域的选项英文显示Haz. material number(危险物料号)) 看了一下对应的时MGEF-STOFF 刚开始在后台配置里面加好了需要的项目发现物料主数据还是选不到 找了半天,查了一堆资料。没有找到MGEF 是在哪里增加配置…

Android 深色模式切换适配

在Android11上测试 1&#xff0c;把需要适配的资源文件复制一份后缀加上-night&#xff0c;里面就放置变主题后的资源 2&#xff0c;两个主题一个白&#xff0c;一个黑&#xff0c;分别放置在对应的valuse-styles.xml中 <style name"Theme.LaserMachPor" parent&…

如何导出PPT画的图为高清图片?插入到world后不压缩图像的设置方法?

期刊投稿的时候&#xff0c;需要图片保持一定的清晰度数&#xff0c;那么我们怎么才能从PPT中导出符合要求的图片呢&#xff1f; 对于矢量图绘图软件所画的图&#xff0c;直接导出即可。 而PPT导出的图片清晰度在60pi&#xff0c;就很模糊。 整体思路&#xff1a; PPT绘图——…

前端Vue 页面滑动监听 拿到滑动的坐标值

前言 前端Vue 页面滑动监听 拿到滑动的坐标值 实现 Vue2写法 mounted() {// 监听页面滚动事件window.addEventListener("scroll", this.scrolling);}, methods: { scrolling() {// 滚动条距文档顶部的距离let scrollTop window.pageYOffset ||document.documentE…