Polygon Miden中的nullifier sets设计

news2025/1/11 12:42:56

1. 引言

前序博客:

  • Polygon Miden zkRollup中的UTXO+账户混合状态模型
  • Polygon Mide状态模型:解决状态膨胀,而不牺牲隐私和去中心化

本文基本结构为:

  • 何为nullifiers?为何需要nullifiers?
  • 使用nullifiers存在的问题?
  • Polygon Miden如何记录nullifiers?
  • 其它项目方如何记录nullifiers?

2. 何为nullifiers?为何需要nullifiers?

为何需要nullifiers?

nullifiers用于:断开 隐私保护链中senders和receivers 之间的linkability(关联性)。

nullifiers的工作原理为:
在这里插入图片描述
其中:

  • Note DB中包含了所有已创建notes的承诺值。
  • Nullifier DB中包含了所有已消费notes的nullifier值。
  • 已知某note的承诺值,无法确定该note的nullifier值。

消费notes的流程为:
在这里插入图片描述

3. 使用nullifiers存在的问题?

使用nullifier存在的问题是:

  • nullifier set会无限增长。
  • 为验证某nullifier值是否在nullifier set中,网络需记录已创建的所有nullifiers。
    • 若tps为1000,则持续10年,存储nullifier set需要10TB空间。
    • 若tps为10000,则持续10年,存储nullifier set需要100TB空间。

在这里插入图片描述

4. Polygon Miden如何记录nullifiers?

Polygon Miden中使用nullifiers,希望实现:

  • Authenticated data structure for non-membership proofs
  • Constant nullifier DB size at given TPS
  • No time limits on spending notes
  • 用户维护其notes spendable所需的工作量最小化(Minimal work by users to keep their notes spendable)

Polygon Miden中的nullifiers采用Nullifier tree结构来存储:
在这里插入图片描述
其中:

  • Nullifier tree:depth为256的Compact Sparse Merkle tree
  • Nullifier值:为Nullifier tree中的path。
  • 叶子节点值:表示该nullifier是否已被消费,若为1则表示已被消费,0值表示未消费。
  • 但该Nullifier tree会无限增长。

为此,Polygon Miden中不只有一棵Nullifier tree,而是每个epoch(每个epoch可为6个月)都有一棵Nullifier tree。网络仅保留最新2个epoch(即window)内的完整Nullifier tree,以及所有历史Nullifier tree的roots。
在这里插入图片描述
这样,就可实现如下关键属性:

  • 新的nullifiers仅插入到current epoch的Nullifier tree中。
  • 节点仅记录最新2个epoch(即current window)的nullifiers,以及其他历史nullifier trees的roots。
  • epoch具有固定时长,如6个月。

