算术化电路中如何使用定制gates?

news2024/11/15 8:34:49

1. 引言

现有ZKP证明系统中,除关注proof size和verification time之外,Prover Time是一个重要瓶颈。
在这里插入图片描述
当侧重Prover Time时,可考虑STARK方案。并借助recursive STARK+SNARK,来获得small proof。

Prover Time:

  • 直接取决于计算size。

针对同一计算,不同的算术化策略,会影响证明时的计算size,进而影响Prover Time。如证明 y = x − 1 m o d    p y=x^{-1}\mod p y=x1modp

  • 方案1:
    • 根据费马小定理有 x − 1 = x p − 2 m o d    p x^{-1}=x^{p-2}\mod p x1=xp2modp
    • 然后采用double and add来计算 x p − 2 x^{p-2} xp2
    • 检查 y = x p − 2 y=x^{p-2} y=xp2是否成立
    • 开销为 log ⁡ ( p ) \log(p) log(p)个约束
      在这里插入图片描述
  • 方案2:
    • 转为证明 1 = x × y m o d    p 1=x\times y \mod p 1=x×ymodp
    • 对应1个约束。

本文重点关注Plonkish算术化系统中的:

  • addition and multiplication约束
  • copy约束
  • selector多项式
  • custom约束
  • lookup约束

如需证明 0 ≤ c 3 < 4 0\leq c_3<4 0c3<4

  • 1)若电路中仅有multiplication约束,则不可能实现该证明。
  • 2)若电路中有addition and multiplication约束,则可做二进制分解,表示为:【缺少足够的结构,无法约束 c 3 = a 1 + 2 a 2 c_3=a_1+2a_2 c3=a1+2a2
    在这里插入图片描述
    在这里插入图片描述
  • 3)若电路中有addition and multiplication约束,以及,copy约束,则:【是否存在过度约束的问题?】
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  • 4)若电路中有addition and multiplication约束,以及,copy约束,以及,selector多项式,则:【其中selector多项式用于选择何时使用哪种gate。】
    在这里插入图片描述

为乘法约束增加零知识属性的策略为:
在这里插入图片描述

2. copy constraints

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

即Copy Constraints enforcement分为3大步:

  • 1)按顺序连接所有public和private inputs
  • 2)展示permuted inputs之间的等价性
  • 3)使用Neff Permutation argument来证明。详细见:
    https://github.com/asn-d6/curdleproofs(Rust)

3. selector多项式

selector多项式用于对约束进行开关。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4. custom约束

如MinRoot Verifiable Delay Function,其需求背景在于:

  • 好的随机数真的很难获得
  • 以太坊需要好的随机数来达成共识

所谓MinRoot Verifiable Delay Function,是指,每一轮都计算:
( x i + 1 , y i + 1 ) = ( ( x i + y i ) 1 3 , x i + i ) (x_{i+1},y_{i+1})=((x_i+y_i)^{\frac{1}{3}},x_i+i) (xi+1,yi+1)=((xi+yi)31,xi+i)

在约束电路中,转为计算:

  • x i + 1 3 = x i + y i x_{i+1}^3=x_i+y_i xi+13=xi+yi,从而需要做大量三次方运算,而不是开三次方运算。

不过在custom约束(定制约束)中,需权衡:

  • 每增加一列,可让定制约束更具表达性,但会增加额外的proof元素开销。
  • 每增加一个乘法运算,可让定制约束更具表达性,但会增加额外的proof元素开销。
  • 每种类型的custom约束会增加额外的proof元素开销。
  • 实际就是在proof size/verifier time 与 prover time之间做权衡取舍。
    在这里插入图片描述

参考资料

[1] 以太坊基金会Mary Maller 2023年2月在第13届 BIU Winter School on Cryptography上的分享视频 How Custom Gates Are Used During Arithmetization - Mary Maller

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【VM】保姆级VM算法平台二次开发之-环境配置

