sonobe:针对IVC的fold arithmetic电路实例

2024-06-03 16:52

本文主要是介绍sonobe:针对IVC的fold arithmetic电路实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 引言

近日,arnaucube发推宣称 在EVM链(Optimistic)上验证了首个Nova+CycleFold proof,对应开源代码实现见:

  • https://github.com/privacy-scaling-explorations/sonobe(Rust + Solidity)

sonobe为:

  • 0xPARC和PSE团队联合开发的folding schemes库
  • 采用模块化结构
  • 用于Incremental Verifiable computation (IVC) 场景
  • 支持多个folding schemes和decider setups,支持用户按需选择
  • 致力于将folding schemes推向实用化,并促进其proof在EVM链上的验证。

在这里插入图片描述

所谓folding scheme,是指高效证明:
z n = F ( ⋯ F ( F ( F ( F ( z 0 , w 0 ) , w 1 ) , w 2 ) , ⋯ ) , w n − 1 ) z_n=F(\cdots F(F(F(F(z_0,w_0),w_1),w_2),\cdots),w_{n-1}) zn=F(F(F(F(F(z0,w0),w1),w2),),wn1)
其中:

  • w i w_i wi为每个递归步骤中额外的witness。

在这里插入图片描述
Sonobe基本流程为:

  • 1)定义要折叠的电路,即前端,支持arkworks、Circom、Noir等。

  • 2)设置所使用的folding scheme方案,如Nova+CycleFold。CycleFold改进了Nova中的cycle of curves使用:
    在这里插入图片描述
    其中,Nova电路与CycleFold电路之间的组合方式为:
    在这里插入图片描述

  • 3)设置生成final proof的final decider,如基于Pasta curves的Spartan、基于BN254的Groth16等。分链上链下两大类:

    • 3.1)On-chain decider
      在这里插入图片描述
    • 3.2)Off-chain decider
  • 4)生成decider verifier。

当前已实现的Folding schemes有:

  • Abhiram Kothapalli、Srinath Setty 和 Ioanna Tzialla 2021年论文 Nova: Recursive Zero-Knowledge Arguments from Folding Schemes
  • Abhiram Kothapalli 和 Srinath Setty 2023年论文 CycleFold: Folding-scheme-based recursive arguments over a cycle of elliptic curves

正在实现中的Folding schemes有:

  • Abhiram Kothapalli 和 Srinath Setty 2023年论文 HyperNova: Recursive arguments for customizable constraint systems
  • Liam Eagen 和 Ariel Gabizon 2023年论文 ProtoGalaxy: Efficient ProtoStar-style folding of multiple instances

2. Sonobe用例

2.1 sonobe-btc:链上Bitcoin light client

sonobe-btc 为利用Sonobe实现的链上Bitcoin light client:

  • 使用Nova来验证比特币上前10万个区块的proof of work
  • 在Optimistic L2链上以Groth16来做该zkSNARK IVC proof验证

开源代码见:

  • https://github.com/dmpierre/sonobe-btc(Solidity+Rust)

运行该light client的开销有:

  • 33h of compute on an aws ec2 c6i.4xlarge instance (16 cores, 32gb RAM) = 26.64 USD
  • Contract deployment + verification on Optimism = 0.91 USD,交易详情见:https://optimistic.etherscan.io/address/0x83c2acbbcc5e223be030288b5e5afb0b80e96f3f

参考资料

[1] 2024年4月19日arnaucube twitter 在EVM链上验证了首个Nova+CycleFold proof
[2] sonobe docs

这篇关于sonobe:针对IVC的fold arithmetic电路实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1027566

相关文章

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

Java Websocket实例【服务端与客户端实现全双工通讯】

Java Websocket实例【服务端与客户端实现全双工通讯】 现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发 出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏 览器需要不断的向服务器发出请求,然而HTTP

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群 华为云最近正在举办828 B2B企业节,Flexus X实例的促销力度非常大,特别适合那些对算力性能有高要求的小伙伴。如果你有自建MySQL、Redis、Nginx等服务的需求,一定不要错过这个机会。赶紧去看看吧! 什么是华为云Flexus X实例 华为云Flexus X实例云服务是新一代开箱即用、体

HNU-2023电路与电子学-实验3

写在前面: 一、实验目的 1.了解简易模型机的内部结构和工作原理。 2.分析模型机的功能,设计 8 重 3-1 多路复用器。 3.分析模型机的功能,设计 8 重 2-1 多路复用器。 4.分析模型机的工作原理,设计模型机控制信号产生逻辑。 二、实验内容 1.用 VERILOG 语言设计模型机的 8 重 3-1 多路复用器; 2.用 VERILOG 语言设计模型机的 8 重 2-1 多

LLVM入门2:如何基于自己的代码生成IR-LLVM IR code generation实例介绍

概述 本节将通过一个简单的例子来介绍如何生成llvm IR,以Kaleidoscope IR中的例子为例,我们基于LLVM接口构建一个简单的编译器,实现简单的语句解析并转化为LLVM IR,生成对应的LLVM IR部分,代码如下,文件名为toy.cpp,先给出代码,后面会详细介绍每一步分代码: #include "llvm/ADT/APFloat.h"#include "llvm/ADT/S

OpenStack离线Train版安装系列—11.5实例使用-Cinder存储服务组件

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

一些数学经验总结——关于将原一元二次函数增加一些限制条件后最优结果的对比(主要针对公平关切相关的建模)

1.没有分段的情况 原函数为一元二次凹函数(开口向下),如下: 因为要使得其存在正解,必须满足,那么。 上述函数的最优结果为:,。 对应的mathematica代码如下: Clear["Global`*"]f0[x_, a_, b_, c_, d_] := (a*x - b)*(d - c*x);(*(b c+a d)/(2 a c)*)Maximize[{f0[x, a, b,

OpenStack实例操作选项解释:启动和停止instance实例

关于启动和停止OpenStack实例 如果你想要启动和停止OpenStack实例时,有四种方法可以考虑。 管理员可以暂停、挂起、搁置、停止OpenStack 的计算实例。但是这些方法之间有什么不同之处? 目录 关于启动和停止OpenStack实例1.暂停和取消暂停实例2.挂起和恢复实例3.搁置(废弃)实例和取消废弃实例4.停止(删除)实例 1.暂停和取消暂停实例