不过,需额外:

  • 根据notes的创建时间,来为该note分配epochs(如 n c n_c nc
  • 验证某note的nullifier值,不存在与任意epochs ≥ n c \geq n_c nc的nullifier trees中

这样,Polygon Miden中消费notes的流程调整为:
在这里插入图片描述
这样调整后,对用户端的影响为:

  • 对于在最近2个epochs中创建的notes,无影响。
  • 对于最近2个epochs之前创建的notes,用户端需:
    • 下载并存储对old nullifier trees的non-membership proofs(once per epoch,且可把下载和存储任务委托给第三方)。
    • 额外 验证old nullifier tree的non-membership proofs 的开销。

这样调整后,对网络的影响为:

  • 额外 在前一nullifier tree中检查某nullifiers值 的开销。

5. 其它项目方如何记录nullifiers?

其它项目方记录nullifiers的方案有:

  • Mutator sets:见Neptune团队2023年论文Mutator Sets and their Application to Scalable Privacy,其对non-membership proofs采用Sliding Window Bloom Filters。
  • Liveness masks:Polygon zero团队采用Sparse Merkle trees和modified Huffman coding,具体见2021年博客:Privacy on Mir。
  • Sharded nullifier space:ZCash daira 2019年研究https://github.com/daira/scaling。

参考资料

[1] 2023年9月Polygon Miden联合创始人Bobbin Threadbare在Fenbushi Capital的分享视频 Efficient tracking of nullifier sets by Bobbin from Polygon Maiden

Miden系列博客

  • zk、zkVM、zkEVM及其未来
  • Polygon L2扩容方案揭秘
  • 混合Rollup:探秘 Metis、Fraxchain、Aztec、Miden和Ola
  • Polygon Miden:扩展以太坊功能集的ZK-optimized rollup
  • Polygon Miden zkRollup中的UTXO+账户混合状态模型
  • Polygon Miden交易模型:Actor模式 + ZKP => 并行 + 隐私
  • Polygon Mide状态模型:解决状态膨胀,而不牺牲隐私和去中心化

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

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

相关文章

Ubuntu 20.04 桌面美化

Ubuntu 20.04 桌面美化 Ubuntu 20.04 在 2020 年 4 月 28 日发布,距今已经快四个月了,我将自己的笔记本升级成 Ubuntu 20.04 操作系统了,Ubuntu 20.04 默认安装完成的桌面比较简单,如下图: 根据我个人的喜好&#xff0…

Android自定义Drawable---灵活多变的矩形背景

Android自定义Drawable—灵活多变的矩形背景 在安卓开发中,我们通常需要为不同的按钮设置不同的背景以实现不同的效果,有时还需要这些按钮根据实际情况进行变化。如果采用编写resource中xml文件的形式,就需要重复定义许多只有微小变动的资源…

Vue中如何进行表单验证码与滑动验证

在Vue中实现表单验证码与滑动验证功能 验证码和滑动验证是Web应用程序中常见的安全功能,用于验证用户的身份并防止恶意活动。Vue.js作为一个流行的JavaScript框架,提供了许多工具和库来实现这些功能。本文将介绍如何使用Vue来实现表单验证码和滑动验证功…

solidity 合约转java

Generate a Java Wrapper from your Smart Contract Solidity Gradle Plugin - Web3j web3j / web3j-maven-plugin GitLab

ARM汇编与C言语的混合编程

1. C言语如何与汇编进行交互 有些时候,我们需要在汇编代码中调用C代码,或者说C代码中调用汇编代码。 那么,汇编调用C代码,或者C代码调用汇编函数,他们的函数参数、返回值是如何传递的? 对应ARM架构来说&…

学习开发一个RISC-V上的操作系统(汪辰老师) — unrecognized opcode `csrr t0,mhartid‘报错问题

前言 (1)此系列文章是跟着汪辰老师的RISC-V课程所记录的学习笔记。 (2)该课程相关代码gitee链接; (3)PLCT实验室实习生长期招聘:招聘信息链接 正文 (1)在跟着…

【重拾C语言】五、模块化程序设计——函数(定义、调用、参数传递、结果返回、函数原型;典例:打印字符图形、验证哥德巴赫猜想)

目录 前言 五、模块化程序设计——函数 5.1 计算三角形的重心 5.2 函数 5.2.1 函数定义 5.2.2 函数调用 a. 函数调用的形式和过程 b. 参数传递 值传递 指针传递 c. 函数结果返回 5.2.3 函数原型(先调用后定义) 5.3 程序设计实例 5.3.1 打印…

【14】c++设计模式——>工厂模式

简单工厂模式的弊端 简单工厂模式虽然简单,但是违反了设计模式中的开放封闭原则,即工厂类在数据增加时需要被修改,而我们在设计时对于已经设计好的类需要避免修改的操作,而选用扩展的方式。 工厂模式设计 简单工厂模式只有一个…

【Java】接口 interface

目录 概述 示例代码: 接口成员访问特点 示例代码: 概述 什么是接口 接口就是一种公共的规范标准,只要符合规范标准,大家都可以调用。 Java 中的接口更多的体现在对行为的抽象! 1. 接口 用关键字 interface 修饰 pub…

AtCoder Beginner Contest 231(D-F,H)

D - Neighbors (atcoder.jp) (1)题意 给出M组关系,问是否有一个排列,能表示A[i]和B[i]相邻 (2)思路 考虑如果有环,显然不能满足排列,因为排列中度数最多为2,若有超过2的显…

JavaScript操作CSS样式

上节课我们基本完成了游戏的主体,这节课我们来学习如果使用JavaScript去操作CSS样式 ● 例如,我们现在想当玩家输入对的数字之后,我们讲背景改为绿色,并且把number的框宽度变大 const secretnumber Math.trunc(Math.random() * …

第十六章 类和对象——运算符重载

运算符重载概念:对已有的运算符重新进行定义,赋予其另一种功能,以适应不同的数据类型。 一、加号运算符重载 作用:实现两个自定义数据类型相加的运算 class Person {public:Person() {};Person(int a, int b){this->m_A a;t…

5个适合初学者的初级网络安全工作,网络安全就业必看

前言 网络安全涉及保护计算机系统、网络和数据免受未经授权的访问、破坏和盗窃 - 防止数字活动和数据访问的中断 - 同时也保护用户的资产和隐私。鉴于公共事业、医疗保健、金融以及联邦政府等行业的网络犯罪攻击不断升级,对网络专业人员的需求很高,这并…

【异常错误】WSL2设置为全核cpu和全部内存

今天偶尔发现 WSL占用的内存是真实内存的一半(通过htop命令查看即可) 现在需要修改配置到使用全部的CPU资源: Windows R 键, 输入 %UserProfile% 并运行进入用户文件夹, 新建文件 .wslconfig,文件内容如下&#xf…

light client轻节点简介

1. 引言 前序博客: Helios——a16z crypto构建的去中心化以太坊轻节点 去中心化和自我主权对于Web3的未来至关重要,但是这些理想并不总适用于每个项目或应用程序。在非托管钱包和bridges等工具中严格优先考虑安全性而不是便利性的用户,可选择运行全节…

【JavaEE】多线程(五)- 基础知识完结篇

多线程(五) 文章目录 多线程(五)volatile关键字保证内存可见性JMM(Java Memory Model) 不保证原子性 wait 和 notifywait()notify()线程饿死 上文我们主要讲了 synchronized以及线程安全的一些话题 可重入…

【Unity】3D贪吃蛇游戏制作/WebGL本地测试及项目部署

本文是Unity3D贪吃蛇游戏从制作到部署的相关细节 项目开源代码:https://github.com/zstar1003/3D_Snake 试玩链接:http://xdxsb.top/Snake_Game_3D 效果预览: 试玩链接中的内容会和该效果图略有不同,后面会详细说明。 游戏规则 …

图像分割中的色块的提取

一 色块提取方法: ①首先是色彩模型的转换 由RGB颜色空间转到HSV颜色空间 原因:RGB颜色空间适合显示系统,但是各分量间相关性很强,比如当图像亮度发生变化时,RGB三个分量都会发生相应改变 但是HSV颜色空间更能感知颜色…

【Java 进阶篇】JDBC 数据库连接池 C3P0 详解

数据库连接池是数据库编程中常用的一种技术,它可以有效地管理数据库连接,提高数据库访问的性能和效率。在 Java 编程中,有多种数据库连接池可供选择,其中之一就是 C3P0。本文将详细介绍 C3P0 数据库连接池的使用,包括原…

LabVIEW使用ZigBee无线传感器开发住宅负载电力应用

LabVIEW使用ZigBee无线传感器开发住宅负载电力应用 长期以来,住宅客户的需求一直是电力行业的一部分。由于公用事业需要建设基础设施以满足即时和长期需求,因此公用事业账单既包含能源费用,其中衡量客户随时间消耗的总电量,也包含…