VM算法平台二次开发 1.下载Visual Studio 20222.项目的创建 C# 应用3.设置属性&#xff0c;去掉属选型32位4. 进行引用的导入工作5. 重新加载&#xff0c;查看引用6. 工具箱添加Dll的依赖。&#xff08;只需要加载一次就行&#xff09; 1.下载Visual Studio 2022 可以直接在官…

PyTorch深度学习遥感影像地物分类与目标检测、分割及遥感影像问题深度学习优化实践技术应用

我国高分辨率对地观测系统重大专项已全面启动&#xff0c;高空间、高光谱、高时间分辨率和宽地面覆盖于一体的全球天空地一体化立体对地观测网逐步形成&#xff0c;将成为保障国家安全的基础性和战略性资源。未来10年全球每天获取的观测数据将超过10PB&#xff0c;遥感大数据时…

未来芯片设计领域的药明康德——青芯如何在N个项目间游走平衡

总部位于上海张江的青芯半导体&#xff08;CyanSemi&#xff09;&#xff0c;ASIC定制设计是其核心业务之一。 青芯在单纯的设计服务维度之上&#xff0c;打造了从设计到生产的一套完整ASIC定制业务&#xff0c;不仅做芯片设计&#xff0c;还提供封装、测试服务&#xff0c;也…

ikuai配置内外网及动态域名,外部可以直接通过域名进行访问私网的网络服务环境。

1.安装ikuai虚拟机&#xff0c;这里可以自行百度&#xff0c;网上一堆教程用vm安装ikuai 2.重要的&#xff0c;配置网卡&#xff0c; 先上图在说。下图是虚拟机配置了两个网卡&#xff0c; 第一个网卡vmnet0配置为自动桥接模式。 第二个网卡vmnat1配置为NAT模式。 配置前需要…

C语言递归写n的k次方

