ezkl

ezkl

零知识深度学习推理与验证框架

EZKL是一个开源库和命令行工具,用于在零知识证明系统中执行深度学习模型和计算图推理。该工具支持将PyTorch或TensorFlow模型转换为ONNX格式,并生成ZK-SNARK电路以验证模型推理的正确性。EZKL采用Halo2作为后端证明系统,能够在区块链、浏览器或设备上实现高效验证。这一项目为零知识机器学习应用提供了灵活且功能强大的解决方案。

EZKL零知识证明深度学习神经网络区块链Github开源项目
<h1 align="center"> <br> :thought_balloon: <br> <br> EZKL <br> <br> <br> </h1>

简易零知识推理

测试

ezkl是一个库和命令行工具,用于在零知识证明(ZKML)中进行深度学习模型和其他计算图的推理。它支持以下工作流程:

  1. 像在pytorch或tensorflow中一样定义计算图,例如神经网络(实际上可以是任意一组操作)。
  2. 将最终的操作图导出为.onnx文件,并将一些样本输入导出到.json文件中。
  3. ezkl指向.onnx.json文件,以生成ZK-SNARK电路,您可以用它来证明以下类型的陈述:

"我在一些私有数据上运行了这个公开可用的神经网络,并得到了这个输出"

笔记本

"我在一些公开数据上运行了我的私有神经网络,并得到了这个输出"

笔记本

"我正确地在一些公开数据上运行了这个公开可用的神经网络,并得到了这个输出"

笔记本

在后端,我们使用协作开发的Halo2作为证明系统。

生成的证明可以用更少的计算资源进行验证,包括在链上(使用以太坊虚拟机)、在浏览器中或在设备上。

  • 如果您有任何问题,我们欢迎您在讨论中开启一个讨论主题。或者,您可以加入✨EZKL社区Telegram群组💫。

  • 如需更多技术文章和详细信息,请查看我们的博客

  • 要了解您可以用ezkl构建什么,请查看cryptoidol.tech,在那里ezkl被用来创建一个永远评判您歌唱的AI。


快速开始 ⚙️

最简单的入门方式是尝试一个笔记本。

Python

通过以下命令安装Python绑定。

pip install ezkl

或者对于GPU版本:

pip install ezkl-gpu

Google Colab示例,学习如何训练神经网络并在链上部署推理验证器以供其他智能合约使用。笔记本

更多笔记本教程可以在examples/notebooks中找到。

CLI

安装CLI

curl https://raw.githubusercontent.com/zkonduit/ezkl/main/install_ezkl_cli.sh | bash

https://user-images.githubusercontent.com/45801863/236771676-5bbbbfd1-ba6f-418a-902e-20738ce0e9f0.mp4

更多详情请访问文档。CLI比Python更快,因为它的开销更少。如需更快速和便捷的体验,请查看远程证明服务,它感觉像CLI但由调优过的集群提供支持。

构建自动生成的rust文档并在本地浏览器中打开文档。cargo doc --open

浏览器内EVM验证器

作为在浏览器中运行原生Halo2验证器作为WASM绑定的替代方案,您可以使用浏览器内EVM验证器。您可以在in-browser-evm-verifier目录中找到其源代码,以及一个包含使用说明的README。

构建项目 🔨

Rust CLI

您可以从源代码安装库

cargo install --locked --path .

ezkl现在会为您自动管理solc安装。

构建Python绑定

Python绑定存在,可以使用maturin构建。您需要安装rustcargo

python -m venv .env source .env/bin/activate pip install -r requirements.txt maturin develop --release --features python-bindings # 教程特定的依赖项 pip install torch pandas numpy seaborn jupyter onnx kaggle py-solc-x web3 librosa tensorflow keras tf2onnx

GPU加速

如果您可以访问NVIDIA GPU,可以通过使用icicle功能构建并设置以下环境变量来启用加速:

export ENABLE_ICICLE_GPU=true

GPU加速由Icicle提供

要切回到使用CPU运行,必须取消设置上述环境变量,而不是将其切换为false值:

unset ENABLE_ICICLE_GPU

**注意:**即使设置了上述环境变量,对于k <= 8的电路,icicle也会被禁用。要更改启用icicle的k值,可以设置环境变量ICICLE_SMALL_K

贡献 🌎

如果您有兴趣贡献但不确定从哪里开始,请联系以下维护者之一:

  • dante (alexander-camuto)
  • jason (jasonmorton)

更广泛地:

您有意提交以包含在作品中的任何贡献均应根据CLA中指定的条款和条件许可给Zkonduit Inc.,您同意通过有意提交贡献来接受这些条款。特别是,您有权提交贡献,我们可以分发它,以及其他条款和条件。

无安全保证

Ezkl是未经审核的测试版软件,正在快速开发中。可能存在错误。不保证安全性,不应在生产环境中依赖它。

注意:由于在将操作从onnx文件转换为zk电路时进行了量化,Python和ezkl中的输出可能略有不同。

无担保

版权所有 (c) 2024 Zkonduit Inc. 本软件"按原样"提供,不提供任何形式的明示或暗示担保,包括但不限于对适销性、特定用途适用性和非侵权性的担保。在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是在合同诉讼、侵权行为还是其他方面,产生于、源于或与本软件或本软件的使用或其他交易有关。

编辑推荐精选

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

下拉加载更多