int Func(int n,int k) {if (k 0){return 1;}else if (k > 1){return n * Func(n, k - 1);;}}int main() {int i 0;int j 0;printf("请输入数n和他的k次方\n");scanf("%d %d", &i,&j);int r Func(i,j);printf("%d的%d次方 %d\n"…

气传导耳机排名,四款市面上热销相当不错的气传导耳机推荐

​在当今快速的生活节奏中&#xff0c;气传导耳机成为了越来越多人的选择。它们以出色的音质和舒适度而广受好评。在本文中&#xff0c;我们将为您推荐四款市面上热销相当不错的气传导耳机&#xff0c;帮助你找到最适合自己的耳机。 推荐一&#xff1a;NANK南卡00压开放式耳机…

spring cloud seata集成

目录 一、seata使用场景 二、seata组成 三、seata服务端搭建 四、客户端使用seata 4.1 客户端增加undo_log表 4.2 客户端增加seata相关配置 4.3 客户端使用注解 五、测试 一、seata使用场景 微服务中&#xff0c;一个业务涉及到多个微服务系统&#xff0c;每个微服务…

elementUI中的table动态表单记录

form表单与table一起使用 之前一直以为form表单是单独使用&#xff0c;现在联动起来发现只是套了一层外壳&#xff0c;并不是很麻烦的事情 form的单独使用 <el-form :model"ruleForm" status-icon :rules"rules" ref"ruleForm" label-widt…

前端进阶之——模块化

在做项目的时候越来越发现模块化的重要性&#xff0c;做好模块化开发不仅给后期的维护带来不少好处而且大大提升项目开发效率&#xff0c;接下来整理一下模块化相关知识吧。 模块化开发的优点 封装方法、提高代码的复用性、可维护性和可读性隔离作用域&#xff0c;避免污染全…

【SpringSecurity】十、JWT工具类

文章目录 1、jwt类库与相关依赖2、工具类3、总结 1、jwt类库与相关依赖 <!-- 添加jwt的依赖 --> <dependency><groupId>com.auth0</groupId><artifactId>java-jwt</artifactId><version>3.11.0</version> </dependency>…

如何看待中小企业实现数字化转型难的问题?有哪些工具可以降低企业数字化的门槛?

中小企业 (SME) 数字化转型的难度可能存在很大差异&#xff0c;具体取决于行业、现有技术基础设施、领导层的数字素养、预算限制以及变革的整体准备程度等因素。但总体而言&#xff0c;中小企业在进行数字化转型时往往面临以下几个挑战&#xff1a; 1.资源有限&#xff1a;与大…

Openlayer系列:利用GeoServer和Openlayer地图显示区域掩模

前言 利用GeoServer和Openlayer地图显示区域掩模 利用GeoServer进行图层发布 Openlayer地图显示区域掩模 对界面地图进行切换&#xff0c;卫星图利用GeoServer&#xff0c;水系等根据geojson文件生成图层&#xff0c;效果如下 卫星图部分代码如下&#xff1a; // 创建卫星图…

淘宝API接口,可以运用到多种业务场景中

淘宝API接口可以运用到多种业务场景中&#xff0c;以下列举了一些主要的场景&#xff1a; 商品信息展示&#xff1a;通过调用淘宝API详情接口&#xff0c;可以获取商品的详细信息&#xff0c;如商品标题、价格、库存、销量、评价等数据。这些信息可以用于在自己的网站或应用程…

@24计算机考研er,招生简章超全汇总来了!持续更新请收藏

今天是8月最后一天&#xff0c;大家复习进度如何&#xff1f;目前已经有多所计算机招生院校公布了24考研的研招通知&#xff0c;包含&#xff1a;招生简章、专业目录、参考书目、考试大纲等。学姐整理成了24计算机考研招生官方信息汇总表&#xff01;终于不用自己一个个去官网翻…

泼辣修图Ploarr5.11.7电脑最新简体中文版下载

泼辣修图专业版是一款强大的专业修图软件&#xff0c;拥有上百款调色工具还有丰富的图层素材&#xff0c; 更有智能的人像修饰面板&#xff0c;具备物体识别的智能蒙板&#xff0c;高效的滤镜管理系统和强大的文字工具&#xff0c;支持批量处理。一切围绕摄影&#xff0c;无论是…

XSS漏洞及分析·

XSS漏洞和分析 知识点模板字符串定时器焦点jquerydom破坏 漏洞复现 xss测试网站&#xff1a;https://xss.pwnfunction.com/ 知识点 模板字符串 模板字面量是用反引号&#xff08;&#xff09;分隔的字面量&#xff0c;允许多行字符串、带嵌入表达式的字符串插值和一种叫带标签…

LLM - LLaMA-2 获取文本向量并计算 Cos 相似度

目录 一.引言 二.获取文本向量 1.hidden_states 与 last_hidden_states ◆ hidden_states ◆ last_hidden_states 2.LLaMA-2 获取 hidden_states ◆ model config ◆ get Embedding 三.获取向量 Cos 相似度 1.向量选择 2.Cos 相似度 3.BERT-whitening 特征白化 …

用户体验地图是什么?UX设计心得分享

大家好&#xff0c;我是设计师l1m0身。本篇文章是关于UX设计中的用户体验地图。 对于新手设计师来说&#xff0c;建立用户体验地图会有一些难度。本篇文章中&#xff0c;我会以简单、易懂的语言分享UX设计师如何制作用户体验地图&#xff0c;希望对你的日常项目体验提升有所帮…

私有化部署无忧企业文档2.1.7版本功能清单已更新!

无忧企业文档是软开企服研发的一款基于云端的在线文档管理工具&#xff0c;适用于团队内部协作、知识管理、项目管理等多个领域。与其他在线文档工具相比&#xff0c;无忧企业文档更注重团队协作和安全性&#xff0c;适合企业和团队使用。并且它还提供了丰富的API接口&#xff…

使用Dbeaver连接GaussDB

1.下载DBeaver&#xff0c;官网地址 2.安装软件&#xff0c;打开软件&#xff0c;点击数据库->驱动管理器&#xff0c;具体操作如下图&#xff1a; 3、选择新建后进行参数设置&#xff0c;如下图&#xff1a; 具体参数如下图 驱动名称: GS #随便定义 驱动类型&#…